Dans les grilles personnalisées des signalétiques, la version 10.10 de Mercator rend aisé l'ajout de colonnes de type Bouton, qui permettent d'ouvrir automatiquement :
- une fiche de signalétique
- un document de vente ou d'achat de la gestion commerciale
- un transfert de dépôts ou un inventaire
- une action du CRM
- une écriture comptable.
Par exemple, cette requête SQL placée dans le signalétique des articles
select pieds_v.date,lignes_v.q,cli.c_nom as client,pieds_v.id_cli as UserDefinedButtonColumnShowSigCli,pieds_v.journal,cast(pieds_v.piece as bigint) as piece,
'V'+str(pieds_v.type,1)+pieds_v.id+pieds_v.journal+str(pieds_v.piece,10)+lignes_v.dl_id as UserDefinedButtonColumnShowBilling
from PIEDS_V inner join LIGNES_V on (pieds_v.id=lignes_v.id) and (pieds_v.journal=lignes_v.journal) and (pieds_v.piece=lignes_v.piece)
inner join CLI on (pieds_v.id_cli=cli.c_id)
where lignes_v.id_article=@s_id
order by pieds_v.date desc
affiche ces deux colonnes contenant un bouton, permettant respectivement, de montrer la fiche du client et d'ouvrir la vente correspondante.
Les colonnes qui devront afficher un bouton de zoom sont reconnues par Mercator car elles sont de type "caractères" et leur nom commence par UserDefinedButtonColumn. La chaîne de caractères contenue dans ces colonnes doit être construite de façon précise afin que Mercator puisse identifier l'action souhaitée. Les noms de colonnes ne sont pas sensibles à la casse. Si plusieurs boutons du même type doivent être présents dans la grille, il est possible de nommer ces colonnes avec un suffixe au choix : UserDefinedButtonColumnShowSigCli2, UserDefinedButtonColumnShowSigCliABC, ...
La présentation de ces boutons (largeur, icône, texte) peut être modifiée avec les règles de colonnes.
Ouvrir une fiche de signalétique
Le nom de la colonne doit être UserDefinedButtonColumnShowSigCli, UserDefinedButtonColumnShowSigFou, UserDefinedButtonColumnShowSigStock, ... en fonction du signalétique souhaité et la chaîne de caractères doit simplement être l'identifiant de la fiche.
Si on souhaite pouvoir ouvrir des fiches de signalétiques de différents types, alors il faut nommer la colonne UserDefinedButtonColumnShowSig et dans ce cas, la chaîne de caractères doit être composée comme suit :
- sur 10 caractères : le code du signalétique en majuscules CLI, FOU, STOCK, ...
- l'identifiant de la fiche
Par exemple :
'CLI '+pieds_v.id_cli as UserDefinedButtonColumnShowSig
Liaison vers un signalétique : voir aussi les exemples sur cette page.
Ouvrir un document de vente ou d'achat de la gestion commerciale
Le nom de la colonne doit être UserDefinedButtonColumnShowBilling. La chaîne de caractères doit contenir :
- V ou A en majuscule
- Type
- Id
- Journal
- Piece
- DL_ID (optionnel : si on souhaite mettre en surbrillance une ligne du document)
Par exemple :
'V'+str(pieds_v.type,1)+pieds_v.id+pieds_v.journal+str(pieds_v.piece,10) as UserDefinedButtonColumnShowBilling
'V'+str(pieds_v.type,1)+pieds_v.id+pieds_v.journal+str(pieds_v.piece,10)+lignes_v.dl_id as UserDefinedButtonColumnShowBilling
Ouvrir un transfert de dépôts ou un inventaire
Le nom de la colonne doit être UserDefinedButtonColumnShowDiverse. La chaîne de caractères doit contenir ces informations de la table LIGNES_D :
- Nature : TRANSF_DEP ou INVENT sur 10 caractères
- Type
- Id_doc
- Piece
- ID (optionnel : si on souhaite mettre en surbrillance une ligne de l'inventaire ou de transfert de dépôts)
Par exemple :
lignes_d.nature+str(lignes_d.type,1)+lignes_d.id_doc+str(lignes_d.piece,10) as UserDefinedButtonColumnShowDiverse
lignes_d.nature+str(lignes_d.type,1)+lignes_d.id_doc+str(lignes_d.piece,10)+lignes_d.id as UserDefinedButtonColumnShowDiverse
Ouvrir une action du CRM
Le nom de la colonne doit être UserDefinedButtonColumnShowAction. La chaîne de caractères doit contenir ces informations de la table ACTIONS :
- ID
- MODULE : le code du signalétique en majuscules sur 10 caractères ou 10 espaces
- ID_SIG : l'ID dans ce signalétique
Par exemple :
actions.id+actions.module+actions.id_sig as UserDefinedButtonColumnShowAction
Ouvrir une écriture comptable
Le nom de la colonne doit être UserDefinedButtonColumnShowBooking. La chaîne de caractères doit contenir ces informations de la table LIGNES_C :
- TYPE
- NUM_EX sur 3 positions
- JOURNAL
- PIECE
- DL_ID (optionnel : si on souhaite mettre en surbrillance une ligne de l'écriture comptable)
Par exemple :
str(pieds_c.type,1)+str(pieds_c.num_ex,3)+pieds_c.journal+str(pieds_c.piece,10) as UserDefinedButtonColumnShowBooking
str(pieds_c.type,1)+str(pieds_c.num_ex,3)+pieds_c.journal+str(pieds_c.piece,10)+lignes_c.dl_id as UserDefinedButtonColumnShowBooking
Exécuter du code custom
Le nom de la colonne doit être UserDefinedButtonColumnCustom. La chaîne de caractères doit contenir le nom de la méthode présente dans le customizer associé. Cette méthode doit accepter deux paramètres :
- MercatorUi.GridPro.DataGridViewXPro
- System.Windows.Forms.DataGridViewCellEventArgs
Par exemple :
'MyClickMethod' as UserDefinedButtonColumnCustom
Et dans le customizer, ce code :
namespace SigCli
{
public class Customizer
{
public void MyClickMethod(MercatorUi.GridPro.DataGridViewXPro grid, System.Windows.Forms.DataGridViewCellEventArgs e)
{
...
}
}
}