Vous consultez une page technique concernant le logiciel de gestion Mercator. Celle-ci contient des informations spécifiques destinées aux professionnels de Mercator. Souhaitez-vous être redirigés vers des informations plus générales ?


   Ne plus poser cette question

Gestion des dimensions

0000000537     -      24/07/2024

Mercator permet de gérer les ventes et les achats d'articles en spécifiant les dimensions.
Par exemple, pour un panneau vendu au mètre carré, il sera possible de saisir la longueur et la largeur, ainsi que le nombre de panneaux vendus. Ceci permet la gestion des découpes, par exemple.
Mercator offre jusqu'à 3 critères de mesures.

L'installation doit se faire via l'ajout des champs suivants dans STOCK :

  • S_UNITE char(10)
  • S_UNITE_V char(10) : unité de vente
  • S_UNITE_A char(10) : unité d'achat
  • S_COEF_U_V float : coefficient de conversion de l'unité de vente vers l'unité de stock
  • S_COEF_U_A float : coefficient de conversion de l'unité d'achat vers l'unité de stock
  • S_CRI_UNIT char(10) : unité résultat de formule de calcul sur base des critères de mesure
  • S_CRITM1 char(10) : critère de mesures 1
  • S_CRITM2 char(10) : critère de mesures 2
  • S_CRITM3 char(10) : critère de mesures 3
  • S_CRITMO1 bit : critère 1 modifiable ou pas
  • S_CRITMO2 bit : critère 2 modifiable ou pas
  • S_CRITMO3 bit : critère 3 modifiable ou pas
  • S_CRIDEF1 float : valeur par défaut du critère de mesures 1
  • S_CRIDEF2 float : valeur par défaut du critère de mesures 2
  • S_CRIDEF3 float : valeur par défaut du critère de mesures 3
  • S_CRIMUL float : coefficient multiplicateur dans formule de calcul sur base des critères de mesures
  • S_CRIDIV float : coefficient diviseur dans formule de calcul sur base des critères de mesures
alter table STOCK add S_UNITE char(10) not null default ''
alter table STOCK add S_UNITE_V char(10) not null default ''
alter table STOCK add S_UNITE_A char(10) not null default ''
alter table STOCK add S_COEF_U_V float not null default 0
alter table STOCK add S_COEF_U_A float not null default 0
alter table STOCK add S_CRI_UNIT char(10) not null default ''
alter table STOCK add S_CRITM1 char(10) not null default ''
alter table STOCK add S_CRITM2 char(10) not null default ''
alter table STOCK add S_CRITM3 char(10) not null default ''
alter table STOCK add S_CRITMO1 bit not null default 0
alter table STOCK add S_CRITMO2 bit not null default 0
alter table STOCK add S_CRITMO3 bit not null default 0
alter table STOCK add S_CRIDEF1 float not null default 0
alter table STOCK add S_CRIDEF2 float not null default 0
alter table STOCK add S_CRIDEF3 float not null default 0
alter table STOCK add S_CRIMUL float not null default 0
alter table STOCK add S_CRIDIV float not null default 0

attention Si vous voulez gérer des unités différentes, voir Différenciation des unités.

 

Ces champs sont visibles dans l'onget "Unités" de la fiche "Articles".
Le paramétrage repris ci-après montre la possibilité de vendre un panneau, à la découpe, en spécifiant la longueur en mm. La largeur en mm est fixée et est non modifiable par l'utilisateur. Le résultat du calcul s'exprime en mètres carrés. Le coefficient diviseur de 1000000 permet de convertir les 2 dimensions en mm vers des mètres carrés.

 

dim1_f

Lors d'une vente, un écran de saisie de dimensions sera présenté si l'unité de vente est égale à l'unité de résultat de formule de calcul sur base des critères de mesures. Lors d'un achat, ce même écran de saisie de dimensions sera présenté si l'unité d'achat est égale à l'unité de résultat de formule de calcul sur base des critères de mesures.

dim2_f

S'il est souhaité de mémoriser ces différentes dimensions, il suffit d'ajouter dans LIGNES_V/LIGNES_A les champs suivants :

  • CRITQ0 float : nombre
  • CRITQ1 float : quantité de la dimension 1
  • CRITQ2 float : quantité de la dimension 2
  • CRITQ3 float : quantité de la dimension 3

Ces variables pourront être reprises dans les layouts d'impression.

alter table LIGNES_V add CRITQ0 float not null default 0
alter table LIGNES_V add CRITQ1 float not null default 0
alter table LIGNES_V add CRITQ2 float not null default 0
alter table LIGNES_V add CRITQ3 float not null default 0

alter table LIGNES_A add CRITQ0 float not null default 0
alter table LIGNES_A add CRITQ1 float not null default 0
alter table LIGNES_A add CRITQ2 float not null default 0
alter table LIGNES_A add CRITQ3 float not null default 0

 

L'onglet pourra être repris à partir du fichier MPGE inclus dans le fichier zip ci-joint (voir manipulations à effectuer).


Depuis la version 11 de Mercator, il est possible d'ajouter un second jeu de critères de mesures. Pour cela, il faut installer ces colonnes supplémentaires :

alter table STOCK add S_CRI_UNIT_BIS char(10) not null default ''
alter table STOCK add S_CRITM1_BIS char(10) not null default ''
alter table STOCK add S_CRITM2_BIS char(10) not null default ''
alter table STOCK add S_CRITM3_BIS char(10) not null default ''
alter table STOCK add S_CRITMO1_BIS bit not null default 0
alter table STOCK add S_CRITMO2_BIS bit not null default 0
alter table STOCK add S_CRITMO3_BIS bit not null default 0
alter table STOCK add S_CRIDEF1_BIS float not null default 0
alter table STOCK add S_CRIDEF2_BIS float not null default 0
alter table STOCK add S_CRIDEF3_BIS float not null default 0
alter table STOCK add S_CRIMUL_BIS float not null default 0
alter table STOCK add S_CRIDIV_BIS float not null default 0

Le fichier 0537_Articles_Dimensions_avec_bis.mpge inclus dans le zip ci-joint contient un second bloc avec ces critères de mesures supplémentaires.


L'événement MeasurementCriteriaAfterUpdateAmounts du BillingEngine permet de modifier le total calculé dans l'écran de saisie de dimensions.

Par exemple, pour forcer un arrondi selon le conditionnement à la vente :

Zoom
namespace Billing
{
    public class Customizer : MercatorUi.ICustomizers.IBillingEngineCreated, MercatorUi.ICustomizers.IBillingEngineClosed
    {

        public void BillingEngineCreated(MercatorUi.Engine.Gescom.BillingEngine billingEngine)
        {
            billingEngine.MeasurementCriteriaAfterUpdateAmounts += billingEngine_MeasurementCriteriaAfterUpdateAmounts;
        }

        public void BillingEngineClosed(MercatorUi.Engine.Gescom.BillingEngine billingEngine)
        {
            billingEngine.MeasurementCriteriaAfterUpdateAmounts -= billingEngine_MeasurementCriteriaAfterUpdateAmounts;
        }

        void billingEngine_MeasurementCriteriaAfterUpdateAmounts(object sender, MercatorUi.Engine.Gescom.BillingEngine.MeasurementCriteriaAfterUpdateAmountsEventArgs e)
        {
            MercatorUi.Engine.Gescom.BillingEngine billingEngine = (MercatorUi.Engine.Gescom.BillingEngine)sender;
            if ((e.StockRecord.S_CONDIT_V.CompareTo(0d, Globals.N_DEC_Q) > 0) && e.DataRowStock["s_unite_v"].Equals(e.DataRowStock["s_cri_unit"]))
                e.ComputedQ = billingEngine.ArrCondit(e.ComputedQ, e.StockRecord.S_CONDIT_V);
        }
    }
}

Mots clés: longueur, largeur, hauteur, profondeur, volume, surface

 



A télécharger : 0000000537.zip (5 Kb - 21/03/2024)