Dépôt officiel du code source de l'ERP OpenConcerto
Rev 180 | Go to most recent revision | Blame | Compare with Previous | Last modification | View Log | RSS feed
/*
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER.
*
* Copyright 2011-2019 OpenConcerto, by ILM Informatique. All rights reserved.
*
* The contents of this file are subject to the terms of the GNU General Public License Version 3
* only ("GPL"). You may not use this file except in compliance with the License. You can obtain a
* copy of the License at http://www.gnu.org/licenses/gpl-3.0.html See the License for the specific
* language governing permissions and limitations under the License.
*
* When distributing the software, include this License Header Notice in each file.
*/
package org.openconcerto.erp.core.common.ui;
import org.openconcerto.erp.config.ComptaPropsConfiguration;
import org.openconcerto.erp.core.finance.accounting.model.CurrencyConverter;
import org.openconcerto.erp.core.finance.tax.model.TaxeCache;
import org.openconcerto.erp.core.sales.pos.io.BarcodeReader;
import org.openconcerto.erp.core.sales.pos.ui.BarcodeListener;
import org.openconcerto.erp.core.sales.product.element.ReferenceArticleSQLElement;
import org.openconcerto.erp.core.sales.product.element.UniteVenteArticleSQLElement;
import org.openconcerto.erp.core.sales.product.ui.CurrencyWithSymbolRenderer;
import org.openconcerto.erp.core.sales.product.ui.DeliveredQtyRowValuesRenderer;
import org.openconcerto.erp.core.sales.product.ui.QteUnitRowValuesRenderer;
import org.openconcerto.erp.core.supplychain.stock.element.DepotStockSQLElement;
import org.openconcerto.erp.core.supplychain.stock.element.StockSQLElement;
import org.openconcerto.erp.preferences.DefaultNXProps;
import org.openconcerto.erp.preferences.GestionArticleGlobalPreferencePanel;
import org.openconcerto.sql.Configuration;
import org.openconcerto.sql.element.SQLElement;
import org.openconcerto.sql.model.FieldPath;
import org.openconcerto.sql.model.SQLRow;
import org.openconcerto.sql.model.SQLRowAccessor;
import org.openconcerto.sql.model.SQLRowListRSH;
import org.openconcerto.sql.model.SQLRowValues;
import org.openconcerto.sql.model.SQLSelect;
import org.openconcerto.sql.model.SQLTable;
import org.openconcerto.sql.model.UndefinedRowValuesCache;
import org.openconcerto.sql.model.Where;
import org.openconcerto.sql.model.graph.Path;
import org.openconcerto.sql.preferences.SQLPreferences;
import org.openconcerto.sql.sqlobject.ITextArticleWithCompletionCellEditor;
import org.openconcerto.sql.sqlobject.ITextWithCompletion;
import org.openconcerto.sql.view.EditFrame;
import org.openconcerto.sql.view.EditPanel.EditMode;
import org.openconcerto.sql.view.list.AutoCompletionManager;
import org.openconcerto.sql.view.list.CellDynamicModifier;
import org.openconcerto.sql.view.list.RowValuesTable;
import org.openconcerto.sql.view.list.RowValuesTableModel;
import org.openconcerto.sql.view.list.SQLTableElement;
import org.openconcerto.sql.view.list.ValidStateChecker;
import org.openconcerto.ui.preferences.DefaultProps;
import org.openconcerto.utils.DecimalUtils;
import org.openconcerto.utils.ExceptionHandler;
import org.openconcerto.utils.Tuple3;
import org.openconcerto.utils.i18n.TranslationManager;
import java.awt.Component;
import java.awt.event.ActionEvent;
import java.awt.event.ActionListener;
import java.awt.event.HierarchyEvent;
import java.awt.event.HierarchyListener;
import java.awt.event.KeyEvent;
import java.awt.event.MouseAdapter;
import java.awt.event.MouseEvent;
import java.math.BigDecimal;
import java.math.RoundingMode;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.Calendar;
import java.util.HashMap;
import java.util.HashSet;
import java.util.List;
import java.util.Map;
import java.util.Set;
import java.util.Vector;
import javax.swing.AbstractAction;
import javax.swing.JButton;
import javax.swing.JFrame;
import javax.swing.JLabel;
import javax.swing.JOptionPane;
import javax.swing.JPopupMenu;
import javax.swing.JTable;
import javax.swing.SwingUtilities;
import javax.swing.ToolTipManager;
import javax.swing.event.TableModelEvent;
import javax.swing.event.TableModelListener;
import javax.swing.table.DefaultTableCellRenderer;
import javax.swing.table.TableCellRenderer;
public abstract class AbstractAchatArticleItemTable extends AbstractArticleItemTable {
private AutoCompletionManager m;
private AutoCompletionManager m2, m3;
private AutoCompletionManager m4;
private final SQLTable tableArticle = getSQLElement().getTable().getTable("ARTICLE");
private SQLRowAccessor rowDevise;
private boolean supplierCode;
public AbstractAchatArticleItemTable() {
super();
}
@Override
public AutoCompletionManager getCodeCompletionManager() {
return this.m;
}
@Override
protected void setModel(RowValuesTableModel model) {
super.setModel(model);
model.addTableModelListener(new TableModelListener() {
@Override
public void tableChanged(TableModelEvent e) {
calculTarifNomenclature();
}
});
}
protected void init() {
final SQLElement e = getSQLElement();
final SQLPreferences prefs = SQLPreferences.getMemCached(getSQLElement().getTable().getDBRoot());
final boolean selectArticle = prefs.getBoolean(GestionArticleGlobalPreferencePanel.USE_CREATED_ARTICLE, false);
final boolean createAuto = prefs.getBoolean(GestionArticleGlobalPreferencePanel.CREATE_ARTICLE_AUTO, true);
final boolean showEco = prefs.getBoolean(AbstractVenteArticleItemTable.SHOW_ECO_CONTRIBUTION_COLUMNS, false);
final boolean showDmdAchat = prefs.getBoolean(GestionArticleGlobalPreferencePanel.ACTIVE_DEMANDE_ACHAT, false);
final boolean showDevise = prefs.getBoolean(AbstractVenteArticleItemTable.ARTICLE_SHOW_DEVISE, false);
this.supplierCode = prefs.getBoolean(GestionArticleGlobalPreferencePanel.SUPPLIER_PRODUCT_CODE, false);
final boolean withDeclinaison = prefs.getBoolean(GestionArticleGlobalPreferencePanel.ACTIVER_DECLINAISON, false);
final List<SQLTableElement> list = new Vector<SQLTableElement>();
final SQLTableElement eNiveau = new SQLTableElement(e.getTable().getField("NIVEAU")) {
@Override
public void setValueFrom(SQLRowValues row, Object value) {
super.setValueFrom(row, value);
}
};
eNiveau.setRenderer(new NiveauTableCellRender());
eNiveau.setEditor(new NiveauTableCellEditor());
list.add(eNiveau);
list.add(new SQLTableElement(e.getTable().getField("ID_STYLE")));
SQLTableElement dmdElt = null;
if (showDmdAchat && e.getTable().contains("ID_DEMANDE_ACHAT_ELEMENT")) {
dmdElt = new SQLTableElement(e.getTable().getField("ID_DEMANDE_ACHAT_ELEMENT"));
list.add(dmdElt);
}
if (e.getTable().contains("ID_AFFAIRE")) {
list.add(new SQLTableElement(e.getTable().getField("ID_AFFAIRE")));
}
SQLTableElement tableElementCodeFournisseur = null;
if (e.getTable().contains("ID_CODE_FOURNISSEUR") && supplierCode) {
tableElementCodeFournisseur = new SQLTableElement(e.getTable().getField("ID_CODE_FOURNISSEUR"), true, true, true);
list.add(tableElementCodeFournisseur);
}
if (e.getTable().contains("ID_COMPTE_PCE")) {
list.add(new SQLTableElement(e.getTable().getField("ID_COMPTE_PCE")));
}
SQLTableElement tableElementArticle = new SQLTableElement(e.getTable().getField("ID_ARTICLE"), true, true, true) {
@Override
public boolean isCellEditable(SQLRowValues vals, int rowIndex, int columnIndex) {
boolean b = super.isCellEditable(vals, rowIndex, columnIndex);
return b && !isFromTranferred(vals);
}
};
list.add(tableElementArticle);
// Article
SQLTableElement tableElementDepot = new SQLTableElement(e.getTable().getField("ID_DEPOT_STOCK"), true, true, true);
list.add(tableElementDepot);
Set<String> fieldsName = e.getTable().getFieldsName();
if (fieldsName.contains("ID_FAMILLE_ARTICLE")) {
final SQLTableElement tableFamille = new SQLTableElement(e.getTable().getField("ID_FAMILLE_ARTICLE"));
list.add(tableFamille);
}
if (fieldsName.contains("ID_ECO_CONTRIBUTION")) {
this.tableElementEcoID = new SQLTableElement(e.getTable().getField("ID_ECO_CONTRIBUTION"));
list.add(this.tableElementEcoID);
}
if (fieldsName.contains("INCOTERM")) {
final SQLTableElement tableElementInco = new SQLTableElement(e.getTable().getField("INCOTERM"));
tableElementInco.setEditable(false);
list.add(tableElementInco);
}
if (fieldsName.contains("PREBILAN")) {
final SQLTableElement tableElementPre = new SQLTableElement(e.getTable().getField("PREBILAN"), BigDecimal.class);
tableElementPre.setRenderer(new DeviseTableCellRenderer());
list.add(tableElementPre);
}
// Code article
final SQLTableElement tableElementCode = new SQLTableElement(e.getTable().getField("CODE"), String.class,
new ITextArticleWithCompletionCellEditor(e.getTable().getTable("ARTICLE"), e.getTable().getTable("ARTICLE_FOURNISSEUR"), withDeclinaison)) {
@Override
public boolean isCellEditable(SQLRowValues vals, int rowIndex, int columnIndex) {
boolean b = super.isCellEditable(vals, rowIndex, columnIndex);
return b && !isFromTranferred(vals);
}
};
list.add(tableElementCode);
// Désignation de l'article
final SQLTableElement tableElementNom = new SQLTableElement(e.getTable().getField("NOM")) {
@Override
public boolean isCellEditable(SQLRowValues vals, int rowIndex, int columnIndex) {
boolean b = super.isCellEditable(vals, rowIndex, columnIndex);
return b && !isFromTranferred(vals);
}
};
list.add(tableElementNom);
List<String> fieldDecl = new ArrayList<>();
if (withDeclinaison) {
for (String string : fieldsName) {
if (string.startsWith("ID_ARTICLE_DECLINAISON")) {
final SQLTableElement tableElementDeclinaison = new SQLTableElement(e.getTable().getField(string));
tableElementDeclinaison.setEditable(false);
fieldDecl.add(string);
list.add(tableElementDeclinaison);
}
}
}
if (fieldsName.contains("DESCRIPTIF")) {
final SQLTableElement tableElementDesc = new SQLTableElement(e.getTable().getField("DESCRIPTIF"));
list.add(tableElementDesc);
}
if (fieldsName.contains("COLORIS")) {
final SQLTableElement tableElementColoris = new SQLTableElement(e.getTable().getField("COLORIS"));
list.add(tableElementColoris);
}
if (fieldsName.contains("ID_FABRICANT")) {
SQLTableElement fab = new SQLTableElement(e.getTable().getField("ID_FABRICANT"));
list.add(fab);
}
// Valeur des métriques
final SQLTableElement tableElement_ValeurMetrique2 = new SQLTableElement(e.getTable().getField("VALEUR_METRIQUE_2"), Float.class);
list.add(tableElement_ValeurMetrique2);
final SQLTableElement tableElement_ValeurMetrique3 = new SQLTableElement(e.getTable().getField("VALEUR_METRIQUE_3"), Float.class);
list.add(tableElement_ValeurMetrique3);
final SQLTableElement tableElement_ValeurMetrique1 = new SQLTableElement(e.getTable().getField("VALEUR_METRIQUE_1"), Float.class);
list.add(tableElement_ValeurMetrique1);
// Prix d'achat HT de la métrique 1
final DeviseNumericHTConvertorCellEditor editorPAHT = new DeviseNumericHTConvertorCellEditor(e.getTable().getField("PRIX_METRIQUE_HA_1"));
final SQLTableElement tableElement_PrixMetrique1_AchatHT = new SQLTableElement(e.getTable().getField("PRIX_METRIQUE_HA_1"), BigDecimal.class, editorPAHT);
tableElement_PrixMetrique1_AchatHT.setRenderer(new CurrencyWithSymbolRenderer());
list.add(tableElement_PrixMetrique1_AchatHT);
if (fieldsName.contains("ECO_CONTRIBUTION")) {
this.tableElementEco = new SQLTableElement(e.getTable().getField("ECO_CONTRIBUTION"));
list.add(this.tableElementEco);
}
final SQLTableElement tableElement_Devise = new SQLTableElement(e.getTable().getField("ID_DEVISE"));
tableElement_Devise.setEditable(false);
final SQLTableElement tableElement_PA_Devise = new SQLTableElement(e.getTable().getField("PA_DEVISE"), BigDecimal.class);
Path p = new Path(getSQLElement().getTable()).addForeignField("ID_DEVISE");
tableElement_PA_Devise.setRenderer(new CurrencyWithSymbolRenderer(new FieldPath(p, "CODE")));
if (showDevise) {
// Devise
list.add(tableElement_Devise);
// Prix d'achat HT devise
list.add(tableElement_PA_Devise);
}
// Mode de vente
final SQLTableElement tableElement_ModeVente = new SQLTableElement(e.getTable().getField("ID_MODE_VENTE_ARTICLE"));
list.add(tableElement_ModeVente);
// Prix d'achat unitaire HT
this.ha = new SQLTableElement(e.getTable().getField("PA_HT"), BigDecimal.class);
this.ha.setRenderer(new CurrencyWithSymbolRenderer());
list.add(this.ha);
SQLTableElement qteU = new SQLTableElement(e.getTable().getField("QTE_UNITAIRE"), BigDecimal.class) {
@Override
public boolean isCellEditable(SQLRowValues vals, int rowIndex, int columnIndex) {
SQLRowAccessor row = vals.getForeign("ID_UNITE_VENTE");
if (row != null && !row.isUndefined() && row.getBoolean("A_LA_PIECE")) {
return false;
} else {
return super.isCellEditable(vals, rowIndex, columnIndex);
}
}
@Override
public TableCellRenderer getTableCellRenderer() {
return new QteUnitRowValuesRenderer();
}
protected Object getDefaultNullValue() {
return BigDecimal.ZERO;
}
};
list.add(qteU);
SQLTableElement uniteVente = new SQLTableElement(e.getTable().getField("ID_UNITE_VENTE"));
list.add(uniteVente);
SQLTableElement tableCmdElt = null;
if (e.getTable().contains("ID_COMMANDE_ELEMENT")) {
tableCmdElt = new SQLTableElement(e.getTable().getField("ID_COMMANDE_ELEMENT"));
tableCmdElt.setRenderer(new DefaultTableCellRenderer() {
@Override
public Component getTableCellRendererComponent(JTable table, Object value, boolean isSelected, boolean hasFocus, int row, int column) {
SQLRowValues rowVals = getRowValuesTable().getRowValuesTableModel().getRowValuesAt(row);
JLabel tableCellRendererComponent = (JLabel) super.getTableCellRendererComponent(table, value, isSelected, hasFocus, row, column);
tableCellRendererComponent.setText("");
if (rowVals.getObject("ID_COMMANDE_ELEMENT") != null && !rowVals.isForeignEmpty("ID_COMMANDE_ELEMENT")) {
SQLRowAccessor rowCmdItem = rowVals.getForeign("ID_COMMANDE_ELEMENT");
int qte = rowCmdItem.getInt("QTE");
BigDecimal qteU = rowCmdItem.getBigDecimal("QTE_UNITAIRE");
BigDecimal qteR = rowCmdItem.getBigDecimal("QTE_RECUE");
qteU = qteU.multiply(new BigDecimal(qte));
if (qteR != null) {
tableCellRendererComponent.setText(qteU.subtract(qteR).setScale(2, RoundingMode.HALF_UP).toString());
} else {
tableCellRendererComponent.setText(qteU.setScale(2, RoundingMode.HALF_UP).toString());
}
}
return tableCellRendererComponent;
}
});
tableCmdElt.setEditable(false);
list.add(tableCmdElt);
}
if (e.getTable().contains("ID_BON_RECEPTION_ELEMENT")) {
SQLTableElement tableBrElt = null;
tableBrElt = new SQLTableElement(e.getTable().getField("ID_BON_RECEPTION_ELEMENT"));
tableBrElt.setEditable(false);
list.add(tableBrElt);
}
if (fieldsName.contains("QTE_ORIGINE")) {
final SQLTableElement tableQteO = new SQLTableElement(e.getTable().getField("QTE_ORIGINE"));
tableQteO.setEditable(false);
list.add(tableQteO);
}
// Quantité
final SQLTableElement qteElement = new SQLTableElement(e.getTable().getField("QTE"), Integer.class) {
protected Object getDefaultNullValue() {
return Integer.valueOf(0);
}
};
if (fieldsName.contains("QTE_ORIGINE")) {
qteElement.setRenderer(new DeliveredQtyRowValuesRenderer(false));
}
list.add(qteElement);
// TVA
this.tableElementTVA = new SQLTableElement(e.getTable().getField("ID_TAXE"));
list.add(this.tableElementTVA);
// Poids piece
SQLTableElement tableElementPoids = new SQLTableElement(e.getTable().getField("POIDS"), Float.class);
list.add(tableElementPoids);
// Poids total
this.tableElementPoidsTotal = new SQLTableElement(e.getTable().getField("T_POIDS"), Float.class);
list.add(this.tableElementPoidsTotal);
// Packaging
if (e.getTable().contains("POIDS_COLIS_NET") && prefs.getBoolean(GestionArticleGlobalPreferencePanel.ITEM_PACKAGING, false)) {
SQLTableElement tareColis = new SQLTableElement(e.getTable().getField("TARE"), BigDecimal.class) {
@Override
public TableCellRenderer getTableCellRenderer() {
return new QteUnitRowValuesRenderer();
}
};
list.add(tareColis);
SQLTableElement poidsColis = new SQLTableElement(e.getTable().getField("POIDS_COLIS_NET"), BigDecimal.class) {
@Override
public TableCellRenderer getTableCellRenderer() {
return new QteUnitRowValuesRenderer();
}
};
list.add(poidsColis);
SQLTableElement nbColis = new SQLTableElement(e.getTable().getField("NB_COLIS"), Integer.class);
list.add(nbColis);
final SQLTableElement totalPoidsColis = new SQLTableElement(e.getTable().getField("T_POIDS_COLIS_NET"), BigDecimal.class) {
@Override
public TableCellRenderer getTableCellRenderer() {
return new QteUnitRowValuesRenderer();
}
};
list.add(totalPoidsColis);
poidsColis.addModificationListener(totalPoidsColis);
nbColis.addModificationListener(totalPoidsColis);
totalPoidsColis.setModifier(new CellDynamicModifier() {
public Object computeValueFrom(final SQLRowValues row, SQLTableElement source) {
final BigDecimal pdsColis = row.getBigDecimal("POIDS_COLIS_NET");
final Object o3 = row.getObject("NB_COLIS");
BigDecimal pdsColisTotal = BigDecimal.ZERO;
if (pdsColis != null && o3 != null) {
int nb = (Integer) o3;
pdsColisTotal = pdsColis.multiply(new BigDecimal(nb), DecimalUtils.HIGH_PRECISION);
}
return pdsColisTotal.setScale(totalPoidsColis.getDecimalDigits(), RoundingMode.HALF_UP);
}
});
final SQLTableElement totalPoidsBrut = new SQLTableElement(e.getTable().getField("T_POIDS_BRUT"), BigDecimal.class) {
@Override
public TableCellRenderer getTableCellRenderer() {
return new QteUnitRowValuesRenderer();
}
};
list.add(totalPoidsBrut);
tareColis.addModificationListener(totalPoidsBrut);
poidsColis.addModificationListener(totalPoidsBrut);
nbColis.addModificationListener(totalPoidsBrut);
this.tableElementPoidsTotal.addModificationListener(totalPoidsBrut);
totalPoidsBrut.setModifier(new CellDynamicModifier() {
public Object computeValueFrom(final SQLRowValues row, SQLTableElement source) {
final BigDecimal tare = row.getBigDecimal("TARE");
final int qte = row.getInt("QTE");
final BigDecimal pdsColis = row.getBigDecimal("POIDS_COLIS_NET");
final Object o3 = row.getObject("NB_COLIS");
BigDecimal pdsBrutTotal = BigDecimal.ZERO;
if (row.getObject("T_POIDS") != null) {
pdsBrutTotal = new BigDecimal(row.getFloat("T_POIDS"));
}
if (tare != null) {
pdsBrutTotal = pdsBrutTotal.add(tare.multiply(new BigDecimal(qte)));
}
if (pdsColis != null && o3 != null) {
int nb = (Integer) o3;
pdsBrutTotal = pdsBrutTotal.add(pdsColis.multiply(new BigDecimal(nb), DecimalUtils.HIGH_PRECISION));
}
// return row.getObject("T_POIDS_COLIS_NET");
return pdsBrutTotal.setScale(totalPoidsBrut.getDecimalDigits(), RoundingMode.HALF_UP);
}
});
}
// Service
String val = DefaultNXProps.getInstance().getStringProperty("ArticleService");
Boolean b = Boolean.valueOf(val);
if (b != null && b.booleanValue()) {
this.service = new SQLTableElement(e.getTable().getField("SERVICE"), Boolean.class);
list.add(this.service);
}
if (showDevise) {
// Prix d'achat HT devise
this.tableElementTotalDevise = new SQLTableElement(e.getTable().getField("PA_DEVISE_T"), BigDecimal.class);
CurrencyWithSymbolRenderer deviseTotalRenderer = new CurrencyWithSymbolRenderer(new FieldPath(p, "CODE"));
deviseTotalRenderer.setHideZeroValue(true);
this.tableElementTotalDevise.setRenderer(deviseTotalRenderer);
list.add(tableElementTotalDevise);
}
SQLTableElement tableElementRemise = null;
if (e.getTable().contains("POURCENT_REMISE")) {
tableElementRemise = new SQLTableElement(e.getTable().getField("POURCENT_REMISE"));
list.add(tableElementRemise);
}
if (fieldsName.contains("T_ECO_CONTRIBUTION")) {
this.tableElementEcoTotal = new SQLTableElement(e.getTable().getField("T_ECO_CONTRIBUTION"));
list.add(this.tableElementEcoTotal);
}
// Total HT
this.totalHT = new SQLTableElement(e.getTable().getField("T_PA_HT"), BigDecimal.class);
DeviseTableCellRenderer totalRenderer = new DeviseTableCellRenderer();
totalRenderer.setHideZeroValue(true);
this.totalHT.setRenderer(totalRenderer);
this.totalHT.setEditable(false);
if (e.getTable().contains("POURCENT_REMISE") && tableElementRemise != null) {
tableElementRemise.addModificationListener(this.totalHT);
}
list.add(this.totalHT);
this.totalHA = this.totalHT;
// Total TTC
this.tableElementTotalTTC = new SQLTableElement(e.getTable().getField("T_PA_TTC"), BigDecimal.class);
this.tableElementTotalTTC.setRenderer(totalRenderer);
list.add(this.tableElementTotalTTC);
this.defaultRowVals = new SQLRowValues(UndefinedRowValuesCache.getInstance().getDefaultRowValues(e.getTable()));
this.defaultRowVals.put("ID_TAXE", TaxeCache.getCache().getFirstTaxeAchat().getID());
this.defaultRowVals.put("CODE", "");
this.defaultRowVals.put("NOM", "");
this.defaultRowVals.put("QTE", 1);
this.defaultRowVals.put("QTE_UNITAIRE", BigDecimal.ONE);
this.defaultRowVals.put("ID_UNITE_VENTE", UniteVenteArticleSQLElement.A_LA_PIECE);
this.defaultRowVals.put("ID_MODE_VENTE_ARTICLE", ReferenceArticleSQLElement.A_LA_PIECE);
if (e.getTable().contains("ID_DEPOT_STOCK")) {
DefaultProps props = DefaultNXProps.getInstance();
Integer depotDefault = props.getIntProperty("DepotStockDefault", DepotStockSQLElement.DEFAULT_ID);
this.defaultRowVals.put("ID_DEPOT_STOCK", depotDefault);
}
final RowValuesTableModel model = new RowValuesTableModel(e, list, e.getTable().getField("QTE"), false, this.defaultRowVals) {
@Override
public void commitData() {
super.commitData(true);
}
};
setModel(model);
this.table = new RowValuesTable(model, getConfigurationFile());
ToolTipManager.sharedInstance().unregisterComponent(this.table);
ToolTipManager.sharedInstance().unregisterComponent(this.table.getTableHeader());
if (getSQLElement().getTable().getName().equals("COMMANDE_ELEMENT")) {
this.table.getClearCloneTableElement().add("QTE_RECUE");
this.table.getClearCloneTableElement().add("RECU");
this.table.getClearCloneTableElement().add("RECU_FORCED");
} else if (getSQLElement().getTable().getName().equals("BON_RECEPTION_ELEMENT")) {
this.table.getClearCloneTableElement().add("ID_COMMANDE_ELEMENT");
} else if (getSQLElement().getTable().getName().equals("FACTURE_FOURNISSEUR_ELEMENT")) {
if (getSQLElement().getTable().contains("ID_COMMANDE_ELEMENT")) {
this.table.getClearCloneTableElement().add("ID_COMMANDE_ELEMENT");
}
if (getSQLElement().getTable().contains("ID_BON_RECEPTION_ELEMENT")) {
this.table.getClearCloneTableElement().add("ID_BON_RECEPTION_ELEMENT");
}
}
table.addMouseListener(new MouseAdapter() {
@Override
public void mouseReleased(MouseEvent e) {
handlePopup(e);
}
@Override
public void mousePressed(MouseEvent e) {
handlePopup(e);
}
public void handlePopup(MouseEvent e) {
final int rowindex = table.getSelectedRow();
if (rowindex < 0)
return;
if (e.isPopupTrigger() && e.getComponent() instanceof JTable) {
JPopupMenu popup = new JPopupMenu();
if (prefs.getBoolean(GestionArticleGlobalPreferencePanel.CAN_EXPAND_NOMENCLATURE_HA, true)) {
popup.add(new AbstractAction(TranslationManager.getInstance().getTranslationForItem("product.bom.expand")) {
@Override
public void actionPerformed(ActionEvent arg0) {
expandNomenclature(rowindex, m, EXPAND_TYPE.EXPAND);
}
});
popup.add(new AbstractAction(TranslationManager.getInstance().getTranslationForItem("product.bom.expose")) {
@Override
public void actionPerformed(ActionEvent arg0) {
expandNomenclature(rowindex, m, EXPAND_TYPE.VIEW_ONLY);
}
});
popup.add(new AbstractAction(TranslationManager.getInstance().getTranslationForItem("product.bom.flat")) {
@Override
public void actionPerformed(ActionEvent arg0) {
expandNomenclature(rowindex, m, EXPAND_TYPE.FLAT);
}
});
}
for (AbstractAction action : getAdditionnalMouseAction(rowindex)) {
popup.add(action);
}
popup.show(e.getComponent(), e.getX(), e.getY());
}
}
});
// Autocompletion
if (dmdElt != null) {
AutoCompletionManager dmd = new AutoCompletionManager(dmdElt, ((ComptaPropsConfiguration) Configuration.getInstance()).getSQLBaseSociete().getField("DEMANDE_ACHAT_ELEMENT.ID"), this.table,
this.table.getRowValuesTableModel(), ITextWithCompletion.MODE_CONTAINS, true, true, new ValidStateChecker());
dmd.fill("ID_FAMILLE_ARTICLE", "ID_FAMILLE_ARTICLE");
}
List<String> completionFields = new ArrayList<String>();
if (fieldsName.contains("INCOTERM")) {
completionFields.add("INCOTERM");
}
if (fieldsName.contains("ID_ECO_CONTRIBUTION")) {
completionFields.add("ID_ECO_CONTRIBUTION");
}
completionFields.add("ID_UNITE_VENTE");
completionFields.add("QTE_UNITAIRE");
completionFields.add("PA_HT");
completionFields.add("PV_HT");
completionFields.add("POIDS");
completionFields.add("ID_TAXE");
completionFields.add("PRIX_METRIQUE_HA_1");
completionFields.add("PRIX_METRIQUE_HA_2");
completionFields.add("PRIX_METRIQUE_HA_3");
completionFields.add("VALEUR_METRIQUE_1");
completionFields.add("VALEUR_METRIQUE_2");
completionFields.add("VALEUR_METRIQUE_3");
completionFields.add("ID_MODE_VENTE_ARTICLE");
completionFields.add("PRIX_METRIQUE_VT_1");
completionFields.add("PRIX_METRIQUE_VT_2");
completionFields.add("PRIX_METRIQUE_VT_3");
completionFields.add("SERVICE");
completionFields.add("ID_DEVISE");
completionFields.add("PA_DEVISE");
completionFields.addAll(fieldDecl);
if (fieldsName.contains("COLORIS")) {
completionFields.add("COLORIS");
}
if (fieldsName.contains("DESCRIPTIF")) {
completionFields.add("DESCRIPTIF");
}
if (fieldsName.contains("ID_FAMILLE_ARTICLE")) {
completionFields.add("ID_FAMILLE_ARTICLE");
}
final SQLTable sqlTableArticle = e.getTable().getTable("ARTICLE");
if (getSQLElement().getTable().getFieldsName().contains("POIDS_COLIS_NET") && sqlTableArticle.getTable().getFieldsName().contains("POIDS_COLIS_NET")) {
completionFields.add("POIDS_COLIS_NET");
}
if (getSQLElement().getTable().getFieldsName().contains("TARE") && sqlTableArticle.getTable().getFieldsName().contains("TARE")) {
completionFields.add("TARE");
}
this.m = new AutoCompletionManager(tableElementCode, sqlTableArticle.getField("CODE"), this.table, this.table.getRowValuesTableModel()) {
@Override
protected Object getValueFrom(SQLRow row, String field, SQLRowAccessor rowDest) {
Object res = tarifCompletion(row, field);
if (res == null) {
if (field.equalsIgnoreCase("ID_CODE_FOURNISSEUR")) {
return null;
} else {
return super.getValueFrom(row, field, rowDest);
}
} else {
return res;
}
}
};
m.fill("NOM", "NOM");
m.fill("ID", "ID_ARTICLE");
if (e.getTable().contains("ID_CODE_FOURNISSEUR") && supplierCode) {
m.fill("ID_CODE_FOURNISSEUR", "ID_CODE_FOURNISSEUR");
}
for (String string : completionFields) {
m.fill(string, string);
}
final Where w = new Where(sqlTableArticle.getField("OBSOLETE"), "=", Boolean.FALSE);
m.setWhere(w);
this.m2 = new AutoCompletionManager(tableElementNom, ((ComptaPropsConfiguration) Configuration.getInstance()).getSQLBaseSociete().getField("ARTICLE.NOM"), this.table,
this.table.getRowValuesTableModel()) {
@Override
protected Object getValueFrom(SQLRow row, String field, SQLRowAccessor rowDest) {
Object res = tarifCompletion(row, field);
if (res == null) {
return super.getValueFrom(row, field, rowDest);
} else {
return res;
}
}
};
m2.fill("CODE", "CODE");
m2.fill("ID", "ID_ARTICLE");
for (String string : completionFields) {
m2.fill(string, string);
}
m2.setWhere(w);
this.m3 = new AutoCompletionManager(tableElementArticle, ((ComptaPropsConfiguration) Configuration.getInstance()).getSQLBaseSociete().getField("ARTICLE.NOM"), this.table,
this.table.getRowValuesTableModel(), ITextWithCompletion.MODE_CONTAINS, true, true, new ValidStateChecker()) {
@Override
protected Object getValueFrom(SQLRow row, String field, SQLRowAccessor rowDest) {
Object res = tarifCompletion(row, field);
if (res == null) {
return super.getValueFrom(row, field, rowDest);
} else {
return res;
}
}
};
m3.fill("CODE", "CODE");
m3.fill("NOM", "NOM");
for (String string : completionFields) {
m3.fill(string, string);
}
m3.setWhere(w);
if (e.getTable().contains("ID_CODE_FOURNISSEUR") && supplierCode) {
this.m4 = new AutoCompletionManager(tableElementCodeFournisseur, ((ComptaPropsConfiguration) Configuration.getInstance()).getSQLBaseSociete().getField("ARTICLE.NOM"), this.table,
this.table.getRowValuesTableModel(), ITextWithCompletion.MODE_CONTAINS, true, true, new ValidStateChecker()) {
@Override
protected Object getValueFrom(SQLRow row, String field, SQLRowAccessor rowDest) {
Object res = tarifCompletion(row, field);
if (res == null) {
return super.getValueFrom(row, field, rowDest);
} else {
return res;
}
}
};
m4.fill("ID", "ID_ARTICLE");
m4.fill("CODE", "CODE");
m4.fill("NOM", "NOM");
for (String string : completionFields) {
m4.fill(string, string);
}
}
tableElementCode.addModificationListener(tableElementArticle);
tableElementArticle.setModifier(new CellDynamicModifier() {
@Override
public Object computeValueFrom(SQLRowValues row, SQLTableElement source) {
try {
SQLRowAccessor foreign = row.getForeign("ID_ARTICLE");
if (foreign != null && !foreign.isUndefined() && foreign.getObject("CODE") != null && foreign.getString("CODE").equals(row.getString("CODE"))) {
return foreign.getID();
} else {
return tableArticle.getUndefinedID();
}
} catch (Exception e) {
return tableArticle.getUndefinedID();
}
}
});
// ECO Contribution
if (this.tableElementEco != null && this.tableElementEcoTotal != null && this.tableElementEcoID != null) {
qteElement.addModificationListener(this.tableElementEcoTotal);
this.tableElementEco.addModificationListener(this.tableElementEcoTotal);
this.tableElementEcoTotal.setModifier(new CellDynamicModifier() {
public Object computeValueFrom(final SQLRowValues row, SQLTableElement source) {
int qte = Integer.parseInt(row.getObject("QTE").toString());
BigDecimal f = (row.getObject("ECO_CONTRIBUTION") == null) ? BigDecimal.ZERO : (BigDecimal) row.getObject("ECO_CONTRIBUTION");
return f.multiply(new BigDecimal(qte));
}
});
this.tableElementEcoID.addModificationListener(this.tableElementEco);
this.tableElementEco.setModifier(new CellDynamicModifier() {
public Object computeValueFrom(final SQLRowValues row, SQLTableElement source) {
if (source.equals(tableElementEcoID)) {
return row.getForeign("ID_ECO_CONTRIBUTION").getBigDecimal("TAUX");
} else {
return row.getObject("ECO_CONTRIBUTION");
}
}
});
}
// Calcul automatique du total HT
qteElement.addModificationListener(this.totalHT);
qteU.addModificationListener(this.totalHT);
this.ha.addModificationListener(this.totalHT);
this.totalHT.setModifier(new CellDynamicModifier() {
public Object computeValueFrom(final SQLRowValues row, SQLTableElement source) {
int qte = Integer.parseInt(row.getObject("QTE").toString());
BigDecimal f = (row.getObject("PA_HT") == null) ? BigDecimal.ZERO : (BigDecimal) row.getObject("PA_HT");
BigDecimal b = (row.getObject("QTE_UNITAIRE") == null) ? BigDecimal.ONE : (BigDecimal) row.getObject("QTE_UNITAIRE");
BigDecimal r = b.multiply(f.multiply(BigDecimal.valueOf(qte)), DecimalUtils.HIGH_PRECISION).setScale(totalHT.getDecimalDigits(), BigDecimal.ROUND_HALF_UP);
if (row.getTable().contains("POURCENT_REMISE")) {
final Object o2 = row.getObject("POURCENT_REMISE");
BigDecimal lremise = (o2 == null) ? BigDecimal.ZERO : ((BigDecimal) o2);
if (lremise.compareTo(BigDecimal.ZERO) >= 0 && lremise.compareTo(BigDecimal.valueOf(100)) < 0) {
r = r.multiply(new BigDecimal(100).subtract(lremise).movePointLeft(2)).setScale(totalHT.getDecimalDigits(), BigDecimal.ROUND_HALF_UP);
}
}
return r;
}
});
if (showDevise) {
if (tableElement_PA_Devise != null) {
tableElement_PA_Devise.addModificationListener(tableElement_PrixMetrique1_AchatHT);
}
if (tableElement_PA_Devise != null) {
tableElement_PrixMetrique1_AchatHT.addModificationListener(tableElement_PA_Devise);
tableElement_PA_Devise.setModifier(new CellDynamicModifier() {
public Object computeValueFrom(SQLRowValues row, SQLTableElement source) {
if (source != null && source.getField().getName().equals("PA_DEVISE")) {
return row.getObject("PA_DEVISE");
} else {
if (row.contains("ID_DEVISE") && !row.isForeignEmpty("ID_DEVISE")) {
String devCode = row.getForeign("ID_DEVISE").getString("CODE");
BigDecimal bigDecimal = (BigDecimal) row.getObject("PRIX_METRIQUE_HA_1");
CurrencyConverter c = new CurrencyConverter();
BigDecimal result = convert(bigDecimal, devCode, true);
if (result == null) {
JOptionPane.showMessageDialog(AbstractAchatArticleItemTable.this, "Unable to convert " + bigDecimal + " from " + c.getCompanyCurrencyCode() + " to " + devCode);
return BigDecimal.ZERO;
}
return result;
} else if (source != null && source.getField().getName().equalsIgnoreCase("PRIX_METRIQUE_HA_1")) {
return row.getObject("PRIX_METRIQUE_HA_1");
}
return row.getObject("PA_DEVISE");
}
}
});
}
qteElement.addModificationListener(this.tableElementTotalDevise);
qteU.addModificationListener(this.tableElementTotalDevise);
tableElement_PA_Devise.addModificationListener(this.tableElementTotalDevise);
if (e.getTable().contains("POURCENT_REMISE") && tableElementRemise != null) {
tableElementRemise.addModificationListener(this.tableElementTotalDevise);
}
this.tableElementTotalDevise.setModifier(new CellDynamicModifier() {
public Object computeValueFrom(final SQLRowValues row, SQLTableElement source) {
int qte = Integer.parseInt(row.getObject("QTE").toString());
BigDecimal f = (BigDecimal) row.getObject("PA_DEVISE");
BigDecimal b = (row.getObject("QTE_UNITAIRE") == null) ? BigDecimal.ONE : (BigDecimal) row.getObject("QTE_UNITAIRE");
BigDecimal r = b.multiply(f.multiply(BigDecimal.valueOf(qte)), DecimalUtils.HIGH_PRECISION).setScale(tableElementTotalDevise.getDecimalDigits(), BigDecimal.ROUND_HALF_UP);
if (row.getTable().contains("POURCENT_REMISE")) {
final Object o2 = row.getObject("POURCENT_REMISE");
BigDecimal lremise = (o2 == null) ? BigDecimal.ZERO : ((BigDecimal) o2);
if (lremise.compareTo(BigDecimal.ZERO) >= 0 && lremise.compareTo(BigDecimal.valueOf(100)) < 0) {
r = r.multiply(new BigDecimal(100).subtract(lremise).movePointLeft(2)).setScale(tableElementTotalDevise.getDecimalDigits(), BigDecimal.ROUND_HALF_UP);
}
}
return r;
}
});
}
// Calcul automatique du total TTC
qteElement.addModificationListener(this.tableElementTotalTTC);
qteU.addModificationListener(this.tableElementTotalTTC);
this.ha.addModificationListener(this.tableElementTotalTTC);
this.tableElementTVA.addModificationListener(this.tableElementTotalTTC);
this.tableElementTotalTTC.setModifier(new CellDynamicModifier() {
@Override
public Object computeValueFrom(SQLRowValues row, SQLTableElement source) {
int qte = Integer.parseInt(row.getObject("QTE").toString());
BigDecimal f = (BigDecimal) row.getObject("PA_HT");
int idTaux = Integer.parseInt(row.getObject("ID_TAXE").toString());
Float resultTaux = TaxeCache.getCache().getTauxFromId(idTaux);
if (resultTaux == null) {
SQLRow rowTax = TaxeCache.getCache().getFirstTaxe();
row.put("ID_TAXE", rowTax.getID());
resultTaux = rowTax.getFloat("TAUX");
}
editorPAHT.setTaxe(resultTaux);
BigDecimal b = (row.getObject("QTE_UNITAIRE") == null) ? BigDecimal.ONE : (BigDecimal) row.getObject("QTE_UNITAIRE");
BigDecimal r = b.multiply(f.multiply(BigDecimal.valueOf(qte), DecimalUtils.HIGH_PRECISION), DecimalUtils.HIGH_PRECISION).setScale(tableElementTotalTTC.getDecimalDigits(),
BigDecimal.ROUND_HALF_UP);
float taux = (resultTaux == null) ? 0.0F : resultTaux.floatValue();
BigDecimal total = r.multiply(BigDecimal.ONE.add(new BigDecimal(taux / 100f))).setScale(tableElementTotalTTC.getDecimalDigits(), RoundingMode.HALF_UP);
return total;
}
});
this.table.readState();
// Mode Gestion article avancé
String valModeAvanceVt = DefaultNXProps.getInstance().getStringProperty("ArticleModeVenteAvance");
Boolean bModeAvance = Boolean.valueOf(valModeAvanceVt);
boolean view = !(bModeAvance != null && !bModeAvance.booleanValue());
setColumnVisible(model.getColumnForField("VALEUR_METRIQUE_1"), view);
setColumnVisible(model.getColumnForField("VALEUR_METRIQUE_2"), view);
setColumnVisible(model.getColumnForField("VALEUR_METRIQUE_3"), view);
setColumnVisible(model.getColumnForField("PRIX_METRIQUE_VT_1"), view);
setColumnVisible(model.getColumnForField("ID_MODE_VENTE_ARTICLE"), view);
setColumnVisible(model.getColumnForField("PA_HT"), view);
if (e.getTable().contains("ID_COMMANDE_ELEMENT")) {
setColumnVisible(model.getColumnForField("ID_COMMANDE_ELEMENT"), false);
}
if (e.getTable().contains("ID_BON_RECEPTION_ELEMENT")) {
setColumnVisible(model.getColumnForField("ID_BON_RECEPTION_ELEMENT"), false);
}
// Gestion des unités de vente
final boolean gestionUV = prefs.getBoolean(GestionArticleGlobalPreferencePanel.UNITE_VENTE, true);
setColumnVisible(model.getColumnForField("QTE_UNITAIRE"), gestionUV);
setColumnVisible(model.getColumnForField("ID_UNITE_VENTE"), gestionUV);
setColumnVisible(model.getColumnForField("ID_STYLE"), DefaultNXProps.getInstance().getBooleanValue("ArticleShowStyle", true));
if (this.tableElementEco != null && this.tableElementEcoTotal != null && this.tableElementEcoID != null) {
setColumnVisible(model.getColumnForField("ID_ECO_CONTRIBUTION"), showEco);
setColumnVisible(model.getColumnForField("ECO_CONTRIBUTION"), showEco);
setColumnVisible(model.getColumnForField("T_ECO_CONTRIBUTION"), showEco);
}
setColumnVisible(model.getColumnForField("ID_ARTICLE"), selectArticle);
setColumnVisible(model.getColumnForField("CODE"), !selectArticle || (selectArticle && createAuto));
setColumnVisible(model.getColumnForField("NOM"), !selectArticle || (selectArticle && createAuto));
setColumnVisible(model.getColumnForField("ID_DEPOT_STOCK"), prefs.getBoolean(GestionArticleGlobalPreferencePanel.STOCK_MULTI_DEPOT, false));
setColumnVisible(model.getColumnForField("T_POIDS_COLIS_NET"), false);
setColumnVisible(model.getColumnForField("T_POIDS_BRUT"), false);
// Calcul automatique du poids unitaire
tableElement_ValeurMetrique1.addModificationListener(tableElementPoids);
tableElement_ValeurMetrique2.addModificationListener(tableElementPoids);
tableElement_ValeurMetrique3.addModificationListener(tableElementPoids);
tableElementPoids.setModifier(new CellDynamicModifier() {
public Object computeValueFrom(SQLRowValues row, SQLTableElement source) {
return new Float(ReferenceArticleSQLElement.getPoidsFromDetails(row));
}
});
// Calcul automatique du poids total
tableElementPoids.addModificationListener(this.tableElementPoidsTotal);
qteElement.addModificationListener(this.tableElementPoidsTotal);
qteU.addModificationListener(this.tableElementPoidsTotal);
this.tableElementPoidsTotal.setModifier(new CellDynamicModifier() {
public Object computeValueFrom(SQLRowValues row, SQLTableElement source) {
Number f = (row.getObject("POIDS") == null) ? 0 : (Number) row.getObject("POIDS");
int qte = Integer.parseInt(row.getObject("QTE").toString());
BigDecimal b = (row.getObject("QTE_UNITAIRE") == null) ? BigDecimal.ONE : (BigDecimal) row.getObject("QTE_UNITAIRE");
// FIXME convertir en float autrement pour éviter une valeur non transposable
// avec floatValue ou passer POIDS en bigDecimal
return b.multiply(new BigDecimal(f.floatValue() * qte)).floatValue();
}
});
tableElement_PrixMetrique1_AchatHT.setModifier(new CellDynamicModifier() {
public Object computeValueFrom(SQLRowValues row, SQLTableElement source) {
if (source != null && source.getField().getName().equals("PRIX_METRIQUE_HA_1")) {
return row.getObject("PRIX_METRIQUE_HA_1");
} else {
if (source != null && source.getField().getName().equals("PA_DEVISE")) {
if (row.contains("ID_DEVISE") && !row.isForeignEmpty("ID_DEVISE")) {
String devCode = row.getForeign("ID_DEVISE").getString("CODE");
BigDecimal bigDecimal = (BigDecimal) row.getObject("PA_DEVISE");
return convert(bigDecimal, devCode, false);
} else {
return row.getObject("PRIX_METRIQUE_HA_1");
}
}
return row.getObject("PRIX_METRIQUE_HA_1");
}
}
});
// Calcul automatique du prix d'achat unitaire HT
tableElement_ValeurMetrique1.addModificationListener(this.ha);
tableElement_ValeurMetrique2.addModificationListener(this.ha);
tableElement_ValeurMetrique3.addModificationListener(this.ha);
tableElement_PrixMetrique1_AchatHT.addModificationListener(this.ha);
this.ha.setModifier(new CellDynamicModifier() {
public Object computeValueFrom(SQLRowValues row, SQLTableElement source) {
if (row.isForeignEmpty("ID_MODE_VENTE_ARTICLE") || row.getInt("ID_MODE_VENTE_ARTICLE") == ReferenceArticleSQLElement.A_LA_PIECE) {
return row.getObject("PRIX_METRIQUE_HA_1");
} else {
final BigDecimal prixHAFromDetails = ReferenceArticleSQLElement.getPrixHAFromDetails(row);
return prixHAFromDetails.setScale(ha.getDecimalDigits(), RoundingMode.HALF_UP);
}
}
});
uniteVente.addModificationListener(qteU);
qteU.setModifier(new CellDynamicModifier() {
public Object computeValueFrom(SQLRowValues row, SQLTableElement source) {
SQLRowAccessor rowUnite = row.getForeign("ID_UNITE_VENTE");
if (rowUnite != null && !rowUnite.isUndefined() && rowUnite.getBoolean("A_LA_PIECE")) {
return BigDecimal.ONE;
} else {
return row.getObject("QTE_UNITAIRE");
}
}
});
// La devise est renseignée globalement dans la commande et est reportée automatiquement sur
// les lignes
setColumnVisible(model.getColumnIndexForElement(tableElement_Devise), false);
for (String string : visibilityMap.keySet()) {
setColumnVisible(model.getColumnForField(string), visibilityMap.get(string));
}
// Barcode reader
final BarcodeReader barcodeReader = ComptaPropsConfiguration.getInstanceCompta().getBarcodeReader();
if (barcodeReader != null) {
final BarcodeListener l = new BarcodeListener() {
@Override
public void keyReceived(KeyEvent ee) {
// TODO Auto-generated method stub
}
@Override
public void barcodeRead(String code) {
if (((JFrame) SwingUtilities.getRoot(getRowValuesTable())).isActive()) {
final SQLSelect selArticle = new SQLSelect();
final SQLTable tableArticle = getSQLElement().getForeignElement("ID_ARTICLE").getTable();
selArticle.addSelectStar(tableArticle);
Where w = new Where(tableArticle.getField("OBSOLETE"), "=", Boolean.FALSE);
w = w.and(new Where(tableArticle.getField("CODE_BARRE"), "=", code));
selArticle.setWhere(w);
List<SQLRow> l2 = SQLRowListRSH.execute(selArticle);
if (l2.size() > 0) {
System.err.println("ARTICLE " + l2.get(0).getString("NOM"));
Tuple3<Double, String, String> art = Tuple3.create(1.0D, l2.get(0).getString("CODE"), l2.get(0).getString("NOM"));
List<Tuple3<Double, String, String>> l = new ArrayList<Tuple3<Double, String, String>>();
l.add(art);
insertFromDrop(l, m);
} else {
System.err.println("ARTICLE NOT FOUND !");
}
}
}
};
getRowValuesTable().addHierarchyListener(new HierarchyListener() {
public void hierarchyChanged(HierarchyEvent e) {
if ((e.getChangeFlags() & HierarchyEvent.DISPLAYABILITY_CHANGED) != 0)
if (getRowValuesTable().isDisplayable()) {
barcodeReader.addBarcodeListener(l);
} else {
barcodeReader.removeBarcodeListener(l);
}
}
});
}
// On réécrit la configuration au cas ou les preferences aurait changé
this.table.writeState();
if (this.table.getRowValuesTableModel().getColumnForField("ID_DEPOT_STOCK") >= 0 && this.table.getRowValuesTableModel().getColumnForField("ID_ARTICLE") >= 0) {
if (this.buttons == null) {
this.buttons = new ArrayList<>();
}
JButton buttonStock = new JButton("Consulter le stock");
buttonStock.addActionListener(new ActionListener() {
public void actionPerformed(ActionEvent event) {
try {
SQLRowValues rowValsSel = table.getSelectedRowValues();
if (rowValsSel != null) {
SQLRowAccessor foreignArt = rowValsSel.getForeign("ID_ARTICLE");
if (foreignArt != null && !foreignArt.isUndefined()) {
SQLRowAccessor rowValsStock = StockSQLElement.getStock(rowValsSel);
if (rowValsStock != null && !rowValsStock.isUndefined()) {
EditFrame frame = new EditFrame(table.getRowValuesTableModel().getSQLElement().getDirectory().getElement("STOCK"), EditMode.READONLY);
frame.selectionId(rowValsStock.getID());
frame.setVisible(true);
}
}
}
} catch (Exception e) {
ExceptionHandler.handle("Erreur d'accès au stock", e);
}
}
});
this.buttons.add(buttonStock);
}
}
private static Map<String, Boolean> visibilityMap = new HashMap<String, Boolean>();
public static Map<String, Boolean> getVisibilityMap() {
return visibilityMap;
}
private String incoterm = "";
public void setIncoterms(String incoterm) {
if (incoterm == null) {
incoterm = "";
}
this.incoterm = incoterm;
}
private SQLRow rowFournisseur = null;
public void setFournisseur(SQLRow rowFournisseur) {
this.rowFournisseur = rowFournisseur;
if (getSQLElement().getTable().contains("ID_CODE_FOURNISSEUR") && this.supplierCode) {
if (rowFournisseur != null && !rowFournisseur.isUndefined()) {
Where w = new Where(getSQLElement().getTable().getTable("CODE_FOURNISSEUR").getField("ID_FOURNISSEUR"), "=", rowFournisseur.getID());
this.m4.setWhere(w);
} else {
this.m4.setWhere(null);
}
}
}
private BigDecimal getPrice(final SQLRowAccessor r, List<String> list) {
BigDecimal result = r.getBigDecimal(list.get(0));
for (int i = 1; i < list.size(); i++) {
BigDecimal m0 = r.getBigDecimal(list.get(i));
if (m0 != null && m0.floatValue() > 0) {
result = result.divide(m0, 2, RoundingMode.HALF_UP);
}
}
return result;
}
public Object tarifCompletion(SQLRow row, String field) {
final SQLTable tTarifFournisseur = this.getSQLElement().getTable().getDBRoot().getTable("ARTICLE_TARIF_FOURNISSEUR");
if (row != null && !row.isUndefined() && (field.equalsIgnoreCase("ID_CODE_FOURNISSEUR")) && this.rowFournisseur != null && !this.rowFournisseur.isUndefined()) {
final SQLTable foreignTableCodeF = getSQLElement().getTable().getForeignTable("ID_CODE_FOURNISSEUR");
List<SQLRow> resultCode = row.getReferentRows(foreignTableCodeF);
for (SQLRow sqlRow : resultCode) {
if (sqlRow.getForeignID("ID_FOURNISSEUR") == this.rowFournisseur.getID()) {
return sqlRow.getID();
}
}
return foreignTableCodeF.getUndefinedIDNumber();
}
if (field.equalsIgnoreCase("ID_CODE_FOURNISSEUR")) {
final SQLTable foreignTableCodeF = getSQLElement().getTable().getForeignTable("ID_CODE_FOURNISSEUR");
return foreignTableCodeF.getUndefinedIDNumber();
}
if (row != null && !row.isUndefined() && (field.equalsIgnoreCase("PRIX_METRIQUE_HA_1") || field.equalsIgnoreCase("PA_HT")) && tTarifFournisseur != null) {
List<String> incoTerms;
if (this.incoterm != null && this.incoterm.equalsIgnoreCase("CPT")) {
incoTerms = Arrays.asList("PRIX_ACHAT", "COEF_TRANSPORT_PORT");
} else if (this.incoterm != null && this.incoterm.equalsIgnoreCase("DDP")) {
incoTerms = Arrays.asList("PRIX_ACHAT", "COEF_TRANSPORT_PORT", "COEF_TAXE_D");
} else {
incoTerms = Arrays.asList("PRIX_ACHAT");
}
List<SQLRow> rows = row.getReferentRows(tTarifFournisseur);
if (row.getBoolean("AUTO_PRIX_ACHAT_NOMENCLATURE") && row.getTable().getDBRoot().contains("ARTICLE_PRIX_REVIENT")) {
List<SQLRow> rowsElt = row.getReferentRows(row.getTable().getTable("ARTICLE_ELEMENT").getField("ID_ARTICLE_PARENT"));
BigDecimal price = BigDecimal.ZERO;
final Set<String> tarifNotFound = new HashSet<String>();
for (SQLRow sqlRow : rowsElt) {
List<SQLRow> rowsT = sqlRow.getForeign("ID_ARTICLE").getReferentRows(tTarifFournisseur);
boolean priceFound = false;
boolean tarifFound = false;
if (rowsT.size() > 0) {
BigDecimal min = BigDecimal.ZERO;
BigDecimal defaultPrice = sqlRow.getForeign("ID_ARTICLE").getBigDecimal("PRIX_METRIQUE_HA_1");
Calendar c = null;
for (SQLRow sqlRowT : rowsT) {
if (this.rowFournisseur != null && this.rowFournisseur.getID() == sqlRowT.getForeignID("ID_FOURNISSEUR")) {
BigDecimal priceT = getPrice(sqlRowT, incoTerms);
defaultPrice = priceT;
final Calendar datePrice = sqlRowT.getDate("DATE_PRIX");
datePrice.set(Calendar.HOUR, 0);
datePrice.set(Calendar.MINUTE, 0);
datePrice.set(Calendar.SECOND, 0);
datePrice.set(Calendar.MILLISECOND, 0);
if (datePrice == null || (this.getDateDevise() != null && !this.getDateDevise().before(datePrice.getTime()))) {
if (c == null || c.before(datePrice)) {
min = priceT;
c = datePrice;
priceFound = true;
} else if (c != null) {
defaultPrice = priceT;
}
}
tarifFound = true;
}
}
if (priceFound) {
price = price.add(min.multiply(sqlRow.getBigDecimal("QTE_UNITAIRE").multiply(new BigDecimal(sqlRow.getInt("QTE"), DecimalUtils.HIGH_PRECISION))));
} else {
price = price.add(defaultPrice.multiply(sqlRow.getBigDecimal("QTE_UNITAIRE").multiply(new BigDecimal(sqlRow.getInt("QTE"), DecimalUtils.HIGH_PRECISION))));
}
}
if (!tarifFound) {
tarifNotFound.add(sqlRow.getForeign("ID_ARTICLE").getString("CODE"));
}
}
if (!tarifNotFound.isEmpty()) {
SwingUtilities.invokeLater(new Runnable() {
@Override
public void run() {
JOptionPane.showMessageDialog(AbstractAchatArticleItemTable.this.table,
"Attention, impossible de calculer le tarif.\nLes articles suivants n'ont pas de tarif associé :\n" + tarifNotFound);
}
});
}
return price;
} else if (!rows.isEmpty()) {
BigDecimal min = row.getBigDecimal("PRIX_METRIQUE_HA_1");
Calendar c = null;
for (SQLRow sqlRow : rows) {
if (this.rowFournisseur != null && this.rowFournisseur.getID() == sqlRow.getForeignID("ID_FOURNISSEUR")) {
BigDecimal price = getPrice(sqlRow, incoTerms);
final Calendar datePrice = sqlRow.getDate("DATE_PRIX");
if (datePrice == null || (this.getDateDevise() != null && !this.getDateDevise().before(datePrice.getTime()))) {
if (c == null || c.before(datePrice)) {
min = price;
c = datePrice;
}
}
}
}
return min.setScale(2, RoundingMode.HALF_UP);
}
}
if (field.equalsIgnoreCase("INCOTERM")) {
// if (tTarifFournisseur != null) {
// List<SQLRow> rows = row.getReferentRows(tTarifFournisseur);
// if (!rows.isEmpty()) {
// final SQLRow sqlRow0 = rows.get(0);
// return sqlRow0.getString("CONDITIONS");
// }
// }
return this.incoterm;
}
if (getDevise() != null && !getDevise().isUndefined()) {
if ((field.equalsIgnoreCase("ID_DEVISE") || field.equalsIgnoreCase("ID_DEVISE_HA"))) {
return getDevise().getID();
} else if ((field.equalsIgnoreCase("PA_DEVISE"))) {
if (row.getBigDecimal("PA_DEVISE") != null && row.getBigDecimal("PA_DEVISE").signum() != 0 && this.incoterm.length() == 0) {
return row.getBigDecimal("PA_DEVISE");
} else {
String devCode = getDevise().getString("CODE");
BigDecimal tarifCompletion = (BigDecimal) tarifCompletion(row, "PRIX_METRIQUE_HA_1");
if (tarifCompletion == null) {
tarifCompletion = row.getBigDecimal("PRIX_METRIQUE_HA_1");
}
if (tarifCompletion == null) {
return null;
} else {
// Remove set scale 2 --> if scale ex : PA = 95.74MAD --> 0.76592€
// with Scale 0.77€ so put 96.25MAD in PA
return convert(tarifCompletion, devCode, true);
}
}
}
} else {
if ((field.equalsIgnoreCase("ID_DEVISE") || field.equalsIgnoreCase("ID_DEVISE_HA"))) {
return Configuration.getInstance().getDirectory().getElement("DEVISE").getTable().getUndefinedID();
} else if ((field.equalsIgnoreCase("PA_DEVISE"))) {
return BigDecimal.ZERO;
}
}
if (field.equalsIgnoreCase("ID_TAXE") && this.rowCatComptable != null) {
return this.rowCatComptable.getForeignID("ID_TAXE_VENTE");
}
return null;
}
@Override
protected void refreshDeviseAmount() {
int count = getRowValuesTable().getRowCount();
final int columnForField = getRowValuesTable().getRowValuesTableModel().getColumnForField("PA_DEVISE");
if (columnForField >= 0) {
SQLTableElement eltDevise = getRowValuesTable().getRowValuesTableModel().getSQLTableElementAt(columnForField);
for (int i = 0; i < count; i++) {
SQLRowValues rowVals = getRowValuesTable().getRowValuesTableModel().getRowValuesAt(i);
// getRowValuesTable().getRowValuesTableModel().putValue(rowVals.getObject("PV_U_DEVISE"),
// i, "PV_U_DEVISE", true);
eltDevise.setValueFrom(rowVals, rowVals.getObject("PA_DEVISE"));
getRowValuesTable().getRowValuesTableModel().fireTableChanged(new TableModelEvent(getRowValuesTable().getRowValuesTableModel(), i, i, columnForField));
}
}
}
public SQLRowAccessor getDevise() {
return this.rowDevise;
}
public void setDevise(SQLRowAccessor deviseRow) {
this.rowDevise = deviseRow;
if (deviseRow == null) {
getDefaultRowValues().put("ID_DEVISE", null);
} else {
getDefaultRowValues().put("ID_DEVISE", this.rowDevise.getID());
}
}
private BigDecimal tauxConversion = null;
public void setTauxConversion(BigDecimal tauxConversion) {
if (tauxConversion != null && tauxConversion.signum() == 0) {
tauxConversion = null;
}
this.tauxConversion = tauxConversion;
refreshDeviseAmount();
}
public BigDecimal convert(BigDecimal val, String devCode, boolean fromCompanyCurrency) {
if (val == null) {
return val;
}
if (this.tauxConversion == null) {
CurrencyConverter c = new CurrencyConverter();
if (fromCompanyCurrency) {
return c.convert(val, c.getCompanyCurrencyCode(), devCode, getDateDevise(), isUsedBiasedDevise());
} else {
return c.convert(val, devCode, c.getCompanyCurrencyCode(), getDateDevise(), isUsedBiasedDevise());
}
} else {
if (fromCompanyCurrency) {
return val.divide(this.tauxConversion, DecimalUtils.HIGH_PRECISION).setScale(val.scale(), RoundingMode.HALF_UP);
} else {
return val.multiply(this.tauxConversion, DecimalUtils.HIGH_PRECISION).setScale(val.scale(), RoundingMode.HALF_UP);
}
}
}
public void setFournisseurFilterOnCompletion(SQLRow row) {
final SQLTable sqlTableArticle = ((ComptaPropsConfiguration) Configuration.getInstance()).getRootSociete().getTable("ARTICLE");
Where w = new Where(sqlTableArticle.getField("OBSOLETE"), "=", Boolean.FALSE);
if (row != null && !row.isUndefined()) {
w = w.and(new Where(this.tableArticle.getField("ID_FOURNISSEUR"), "=", row.getID()));
}
this.m.setWhere(w);
this.m2.setWhere(w);
this.m3.setWhere(w);
}
private void insertFromDrop(List<Tuple3<Double, String, String>> articles, AutoCompletionManager m) {
List<String> code = new ArrayList<String>(articles.size());
for (int i = articles.size() - 1; i >= 0; i--) {
Tuple3<Double, String, String> tuple = articles.get(i);
code.add(tuple.get1());
}
int rowCount = getRowValuesTable().getRowValuesTableModel().getRowCount();
Map<Integer, Integer> mapRows = new HashMap<Integer, Integer>();
for (int i = 0; i < rowCount; i++) {
SQLRowValues rowVals = getRowValuesTable().getRowValuesTableModel().getRowValuesAt(i);
if (rowVals.getObject("ID_ARTICLE") != null && !rowVals.isForeignEmpty("ID_ARTICLE")) {
mapRows.put(rowVals.getForeignID("ID_ARTICLE"), i);
}
}
SQLSelect sel = new SQLSelect();
final SQLTable articleTable = getSQLElement().getTable().getForeignTable("ID_ARTICLE");
sel.addSelectStar(articleTable);
sel.setWhere(new Where(articleTable.getField("CODE"), code));
List<SQLRow> matchCode = SQLRowListRSH.execute(sel);
Map<String, SQLRow> mapCode = new HashMap<String, SQLRow>();
for (SQLRow sqlRow : matchCode) {
mapCode.put(sqlRow.getString("CODE"), sqlRow);
}
Set<String> fieldsFrom = m.getFieldsFrom();
fieldsFrom.remove("POURCENT_REMISE");
for (int i = articles.size() - 1; i >= 0; i--) {
Tuple3<Double, String, String> tuple = articles.get(i);
SQLRow article = mapCode.get(tuple.get1());
if (article != null && mapRows.containsKey(article.getID())) {
Integer index = mapRows.get(article.getID());
SQLRowValues rowVals = getRowValuesTable().getRowValuesTableModel().getRowValuesAt(index);
getRowValuesTable().getRowValuesTableModel().putValue(rowVals.getInt("QTE") + 1, index, "QTE");
} else {
final SQLRowValues row2Insert = new SQLRowValues(getRowValuesTable().getRowValuesTableModel().getDefaultRowValues());
// Completion depuis l'article trouvé
if (article != null) {
m.fillRowValues(article, fieldsFrom, row2Insert);
// Fill prix total
row2Insert.put("ID_ARTICLE", article.getID());
row2Insert.put("CODE", article.getObject("CODE"));
row2Insert.put("NOM", article.getObject("NOM"));
} else {
row2Insert.put("CODE", tuple.get1());
row2Insert.put("NOM", tuple.get2());
}
row2Insert.put("QTE", Math.round(tuple.get0().floatValue()));
row2Insert.put("PA_HT", row2Insert.getObject("PRIX_METRIQUE_HA_1"));
//
final BigDecimal resultTotalHT = row2Insert.getBigDecimal("PA_HT").multiply(new BigDecimal(row2Insert.getInt("QTE")));
row2Insert.put("T_PA_HT", resultTotalHT);
Float resultTaux = TaxeCache.getCache().getTauxFromId(row2Insert.getForeignID("ID_TAXE"));
if (resultTaux == null) {
SQLRow rowTax = TaxeCache.getCache().getFirstTaxeAchat();
resultTaux = rowTax.getFloat("TAUX");
}
float taux = (resultTaux == null) ? 0.0F : resultTaux.floatValue();
BigDecimal r = resultTotalHT.multiply(BigDecimal.valueOf(taux).movePointLeft(2).add(BigDecimal.ONE), DecimalUtils.HIGH_PRECISION);
row2Insert.put("T_PA_TTC", r);
// row2Insert.put("ID_STYLE", allStyleByName.get("Composant"));
getRowValuesTable().getRowValuesTableModel().addRowAt(0, row2Insert);
}
}
}
private final List<String> trFields = Arrays.asList("ID_COMMANDE_ELEMENT", "ID_BON_RECEPTION_ELEMENT");
private boolean isFromTranferred(SQLRowValues vals) {
for (String trField : this.trFields) {
if (vals.getTable().contains(trField)) {
boolean noCmdElt = vals.getObject(trField) == null || vals.isForeignEmpty(trField);
if (!noCmdElt) {
return true;
}
}
}
return false;
}
}