40require
'../main.inc.php';
41require_once DOL_DOCUMENT_ROOT.
'/core/class/html.formadmin.class.php';
42require_once DOL_DOCUMENT_ROOT.
'/core/class/html.formcompany.class.php';
43require_once DOL_DOCUMENT_ROOT.
'/core/lib/admin.lib.php';
44require_once DOL_DOCUMENT_ROOT.
'/core/lib/functions2.lib.php';
45require_once DOL_DOCUMENT_ROOT.
'/core/class/doleditor.class.php';
46require_once DOL_DOCUMENT_ROOT.
'/core/lib/accounting.lib.php';
47require_once DOL_DOCUMENT_ROOT.
'/core/class/html.formaccounting.class.php';
48require_once DOL_DOCUMENT_ROOT.
'/core/lib/socialnetwork.lib.php';
51const DICT_FORME_JURIDIQUE = 1;
52const DICT_DEPARTEMENTS = 2;
53const DICT_REGIONS = 3;
54const DICT_COUNTRY = 4;
55const DICT_CIVILITY = 5;
56const DICT_ACTIONCOMM = 6;
57const DICT_CHARGESOCIALES = 7;
59const DICT_CURRENCIES = 9;
61const DICT_TYPE_CONTACT = 11;
62const DICT_PAYMENT_TERM = 12;
63const DICT_PAIEMENT = 13;
64const DICT_ECOTAXE = 14;
65const DICT_PAPER_FORMAT = 15;
66const DICT_PROSPECTLEVEL = 16;
67const DICT_TYPE_FEES = 17;
68const DICT_SHIPMENT_MODE = 18;
69const DICT_EFFECTIF = 19;
70const DICT_INPUT_METHOD = 20;
71const DICT_AVAILABILITY = 21;
72const DICT_INPUT_REASON = 22;
73const DICT_REVENUESTAMP = 23;
74const DICT_TYPE_RESOURCE = 24;
75const DICT_TYPE_CONTAINER = 25;
77const DICT_STCOMM = 27;
78const DICT_HOLIDAY_TYPES = 28;
79const DICT_LEAD_STATUS = 29;
80const DICT_FORMAT_CARDS = 30;
81const DICT_INVOICE_SUBTYPE = 31;
82const DICT_HRM_PUBLIC_HOLIDAY = 32;
83const DICT_HRM_DEPARTMENT = 33;
84const DICT_HRM_FUNCTION = 34;
85const DICT_EXP_TAX_CAT = 35;
86const DICT_EXP_TAX_RANGE = 36;
88const DICT_SOCIALNETWORKS = 38;
89const DICT_PROSPECTCONTACTLEVEL = 39;
90const DICT_STCOMMCONTACT = 40;
91const DICT_TRANSPORT_MODE = 41;
92const DICT_PRODUCT_NATURE = 42;
93const DICT_PRODUCTBATCH_QCSTATUS = 43;
94const DICT_ASSET_DISPOSAL_TYPE = 44;
106$langs->loadLangs(array(
"errors",
"admin",
"main",
"companies",
"resource",
"holiday",
"accountancy",
"hrm",
"orders",
"contracts",
"projects",
"propal",
"bills",
"interventions",
"ticket"));
108$action =
GETPOST(
'action',
'alpha') ?
GETPOST(
'action',
'alpha') :
'view';
109$confirm =
GETPOST(
'confirm',
'alpha');
112$rowid =
GETPOST(
'rowid',
'alpha');
113$entity =
GETPOST(
'entity',
'alpha');
114$code =
GETPOST(
'code',
'alpha');
115$from =
GETPOST(
'from',
'alpha');
119$acts[0] =
"activate";
121$actl[0] =
img_picto($langs->trans(
"Disabled"),
'switch_off',
'class="size15x"');
122$actl[1] =
img_picto($langs->trans(
"Activated"),
'switch_on',
'class="size15x"');
125$listoffset =
GETPOST(
'listoffset');
126$listlimit =
GETPOST(
'listlimit') > 0 ?
GETPOST(
'listlimit') : 1000;
127$sortfield =
GETPOST(
'sortfield',
'aZ09comma');
128$sortorder =
GETPOST(
'sortorder',
'aZ09comma');
130if (empty($page) || $page < 0 ||
GETPOST(
'button_search',
'alpha') ||
GETPOST(
'button_removefilter',
'alpha')) {
134$offset = $listlimit * $page;
135$pageprev = $page - 1;
136$pagenext = $page + 1;
138$search_country_id =
GETPOST(
'search_country_id',
'int');
139$search_code =
GETPOST(
'search_code',
'alpha');
140$search_active =
GETPOST(
'search_active',
'alpha');
143if (!GETPOSTISSET(
'search_country_id') && $search_country_id ==
'' && ($id == DICT_DEPARTEMENTS || $id == DICT_REGIONS || $id == DICT_TVA)) {
144 $search_country_id = $mysoc->country_id;
148$hookmanager->initHooks(array(
'admin',
'dictionaryadmin'));
150$allowed = $user->admin;
151if ($id == DICT_CHARGESOCIALES && $user->hasRight(
'accounting',
'chartofaccount')) {
154if ($id == DICT_TVA && $user->hasRight(
'accounting',
'chartofaccount')) {
157if ($id == DICT_TYPE_FEES && $user->hasRight(
'accounting',
'chartofaccount')) {
164$permissiontoadd = $allowed;
171$taborder = array(DICT_CURRENCIES, DICT_PAPER_FORMAT, DICT_FORMAT_CARDS, 0, DICT_COUNTRY, DICT_REGIONS, DICT_DEPARTEMENTS, 0, DICT_FORME_JURIDIQUE, DICT_TYPENT, DICT_EFFECTIF, DICT_PROSPECTLEVEL, DICT_PROSPECTCONTACTLEVEL, DICT_STCOMM, DICT_STCOMMCONTACT, DICT_SOCIALNETWORKS, 0, DICT_CIVILITY, DICT_TYPE_CONTACT, 0, DICT_ACTIONCOMM, DICT_TYPE_RESOURCE, 0, DICT_LEAD_STATUS, 0, DICT_HRM_DEPARTMENT, DICT_HRM_FUNCTION, DICT_HRM_PUBLIC_HOLIDAY, DICT_HOLIDAY_TYPES, DICT_TYPE_FEES, DICT_EXP_TAX_CAT, DICT_EXP_TAX_RANGE, 0, DICT_TVA, DICT_INVOICE_SUBTYPE, DICT_REVENUESTAMP, DICT_PAYMENT_TERM, DICT_PAIEMENT, DICT_CHARGESOCIALES, 0, DICT_ECOTAXE, 0, DICT_INPUT_REASON, DICT_INPUT_METHOD, DICT_SHIPMENT_MODE, DICT_AVAILABILITY, DICT_TRANSPORT_MODE, 0, DICT_UNITS, DICT_PRODUCT_NATURE, 0, DICT_PRODUCTBATCH_QCSTATUS, 0, DICT_TYPE_CONTAINER, 0, DICT_ASSET_DISPOSAL_TYPE, 0);
175$tabname[DICT_FORME_JURIDIQUE] =
"c_forme_juridique";
176$tabname[DICT_DEPARTEMENTS] =
"c_departements";
177$tabname[DICT_REGIONS] =
"c_regions";
178$tabname[DICT_COUNTRY] =
"c_country";
179$tabname[DICT_CIVILITY] =
"c_civility";
180$tabname[DICT_ACTIONCOMM] =
"c_actioncomm";
181$tabname[DICT_CHARGESOCIALES] =
"c_chargesociales";
182$tabname[DICT_TYPENT] =
"c_typent";
183$tabname[DICT_CURRENCIES] =
"c_currencies";
184$tabname[DICT_TVA] =
"c_tva";
185$tabname[DICT_TYPE_CONTACT] =
"c_type_contact";
186$tabname[DICT_PAYMENT_TERM] =
"c_payment_term";
187$tabname[DICT_PAIEMENT] =
"c_paiement";
188$tabname[DICT_ECOTAXE] =
"c_ecotaxe";
189$tabname[DICT_PAPER_FORMAT] =
"c_paper_format";
190$tabname[DICT_PROSPECTLEVEL] =
"c_prospectlevel";
191$tabname[DICT_TYPE_FEES] =
"c_type_fees";
192$tabname[DICT_SHIPMENT_MODE] =
"c_shipment_mode";
193$tabname[DICT_EFFECTIF] =
"c_effectif";
194$tabname[DICT_INPUT_METHOD] =
"c_input_method";
195$tabname[DICT_AVAILABILITY] =
"c_availability";
196$tabname[DICT_INPUT_REASON] =
"c_input_reason";
197$tabname[DICT_REVENUESTAMP] =
"c_revenuestamp";
198$tabname[DICT_TYPE_RESOURCE] =
"c_type_resource";
199$tabname[DICT_TYPE_CONTAINER] =
"c_type_container";
201$tabname[DICT_STCOMM] =
"c_stcomm";
202$tabname[DICT_HOLIDAY_TYPES] =
"c_holiday_types";
203$tabname[DICT_LEAD_STATUS] =
"c_lead_status";
204$tabname[DICT_FORMAT_CARDS] =
"c_format_cards";
205$tabname[DICT_INVOICE_SUBTYPE] =
"c_invoice_subtype";
206$tabname[DICT_HRM_PUBLIC_HOLIDAY] =
"c_hrm_public_holiday";
207$tabname[DICT_HRM_DEPARTMENT] =
"c_hrm_department";
208$tabname[DICT_HRM_FUNCTION] =
"c_hrm_function";
209$tabname[DICT_EXP_TAX_CAT] =
"c_exp_tax_cat";
210$tabname[DICT_EXP_TAX_RANGE] =
"c_exp_tax_range";
211$tabname[DICT_UNITS] =
"c_units";
212$tabname[DICT_SOCIALNETWORKS] =
"c_socialnetworks";
213$tabname[DICT_PROSPECTCONTACTLEVEL] =
"c_prospectcontactlevel";
214$tabname[DICT_STCOMMCONTACT] =
"c_stcommcontact";
215$tabname[DICT_TRANSPORT_MODE] =
"c_transport_mode";
216$tabname[DICT_PRODUCT_NATURE] =
"c_product_nature";
217$tabname[DICT_PRODUCTBATCH_QCSTATUS] =
"c_productbatch_qcstatus";
218$tabname[DICT_ASSET_DISPOSAL_TYPE] =
"c_asset_disposal_type";
222$tablib[DICT_FORME_JURIDIQUE] =
"DictionaryCompanyJuridicalType";
223$tablib[DICT_DEPARTEMENTS] =
"DictionaryCanton";
224$tablib[DICT_REGIONS] =
"DictionaryRegion";
225$tablib[DICT_COUNTRY] =
"DictionaryCountry";
226$tablib[DICT_CIVILITY] =
"DictionaryCivility";
227$tablib[DICT_ACTIONCOMM] =
"DictionaryActions";
228$tablib[DICT_CHARGESOCIALES] =
"DictionarySocialContributions";
229$tablib[DICT_TYPENT] =
"DictionaryCompanyType";
230$tablib[DICT_CURRENCIES] =
"DictionaryCurrency";
231$tablib[DICT_TVA] =
"DictionaryVAT";
232$tablib[DICT_TYPE_CONTACT] =
"DictionaryTypeContact";
233$tablib[DICT_PAYMENT_TERM] =
"DictionaryPaymentConditions";
234$tablib[DICT_PAIEMENT] =
"DictionaryPaymentModes";
235$tablib[DICT_ECOTAXE] =
"DictionaryEcotaxe";
236$tablib[DICT_PAPER_FORMAT] =
"DictionaryPaperFormat";
237$tablib[DICT_PROSPECTLEVEL] =
"DictionaryProspectLevel";
238$tablib[DICT_TYPE_FEES] =
"DictionaryFees";
239$tablib[DICT_SHIPMENT_MODE] =
"DictionarySendingMethods";
240$tablib[DICT_EFFECTIF] =
"DictionaryStaff";
241$tablib[DICT_INPUT_METHOD] =
"DictionaryOrderMethods";
242$tablib[DICT_AVAILABILITY] =
"DictionaryAvailability";
243$tablib[DICT_INPUT_REASON] =
"DictionarySource";
244$tablib[DICT_REVENUESTAMP] =
"DictionaryRevenueStamp";
245$tablib[DICT_TYPE_RESOURCE] =
"DictionaryResourceType";
246$tablib[DICT_TYPE_CONTAINER] =
"DictionaryTypeOfContainer";
248$tablib[DICT_STCOMM] =
"DictionaryProspectStatus";
249$tablib[DICT_HOLIDAY_TYPES] =
"DictionaryHolidayTypes";
250$tablib[DICT_LEAD_STATUS] =
"DictionaryOpportunityStatus";
251$tablib[DICT_FORMAT_CARDS] =
"DictionaryFormatCards";
252$tablib[DICT_INVOICE_SUBTYPE] =
"DictionaryInvoiceSubtype";
253$tablib[DICT_HRM_PUBLIC_HOLIDAY] =
"DictionaryPublicHolidays";
254$tablib[DICT_HRM_DEPARTMENT] =
"DictionaryDepartment";
255$tablib[DICT_HRM_FUNCTION] =
"DictionaryFunction";
256$tablib[DICT_EXP_TAX_CAT] =
"DictionaryExpenseTaxCat";
257$tablib[DICT_EXP_TAX_RANGE] =
"DictionaryExpenseTaxRange";
258$tablib[DICT_UNITS] =
"DictionaryMeasuringUnits";
259$tablib[DICT_SOCIALNETWORKS] =
"DictionarySocialNetworks";
260$tablib[DICT_PROSPECTCONTACTLEVEL] =
"DictionaryProspectContactLevel";
261$tablib[DICT_STCOMMCONTACT] =
"DictionaryProspectContactStatus";
262$tablib[DICT_TRANSPORT_MODE] =
"DictionaryTransportMode";
263$tablib[DICT_PRODUCT_NATURE] =
"DictionaryProductNature";
264$tablib[DICT_PRODUCTBATCH_QCSTATUS] =
"DictionaryBatchStatus";
265$tablib[DICT_ASSET_DISPOSAL_TYPE] =
"DictionaryAssetDisposalType";
269$tabsql[DICT_FORME_JURIDIQUE] =
"SELECT f.rowid as rowid, f.code, f.libelle, c.code as country_code, c.label as country, f.active FROM ".MAIN_DB_PREFIX.
"c_forme_juridique as f, ".MAIN_DB_PREFIX.
"c_country as c WHERE f.fk_pays=c.rowid";
270$tabsql[DICT_DEPARTEMENTS] =
"SELECT d.rowid as rowid, d.code_departement as code, d.nom as libelle, d.fk_region as region_id, r.nom as region, c.code as country_code, c.label as country, d.active FROM ".MAIN_DB_PREFIX.
"c_departements as d, ".MAIN_DB_PREFIX.
"c_regions as r, ".MAIN_DB_PREFIX.
"c_country as c WHERE d.fk_region=r.code_region and r.fk_pays=c.rowid and r.active=1 and c.active=1";
271$tabsql[DICT_REGIONS] =
"SELECT r.rowid as rowid, r.code_region as code, r.nom as libelle, r.fk_pays as country_id, c.code as country_code, c.label as country, r.active FROM ".MAIN_DB_PREFIX.
"c_regions as r, ".MAIN_DB_PREFIX.
"c_country as c WHERE r.fk_pays=c.rowid and c.active=1";
272$tabsql[DICT_COUNTRY] =
"SELECT c.rowid as rowid, c.code, c.label, c.active, c.favorite, c.eec, c.sepa FROM ".MAIN_DB_PREFIX.
"c_country AS c";
273$tabsql[DICT_CIVILITY] =
"SELECT c.rowid as rowid, c.code as code, c.label, c.active FROM ".MAIN_DB_PREFIX.
"c_civility AS c";
274$tabsql[DICT_ACTIONCOMM] =
"SELECT a.id as rowid, a.code as code, a.libelle AS libelle, a.type, a.active, a.module, a.color, a.position FROM ".MAIN_DB_PREFIX.
"c_actioncomm AS a";
275$tabsql[DICT_CHARGESOCIALES] =
"SELECT a.id as rowid, a.code as code, a.libelle AS libelle, a.accountancy_code as accountancy_code, c.code as country_code, c.label as country, a.fk_pays as country_id, a.active FROM ".MAIN_DB_PREFIX.
"c_chargesociales AS a, ".MAIN_DB_PREFIX.
"c_country as c WHERE a.fk_pays = c.rowid and c.active = 1";
276$tabsql[DICT_TYPENT] =
"SELECT t.id as rowid, t.code as code, t.libelle, t.fk_country as country_id, c.code as country_code, c.label as country, t.position, t.module, t.active FROM ".MAIN_DB_PREFIX.
"c_typent as t LEFT JOIN ".MAIN_DB_PREFIX.
"c_country as c ON t.fk_country=c.rowid";
277$tabsql[DICT_CURRENCIES] =
"SELECT c.code_iso as code, c.label, c.unicode, c.active FROM ".MAIN_DB_PREFIX.
"c_currencies AS c";
278$tabsql[DICT_TVA] =
"SELECT t.rowid, t.entity, t.code, t.type_vat, t.taux, t.localtax1_type, t.localtax1, t.localtax2_type, t.localtax2, c.label as country, c.code as country_code, t.fk_pays as country_id, t.fk_department_buyer as department_buyer_id, db.nom as department_buyer, t.recuperableonly, t.note, t.active, t.accountancy_code_sell, t.accountancy_code_buy, t.use_default FROM ".MAIN_DB_PREFIX.
"c_tva as t INNER JOIN ".MAIN_DB_PREFIX.
"c_country as c ON t.fk_pays = c.rowid LEFT JOIN ".MAIN_DB_PREFIX.
"c_departements as db ON t.fk_department_buyer = db.rowid WHERE t.entity IN (".
getEntity($tabname[DICT_TVA]).
")";
279$tabsql[DICT_TYPE_CONTACT] =
"SELECT t.rowid as rowid, t.element, t.source, t.code, t.libelle, t.position, t.active FROM ".MAIN_DB_PREFIX.
"c_type_contact AS t";
280$tabsql[DICT_PAYMENT_TERM] =
"SELECT c.rowid as rowid, c.code, c.libelle, c.libelle_facture, c.deposit_percent, c.nbjour, c.type_cdr, c.decalage, c.active, c.sortorder, c.entity FROM ".MAIN_DB_PREFIX.
"c_payment_term AS c WHERE c.entity IN (".
getEntity($tabname[DICT_PAYMENT_TERM]).
")";
281$tabsql[DICT_PAIEMENT] =
"SELECT c.id as rowid, c.code, c.libelle, c.type, c.active, c.entity FROM ".MAIN_DB_PREFIX.
"c_paiement AS c WHERE c.entity IN (".
getEntity($tabname[DICT_PAIEMENT]).
")";
282$tabsql[DICT_ECOTAXE] =
"SELECT e.rowid as rowid, e.code as code, e.label, e.price, e.organization, e.fk_pays as country_id, c.code as country_code, c.label as country, e.active FROM ".MAIN_DB_PREFIX.
"c_ecotaxe AS e, ".MAIN_DB_PREFIX.
"c_country as c WHERE e.fk_pays=c.rowid and c.active=1";
283$tabsql[DICT_PAPER_FORMAT] =
"SELECT t.rowid as rowid, t.code, t.label as libelle, t.width, t.height, t.unit, t.active FROM ".MAIN_DB_PREFIX.
"c_paper_format as t";
284$tabsql[DICT_PROSPECTLEVEL] =
"SELECT t.code, t.label as libelle, t.sortorder, t.active FROM ".MAIN_DB_PREFIX.
"c_prospectlevel as t";
285$tabsql[DICT_TYPE_FEES] =
"SELECT t.id as rowid, t.code, t.label, t.accountancy_code, t.active FROM ".MAIN_DB_PREFIX.
"c_type_fees as t";
286$tabsql[DICT_SHIPMENT_MODE] =
"SELECT t.rowid as rowid, t.code, t.libelle, t.tracking, t.active FROM ".MAIN_DB_PREFIX.
"c_shipment_mode as t";
287$tabsql[DICT_EFFECTIF] =
"SELECT t.id as rowid, t.code, t.libelle, t.active FROM ".MAIN_DB_PREFIX.
"c_effectif as t";
288$tabsql[DICT_INPUT_METHOD] =
"SELECT t.rowid as rowid, t.code, t.libelle, t.active FROM ".MAIN_DB_PREFIX.
"c_input_method as t";
289$tabsql[DICT_AVAILABILITY] =
"SELECT c.rowid as rowid, c.code, c.label, c.type_duration, c.qty, c.active, c.position FROM ".MAIN_DB_PREFIX.
"c_availability AS c";
290$tabsql[DICT_INPUT_REASON] =
"SELECT t.rowid as rowid, t.code, t.label, t.active FROM ".MAIN_DB_PREFIX.
"c_input_reason as t";
291$tabsql[DICT_REVENUESTAMP] =
"SELECT t.rowid as rowid, t.taux, t.revenuestamp_type, c.label as country, c.code as country_code, t.fk_pays as country_id, t.note, t.active, t.accountancy_code_sell, t.accountancy_code_buy FROM ".MAIN_DB_PREFIX.
"c_revenuestamp as t, ".MAIN_DB_PREFIX.
"c_country as c WHERE t.fk_pays=c.rowid";
292$tabsql[DICT_TYPE_RESOURCE] =
"SELECT t.rowid as rowid, t.code, t.label, t.active FROM ".MAIN_DB_PREFIX.
"c_type_resource as t";
293$tabsql[DICT_TYPE_CONTAINER] =
"SELECT t.rowid as rowid, t.code, t.label, t.active, t.module FROM ".MAIN_DB_PREFIX.
"c_type_container as t WHERE t.entity IN (".
getEntity($tabname[DICT_TYPE_CONTAINER]).
")";
295$tabsql[DICT_STCOMM] =
"SELECT t.id as rowid, t.code, t.libelle, t.picto, t.active FROM ".MAIN_DB_PREFIX.
"c_stcomm as t";
296$tabsql[DICT_HOLIDAY_TYPES] =
"SELECT h.rowid as rowid, h.code, h.label, h.affect, h.delay, h.newbymonth, h.fk_country as country_id, c.code as country_code, c.label as country, h.block_if_negative, h.sortorder, h.active FROM ".MAIN_DB_PREFIX.
"c_holiday_types as h LEFT JOIN ".MAIN_DB_PREFIX.
"c_country as c ON h.fk_country=c.rowid WHERE h.entity IN (".
getEntity($tabname[DICT_HOLIDAY_TYPES]).
")";
297$tabsql[DICT_LEAD_STATUS] =
"SELECT t.rowid as rowid, t.code, t.label, percent, t.position, t.active FROM ".MAIN_DB_PREFIX.
"c_lead_status as t";
298$tabsql[DICT_FORMAT_CARDS] =
"SELECT t.rowid, t.code, t.name, t.paper_size, t.orientation, t.metric, t.leftmargin, t.topmargin, t.nx, t.ny, t.spacex, t.spacey, t.width, t.height, t.font_size, t.custom_x, t.custom_y, t.active FROM ".MAIN_DB_PREFIX.
"c_format_cards as t";
299$tabsql[DICT_INVOICE_SUBTYPE] =
"SELECT t.rowid, t.code, t.label, c.label as country, c.code as country_code, t.fk_country as country_id, t.active FROM ".MAIN_DB_PREFIX.
"c_invoice_subtype as t, ".MAIN_DB_PREFIX.
"c_country as c WHERE t.fk_country = c.rowid";
300$tabsql[DICT_HRM_PUBLIC_HOLIDAY] =
"SELECT a.id as rowid, a.entity, a.code, a.fk_country as country_id, c.code as country_code, c.label as country, a.dayrule, a.day, a.month, a.year, a.active FROM ".MAIN_DB_PREFIX.
"c_hrm_public_holiday as a LEFT JOIN ".MAIN_DB_PREFIX.
"c_country as c ON a.fk_country=c.rowid AND c.active=1 WHERE a.entity IN (".
getEntity($tabname[DICT_HRM_PUBLIC_HOLIDAY]).
")";
301$tabsql[DICT_HRM_DEPARTMENT] =
"SELECT t.rowid, t.pos, t.code, t.label, t.active FROM ".MAIN_DB_PREFIX.
"c_hrm_department as t";
302$tabsql[DICT_HRM_FUNCTION] =
"SELECT t.rowid, t.pos, t.code, t.label, t.c_level, t.active FROM ".MAIN_DB_PREFIX.
"c_hrm_function as t";
303$tabsql[DICT_EXP_TAX_CAT] =
"SELECT c.rowid, c.label, c.active, c.entity FROM ".MAIN_DB_PREFIX.
"c_exp_tax_cat as c";
304$tabsql[DICT_EXP_TAX_RANGE] =
"SELECT r.rowid, r.fk_c_exp_tax_cat, r.range_ik, r.active, r.entity FROM ".MAIN_DB_PREFIX.
"c_exp_tax_range r";
305$tabsql[DICT_UNITS] =
"SELECT r.rowid, r.code, r.sortorder, r.label, r.short_label, r.unit_type, r.scale, r.active FROM ".MAIN_DB_PREFIX.
"c_units r";
306$tabsql[DICT_SOCIALNETWORKS] =
"SELECT s.rowid, s.entity, s.code, s.label, s.url, s.icon, s.active FROM ".MAIN_DB_PREFIX.
"c_socialnetworks as s WHERE s.entity IN (".
getEntity($tabname[DICT_SOCIALNETWORKS]).
")";
307$tabsql[DICT_PROSPECTCONTACTLEVEL] =
"SELECT t.code, t.label as libelle, t.sortorder, t.active FROM ".MAIN_DB_PREFIX.
"c_prospectcontactlevel as t";
308$tabsql[DICT_STCOMMCONTACT] =
"SELECT t.id as rowid, t.code, t.libelle, t.picto, t.active FROM ".MAIN_DB_PREFIX.
"c_stcommcontact as t";
309$tabsql[DICT_TRANSPORT_MODE] =
"SELECT t.rowid as rowid, t.code, t.label, t.active FROM ".MAIN_DB_PREFIX.
"c_transport_mode as t";
310$tabsql[DICT_PRODUCT_NATURE] =
"SELECT t.rowid as rowid, t.code, t.label, t.active FROM ".MAIN_DB_PREFIX.
"c_product_nature as t";
311$tabsql[DICT_PRODUCTBATCH_QCSTATUS] =
"SELECT t.rowid, t.code, t.label, t.active FROM ".MAIN_DB_PREFIX.
"c_productbatch_qcstatus as t";
312$tabsql[DICT_ASSET_DISPOSAL_TYPE] =
"SELECT t.rowid, t.code, t.label, t.active FROM ".MAIN_DB_PREFIX.
"c_asset_disposal_type as t";
315$tabsqlsort = array();
316$tabsqlsort[DICT_FORME_JURIDIQUE] =
"country ASC, code ASC";
317$tabsqlsort[DICT_DEPARTEMENTS] =
"country ASC, code ASC";
318$tabsqlsort[DICT_REGIONS] =
"country ASC, code ASC";
319$tabsqlsort[DICT_COUNTRY] =
"code ASC";
320$tabsqlsort[DICT_CIVILITY] =
"label ASC";
321$tabsqlsort[DICT_ACTIONCOMM] =
"a.type ASC, a.module ASC, a.position ASC, a.code ASC";
322$tabsqlsort[DICT_CHARGESOCIALES] =
"c.label ASC, a.code ASC, a.libelle ASC";
323$tabsqlsort[DICT_TYPENT] =
"country DESC,".(getDolGlobalString(
'SOCIETE_SORT_ON_TYPEENT') ?
' t.position ASC,' :
'').
" libelle ASC";
324$tabsqlsort[DICT_CURRENCIES] =
"label ASC";
325$tabsqlsort[DICT_TVA] =
"country ASC, department_buyer ASC, code ASC, taux ASC, recuperableonly ASC, localtax1 ASC, localtax2 ASC";
326$tabsqlsort[DICT_TYPE_CONTACT] =
"t.element ASC, t.source ASC, t.position ASC, t.code ASC";
327$tabsqlsort[DICT_PAYMENT_TERM] =
"sortorder ASC, code ASC";
328$tabsqlsort[DICT_PAIEMENT] =
"code ASC";
329$tabsqlsort[DICT_ECOTAXE] =
"country ASC, e.organization ASC, code ASC";
330$tabsqlsort[DICT_PAPER_FORMAT] =
"rowid ASC";
331$tabsqlsort[DICT_PROSPECTLEVEL] =
"sortorder ASC";
332$tabsqlsort[DICT_TYPE_FEES] =
"code ASC";
333$tabsqlsort[DICT_SHIPMENT_MODE] =
"code ASC, libelle ASC";
334$tabsqlsort[DICT_EFFECTIF] =
"id ASC";
335$tabsqlsort[DICT_INPUT_METHOD] =
"code ASC, libelle ASC";
336$tabsqlsort[DICT_AVAILABILITY] =
"position ASC, type_duration ASC, qty ASC";
337$tabsqlsort[DICT_INPUT_REASON] =
"code ASC, label ASC";
338$tabsqlsort[DICT_REVENUESTAMP] =
"country ASC, taux ASC";
339$tabsqlsort[DICT_TYPE_RESOURCE] =
"code ASC, label ASC";
340$tabsqlsort[DICT_TYPE_CONTAINER] =
"t.module ASC, t.code ASC, t.label ASC";
342$tabsqlsort[DICT_STCOMM] =
"code ASC";
343$tabsqlsort[DICT_HOLIDAY_TYPES] =
"sortorder ASC, country ASC, code ASC";
344$tabsqlsort[DICT_LEAD_STATUS] =
"position ASC";
345$tabsqlsort[DICT_FORMAT_CARDS] =
"code ASC";
346$tabsqlsort[DICT_INVOICE_SUBTYPE] =
"country ASC, code ASC";
347$tabsqlsort[DICT_HRM_PUBLIC_HOLIDAY] =
"country, year ASC, month ASC, day ASC";
348$tabsqlsort[DICT_HRM_DEPARTMENT] =
"code ASC";
349$tabsqlsort[DICT_HRM_FUNCTION] =
"code ASC";
350$tabsqlsort[DICT_EXP_TAX_CAT] =
"c.label ASC";
351$tabsqlsort[DICT_EXP_TAX_RANGE] =
"r.fk_c_exp_tax_cat ASC, r.range_ik ASC";
352$tabsqlsort[DICT_UNITS] =
"sortorder ASC";
353$tabsqlsort[DICT_SOCIALNETWORKS] =
"rowid, code ASC";
354$tabsqlsort[DICT_PROSPECTCONTACTLEVEL] =
"sortorder ASC";
355$tabsqlsort[DICT_STCOMMCONTACT] =
"code ASC";
356$tabsqlsort[DICT_TRANSPORT_MODE] =
"code ASC";
357$tabsqlsort[DICT_PRODUCT_NATURE] =
"code ASC";
358$tabsqlsort[DICT_PRODUCTBATCH_QCSTATUS] =
"code ASC";
359$tabsqlsort[DICT_ASSET_DISPOSAL_TYPE] =
"code ASC";
363$tabfield[DICT_FORME_JURIDIQUE] =
"code,libelle,country";
364$tabfield[DICT_DEPARTEMENTS] =
"code,libelle,region_id,region,country";
365$tabfield[DICT_REGIONS] =
"code,libelle,country_id,country";
366$tabfield[DICT_COUNTRY] =
"code,label";
367$tabfield[DICT_CIVILITY] =
"code,label";
368$tabfield[DICT_ACTIONCOMM] =
"code,libelle,type,color,position";
369$tabfield[DICT_CHARGESOCIALES] =
"code,libelle,country,accountancy_code";
370$tabfield[DICT_TYPENT] =
"code,libelle,module,country_id,country".(getDolGlobalString(
'SOCIETE_SORT_ON_TYPEENT') ?
',position' :
'');
371$tabfield[DICT_CURRENCIES] =
"code,label,unicode";
372$tabfield[DICT_TVA] =
"country_id,country,department_buyer_id,department_buyer,code,type_vat,taux,localtax1_type,localtax1,localtax2_type,localtax2,recuperableonly,accountancy_code_sell,accountancy_code_buy,use_default,note";
373$tabfield[DICT_TYPE_CONTACT] =
"element,source,code,libelle,position";
374$tabfield[DICT_PAYMENT_TERM] =
"code,libelle,libelle_facture,deposit_percent,nbjour,type_cdr,decalage,sortorder";
375$tabfield[DICT_PAIEMENT] =
"code,libelle,type";
376$tabfield[DICT_ECOTAXE] =
"code,label,price,organization,country";
377$tabfield[DICT_PAPER_FORMAT] =
"code,libelle,width,height,unit";
378$tabfield[DICT_PROSPECTLEVEL] =
"code,libelle,sortorder";
379$tabfield[DICT_TYPE_FEES] =
"code,label,accountancy_code";
380$tabfield[DICT_SHIPMENT_MODE] =
"code,libelle,tracking";
381$tabfield[DICT_EFFECTIF] =
"code,libelle";
382$tabfield[DICT_INPUT_METHOD] =
"code,libelle";
383$tabfield[DICT_AVAILABILITY] =
"code,label,qty,type_duration,position";
384$tabfield[DICT_INPUT_REASON] =
"code,label";
385$tabfield[DICT_REVENUESTAMP] =
"country_id,country,taux,revenuestamp_type,accountancy_code_sell,accountancy_code_buy,note";
386$tabfield[DICT_TYPE_RESOURCE] =
"code,label";
387$tabfield[DICT_TYPE_CONTAINER] =
"code,label";
389$tabfield[DICT_STCOMM] =
"code,libelle,picto";
390$tabfield[DICT_HOLIDAY_TYPES] =
"code,label,affect,delay,newbymonth,country_id,country,block_if_negative,sortorder";
391$tabfield[DICT_LEAD_STATUS] =
"code,label,percent,position";
392$tabfield[DICT_FORMAT_CARDS] =
"code,name,paper_size,orientation,metric,leftmargin,topmargin,nx,ny,spacex,spacey,width,height,font_size,custom_x,custom_y";
393$tabfield[DICT_INVOICE_SUBTYPE] =
"country_id,country,code,label";
394$tabfield[DICT_HRM_PUBLIC_HOLIDAY] =
"code,dayrule,year,month,day,country_id,country";
395$tabfield[DICT_HRM_DEPARTMENT] =
"code,label";
396$tabfield[DICT_HRM_FUNCTION] =
"code,label";
397$tabfield[DICT_EXP_TAX_CAT] =
"label";
398$tabfield[DICT_EXP_TAX_RANGE] =
"range_ik,fk_c_exp_tax_cat";
399$tabfield[DICT_UNITS] =
"code,label,short_label,unit_type,scale,sortorder";
400$tabfield[DICT_SOCIALNETWORKS] =
"code,label,url,icon";
401$tabfield[DICT_PROSPECTCONTACTLEVEL] =
"code,libelle,sortorder";
402$tabfield[DICT_STCOMMCONTACT] =
"code,libelle,picto";
403$tabfield[DICT_TRANSPORT_MODE] =
"code,label";
404$tabfield[DICT_PRODUCT_NATURE] =
"code,label";
405$tabfield[DICT_PRODUCTBATCH_QCSTATUS] =
"code,label";
406$tabfield[DICT_ASSET_DISPOSAL_TYPE] =
"code,label";
409$tabfieldvalue = array();
410$tabfieldvalue[DICT_FORME_JURIDIQUE] =
"code,libelle,country";
411$tabfieldvalue[DICT_DEPARTEMENTS] =
"code,libelle,region";
412$tabfieldvalue[DICT_REGIONS] =
"code,libelle,country";
413$tabfieldvalue[DICT_COUNTRY] =
"code,label";
414$tabfieldvalue[DICT_CIVILITY] =
"code,label";
415$tabfieldvalue[DICT_ACTIONCOMM] =
"code,libelle,type,color,position";
416$tabfieldvalue[DICT_CHARGESOCIALES] =
"code,libelle,country,accountancy_code";
417$tabfieldvalue[DICT_TYPENT] =
"code,libelle,country".(getDolGlobalString(
'SOCIETE_SORT_ON_TYPEENT') ?
',position' :
'');
418$tabfieldvalue[DICT_CURRENCIES] =
"code,label,unicode";
419$tabfieldvalue[DICT_TVA] =
"country,department_buyer_id,code,type_vat,taux,localtax1_type,localtax1,localtax2_type,localtax2,recuperableonly,accountancy_code_sell,accountancy_code_buy,use_default,note";
420$tabfieldvalue[DICT_TYPE_CONTACT] =
"element,source,code,libelle,position";
421$tabfieldvalue[DICT_PAYMENT_TERM] =
"code,libelle,libelle_facture,deposit_percent,nbjour,type_cdr,decalage,sortorder";
422$tabfieldvalue[DICT_PAIEMENT] =
"code,libelle,type";
423$tabfieldvalue[DICT_ECOTAXE] =
"code,label,price,organization,country";
424$tabfieldvalue[DICT_PAPER_FORMAT] =
"code,libelle,width,height,unit";
425$tabfieldvalue[DICT_PROSPECTLEVEL] =
"code,libelle,sortorder";
426$tabfieldvalue[DICT_TYPE_FEES] =
"code,label,accountancy_code";
427$tabfieldvalue[DICT_SHIPMENT_MODE] =
"code,libelle,tracking";
428$tabfieldvalue[DICT_EFFECTIF] =
"code,libelle";
429$tabfieldvalue[DICT_INPUT_METHOD] =
"code,libelle";
430$tabfieldvalue[DICT_AVAILABILITY] =
"code,label,qty,type_duration,position";
431$tabfieldvalue[DICT_INPUT_REASON] =
"code,label";
432$tabfieldvalue[DICT_REVENUESTAMP] =
"country,taux,revenuestamp_type,accountancy_code_sell,accountancy_code_buy,note";
433$tabfieldvalue[DICT_TYPE_RESOURCE] =
"code,label";
434$tabfieldvalue[DICT_TYPE_CONTAINER] =
"code,label";
436$tabfieldvalue[DICT_STCOMM] =
"code,libelle,picto";
437$tabfieldvalue[DICT_HOLIDAY_TYPES] =
"code,label,affect,delay,newbymonth,country,block_if_negative,sortorder";
438$tabfieldvalue[DICT_LEAD_STATUS] =
"code,label,percent,position";
439$tabfieldvalue[DICT_FORMAT_CARDS] =
"code,name,paper_size,orientation,metric,leftmargin,topmargin,nx,ny,spacex,spacey,width,height,font_size,custom_x,custom_y";
440$tabfieldvalue[DICT_INVOICE_SUBTYPE] =
"country,code,label";
441$tabfieldvalue[DICT_HRM_PUBLIC_HOLIDAY] =
"code,dayrule,day,month,year,country";
442$tabfieldvalue[DICT_HRM_DEPARTMENT] =
"code,label";
443$tabfieldvalue[DICT_HRM_FUNCTION] =
"code,label";
444$tabfieldvalue[DICT_EXP_TAX_CAT] =
"label";
445$tabfieldvalue[DICT_EXP_TAX_RANGE] =
"range_ik,fk_c_exp_tax_cat";
446$tabfieldvalue[DICT_UNITS] =
"code,label,short_label,unit_type,scale,sortorder";
447$tabfieldvalue[DICT_SOCIALNETWORKS] =
"code,label,url,icon";
448$tabfieldvalue[DICT_PROSPECTCONTACTLEVEL] =
"code,libelle,sortorder";
449$tabfieldvalue[DICT_STCOMMCONTACT] =
"code,libelle,picto";
450$tabfieldvalue[DICT_TRANSPORT_MODE] =
"code,label";
451$tabfieldvalue[DICT_PRODUCT_NATURE] =
"code,label";
452$tabfieldvalue[DICT_PRODUCTBATCH_QCSTATUS] =
"code,label";
453$tabfieldvalue[DICT_ASSET_DISPOSAL_TYPE] =
"code,label";
456$tabfieldinsert = array();
457$tabfieldinsert[DICT_FORME_JURIDIQUE] =
"code,libelle,fk_pays";
458$tabfieldinsert[DICT_DEPARTEMENTS] =
"code_departement,nom,fk_region";
459$tabfieldinsert[DICT_REGIONS] =
"code_region,nom,fk_pays";
460$tabfieldinsert[DICT_COUNTRY] =
"code,label";
461$tabfieldinsert[DICT_CIVILITY] =
"code,label";
462$tabfieldinsert[DICT_ACTIONCOMM] =
"code,libelle,type,color,position";
463$tabfieldinsert[DICT_CHARGESOCIALES] =
"code,libelle,fk_pays,accountancy_code";
464$tabfieldinsert[DICT_TYPENT] =
"code,libelle,fk_country".(getDolGlobalString(
'SOCIETE_SORT_ON_TYPEENT') ?
',position' :
'');
465$tabfieldinsert[DICT_CURRENCIES] =
"code_iso,label,unicode";
466$tabfieldinsert[DICT_TVA] =
"fk_pays,fk_department_buyer,code,type_vat,taux,localtax1_type,localtax1,localtax2_type,localtax2,recuperableonly,accountancy_code_sell,accountancy_code_buy,use_default,note,entity";
467$tabfieldinsert[DICT_TYPE_CONTACT] =
"element,source,code,libelle,position";
468$tabfieldinsert[DICT_PAYMENT_TERM] =
"code,libelle,libelle_facture,deposit_percent,nbjour,type_cdr,decalage,sortorder,entity";
469$tabfieldinsert[DICT_PAIEMENT] =
"code,libelle,type,entity";
470$tabfieldinsert[DICT_ECOTAXE] =
"code,label,price,organization,fk_pays";
471$tabfieldinsert[DICT_PAPER_FORMAT] =
"code,label,width,height,unit";
472$tabfieldinsert[DICT_PROSPECTLEVEL] =
"code,label,sortorder";
473$tabfieldinsert[DICT_TYPE_FEES] =
"code,label,accountancy_code";
474$tabfieldinsert[DICT_SHIPMENT_MODE] =
"code,libelle,tracking";
475$tabfieldinsert[DICT_EFFECTIF] =
"code,libelle";
476$tabfieldinsert[DICT_INPUT_METHOD] =
"code,libelle";
477$tabfieldinsert[DICT_AVAILABILITY] =
"code,label,qty,type_duration,position";
478$tabfieldinsert[DICT_INPUT_REASON] =
"code,label";
479$tabfieldinsert[DICT_REVENUESTAMP] =
"fk_pays,taux,revenuestamp_type,accountancy_code_sell,accountancy_code_buy,note";
480$tabfieldinsert[DICT_TYPE_RESOURCE] =
"code,label";
481$tabfieldinsert[DICT_TYPE_CONTAINER] =
"code,label,entity";
483$tabfieldinsert[DICT_STCOMM] =
"code,libelle,picto";
484$tabfieldinsert[DICT_HOLIDAY_TYPES] =
"code,label,affect,delay,newbymonth,fk_country,block_if_negative,sortorder,entity";
485$tabfieldinsert[DICT_LEAD_STATUS] =
"code,label,percent,position";
486$tabfieldinsert[DICT_FORMAT_CARDS] =
"code,name,paper_size,orientation,metric,leftmargin,topmargin,nx,ny,spacex,spacey,width,height,font_size,custom_x,custom_y";
487$tabfieldinsert[DICT_INVOICE_SUBTYPE] =
"fk_country,code,label";
488$tabfieldinsert[DICT_HRM_PUBLIC_HOLIDAY] =
"code,dayrule,day,month,year,fk_country,entity";
489$tabfieldinsert[DICT_HRM_DEPARTMENT] =
"code,label";
490$tabfieldinsert[DICT_HRM_FUNCTION] =
"code,label";
491$tabfieldinsert[DICT_EXP_TAX_CAT] =
"label";
492$tabfieldinsert[DICT_EXP_TAX_RANGE] =
"range_ik,fk_c_exp_tax_cat";
493$tabfieldinsert[DICT_UNITS] =
"code,label,short_label,unit_type,scale,sortorder";
494$tabfieldinsert[DICT_SOCIALNETWORKS] =
"code,label,url,icon,entity";
495$tabfieldinsert[DICT_PROSPECTCONTACTLEVEL] =
"code,label,sortorder";
496$tabfieldinsert[DICT_STCOMMCONTACT] =
"code,libelle,picto";
497$tabfieldinsert[DICT_TRANSPORT_MODE] =
"code,label";
498$tabfieldinsert[DICT_PRODUCT_NATURE] =
"code,label";
499$tabfieldinsert[DICT_PRODUCTBATCH_QCSTATUS] =
"code,label";
500$tabfieldinsert[DICT_ASSET_DISPOSAL_TYPE] =
"code,label";
506$tabrowid[DICT_FORME_JURIDIQUE] =
"";
507$tabrowid[DICT_DEPARTEMENTS] =
"";
508$tabrowid[DICT_REGIONS] =
"";
509$tabrowid[DICT_COUNTRY] =
"rowid";
510$tabrowid[DICT_CIVILITY] =
"rowid";
511$tabrowid[DICT_ACTIONCOMM] =
"id";
512$tabrowid[DICT_CHARGESOCIALES] =
"id";
513$tabrowid[DICT_TYPENT] =
"id";
514$tabrowid[DICT_CURRENCIES] =
"code_iso";
515$tabrowid[DICT_TVA] =
"";
516$tabrowid[DICT_TYPE_CONTACT] =
"rowid";
517$tabrowid[DICT_PAYMENT_TERM] =
"";
518$tabrowid[DICT_PAIEMENT] =
"id";
519$tabrowid[DICT_ECOTAXE] =
"";
520$tabrowid[DICT_PAPER_FORMAT] =
"";
521$tabrowid[DICT_PROSPECTLEVEL] =
"code";
522$tabrowid[DICT_TYPE_FEES] =
"id";
523$tabrowid[DICT_SHIPMENT_MODE] =
"rowid";
524$tabrowid[DICT_EFFECTIF] =
"id";
525$tabrowid[DICT_INPUT_METHOD] =
"";
526$tabrowid[DICT_AVAILABILITY] =
"rowid";
527$tabrowid[DICT_INPUT_REASON] =
"rowid";
528$tabrowid[DICT_REVENUESTAMP] =
"";
529$tabrowid[DICT_TYPE_RESOURCE] =
"";
530$tabrowid[DICT_TYPE_CONTAINER] =
"";
532$tabrowid[DICT_STCOMM] =
"id";
533$tabrowid[DICT_HOLIDAY_TYPES] =
"";
534$tabrowid[DICT_LEAD_STATUS] =
"";
535$tabrowid[DICT_FORMAT_CARDS] =
"";
536$tabrowid[DICT_INVOICE_SUBTYPE] =
"";
537$tabrowid[DICT_HRM_PUBLIC_HOLIDAY] =
"id";
538$tabrowid[DICT_HRM_DEPARTMENT] =
"rowid";
539$tabrowid[DICT_HRM_FUNCTION] =
"rowid";
540$tabrowid[DICT_EXP_TAX_CAT] =
"";
541$tabrowid[DICT_EXP_TAX_RANGE] =
"";
542$tabrowid[DICT_UNITS] =
"";
543$tabrowid[DICT_SOCIALNETWORKS] =
"";
544$tabrowid[DICT_PROSPECTCONTACTLEVEL] =
"code";
545$tabrowid[DICT_STCOMMCONTACT] =
"id";
546$tabrowid[DICT_TRANSPORT_MODE] =
"";
547$tabrowid[DICT_PRODUCT_NATURE] =
"rowid";
548$tabrowid[DICT_PRODUCTBATCH_QCSTATUS] =
"rowid";
549$tabrowid[DICT_ASSET_DISPOSAL_TYPE] =
"rowid";
553$tabcond[DICT_FORME_JURIDIQUE] = (isModEnabled(
"societe"));
554$tabcond[DICT_DEPARTEMENTS] =
true;
555$tabcond[DICT_REGIONS] =
true;
556$tabcond[DICT_COUNTRY] =
true;
557$tabcond[DICT_CIVILITY] = (isModEnabled(
"societe") || isModEnabled(
'member'));
558$tabcond[DICT_ACTIONCOMM] = isModEnabled(
'agenda');
559$tabcond[DICT_CHARGESOCIALES] = isModEnabled(
'tax');
560$tabcond[DICT_TYPENT] = isModEnabled(
"societe");
561$tabcond[DICT_CURRENCIES] =
true;
562$tabcond[DICT_TVA] =
true;
563$tabcond[DICT_TYPE_CONTACT] = (isModEnabled(
"societe"));
564$tabcond[DICT_PAYMENT_TERM] = (isModEnabled(
'order') || isModEnabled(
"propal") || isModEnabled(
'invoice') || isModEnabled(
"supplier_invoice") || isModEnabled(
"supplier_order"));
565$tabcond[DICT_PAIEMENT] = (isModEnabled(
'order') || isModEnabled(
"propal") || isModEnabled(
'invoice') || isModEnabled(
"supplier_invoice") || isModEnabled(
"supplier_order"));
566$tabcond[DICT_ECOTAXE] = (isModEnabled(
"product") && (isModEnabled(
'ecotax') ||
getDolGlobalString(
'MAIN_SHOW_ECOTAX_DICTIONNARY')));
567$tabcond[DICT_PAPER_FORMAT] =
true;
568$tabcond[DICT_PROSPECTLEVEL] = (isModEnabled(
"societe") && !
getDolGlobalString(
'SOCIETE_DISABLE_PROSPECTS'));
569$tabcond[DICT_TYPE_FEES] = (isModEnabled(
'deplacement') || isModEnabled(
'expensereport'));
570$tabcond[DICT_SHIPMENT_MODE] = isModEnabled(
"shipping") || isModEnabled(
"reception");
571$tabcond[DICT_EFFECTIF] = isModEnabled(
"societe");
572$tabcond[DICT_INPUT_METHOD] = isModEnabled(
"supplier_order");
573$tabcond[DICT_AVAILABILITY] = isModEnabled(
"propal");
574$tabcond[DICT_INPUT_REASON] = (isModEnabled(
'order') || isModEnabled(
"propal"));
575$tabcond[DICT_REVENUESTAMP] =
true;
576$tabcond[DICT_TYPE_RESOURCE] = isModEnabled(
'resource');
577$tabcond[DICT_TYPE_CONTAINER] = isModEnabled(
'website');
579$tabcond[DICT_STCOMM] = isModEnabled(
"societe");
580$tabcond[DICT_HOLIDAY_TYPES] = isModEnabled(
'holiday');
581$tabcond[DICT_LEAD_STATUS] = isModEnabled(
'project');
582$tabcond[DICT_FORMAT_CARDS] = (isModEnabled(
'label') || isModEnabled(
'barcode') || isModEnabled(
'member'));
583$tabcond[DICT_INVOICE_SUBTYPE] = ((isModEnabled(
'invoice') || isModEnabled(
'supplier_invoice')) && $mysoc->country_code ==
'GR');
584$tabcond[DICT_HRM_PUBLIC_HOLIDAY] = (isModEnabled(
'holiday') || isModEnabled(
'hrm'));
585$tabcond[DICT_HRM_DEPARTMENT] = isModEnabled(
'hrm');
586$tabcond[DICT_HRM_FUNCTION] = isModEnabled(
'hrm');
587$tabcond[DICT_EXP_TAX_CAT] = isModEnabled(
'expensereport') &&
getDolGlobalString(
'MAIN_USE_EXPENSE_IK');
588$tabcond[DICT_EXP_TAX_RANGE] = isModEnabled(
'expensereport') &&
getDolGlobalString(
'MAIN_USE_EXPENSE_IK');
589$tabcond[DICT_UNITS] = isModEnabled(
"product");
590$tabcond[DICT_SOCIALNETWORKS] = isModEnabled(
'socialnetworks');
591$tabcond[DICT_PROSPECTCONTACTLEVEL] = (isModEnabled(
"societe") && !
getDolGlobalString(
'SOCIETE_DISABLE_PROSPECTS') &&
getDolGlobalString(
'THIRDPARTY_ENABLE_PROSPECTION_ON_ALTERNATIVE_ADRESSES'));
592$tabcond[DICT_STCOMMCONTACT] = (isModEnabled(
"societe") &&
getDolGlobalString(
'THIRDPARTY_ENABLE_PROSPECTION_ON_ALTERNATIVE_ADRESSES'));
593$tabcond[DICT_TRANSPORT_MODE] = isModEnabled(
'intracommreport');
594$tabcond[DICT_PRODUCT_NATURE] = isModEnabled(
"product");
595$tabcond[DICT_PRODUCTBATCH_QCSTATUS] = isModEnabled(
"product") && isModEnabled(
'productbatch') &&
getDolGlobalInt(
'MAIN_FEATURES_LEVEL') >= 2;
596$tabcond[DICT_ASSET_DISPOSAL_TYPE] = isModEnabled(
'asset');
603 'c_forme_juridique' => array(
604 'picto' =>
'company',
605 'help' => array(
'code' => $langs->trans(
"EnterAnyCode"))
607 'c_departements' => array(
609 'help' => array(
'code' => $langs->trans(
"EnterAnyCode"))
611 'c_regions' => array(
613 'help' => array(
'code' => $langs->trans(
"EnterAnyCode"))
615 'c_country' => array(
'picto' =>
'country',
'help' => array(
'code' => $langs->trans(
"EnterAnyCode"))),
616 'c_civility' => array(
'picto' =>
'contact',
'help' => array(
'code' => $langs->trans(
"EnterAnyCode"))),
617 'c_actioncomm' => array(
'picto' =>
'action',
'help' => array(
'code' => $langs->trans(
"EnterAnyCode"),
'color' => $langs->trans(
"ColorFormat"),
'position' => $langs->trans(
"PositionIntoComboList"))),
618 'c_chargesociales' => array(
'picto' =>
'bill',
'help' => array(
'code' => $langs->trans(
"EnterAnyCode"))),
619 'c_typent' => array(
'picto' =>
'company',
'help' => array(
'code' => $langs->trans(
"EnterAnyCode"),
'position' => $langs->trans(
"PositionIntoComboList"))),
620 'c_currencies' => array(
'picto' =>
'multicurrency',
'help' => array(
'code' => $langs->trans(
"EnterAnyCode"),
'unicode' => $langs->trans(
"UnicodeCurrency"))),
621 'c_tva' => array(
'picto' =>
'bill',
'help' => array(
'code' => $langs->trans(
"EnterAnyCode"),
'taux' => $langs->trans(
"SellTaxRate"),
'recuperableonly' => $langs->trans(
"RecuperableOnly"),
'localtax1_type' => $langs->trans(
"LocalTaxDesc"),
'localtax2_type' => $langs->trans(
"LocalTaxDesc"))),
622 'c_type_contact' => array(
'picto' =>
'contact',
'help' => array(
'code' => $langs->trans(
"EnterAnyCode"),
'position' => $langs->trans(
"PositionIntoComboList"))),
623 'c_payment_term' => array(
'picto' =>
'bill',
'help' => array(
'code' => $langs->trans(
"EnterAnyCode"),
'type_cdr' => $langs->trans(
"TypeCdr", $langs->transnoentitiesnoconv(
"NbOfDays"), $langs->transnoentitiesnoconv(
"Offset"), $langs->transnoentitiesnoconv(
"NbOfDays"), $langs->transnoentitiesnoconv(
"Offset")))),
624 'c_paiement' => array(
'picto' =>
'bill',
'help' => array(
'code' => $langs->trans(
"EnterAnyCode"))),
625 'c_ecotaxe' => array(
'picto' =>
'bill',
'help' => array(
'code' => $langs->trans(
"EnterAnyCode"))),
626 'c_paper_format' => array(
'picto' =>
'generic',
'help' => array(
'code' => $langs->trans(
"EnterAnyCode"))),
627 'c_prospectlevel' => array(
'picto' =>
'company',
'help' => array(
'code' => $langs->trans(
"EnterAnyCode"))),
628 'c_type_fees' => array(
'picto' =>
'trip',
'help' => array(
'code' => $langs->trans(
"EnterAnyCode"))),
629 'c_shipment_mode' => array(
'picto' =>
'shipment',
'help' => array(
'code' => $langs->trans(
"EnterAnyCode"),
'tracking' => $langs->trans(
"UrlTrackingDesc"))),
630 'c_effectif' => array(
'picto' =>
'company',
'help' => array(
'code' => $langs->trans(
"EnterAnyCode"))),
631 'c_input_method' => array(
'picto' =>
'order',
'help' => array(
'code' => $langs->trans(
"EnterAnyCode"))),
632 'c_input_reason' => array(
'picto' =>
'order',
'help' => array(
'code' => $langs->trans(
"EnterAnyCode"),
'position' => $langs->trans(
"PositionIntoComboList"))),
633 'c_availability' => array(
'picto' =>
'shipment',
'help' => array(
'code' => $langs->trans(
"EnterAnyCode"))),
634 'c_revenuestamp' => array(
'picto' =>
'bill',
'help' => array(
'revenuestamp_type' => $langs->trans(
'FixedOrPercent'))),
635 'c_type_resource' => array(
'picto' =>
'resource',
'help' => array(
'code' => $langs->trans(
"EnterAnyCode"))),
636 'c_type_container' => array(
'picto' =>
'website',
'help' => array(
'code' => $langs->trans(
"EnterAnyCode"))),
637 'c_stcomm' => array(
'picto' =>
'company',
'help' => array(
'code' => $langs->trans(
"EnterAnyCode"),
'picto' => $langs->trans(
"PictoHelp"))),
638 'c_holiday_types' => array(
'picto' =>
'holiday',
'help' => array(
'affect' => $langs->trans(
"FollowedByACounter"),
'delay' => $langs->trans(
"MinimumNoticePeriod"),
'newbymonth' => $langs->trans(
"NbAddedAutomatically"))),
639 'c_lead_status' => array(
'picto' =>
'project',
'help' => array(
'code' => $langs->trans(
"EnterAnyCode"),
'percent' => $langs->trans(
"OpportunityPercent"),
'position' => $langs->trans(
"PositionIntoComboList"))),
640 'c_format_cards' => array(
'picto' =>
'generic',
'help' => array(
'code' => $langs->trans(
"EnterAnyCode"),
'name' => $langs->trans(
"LabelName"),
'paper_size' => $langs->trans(
"LabelPaperSize"))),
641 'c_hrm_public_holiday' => array(
'picto' =>
'holiday',
'help' => array(
'code' => $langs->trans(
"EnterAnyCode"),
'dayrule' =>
"Keep empty for a date defined with month and day (most common case).<br>Use a keyword like 'easter', 'eastermonday', ... for a date predefined by complex rules.",
'country' => $langs->trans(
"CountryIfSpecificToOneCountry"),
'year' => $langs->trans(
"ZeroMeansEveryYear"))),
642 'c_hrm_department' => array(
'picto' =>
'hrm',
'help' => array(
'code' => $langs->trans(
"EnterAnyCode"))),
643 'c_hrm_function' => array(
'picto' =>
'hrm',
'help' => array(
'code' => $langs->trans(
"EnterAnyCode"))),
644 'c_exp_tax_cat' => array(
'picto' =>
'expensereport',
'help' => array()),
645 'c_exp_tax_range' => array(
'picto' =>
'expensereport',
'help' => array(
'range_ik' => $langs->trans(
'PrevRangeToThisRange'))),
646 'c_units' => array(
'picto' =>
'product',
'help' => array(
'code' => $langs->trans(
"EnterAnyCode"),
'unit_type' => $langs->trans(
'Measuringtype_durationDesc'),
'scale' => $langs->trans(
'MeasuringScaleDesc'))),
647 'c_socialnetworks' => array(
'picto' =>
'share-alt',
'help' => array(
'code' => $langs->trans(
"EnterAnyCode"),
'url' => $langs->trans(
'UrlSocialNetworksDesc'),
'icon' => $langs->trans(
'FafaIconSocialNetworksDesc'))),
648 'c_prospectcontactlevel' => array(
'picto' =>
'company',
'help' => array(
'code' => $langs->trans(
"EnterAnyCode"))),
649 'c_stcommcontact' => array(
'picto' =>
'company',
'help' => array(
'code' => $langs->trans(
"EnterAnyCode"),
'picto' => $langs->trans(
"PictoHelp"))),
650 'c_transport_mode' => array(
'picto' =>
'incoterm',
'help' => array(
'code' => $langs->trans(
"EnterAnyCode"))),
651 'c_product_nature' => array(
'picto' =>
'product',
'help' => array(
'code' => $langs->trans(
"EnterAnyCode"))),
652 'c_productbatch_qcstatus' => array(
'picto' =>
'lot',
'help' => array(
'code' => $langs->trans(
"EnterAnyCode"))),
653 'c_asset_disposal_type' => array(
'picto' =>
'asset',
'help' => array(
'code' => $langs->trans(
"EnterAnyCode"))),
654 'c_invoice_subtype' => array(
'picto' =>
'bill',
'help' => array(
'code' => $langs->trans(
"EnterAnyCode"))),
659complete_dictionary_with_modules($taborder, $tabname, $tablib, $tabsql, $tabsqlsort, $tabfield, $tabfieldvalue, $tabfieldinsert, $tabrowid, $tabcond, $tabhelp, $tabcomplete);
663foreach ($tabcomplete as $key => $value) {
666 if (!isset($tabcond[$i])) {
669 $tabcomplete[$key][
'id'] = $i;
672 $tabcomplete[$key][
'cond'] = $tabcond[$i];
673 $tabcomplete[$key][
'rowid'] = $tabrowid[$i];
674 $tabcomplete[$key][
'fieldinsert'] = $tabfieldinsert[$i];
675 $tabcomplete[$key][
'fieldvalue'] = $tabfieldvalue[$i];
676 $tabcomplete[$key][
'lib'] = $tablib[$i];
677 $tabcomplete[$key][
'sql'] = $tabsql[$i];
678 $tabcomplete[$key][
'sqlsort'] = $tabsqlsort[$i];
679 $tabcomplete[$key][
'field'] = $tabfield[$i];
686 $arrayofkeys = array_keys($tabcomplete);
687 if (array_key_exists($id - 1, $arrayofkeys)) {
688 $keytable = $arrayofkeys[
$id - 1];
693if (empty($sortfield)) {
694 $tmp1 = explode(
',', empty($tabcomplete[$keytable][
'sqlsort']) ?
'' : $tabcomplete[$keytable][
'sqlsort']);
695 $tmp2 = explode(
' ', $tmp1[0]);
696 $sortfield = preg_replace(
'/^.*\./',
'', $tmp2[0]);
697 $sortorder = (!empty($tmp2[1]) ? $tmp2[1] :
'');
702$elementList = array();
703$sourceList = array();
704if ($id == DICT_TYPE_CONTACT) {
705 $elementList = array(
707 'agenda' =>
img_picto(
'',
'action',
'class="pictofixedwidth"').$langs->trans(
'Agenda'),
708 'dolresource' =>
img_picto(
'',
'resource',
'class="pictofixedwidth"').$langs->trans(
'Resource'),
709 'societe' =>
img_picto(
'',
'company',
'class="pictofixedwidth"').$langs->trans(
'ThirdParty'),
715 'project' =>
img_picto(
'',
'project',
'class="pictofixedwidth"').$langs->trans(
'Project'),
716 'project_task' =>
img_picto(
'',
'projecttask',
'class="pictofixedwidth"').$langs->trans(
'Task'),
717 'propal' =>
img_picto(
'',
'propal',
'class="pictofixedwidth"').$langs->trans(
'Proposal'),
718 'commande' =>
img_picto(
'',
'order',
'class="pictofixedwidth"').$langs->trans(
'Order'),
719 'shipping' =>
img_picto(
'',
'dolly',
'class="pictofixedwidth"') . $langs->trans(
'Shipment'),
720 'facture' =>
img_picto(
'',
'bill',
'class="pictofixedwidth"').$langs->trans(
'Bill'),
721 'fichinter' =>
img_picto(
'',
'intervention',
'class="pictofixedwidth"').$langs->trans(
'InterventionCard'),
722 'contrat' =>
img_picto(
'',
'contract',
'class="pictofixedwidth"').$langs->trans(
'Contract'),
723 'ticket' =>
img_picto(
'',
'ticket',
'class="pictofixedwidth"').$langs->trans(
'Ticket'),
724 'supplier_proposal' =>
img_picto(
'',
'supplier_proposal',
'class="pictofixedwidth"').$langs->trans(
'SupplierProposal'),
725 'order_supplier' =>
img_picto(
'',
'supplier_order',
'class="pictofixedwidth"').$langs->trans(
'SupplierOrder'),
726 'invoice_supplier' =>
img_picto(
'',
'supplier_invoice',
'class="pictofixedwidth"').$langs->trans(
'SupplierBill'),
727 'conferenceorbooth' =>
img_picto(
'',
'eventorganization',
'class="pictofixedwidth"').$langs->trans(
'ConferenceOrBooth'),
734 'internal' => $langs->trans(
'Internal'),
735 'external' => $langs->trans(
'External')
740$type_vatList = array(
741 "0" => $langs->trans(
"Sell").
'+'.$langs->trans(
"Buy"),
742 "1" => $langs->trans(
"Sell"),
743 "2" => $langs->trans(
"Buy")
747$localtax_typeList = array(
748 "0" => $langs->trans(
"No"),
749 "1" => $langs->trans(
"Yes").
' ('.$langs->trans(
"Type").
" 1)",
750 "2" => $langs->trans(
"Yes").
' ('.$langs->trans(
"Type").
" 2)",
751 "3" => $langs->trans(
"Yes").
' ('.$langs->trans(
"Type").
" 3)",
752 "4" => $langs->trans(
"Yes").
' ('.$langs->trans(
"Type").
" 4)",
753 "5" => $langs->trans(
"Yes").
' ('.$langs->trans(
"Type").
" 5)",
754 "6" => $langs->trans(
"Yes").
' ('.$langs->trans(
"Type").
" 6)"
768 'confirm' => $confirm,
770 'taborder' => $taborder,
771 'tabname' => $tabname,
774 'tabsqlsort' => $tabsqlsort,
775 'tabfield' => $tabfield,
776 'tabfieldvalue' => $tabfieldvalue,
777 'tabfieldinsert' => $tabfieldinsert,
778 'tabrowid' => $tabrowid,
779 'tabcond' => $tabcond,
780 'tabhelp' => $tabhelp,
781 'tabcomplete' => $tabcomplete
783$reshook = $hookmanager->executeHooks(
'doActions', $parameters, $object, $action);
788if (
GETPOST(
'button_removefilter',
'alpha') ||
GETPOST(
'button_removefilter.x',
'alpha') ||
GETPOST(
'button_removefilter_x',
'alpha')) {
789 $search_country_id =
'';
794if (empty($reshook)) {
797 $listfield = explode(
',', str_replace(
' ',
'', $tabfield[$id]));
798 $listfieldinsert = explode(
',', $tabfieldinsert[$id]);
799 $listfieldmodify = explode(
',', $tabfieldinsert[$id]);
800 $listfieldvalue = explode(
',', $tabfieldvalue[$id]);
804 foreach ($listfield as $f => $value) {
806 if ($value ==
'country_id' && in_array($tablib[$id], array(
'DictionaryPublicHolidays',
'DictionaryVAT',
'DictionaryInvoiceSubtype',
'DictionaryRegion',
'DictionaryCompanyType',
'DictionaryHolidayTypes',
'DictionaryRevenueStamp',
'DictionaryAccountancysystem',
'DictionaryAccountancyCategory'))) {
809 if ($value ==
'country' && in_array($tablib[$id], array(
'DictionaryPublicHolidays',
'DictionaryCanton',
'DictionaryCompanyType',
'DictionaryHolidayTypes',
'DictionaryRevenueStamp'))) {
813 if (
GETPOST(
'actionadd') && $value ==
'department_buyer_id' && $tablib[$id] ==
'DictionaryVAT') {
817 if ($value ==
'department_buyer' && $tablib[$id] ==
'DictionaryVAT') {
821 if ($value ==
'localtax1' && !
GETPOST(
'localtax1_type')) {
824 if ($value ==
'localtax2' && !
GETPOST(
'localtax2_type')) {
827 if ($value ==
'color' && !
GETPOST(
'color')) {
830 if ($value ==
'formula' && !
GETPOST(
'formula')) {
833 if ($value ==
'dayrule' && !
GETPOST(
'dayrule')) {
836 if ($value ==
'sortorder') {
839 if ((!GETPOSTISSET($value) ||
GETPOST($value) ==
'')
841 !in_array($value, array(
'decalage',
'module',
'accountancy_code',
'accountancy_code_sell',
'accountancy_code_buy',
'tracking',
'picto',
'deposit_percent'))
842 && ($id != DICT_TVA || ($value !=
'code' && $value !=
'note'))
846 $fieldnamekey = $value;
848 if ($fieldnamekey ==
'libelle' || ($fieldnamekey ==
'label')) {
849 $fieldnamekey =
'Label';
851 if ($fieldnamekey ==
'libelle_facture') {
852 $fieldnamekey =
'LabelOnDocuments';
854 if ($fieldnamekey ==
'deposit_percent') {
855 $fieldnamekey =
'DepositPercent';
857 if ($fieldnamekey ==
'nbjour') {
858 $fieldnamekey =
'NbOfDays';
860 if ($fieldnamekey ==
'decalage') {
861 $fieldnamekey =
'Offset';
863 if ($fieldnamekey ==
'module') {
864 $fieldnamekey =
'Module';
866 if ($fieldnamekey ==
'code') {
867 $fieldnamekey =
'Code';
869 if ($fieldnamekey ==
'note') {
870 $fieldnamekey =
'Note';
872 if ($fieldnamekey ==
'taux') {
873 $fieldnamekey =
'Rate';
875 if ($fieldnamekey ==
'type') {
876 $fieldnamekey =
'Type';
878 if ($fieldnamekey ==
'position') {
879 $fieldnamekey =
'Position';
881 if ($fieldnamekey ==
'unicode') {
882 $fieldnamekey =
'Unicode';
884 if ($fieldnamekey ==
'deductible') {
885 $fieldnamekey =
'Deductible';
887 if ($fieldnamekey ==
'sortorder') {
888 $fieldnamekey =
'SortOrder';
890 if ($fieldnamekey ==
'category_type') {
891 $fieldnamekey =
'Calculated';
893 if ($fieldnamekey ==
'revenuestamp_type') {
894 $fieldnamekey =
'TypeOfRevenueStamp';
896 if ($fieldnamekey ==
'use_default') {
897 $fieldnamekey =
'UseByDefault';
900 setEventMessages($langs->transnoentities(
"ErrorFieldRequired", $langs->transnoentities($fieldnamekey)),
null,
'errors');
904 if (
GETPOST(
'actionadd') && $tabname[$id] ==
"c_actioncomm" && GETPOSTISSET(
"type") && in_array(
GETPOST(
"type"), array(
'system',
'systemauto'))) {
906 setEventMessages($langs->transnoentities(
'ErrorReservedTypeSystemSystemAuto'),
null,
'errors');
908 if (GETPOSTISSET(
"code")) {
911 setEventMessages($langs->transnoentities(
'ErrorCodeCantContainZero'),
null,
'errors');
914 if (GETPOSTISSET(
"country") && (
GETPOST(
"country") ==
'0') && ($id != DICT_DEPARTEMENTS)) {
915 if (in_array($tablib[$id], array(
'DictionaryCompanyType',
'DictionaryHolidayTypes'))) {
916 $_POST[
"country"] =
'';
919 setEventMessages($langs->transnoentities(
"ErrorFieldRequired", $langs->transnoentities(
"Country")),
null,
'errors');
922 if (($id == DICT_REGIONS || $id == DICT_PRODUCT_NATURE) && !is_numeric(
GETPOST(
"code")) &&
GETPOST(
'actionadd')) {
924 setEventMessages($langs->transnoentities(
"ErrorFieldMustBeANumeric", $langs->transnoentities(
"Code")),
null,
'errors');
926 if ($id == DICT_COUNTRY && strlen(
GETPOST(
"code")) != 2) {
928 setEventMessages($langs->transnoentities(
"ErrorCountryCodeMustBe2Char", $langs->transnoentities(
"Code")),
null,
'errors');
930 if ($id == DICT_PAIEMENT && strlen(
GETPOST(
"code")) >= 6) {
932 setEventMessages($langs->transnoentities(
"ErrorFieldMustHaveLessThanXChar", $langs->transnoentities(
"Code"),
'6'),
null,
'errors');
937 $_POST[
"localtax1"] =
'0';
940 $_POST[
"localtax2"] =
'0';
942 if (
GETPOST(
'department_buyer_id') <= 0) {
943 $_POST[
'department_buyer_id'] =
'';
945 if (
GETPOST(
"accountancy_code") <= 0) {
946 $_POST[
"accountancy_code"] =
'';
948 if (
GETPOST(
"accountancy_code_sell") <= 0) {
949 $_POST[
"accountancy_code_sell"] =
'';
951 if (
GETPOST(
"accountancy_code_buy") <= 0) {
952 $_POST[
"accountancy_code_buy"] =
'';
954 if ($id == DICT_TVA && GETPOSTISSET(
"code")) {
955 $_POST[
"code"] = preg_replace(
'/[^a-zA-Z0-9_\-\+]/',
'',
GETPOST(
"code"));
958 $tablename = $tabname[
$id];
959 $tablename = preg_replace(
'/^'.preg_quote(MAIN_DB_PREFIX,
'/').
'/',
'', $tablename);
962 if ($ok &&
GETPOST(
'actionadd')) {
964 if ($tabrowid[$id] && !in_array($tabrowid[$id], $listfieldinsert)) {
966 $sql =
"SELECT MAX(".$tabrowid[
$id].
") as newid FROM ".MAIN_DB_PREFIX.$tablename;
967 $result = $db->query($sql);
969 $obj = $db->fetch_object($result);
970 $newid = ((int) $obj->newid) + 1;
977 $sql =
"INSERT INTO ".MAIN_DB_PREFIX.$tablename.
" (";
979 if ($tabrowid[$id] && !in_array($tabrowid[$id], $listfieldinsert)) {
980 $sql .= $tabrowid[
$id].
",";
982 $sql .= $tabfieldinsert[
$id];
987 if ($tabrowid[$id] && !in_array($tabrowid[$id], $listfieldinsert)) {
991 foreach ($listfieldinsert as $f => $value) {
992 $keycode = (isset($listfieldvalue[$i]) ? $listfieldvalue[$i] :
'');
993 if (empty($keycode)) {
997 if ($value ==
'price' || preg_match(
'/^amount/i', $value)) {
999 } elseif ($value ==
'taux' || $value ==
'localtax1') {
1001 } elseif ($value ==
'entity') {
1002 $_POST[$keycode] =
getEntity($tablename);
1009 if ($keycode ==
'sortorder') {
1011 } elseif (
GETPOST($keycode) ==
'' && !($keycode ==
'code' && $id == DICT_TVA)) {
1013 } elseif ($keycode ==
'content') {
1014 $sql .=
"'".$db->escape(
GETPOST($keycode,
'restricthtml')).
"'";
1015 } elseif (in_array($keycode, array(
'joinfile',
'private',
'pos',
'position',
'scale',
'use_default'))) {
1018 $sql .=
"'".$db->escape(
GETPOST($keycode,
'alphanohtml')).
"'";
1026 $resql = $db->query($sql);
1028 setEventMessages($langs->transnoentities(
"RecordCreatedSuccessfully"),
null,
'mesgs');
1031 if ($id == DICT_TVA &&
GETPOSTINT(
'country') > 0) {
1034 $_POST = array(
'id' => $id);
1036 if ($db->errno() ==
'DB_ERROR_RECORD_ALREADY_EXISTS') {
1037 setEventMessages($langs->transnoentities(
"ErrorRecordAlreadyExists"),
null,
'errors');
1045 if ($ok &&
GETPOST(
'actionmodify')) {
1046 if ($tabrowid[$id]) {
1047 $rowidcol = $tabrowid[
$id];
1049 $rowidcol =
"rowid";
1053 $sql =
"UPDATE ".MAIN_DB_PREFIX.$tablename.
" SET ";
1055 if ($tabrowid[$id] && !in_array($tabrowid[$id], $listfieldmodify)) {
1056 $sql .= $tabrowid[
$id].
"=";
1057 $sql .=
"'".$db->escape($rowid).
"', ";
1060 foreach ($listfieldmodify as $field) {
1061 $keycode = empty($listfieldvalue[$i]) ?
'' : $listfieldvalue[$i];
1062 if (empty($keycode)) {
1066 if ($field ==
'price' || preg_match(
'/^amount/i', $field)) {
1068 } elseif ($field ==
'taux' || $field ==
'localtax1') {
1070 } elseif ($field ==
'entity') {
1071 $_POST[$keycode] =
getEntity($tablename);
1078 if ($keycode ==
'sortorder') {
1080 } elseif (
GETPOST($keycode) ==
'' && !($keycode ==
'code' && $id == DICT_TVA)) {
1082 } elseif ($keycode ==
'content') {
1083 $sql .=
"'".$db->escape(
GETPOST($keycode,
'restricthtml')).
"'";
1084 } elseif (in_array($keycode, array(
'joinfile',
'private',
'pos',
'position',
'scale',
'use_default'))) {
1087 $sql .=
"'".$db->escape(
GETPOST($keycode,
'alphanohtml')).
"'";
1092 if (in_array($rowidcol, array(
'code',
'code_iso'))) {
1093 $sql .=
" WHERE ".$db->sanitize($rowidcol).
" = '".$db->escape($rowid).
"'";
1095 $sql .=
" WHERE ".$db->sanitize($rowidcol).
" = ".((int) $rowid);
1097 if (in_array(
'entity', $listfieldmodify)) {
1098 $sql .=
" AND entity = ".((int)
getEntity($tablename, 0));
1103 $resql = $db->query($sql);
1109 if (!$ok &&
GETPOST(
'actionadd')) {
1112 if (!$ok &&
GETPOST(
'actionmodify')) {
1117 if ($action ==
'confirm_delete' && $confirm ==
'yes') {
1118 if ($tabrowid[$id]) {
1119 $rowidcol = $tabrowid[
$id];
1121 $rowidcol =
"rowid";
1124 $tablename = $tabname[
$id];
1125 $tablename = preg_replace(
'/^'.preg_quote(MAIN_DB_PREFIX,
'/').
'/',
'', $tablename);
1127 $sql =
"DELETE FROM ".MAIN_DB_PREFIX.$tablename.
" WHERE ".$rowidcol.
" = '".$db->escape($rowid).
"'".($entity !=
'' ?
" AND entity = ".(int) $entity :
'');
1130 $result = $db->query($sql);
1132 if ($db->errno() ==
'DB_ERROR_CHILD_EXISTS') {
1133 setEventMessages($langs->transnoentities(
"ErrorRecordIsUsedByChild"),
null,
'errors');
1141 if ($action == $acts[0]) {
1142 if ($tabrowid[$id]) {
1143 $rowidcol = $tabrowid[
$id];
1145 $rowidcol =
"rowid";
1148 $tablename = $tabname[
$id];
1149 $tablename = preg_replace(
'/^'.preg_quote(MAIN_DB_PREFIX,
'/').
'/',
'', $tablename);
1152 $sql =
"UPDATE ".MAIN_DB_PREFIX.$tablename.
" SET active = 1 WHERE ".$db->escape($rowidcol).
" = '".$db->escape($rowid).
"'".($entity !=
'' ?
" AND entity = ".(int) $entity :
'');
1154 $sql =
"UPDATE ".MAIN_DB_PREFIX.$tablename.
" SET active = 1 WHERE code = '".$db->escape(
dol_escape_htmltag($code)).
"'".($entity !=
'' ?
" AND entity = ".(int) $entity :
'');
1159 if ($sql !==
null) {
1160 $result = $db->query($sql);
1170 if ($action == $acts[1]) {
1171 if ($tabrowid[$id]) {
1172 $rowidcol = $tabrowid[
$id];
1174 $rowidcol =
"rowid";
1177 $tablename = $tabname[
$id];
1178 $tablename = preg_replace(
'/^'.preg_quote(MAIN_DB_PREFIX,
'/').
'/',
'', $tablename);
1181 $sql =
"UPDATE ".MAIN_DB_PREFIX.$tablename.
" SET active = 0 WHERE ".$rowidcol.
" = '".$db->escape($rowid).
"'".($entity !=
'' ?
" AND entity = ".(int) $entity :
'');
1183 $sql =
"UPDATE ".MAIN_DB_PREFIX.$tablename.
" SET active = 0 WHERE code = '".$db->escape(
dol_escape_htmltag($code)).
"'".($entity !=
'' ?
" AND entity = ".(int) $entity :
'');
1188 if ($sql !==
null) {
1189 $result = $db->query($sql);
1199 if ($action ==
'activate_favorite') {
1200 if ($tabrowid[$id]) {
1201 $rowidcol = $tabrowid[
$id];
1203 $rowidcol =
"rowid";
1206 $tablename = $tabname[
$id];
1207 $tablename = preg_replace(
'/^'.preg_quote(MAIN_DB_PREFIX,
'/').
'/',
'', $tablename);
1210 $sql =
"UPDATE ".MAIN_DB_PREFIX.$tablename.
" SET favorite = 1 WHERE ".$rowidcol.
" = '".$db->escape($rowid).
"'".($entity !=
'' ?
" AND entity = ".(int) $entity :
'');
1212 $sql =
"UPDATE ".MAIN_DB_PREFIX.$tablename.
" SET favorite = 1 WHERE code = '".$db->escape(
dol_escape_htmltag($code)).
"'".($entity !=
'' ?
" AND entity = ".(int) $entity :
'');
1217 if ($sql !==
null) {
1218 $result = $db->query($sql);
1228 if ($action ==
'disable_favorite') {
1229 if ($tabrowid[$id]) {
1230 $rowidcol = $tabrowid[
$id];
1232 $rowidcol =
"rowid";
1235 $tablename = $tabname[
$id];
1236 $tablename = preg_replace(
'/^'.preg_quote(MAIN_DB_PREFIX,
'/').
'/',
'', $tablename);
1239 $sql =
"UPDATE ".MAIN_DB_PREFIX.$tablename.
" SET favorite = 0 WHERE ".$rowidcol.
" = '".$db->escape($rowid).
"'".($entity !=
'' ?
" AND entity = ".(int) $entity :
'');
1241 $sql =
"UPDATE ".MAIN_DB_PREFIX.$tablename.
" SET favorite = 0 WHERE code = '".$db->escape(
dol_escape_htmltag($code)).
"'".($entity !=
'' ?
" AND entity = ".(int) $entity :
'');
1246 if ($sql !==
null) {
1247 $result = $db->query($sql);
1257 if ($action ==
'activate_eec') {
1258 if ($tabrowid[$id]) {
1259 $rowidcol = $tabrowid[
$id];
1261 $rowidcol =
"rowid";
1264 $tablename = $tabname[
$id];
1265 $tablename = preg_replace(
'/^'.preg_quote(MAIN_DB_PREFIX,
'/').
'/',
'', $tablename);
1268 $sql =
"UPDATE ".MAIN_DB_PREFIX.$tablename.
" SET eec = 1 WHERE ".$rowidcol.
" = '".$db->escape($rowid).
"'".($entity !=
'' ?
" AND entity = ".(int) $entity :
'');
1270 $sql =
"UPDATE ".MAIN_DB_PREFIX.$tablename.
" SET eec = 1 WHERE code = '".$db->escape(
dol_escape_htmltag($code)).
"'".($entity !=
'' ?
" AND entity = ".(int) $entity :
'');
1275 if ($sql !==
null) {
1276 $result = $db->query($sql);
1286 if ($action ==
'disable_eec') {
1287 if ($tabrowid[$id]) {
1288 $rowidcol = $tabrowid[
$id];
1290 $rowidcol =
"rowid";
1293 $tablename = $tabname[
$id];
1294 $tablename = preg_replace(
'/^'.preg_quote(MAIN_DB_PREFIX,
'/').
'/',
'', $tablename);
1297 $sql =
"UPDATE ".MAIN_DB_PREFIX.$tablename.
" SET eec = 0 WHERE ".$rowidcol.
" = '".$db->escape($rowid).
"'".($entity !=
'' ?
" AND entity = ".(int) $entity :
'');
1299 $sql =
"UPDATE ".MAIN_DB_PREFIX.$tablename.
" SET eec = 0 WHERE code = '".$db->escape(
dol_escape_htmltag($code)).
"'".($entity !=
'' ?
" AND entity = ".(int) $entity :
'');
1304 if ($sql !==
null) {
1305 $result = $db->query($sql);
1315 if ($action ==
'activate_sepa') {
1316 if ($tabrowid[$id]) {
1317 $rowidcol = $tabrowid[
$id];
1319 $rowidcol =
"rowid";
1322 $tablename = $tabname[
$id];
1323 $tablename = preg_replace(
'/^'.preg_quote(MAIN_DB_PREFIX,
'/').
'/',
'', $tablename);
1326 $sql =
"UPDATE ".MAIN_DB_PREFIX.$tablename.
" SET sepa = 1 WHERE ".$rowidcol.
" = '".$db->escape($rowid).
"'".($entity !=
'' ?
" AND entity = ".(int) $entity :
'');
1328 $sql =
"UPDATE ".MAIN_DB_PREFIX.$tablename.
" SET sepa = 1 WHERE code = '".$db->escape(
dol_escape_htmltag($code)).
"'".($entity !=
'' ?
" AND entity = ".(int) $entity :
'');
1333 if ($sql !==
null) {
1334 $result = $db->query($sql);
1344 if ($action ==
'disable_sepa') {
1345 if ($tabrowid[$id]) {
1346 $rowidcol = $tabrowid[
$id];
1348 $rowidcol =
"rowid";
1351 $tablename = $tabname[
$id];
1352 $tablename = preg_replace(
'/^'.preg_quote(MAIN_DB_PREFIX,
'/').
'/',
'', $tablename);
1355 $sql =
"UPDATE ".MAIN_DB_PREFIX.$tablename.
" SET sepa = 0 WHERE ".$rowidcol.
" = '".$db->escape($rowid).
"'".($entity !=
'' ?
" AND entity = ".(int) $entity :
'');
1357 $sql =
"UPDATE ".MAIN_DB_PREFIX.$tablename.
" SET sepa = 0 WHERE code = '".$db->escape(
dol_escape_htmltag($code)).
"'".($entity !=
'' ?
" AND entity = ".(int) $entity :
'');
1362 if ($sql !==
null) {
1363 $result = $db->query($sql);
1378$form =
new Form($db);
1380$title = $langs->trans(
"DictionarySetup");
1382llxHeader(
'', $title,
'',
'', 0, 0,
'',
'',
'',
'mod-admin page-dict');
1384if (
GETPOSTINT(
'id') == DICT_SOCIALNETWORKS && $from ==
'socialnetworksetup') {
1385 $head = socialnetwork_prepare_head();
1391if ($id && empty($from)) {
1392 $title .=
' - '.$langs->trans($tablib[$id]);
1393 $linkback =
'<a href="'.$_SERVER[
'PHP_SELF'].
'">'.
img_picto($langs->trans(
"BackToDictionaryList"),
'back',
'class="pictofixedwidth"').
'<span class="hideonsmartphone">'.$langs->trans(
"BackToDictionaryList").
'</span></a>';
1395$titlepicto =
'title_setup';
1396if ($id == DICT_TVA &&
GETPOST(
'from') ==
'accountancy') {
1397 $title = $langs->trans(
"MenuVatAccounts");
1398 $titlepicto =
'accountancy';
1400if ($id == DICT_CHARGESOCIALES &&
GETPOST(
'from') ==
'accountancy') {
1401 $title = $langs->trans(
"MenuTaxAccounts");
1402 $titlepicto =
'accountancy';
1405$param =
'&id='.urlencode((
string) ($id));
1406if ($search_country_id || GETPOSTISSET(
'page') ||
GETPOST(
'button_removefilter',
'alpha') ||
GETPOST(
'button_removefilter.x',
'alpha') ||
GETPOST(
'button_removefilter_x',
'alpha')) {
1407 $param .=
'&search_country_id='.urlencode((
string) ($search_country_id ? $search_country_id : -1));
1409if ($search_code !=
'') {
1410 $param .=
'&search_code='.urlencode($search_code);
1412if ($search_active !=
'') {
1413 $param .=
'&search_active='.urlencode($search_active);
1416 $param .=
'&entity='.(int) $entity;
1419 $param .=
'&from='.urlencode($from);
1421$paramwithsearch = $param;
1423 $paramwithsearch .=
'&sortorder='.urlencode($sortorder);
1426 $paramwithsearch .=
'&sortfield='.urlencode($sortfield);
1429 $paramwithsearch .=
'&from='.urlencode($from);
1434if ($action ==
'delete') {
1435 print $form->formconfirm($_SERVER[
"PHP_SELF"].
'?'.($page ?
'page='.$page.
'&' :
'').
'rowid='.urlencode($rowid).
'&code='.urlencode($code).$paramwithsearch, $langs->trans(
'DeleteLine'), $langs->trans(
'ConfirmDeleteLine'),
'confirm_delete',
'', 0, 1);
1441 $sqlfields = $tabsql[
$id];
1443 $tablecode =
't.code';
1445 $tableprefixarray = array(
1446 DICT_FORME_JURIDIQUE =>
'f.code',
1447 DICT_DEPARTEMENTS =>
'd.code_departement',
1448 DICT_REGIONS =>
'r.code_region',
1449 DICT_COUNTRY =>
'c.code',
1450 DICT_CIVILITY =>
'c.code',
1451 DICT_ACTIONCOMM =>
'a.code',
1452 DICT_CHARGESOCIALES =>
'a.code',
1453 DICT_TYPENT =>
't.code',
1454 DICT_CURRENCIES =>
'c.code_iso',
1455 DICT_ECOTAXE =>
'e.code',
1456 DICT_HOLIDAY_TYPES =>
'h.code',
1457 DICT_HRM_PUBLIC_HOLIDAY =>
'a.code',
1458 DICT_UNITS =>
'r.code',
1459 DICT_SOCIALNETWORKS =>
's.code',
1465 if (!empty($tableprefixarray[$id])) {
1466 $tablecode = $tableprefixarray[
$id];
1467 $tableprefix = preg_replace(
'/\..*$/',
'.', $tablecode);
1470 if (empty($tableprefix) && preg_match(
'/SELECT ([a-z]\.)rowid/i', $sqlfields, $reg)) {
1471 $tableprefix = $reg[1];
1475 if (!preg_match(
'/ WHERE /', $sql)) {
1476 $sql .=
" WHERE 1 = 1";
1478 if ($search_country_id > 0) {
1479 $sql .=
" AND c.rowid = ".((int) $search_country_id);
1481 if ($search_code !=
'') {
1484 if ($search_active ==
'yes') {
1485 $sql .=
" AND ".$db->sanitize($tableprefix).
"active = 1";
1486 } elseif ($search_active ==
'no') {
1487 $sql .=
" AND ".$db->sanitize($tableprefix).
"active = 0";
1491 $nbtotalofrecords =
'';
1494 $sqlforcount = preg_replace(
'/^.*\sFROM\s/',
'SELECT COUNT(*) as nbtotalofrecords FROM ', $sql);
1495 $sqlforcount = preg_replace(
'/GROUP BY .*$/',
'', $sqlforcount);
1496 $resql = $db->query($sqlforcount);
1498 $objforcount = $db->fetch_object($resql);
1499 $nbtotalofrecords = $objforcount->nbtotalofrecords;
1504 if (($page * $listlimit) > $nbtotalofrecords) {
1513 if ($sortfield ==
'country') {
1514 $sortfield =
'country_code';
1516 $sql .= $db->order($sortfield, $sortorder);
1519 $tabsqlsort[
$id] = preg_replace(
'/([a-z]+\.)?'.$sortfield.
' '.$sortorder.
',/i',
'', $tabsqlsort[$id]);
1520 $tabsqlsort[
$id] = preg_replace(
'/([a-z]+\.)?'.$sortfield.
',/i',
'', $tabsqlsort[$id]);
1522 $sql .=
" ORDER BY ";
1524 $sql .= $tabsqlsort[
$id];
1526 $sql .= $db->plimit($listlimit + 1, $offset);
1528 $resql = $db->query($sql);
1533 $num = $db->num_rows($resql);
1537 if (empty($tabfield[$id])) {
1541 $fieldlist = explode(
',', $tabfield[$id]);
1543 print
'<form action="'.$_SERVER[
'PHP_SELF'].
'?id='.
$id.
'" method="POST">';
1544 print
'<input type="hidden" name="token" value="'.newToken().
'">';
1545 print
'<input type="hidden" name="from" value="'.dol_escape_htmltag($from).
'">';
1549 print
info_admin($langs->trans(
"VATIsUsedIsOff", $langs->transnoentities(
"Setup"), $langs->transnoentities(
"CompanyFoundation")));
1556 $resql = $db->query($sql);
1558 $num = $db->num_rows($resql);
1561 $massactionbutton = $linkback;
1563 $newcardbutton =
'';
1568 $newcardbutton .=
dolGetButtonTitle($langs->trans(
'New'),
'',
'fa fa-plus-circle', DOL_URL_ROOT.
'/admin/dict.php?action=create'.$param.
'&backtopage='.urlencode($_SERVER[
'PHP_SELF']),
'', $permissiontoadd);
1570 print_barre_liste($title, $page, $_SERVER[
"PHP_SELF"], $param, $sortfield, $sortorder, $massactionbutton, $num, $nbtotalofrecords,
'tools', 0, $newcardbutton,
'', $listlimit, 1, 0, 1);
1573 if ($action ==
'create') {
1575 if ($tabname[$id]) {
1578 $fieldlist = explode(
',', $tabfield[$id]);
1580 print
'<div class="div-table-responsive-no-min">';
1581 print
'<table class="noborder centpercent">';
1584 print
'<!-- line title to add new entry -->';
1585 $tdsoffields =
'<tr class="liste_titre">';
1586 foreach ($fieldlist as $field => $value) {
1587 if ($value ==
'entity') {
1593 $valuetoshow = ucfirst($value);
1594 $valuetoshow = $langs->trans($valuetoshow);
1597 if ($value ==
'pos') {
1598 $valuetoshow = $langs->trans(
"Position");
1601 if ($value ==
'source') {
1602 $valuetoshow = $langs->trans(
"Contact");
1604 if ($value ==
'price') {
1605 $valuetoshow = $langs->trans(
"PriceUHT");
1607 if ($value ==
'taux') {
1608 if ($tabname[$id] !=
"c_revenuestamp") {
1609 $valuetoshow = $langs->trans(
"Rate");
1611 $valuetoshow = $langs->trans(
"Amount");
1615 if ($value ==
'localtax1_type') {
1616 $valuetoshow = $langs->trans(
"UseLocalTax").
" 2";
1620 if ($value ==
'localtax1') {
1621 $valuetoshow = $langs->trans(
"RateOfTaxN",
'2');
1622 $class =
"center minwidth75";
1624 if ($value ==
'localtax2_type') {
1625 $valuetoshow = $langs->trans(
"UseLocalTax").
" 3";
1629 if ($value ==
'localtax2') {
1630 $valuetoshow = $langs->trans(
"RateOfTaxN",
'3');
1631 $class =
"center minwidth75";
1633 if ($value ==
'type_vat') {
1634 $valuetoshow = $langs->trans(
"VATType");
1636 if ($value ==
'organization') {
1637 $valuetoshow = $langs->trans(
"Organization");
1639 if ($value ==
'lang') {
1640 $valuetoshow = $langs->trans(
"Language");
1642 if ($value ==
'type') {
1643 if ($tabname[$id] ==
"c_paiement") {
1644 $valuetoshow = $form->textwithtooltip($langs->trans(
"Type"), $langs->trans(
"TypePaymentDesc"), 2, 1,
img_help(1,
''));
1646 $valuetoshow = $langs->trans(
"Type");
1649 if ($value ==
'code') {
1650 $valuetoshow = $langs->trans(
"Code");
1651 $class =
'maxwidth100';
1653 if ($value ==
'libelle' || $value ==
'label') {
1654 $valuetoshow = $form->textwithtooltip($langs->trans(
"Label"), $langs->trans(
"LabelUsedByDefault"), 2, 1,
img_help(1,
''));
1656 if ($value ==
'libelle_facture') {
1657 $valuetoshow = $form->textwithtooltip($langs->trans(
"LabelOnDocuments"), $langs->trans(
"LabelUsedByDefault"), 2, 1,
img_help(1,
''));
1659 if ($value ==
'deposit_percent') {
1660 $valuetoshow = $langs->trans(
'DepositPercent');
1663 if ($value ==
'country') {
1664 if (in_array(
'region_id', $fieldlist)) {
1668 $valuetoshow = $langs->trans(
"Country");
1670 if ($value ==
'department_buyer') {
1673 if ($value ==
'recuperableonly') {
1674 $valuetoshow = $langs->trans(
"NPR");
1677 if ($value ==
'nbjour') {
1678 $valuetoshow = $langs->trans(
"NbOfDays");
1681 if ($value ==
'type_cdr') {
1682 $valuetoshow = $langs->trans(
"AtEndOfMonth");
1685 if ($value ==
'decalage') {
1686 $valuetoshow = $langs->trans(
"Offset");
1689 if ($value ==
'width' || $value ==
'nx') {
1690 $valuetoshow = $langs->trans(
"Width");
1692 if ($value ==
'height' || $value ==
'ny') {
1693 $valuetoshow = $langs->trans(
"Height");
1695 if ($value ==
'unit' || $value ==
'metric') {
1696 $valuetoshow = $langs->trans(
"MeasuringUnit");
1698 if ($value ==
'region_id' || $value ==
'country_id' || $value ==
'department_buyer_id') {
1701 if ($value ==
'accountancy_code') {
1702 $valuetoshow = $langs->trans(
"AccountancyCode");
1704 if ($value ==
'accountancy_code_sell') {
1705 $valuetoshow = $langs->trans(
"AccountancyCodeSell");
1707 if ($value ==
'accountancy_code_buy') {
1708 $valuetoshow = $langs->trans(
"AccountancyCodeBuy");
1710 if ($value ==
'pcg_version' || $value ==
'fk_pcg_version') {
1711 $valuetoshow = $langs->trans(
"Pcg_version");
1713 if ($value ==
'account_parent') {
1714 $valuetoshow = $langs->trans(
"Accountparent");
1716 if ($value ==
'pcg_type') {
1717 $valuetoshow = $langs->trans(
"Pcg_type");
1719 if ($value ==
'pcg_subtype') {
1720 $valuetoshow = $langs->trans(
"Pcg_subtype");
1722 if ($value ==
'sortorder') {
1723 $valuetoshow = $langs->trans(
"SortOrder");
1726 if ($value ==
'short_label') {
1727 $valuetoshow = $langs->trans(
"ShortLabel");
1729 if ($value ==
'fk_parent') {
1730 $valuetoshow = $langs->trans(
"ParentID");
1733 if ($value ==
'range_account') {
1734 $valuetoshow = $langs->trans(
"Range");
1736 if ($value ==
'sens') {
1737 $valuetoshow = $langs->trans(
"Sens");
1739 if ($value ==
'category_type') {
1740 $valuetoshow = $langs->trans(
"Calculated");
1742 if ($value ==
'formula') {
1743 $valuetoshow = $langs->trans(
"Formula");
1745 if ($value ==
'paper_size') {
1746 $valuetoshow = $langs->trans(
"PaperSize");
1748 if ($value ==
'orientation') {
1749 $valuetoshow = $langs->trans(
"Orientation");
1751 if ($value ==
'leftmargin') {
1752 $valuetoshow = $langs->trans(
"LeftMargin");
1754 if ($value ==
'topmargin') {
1755 $valuetoshow = $langs->trans(
"TopMargin");
1757 if ($value ==
'spacex') {
1758 $valuetoshow = $langs->trans(
"SpaceX");
1760 if ($value ==
'spacey') {
1761 $valuetoshow = $langs->trans(
"SpaceY");
1763 if ($value ==
'font_size') {
1764 $valuetoshow = $langs->trans(
"FontSize");
1766 if ($value ==
'custom_x') {
1767 $valuetoshow = $langs->trans(
"CustomX");
1769 if ($value ==
'custom_y') {
1770 $valuetoshow = $langs->trans(
"CustomY");
1772 if ($value ==
'percent') {
1773 $valuetoshow = $langs->trans(
"Percentage");
1775 if ($value ==
'affect') {
1776 $valuetoshow = $langs->trans(
"WithCounter");
1778 if ($value ==
'delay') {
1779 $valuetoshow = $langs->trans(
"NoticePeriod");
1781 if ($value ==
'newbymonth') {
1782 $valuetoshow = $langs->trans(
"NewByMonth");
1784 if ($value ==
'fk_tva') {
1785 $valuetoshow = $langs->trans(
"VAT");
1787 if ($value ==
'range_ik') {
1788 $valuetoshow = $langs->trans(
"RangeIk");
1790 if ($value ==
'fk_c_exp_tax_cat') {
1791 $valuetoshow = $langs->trans(
"CarCategory");
1793 if ($value ==
'revenuestamp_type') {
1794 $valuetoshow = $langs->trans(
'TypeOfRevenueStamp');
1796 if ($value ==
'use_default') {
1797 $valuetoshow = $langs->trans(
'Default');
1800 if ($value ==
'unit_type') {
1801 $valuetoshow = $langs->trans(
'TypeOfUnit');
1803 if ($value ==
'public' && $tablib[$id] ==
'TicketDictCategory') {
1804 $valuetoshow = $langs->trans(
'TicketGroupIsPublic');
1807 if ($value ==
'block_if_negative') {
1808 $valuetoshow = $langs->trans(
'BlockHolidayIfNegative');
1810 if ($value ==
'type_duration') {
1811 $valuetoshow = $langs->trans(
'Unit');
1814 if ($id == DICT_DEPARTEMENTS) {
1815 if ($value ==
'region_id') {
1816 $valuetoshow =
' ';
1819 if ($value ==
'region') {
1820 $valuetoshow = $langs->trans(
"Country").
'/'.$langs->trans(
"Region");
1825 if ($valuetoshow !=
'') {
1826 $tooltiphelp = (isset($tabcomplete[$tabname[$id]][
'help'][$value]) ? $tabcomplete[$tabname[
$id]][
'help'][$value] :
'');
1828 $tdsoffields .=
'<th'.($class ?
' class="'.$class.
'"' :
'').
'>';
1829 if ($tooltiphelp && preg_match(
'/^http(s*):/i', $tooltiphelp)) {
1830 $tdsoffields .=
'<a href="'.$tooltiphelp.
'" target="_blank">'.$valuetoshow.
' '.
img_help(1, $valuetoshow).
'</a>';
1831 } elseif ($tooltiphelp) {
1832 $tdsoffields .= $form->textwithpicto($valuetoshow, $tooltiphelp);
1834 $tdsoffields .= $valuetoshow;
1836 $tdsoffields .=
'</th>';
1840 if ($id == DICT_COUNTRY) {
1841 $tdsoffields .=
'<th></th>';
1842 $tdsoffields .=
'<th></th>';
1844 $tdsoffields .=
'<th>';
1845 $tdsoffields .=
'<input type="hidden" name="id" value="'.$id.
'">';
1846 if (!is_null($withentity)) {
1847 $tdsoffields .=
'<input type="hidden" name="entity" value="'.$withentity.
'">';
1849 $tdsoffields .=
'</th>';
1850 $tdsoffields .=
'<th style="min-width: 26px;"></th>';
1851 $tdsoffields .=
'<th style="min-width: 26px;"></th>';
1852 $tdsoffields .=
'</tr>';
1858 print
'<!-- line input to add new entry -->';
1859 print
'<tr class="oddeven nodrag nodrop nohover">';
1864 foreach ($fieldlist as $key => $val) {
1871 $tmpaction =
'create';
1872 $parameters = array(
'fieldlist' => $fieldlist,
'tabname' => $tabname[$id]);
1873 $reshook = $hookmanager->executeHooks(
'createDictionaryFieldlist', $parameters, $obj, $tmpaction);
1874 $error = $hookmanager->error;
1875 $errors = $hookmanager->errors;
1877 if ($id == DICT_REGIONS) {
1878 unset($fieldlist[2]);
1881 if (empty($reshook)) {
1885 if ($id == DICT_COUNTRY) {
1890 print
'<td colspan="3" class="center">';
1891 if ($action !=
'edit') {
1892 print
'<input type="submit" class="button button-add small" name="actionadd" value="'.$langs->trans(
"Add").
'">';
1894 print
'<input type="submit" class="button button-add small disabled" name="actionadd" value="'.$langs->trans(
"Add").
'">';
1906 print
'<form action="'.$_SERVER[
'PHP_SELF'].
'?id='.
$id.
'" method="POST">';
1907 print
'<input type="hidden" name="token" value="'.newToken().
'">';
1908 print
'<input type="hidden" name="from" value="'.dol_escape_htmltag(
GETPOST(
'from',
'alpha')).
'">';
1913 foreach ($fieldlist as $field => $value) {
1914 if ($value ==
'entity') {
1919 if ($value ==
'region_id' || $value ==
'country_id' || $value ==
'department_buyer_id') {
1924 if ($value ==
'country') {
1926 } elseif ($value ==
'code') {
1932 print
'<div class="div-table-responsive">';
1933 print
'<table class="noborder centpercent noborder">';
1938 print
'<!-- line title to search record -->'.
"\n";
1939 print
'<tr class="liste_titre_filter">';
1943 print
'<td class="liste_titre center">';
1945 $searchpicto = $form->showFilterAndCheckAddButtons(0);
1952 foreach ($fieldlist as $field => $value) {
1953 if ($value ==
'entity') {
1958 if ($value ==
'region_id' || $value ==
'country_id' || $value ==
'department_buyer_id') {
1963 if ($value ==
'country') {
1964 print
'<td class="liste_titre">';
1965 print $form->select_country($search_country_id,
'search_country_id',
'', 28,
'minwidth100 maxwidth150 maxwidthonsmartphone',
'',
' ');
1968 } elseif ($value ==
'code') {
1969 print
'<td class="liste_titre">';
1970 print
'<input type="text" class="maxwidth100" name="search_code" value="'.dol_escape_htmltag($search_code).
'">';
1973 } elseif ($value ==
'type_vat') {
1974 print
'<td class="liste_titre">';
1975 print $form->selectarray(
'search_'.$value, $type_vatList, (empty($obj->{$value}) ?
'' : $obj->{$value}), 1);
1979 print
'<td class="liste_titre">';
1985 if ($id == DICT_COUNTRY) {
1995 print
'<td class="liste_titre center parentonrightofpage">';
1996 print $form->selectyesno(
'search_active', $search_active, 0,
false, 1, 1,
'maxwidth100 onrightofpage',
'Activated',
'Disabled');
2002 print
'<td class="liste_titre center">';
2004 $searchpicto = $form->showFilterAndCheckAddButtons(0);
2015 print
'<!-- line title of record -->'.
"\n";
2016 print
'<tr class="liste_titre">';
2023 foreach ($fieldlist as $field => $value) {
2024 if ($value ==
'entity') {
2028 if (in_array($value, array(
'label',
'libelle',
'libelle_facture')) && empty($tabcomplete[$tabname[$id]][
'help'][$value])) {
2029 if (!isset($tabcomplete[$tabname[$id]][
'help']) || !is_array($tabcomplete[$tabname[$id]][
'help'])) {
2030 $tabcomplete[$tabname[
$id]][
'help'] = array();
2032 $tabcomplete[$tabname[
$id]][
'help'][$value] = $langs->trans(
'LabelUsedByDefault');
2040 $valuetoshow = ucfirst($value);
2041 $valuetoshow = $langs->trans($valuetoshow);
2044 if ($value ==
'source') {
2045 $valuetoshow = $langs->trans(
"Contact");
2047 if ($value ==
'price') {
2048 $valuetoshow = $langs->trans(
"PriceUHT");
2050 if ($value ==
'taux') {
2051 if ($tabname[$id] !=
"c_revenuestamp") {
2052 $valuetoshow = $langs->trans(
"Rate");
2054 $valuetoshow = $langs->trans(
"Amount");
2056 $cssprefix =
'center ';
2059 if ($value ==
'type_vat') {
2060 $valuetoshow = $langs->trans(
"VATType");
2061 $cssprefix =
"center minwidth75 ";
2064 if ($value ==
'localtax1_type') {
2065 $valuetoshow = $langs->trans(
"UseLocalTax").
" 2";
2066 $cssprefix =
"center minwidth75 ";
2069 if ($value ==
'localtax1') {
2070 $valuetoshow = $langs->trans(
"RateOfTaxN",
'2');
2071 $cssprefix =
"center minwidth75 ";
2074 if ($value ==
'localtax2_type') {
2075 $valuetoshow = $langs->trans(
"UseLocalTax").
" 3";
2076 $cssprefix =
"center minwidth75 ";
2079 if ($value ==
'localtax2') {
2080 $valuetoshow = $langs->trans(
"RateOfTaxN",
'3');
2081 $cssprefix =
"center minwidth75 ";
2084 if ($value ==
'organization') {
2085 $valuetoshow = $langs->trans(
"Organization");
2087 if ($value ==
'lang') {
2088 $valuetoshow = $langs->trans(
"Language");
2090 if ($value ==
'type') {
2091 $valuetoshow = $langs->trans(
"Type");
2093 if ($value ==
'code') {
2094 $valuetoshow = $langs->trans(
"Code");
2096 if (in_array($value, array(
'pos',
'position'))) {
2097 $valuetoshow = $langs->trans(
"Position");
2098 $cssprefix =
'right ';
2100 if ($value ==
'libelle' || $value ==
'label') {
2101 $valuetoshow = $langs->trans(
"Label");
2103 if ($value ==
'libelle_facture') {
2104 $valuetoshow = $langs->trans(
"LabelOnDocuments");
2106 if ($value ==
'deposit_percent') {
2107 $valuetoshow = $langs->trans(
'DepositPercent');
2108 $cssprefix =
'right ';
2110 if ($value ==
'country') {
2111 $valuetoshow = $langs->trans(
"Country");
2113 if ($value ==
'department_buyer') {
2114 $valuetoshow = $langs->trans(
'DepartmentBuyer');
2116 if ($value ==
'recuperableonly') {
2117 $valuetoshow = $langs->trans(
"NPR");
2118 $cssprefix =
"center ";
2120 if ($value ==
'nbjour') {
2121 $valuetoshow = $langs->trans(
"NbOfDays");
2122 $cssprefix =
'right ';
2124 if ($value ==
'type_cdr') {
2125 $valuetoshow = $langs->trans(
"AtEndOfMonth");
2126 $cssprefix =
"center ";
2128 if ($value ==
'decalage') {
2129 $valuetoshow = $langs->trans(
"Offset");
2130 $cssprefix =
'right ';
2132 if ($value ==
'width' || $value ==
'nx') {
2133 $valuetoshow = $langs->trans(
"Width");
2135 if ($value ==
'height' || $value ==
'ny') {
2136 $valuetoshow = $langs->trans(
"Height");
2138 if ($value ==
'unit' || $value ==
'metric') {
2139 $valuetoshow = $langs->trans(
"MeasuringUnit");
2141 if ($value ==
'accountancy_code') {
2142 $valuetoshow = $langs->trans(
"AccountancyCode");
2144 if ($value ==
'accountancy_code_sell') {
2145 $valuetoshow = $langs->trans(
"AccountancyCodeSell");
2148 if ($value ==
'accountancy_code_buy') {
2149 $valuetoshow = $langs->trans(
"AccountancyCodeBuy");
2152 if ($value ==
'fk_pcg_version') {
2153 $valuetoshow = $langs->trans(
"Pcg_version");
2155 if ($value ==
'account_parent') {
2156 $valuetoshow = $langs->trans(
"Accountsparent");
2158 if ($value ==
'pcg_type') {
2159 $valuetoshow = $langs->trans(
"Pcg_type");
2161 if ($value ==
'pcg_subtype') {
2162 $valuetoshow = $langs->trans(
"Pcg_subtype");
2164 if ($value ==
'sortorder') {
2165 $valuetoshow = $langs->trans(
"SortOrder");
2166 $cssprefix =
'center ';
2168 if ($value ==
'short_label') {
2169 $valuetoshow = $langs->trans(
"ShortLabel");
2171 if ($value ==
'fk_parent') {
2172 $valuetoshow = $langs->trans(
"ParentID");
2173 $cssprefix =
'center ';
2175 if ($value ==
'range_account') {
2176 $valuetoshow = $langs->trans(
"Range");
2178 if ($value ==
'sens') {
2179 $valuetoshow = $langs->trans(
"Sens");
2181 if ($value ==
'category_type') {
2182 $valuetoshow = $langs->trans(
"Calculated");
2184 if ($value ==
'formula') {
2185 $valuetoshow = $langs->trans(
"Formula");
2187 if ($value ==
'paper_size') {
2188 $valuetoshow = $langs->trans(
"PaperSize");
2190 if ($value ==
'orientation') {
2191 $valuetoshow = $langs->trans(
"Orientation");
2193 if ($value ==
'leftmargin') {
2194 $valuetoshow = $langs->trans(
"LeftMargin");
2196 if ($value ==
'topmargin') {
2197 $valuetoshow = $langs->trans(
"TopMargin");
2199 if ($value ==
'spacex') {
2200 $valuetoshow = $langs->trans(
"SpaceX");
2202 if ($value ==
'spacey') {
2203 $valuetoshow = $langs->trans(
"SpaceY");
2205 if ($value ==
'font_size') {
2206 $valuetoshow = $langs->trans(
"FontSize");
2208 if ($value ==
'custom_x') {
2209 $valuetoshow = $langs->trans(
"CustomX");
2211 if ($value ==
'custom_y') {
2212 $valuetoshow = $langs->trans(
"CustomY");
2214 if ($value ==
'percent') {
2215 $valuetoshow = $langs->trans(
"Percentage");
2217 if ($value ==
'affect') {
2218 $valuetoshow = $langs->trans(
"WithCounter");
2220 if ($value ==
'delay') {
2221 $valuetoshow = $langs->trans(
"NoticePeriod");
2223 if ($value ==
'newbymonth') {
2224 $valuetoshow = $langs->trans(
"NewByMonth");
2226 if ($value ==
'fk_tva') {
2227 $valuetoshow = $langs->trans(
"VAT");
2229 if ($value ==
'range_ik') {
2230 $valuetoshow = $langs->trans(
"RangeIk");
2232 if ($value ==
'fk_c_exp_tax_cat') {
2233 $valuetoshow = $langs->trans(
"CarCategory");
2235 if ($value ==
'revenuestamp_type') {
2236 $valuetoshow = $langs->trans(
'TypeOfRevenueStamp');
2238 if ($value ==
'use_default') {
2239 $valuetoshow = $langs->trans(
'Default');
2240 $cssprefix =
'center ';
2242 if ($value ==
'unit_type') {
2243 $valuetoshow = $langs->trans(
'TypeOfUnit');
2245 if ($value ==
'public' && $tablib[$id] ==
'TicketDictCategory') {
2246 $valuetoshow = $langs->trans(
'TicketGroupIsPublic');
2247 $cssprefix =
'center ';
2249 if ($value ==
'block_if_negative') {
2250 $valuetoshow = $langs->trans(
'BlockHolidayIfNegative');
2252 if ($value ==
'type_duration') {
2253 $valuetoshow = $langs->trans(
'Unit');
2256 if ($value ==
'region_id' || $value ==
'country_id' || $value ==
'department_buyer_id') {
2262 $tooltiphelp = (isset($tabcomplete[$tabname[$id]][
'help'][$value]) ? $tabcomplete[$tabname[
$id]][
'help'][$value] :
'');
2264 if ($tooltiphelp && preg_match(
'/^http(s*):/i', $tooltiphelp)) {
2265 $newvaluetoshow =
'<a href="'.$tooltiphelp.
'" target="_blank">'.$valuetoshow.
' '.
img_help(1, $valuetoshow).
'</a>';
2266 } elseif ($tooltiphelp) {
2267 $newvaluetoshow = $form->textwithpicto($valuetoshow, $tooltiphelp);
2269 $newvaluetoshow = $valuetoshow;
2272 print
getTitleFieldOfList($newvaluetoshow, 0, $_SERVER[
"PHP_SELF"], ($sortable ? $value :
''), ($page ?
'page='.$page.
'&' :
''), $param,
'', $sortfield, $sortorder, $cssprefix);
2276 if ($id == DICT_COUNTRY) {
2277 print
getTitleFieldOfList($langs->trans(
"InEEC"), 0, $_SERVER[
"PHP_SELF"],
"eec", ($page ?
'page='.$page.
'&' :
''), $param,
'', $sortfield, $sortorder,
'center ', 0, $langs->trans(
"CountryIsInEEC"));
2278 print
getTitleFieldOfList($langs->trans(
"InSepa"), 0, $_SERVER[
"PHP_SELF"],
"sepa", ($page ?
'page='.$page.
'&' :
''), $param,
'', $sortfield, $sortorder,
'center ', 0, $langs->trans(
"CountryIsInSepa"));
2279 print
getTitleFieldOfList($langs->trans(
"Favorite"), 0, $_SERVER[
"PHP_SELF"],
"favorite", ($page ?
'page='.$page.
'&' :
''), $param,
'', $sortfield, $sortorder,
'center ');
2283 print
getTitleFieldOfList($langs->trans(
"Status"), 0, $_SERVER[
"PHP_SELF"],
"active", ($page ?
'page='.$page.
'&' :
''), $param,
'', $sortfield, $sortorder,
'center ');
2294 print
'<!-- lines of dict -->'.
"\n";
2296 $obj = $db->fetch_object($resql);
2301 if ($id == DICT_COUNTRY) {
2302 if ($obj->code ==
'') {
2312 if (isset($obj->code) && $id != DICT_TVA && $id != DICT_PRODUCT_NATURE) {
2313 if (($obj->code ==
'0' || $obj->code ==
'' || preg_match(
'/unknown/i', $obj->code))) {
2316 } elseif ($obj->code ==
'RECEP') {
2319 } elseif ($obj->code ==
'EF0') {
2324 if ($id == DICT_TYPE_CONTAINER && $obj->module ==
'system') {
2327 if (in_array($obj->code, array(
'banner'))) {
2331 if (isset($obj->type) && in_array($obj->type, array(
'system',
'systemauto'))) {
2334 if (in_array(empty($obj->code) ?
'' : $obj->code, array(
'AC_OTH',
'AC_OTH_AUTO')) || in_array(empty($obj->
type) ?
'' : $obj->
type, array(
'systemauto'))) {
2338 $canbemodified = $iserasable;
2340 if (!empty($obj->code) && $obj->code ==
'RECEP') {
2343 if ($tabname[$id] ==
"c_actioncomm") {
2347 if ($tabname[$id] ==
"c_product_nature" && in_array($obj->code, array(0, 1))) {
2353 $rowidcol = empty($tabrowid[$id]) ?
'rowid' : $tabrowid[
$id];
2355 if (empty($rowidcol) || in_array($id, array(DICT_ACTIONCOMM, DICT_CHARGESOCIALES, DICT_TYPENT, DICT_PAIEMENT, DICT_TYPE_FEES, DICT_EFFECTIF, DICT_STCOMM, DICT_HRM_PUBLIC_HOLIDAY))) {
2356 $rowidcol =
'rowid';
2358 $url = $_SERVER[
"PHP_SELF"].
'?'.($page ?
'page='.$page.
'&' :
'').
'sortfield='.urlencode($sortfield).
'&sortorder='.urlencode($sortorder);
2359 $url .=
'&rowid='.(isset($obj->$rowidcol) ? ((int) $obj->$rowidcol) : (!empty($obj->code) ? urlencode($obj->code) :
''));
2360 $url .=
'&code='.(!empty($obj->code) ? urlencode($obj->code) :
'');
2361 if (!empty($param)) {
2365 if (!is_null($withentity)) {
2366 $url .=
'&entity='.((int) $withentity);
2372 print
'<tr class="oddeven" id="rowid-'.(empty($obj->rowid) ?
'' : $obj->rowid).
'">';
2376 print
'<td class="center maxwidthsearch nowraponall">';
2378 if ($canbemodified) {
2379 print
'<a class="reposition editfielda marginleftonly paddingleft marginrightonly paddingright" href="'.$url.
'action=edit&token='.
newToken().
'">'.
img_edit().
'</a>';
2384 print
'<a class="reposition marginleftonly paddingleft marginrightonly paddingright" href="'.$url.
'action=delete&token='.
newToken().
'">'.
img_delete().
'</a>';
2390 if ($action ==
'edit' && ($rowid == (!empty($obj->rowid) ? $obj->rowid : $obj->code))) {
2391 $tmpaction =
'edit';
2392 $parameters = array(
'fieldlist' => $fieldlist,
'tabname' => $tabname[$id]);
2393 $reshook = $hookmanager->executeHooks(
'editDictionaryFieldlist', $parameters, $obj, $tmpaction);
2394 $error = $hookmanager->error;
2395 $errors = $hookmanager->errors;
2398 if (empty($reshook)) {
2399 $withentity =
dictFieldList($fieldlist, $obj, $tabname[$id],
'edit');
2402 print
'<td colspan="3" class="center">';
2403 print
'<div name="'.(!empty($obj->rowid) ? $obj->rowid : $obj->code).
'"></div>';
2404 print
'<input type="hidden" name="page" value="'.dol_escape_htmltag((
string) $page).
'">';
2405 print
'<input type="hidden" name="rowid" value="'.dol_escape_htmltag($rowid).
'">';
2406 if (!is_null($withentity)) {
2407 print
'<input type="hidden" name="entity" value="'.$withentity.
'">';
2409 print
'<input type="submit" class="button button-edit smallpaddingimp" name="actionmodify" value="'.$langs->trans(
"Modify").
'">';
2410 print
'<input type="submit" class="button button-cancel smallpaddingimp" name="actioncancel" value="'.$langs->trans(
"Cancel").
'">';
2413 $tmpaction =
'view';
2414 $parameters = array(
'fieldlist' => $fieldlist,
'tabname' => $tabname[$id]);
2415 $reshook = $hookmanager->executeHooks(
'viewDictionaryFieldlist', $parameters, $obj, $tmpaction);
2417 $error = $hookmanager->error;
2418 $errors = $hookmanager->errors;
2420 $langs->loadLangs(array(
"bills",
"agenda",
"propal"));
2422 if (empty($reshook)) {
2425 foreach ($fieldlist as $field => $value) {
2429 $valuetoshow = empty($obj->$value) ?
'' : $obj->$value;
2432 if ($value ==
'entity') {
2433 $withentity = $valuetoshow;
2438 if ($value ==
'code' && $id == DICT_PRODUCT_NATURE) {
2439 $valuetoshow = (int) $valuetoshow;
2440 } elseif ($value ==
'element') {
2441 $valuetoshow = isset($elementList[$valuetoshow]) ? $elementList[$valuetoshow] : $valuetoshow;
2442 } elseif ($value ==
'source') {
2443 $valuetoshow = isset($sourceList[$valuetoshow]) ? $sourceList[$valuetoshow] : $valuetoshow;
2444 } elseif ($valuetoshow ==
'all') {
2445 $valuetoshow = $langs->trans(
'All');
2446 } elseif ($value ==
'country') {
2447 if (empty($obj->country_code)) {
2450 $key = $langs->trans(
"Country".strtoupper($obj->country_code));
2451 $valuetoshow = ($key !=
"Country".strtoupper($obj->country_code) ? $obj->country_code.
" - ".$key : $obj->country);
2453 } elseif ($value ==
'recuperableonly' || $value ==
'deductible' || $value ==
'category_type') {
2454 $valuetoshow =
yn($valuetoshow ? 1 : 0);
2456 } elseif ($value ==
'type_cdr') {
2457 if (empty($valuetoshow)) {
2458 $valuetoshow = $langs->trans(
'None');
2459 } elseif ($valuetoshow == 1) {
2460 $valuetoshow = $langs->trans(
'AtEndOfMonth');
2461 } elseif ($valuetoshow == 2) {
2462 $valuetoshow = $langs->trans(
'CurrentNext');
2464 $class =
"center tdoverflowmax125";
2465 } elseif ($value ==
'price' || preg_match(
'/^amount/i', $value)) {
2466 $valuetoshow =
price($valuetoshow);
2468 if (in_array($value, array(
'private',
'joinfile',
'use_default'))) {
2470 $valuetoshow =
yn($valuetoshow);
2472 } elseif ($value ==
'libelle_facture') {
2473 $key = $langs->trans(
"PaymentCondition".strtoupper($obj->code));
2474 $valuetoshow = ($obj->code && $key !=
"PaymentCondition".strtoupper($obj->code) ? $key : $obj->$value);
2475 $valuetoshow = nl2br($valuetoshow);
2476 $titletoshow = $valuetoshow;
2477 $class =
'small tdoverflowmax200';
2478 } elseif ($value ==
'label' && $tabname[$id] ==
'c_country') {
2479 $key = $langs->trans(
"Country".strtoupper($obj->code));
2480 $valuetoshow = ($obj->code && $key !=
"Country".strtoupper($obj->code) ? $key : $obj->$value);
2481 } elseif ($value ==
'label' && $tabname[$id] ==
'c_availability') {
2482 $key = $langs->trans(
"AvailabilityType".strtoupper($obj->code));
2483 $valuetoshow = ($obj->code && $key !=
"AvailabilityType".strtoupper($obj->code) ? $key : $obj->$value);
2484 } elseif ($value ==
'libelle' && $tabname[$id] ==
'c_actioncomm') {
2485 $key = $langs->trans(
"Action".strtoupper($obj->code));
2486 $valuetoshow = ($obj->code && $key !=
"Action".strtoupper($obj->code) ? $key : $obj->$value);
2487 } elseif (!empty($obj->code_iso) && $value ==
'label' && $tabname[$id] ==
'c_currencies') {
2488 $key = $langs->trans(
"Currency".strtoupper($obj->code_iso));
2489 $valuetoshow = ( $key !=
"Currency".strtoupper($obj->code_iso) ? $key : $obj->$value);
2490 } elseif ($value ==
'libelle' && $tabname[$id] ==
'c_typent') {
2491 $key = $langs->trans(strtoupper($obj->code));
2492 $valuetoshow = ($key != strtoupper($obj->code) ? $key : $obj->$value);
2493 } elseif ($value ==
'libelle' && $tabname[$id] ==
'c_prospectlevel') {
2494 $key = $langs->trans(strtoupper($obj->code));
2495 $valuetoshow = ($key != strtoupper($obj->code) ? $key : $obj->$value);
2496 } elseif ($value ==
'label' && $tabname[$id] ==
'c_civility') {
2497 $key = $langs->trans(
"Civility".strtoupper($obj->code));
2498 $valuetoshow = ($obj->code && $key !=
"Civility".strtoupper($obj->code) ? $key : $obj->$value);
2499 } elseif ($value ==
'libelle' && $tabname[$id] ==
'c_type_contact') {
2500 $key = $langs->trans(
"TypeContact_".$obj->element.
"_".$obj->source.
"_".strtoupper($obj->code));
2501 $valuetoshow = ($obj->code && $key !=
"TypeContact_".$obj->element.
"_".$obj->source.
"_".strtoupper($obj->code) ? $key : $obj->$value);
2502 } elseif ($value ==
'libelle' && $tabname[$id] ==
'c_payment_term') {
2503 $key = $langs->trans(
"PaymentConditionShort".strtoupper($obj->code));
2504 $valuetoshow = ($obj->code && $key !=
"PaymentConditionShort".strtoupper($obj->code) ? $key : $obj->$value);
2505 $titletoshow = $key;
2506 $class =
"tdoverflowmax150";
2507 } elseif ($value ==
'libelle' && $tabname[$id] ==
'c_paiement') {
2508 $key = $langs->trans(
"PaymentType".strtoupper($obj->code));
2509 $valuetoshow = $obj->$value;
2510 if ($obj->code && array_key_exists(
"PaymentType".strtoupper($obj->code), $langs->tab_translate)) {
2511 $htmltext = $form->textwithpicto($langs->trans(
"TranslationFound").
': '.$key, $langs->trans(
"TheTranslationIsSearchedFromKey",
"PaymentType".strtoupper($obj->code)));
2513 $htmltext = $form->textwithpicto($langs->trans(
"TranslationFound").
': '.$langs->trans(
"No"), $langs->trans(
"TheTranslationIsSearchedFromKey",
"PaymentType".strtoupper($obj->code)));
2516 $valuetoshow .=
'<br><span class="opacitymedium small">'.$htmltext.
'</span>';
2517 } elseif ($value ==
'type' && $tabname[$id] ==
'c_paiement') {
2518 $payment_type_list = array(0 => $langs->trans(
'PaymentTypeCustomer'), 1 => $langs->trans(
'PaymentTypeSupplier'), 2 => $langs->trans(
'PaymentTypeBoth'));
2519 $valuetoshow = $payment_type_list[$valuetoshow];
2520 } elseif ($value ==
'label' && $tabname[$id] ==
'c_input_reason') {
2521 $key = $langs->trans(
"DemandReasonType".strtoupper($obj->code));
2522 $valuetoshow = ($obj->code && $key !=
"DemandReasonType".strtoupper($obj->code) ? $key : $obj->$value);
2523 } elseif ($value ==
'libelle' && $tabname[$id] ==
'c_input_method') {
2524 $langs->load(
"orders");
2525 $key = $langs->trans($obj->code);
2526 $valuetoshow = ($obj->code && $key != $obj->code) ? $key : $obj->$value;
2527 } elseif ($value ==
'libelle' && $tabname[$id] ==
'c_shipment_mode') {
2528 $langs->load(
"sendings");
2529 $key = $langs->trans(
"SendingMethod".strtoupper($obj->code));
2530 $valuetoshow = ($obj->code && $key !=
"SendingMethod".strtoupper($obj->code) ? $key : $obj->$value);
2531 } elseif ($value ==
'libelle' && $tabname[$id] ==
'c_paper_format') {
2532 $key = $langs->trans(
'PaperFormat'.strtoupper($obj->code));
2533 $valuetoshow = ($obj->code && $key !=
'PaperFormat'.strtoupper($obj->code) ? $key : $obj->$value);
2534 } elseif ($value ==
'label' && $tabname[$id] ==
'c_type_fees') {
2535 $langs->load(
'trips');
2536 $key = $langs->trans(strtoupper($obj->code));
2537 $valuetoshow = ($obj->code && $key != strtoupper($obj->code) ? $key : $obj->$value);
2538 } elseif ($value ==
'region_id' || $value ==
'country_id' || $value ==
'department_buyer_id') {
2540 } elseif ($value ==
'unicode') {
2541 $valuetoshow = $langs->getCurrencySymbol($obj->code, 1);
2542 } elseif ($value ==
'label' && $tabname[
GETPOSTINT(
"id")] ==
'c_units') {
2543 $langs->load(
"products");
2544 $valuetoshow = $langs->trans($obj->$value);
2545 } elseif ($value ==
'short_label' && $tabname[
GETPOSTINT(
"id")] ==
'c_units') {
2546 $langs->load(
"products");
2547 $valuetoshow = $langs->trans($obj->$value);
2548 } elseif (($value ==
'unit') && ($tabname[$id] ==
'c_paper_format')) {
2549 $key = $langs->trans(
'SizeUnit'.strtolower($obj->unit));
2550 $valuetoshow = ($obj->code && $key !=
'SizeUnit'.strtolower($obj->unit) ? $key : $obj->$value);
2551 } elseif ($value ==
'localtax1' || $value ==
'localtax2') {
2553 } elseif ($value ==
'type_vat') {
2554 $valuetoshow = $type_vatList[(int) $valuetoshow];
2556 } elseif ($value ==
'localtax1_type') {
2557 if ($obj->localtax1 != 0) {
2558 $valuetoshow = $localtax_typeList[$valuetoshow];
2563 } elseif ($value ==
'localtax2_type') {
2564 if ($obj->localtax2 != 0) {
2565 $valuetoshow = $localtax_typeList[$valuetoshow];
2570 } elseif ($value ==
'taux') {
2571 $valuetoshow =
price($valuetoshow, 0, $langs, 0, 0);
2573 } elseif (in_array($value, array(
'recuperableonly'))) {
2575 } elseif ($value ==
'accountancy_code' || $value ==
'accountancy_code_sell' || $value ==
'accountancy_code_buy') {
2576 if (isModEnabled(
'accounting')) {
2577 require_once DOL_DOCUMENT_ROOT.
'/accountancy/class/accountingaccount.class.php';
2579 $tmpaccountingaccount->fetch(0, $valuetoshow, 1);
2580 $titletoshow = $langs->transnoentitiesnoconv(
"Pcgtype").
': '.$tmpaccountingaccount->pcg_type;
2583 } elseif ($value ==
'fk_tva') {
2584 if (empty($form->cache_vatrates)) {
2585 $form->load_tva(
'cache_fk_tva',
'', $mysoc,
new Societe($db), 0, 0,
'',
false, -1);
2587 foreach ($form->cache_vatrates as $key => $Tab) {
2588 if ($form->cache_vatrates[$key][
'rowid'] == $valuetoshow) {
2589 $valuetoshow = $form->cache_vatrates[$key][
'label'];
2593 } elseif ($value ==
'fk_c_exp_tax_cat') {
2594 $tmpid = $valuetoshow;
2596 $valuetoshow = $langs->trans($valuetoshow ? $valuetoshow : $tmpid);
2597 } elseif ($tabname[$id] ==
'c_exp_tax_cat') {
2598 $valuetoshow = $langs->trans($valuetoshow);
2599 } elseif ($value ==
'label' && $tabname[$id] ==
'c_units') {
2600 $langs->load(
'other');
2601 $key = $langs->trans($obj->label);
2602 $valuetoshow = ($obj->label && $key != strtoupper($obj->label) ? $key : $obj->{$value});
2603 } elseif ($value ==
'label' && $tabname[$id] ==
'c_product_nature') {
2604 $langs->load(
"products");
2605 $valuetoshow = $langs->trans($obj->{$value});
2606 } elseif ($fieldlist[$field] ==
'label' && $tabname[$id] ==
'c_productbatch_qcstatus') {
2607 $langs->load(
"productbatch");
2608 $valuetoshow = $langs->trans($obj->{$value});
2609 } elseif ($value ==
'block_if_negative') {
2610 $valuetoshow =
yn($obj->{$value});
2611 } elseif ($value ==
'icon') {
2612 $valuetoshow = $obj->{$value}.
" ".
img_picto(
"", preg_replace(
'/^fa-/',
'', $obj->{$value}));
2613 } elseif ($value ==
'type_duration') {
2614 $TDurationTypes = array(
'y' => $langs->trans(
'Years'),
'm' => $langs->trans(
'Month'),
'w' => $langs->trans(
'Weeks'),
'd' => $langs->trans(
'Days'),
'h' => $langs->trans(
'Hours'),
'i' => $langs->trans(
'Minutes'));
2615 if (!empty($obj->{$value}) && array_key_exists($obj->{$value}, $TDurationTypes)) {
2616 $valuetoshow = $TDurationTypes[$obj->{$value}];
2620 $class .= ($class ?
' ' :
'').
'tddict';
2621 if ($value ==
'name') {
2622 $class .=
' tdoverflowmax200';
2624 if ($value ==
'note' && $id == DICT_TVA) {
2625 $class .=
' tdoverflowmax200';
2627 if ($value ==
'tracking') {
2628 $class .=
' tdoverflowauto';
2630 if (in_array($value, array(
'nbjour',
'decalage',
'pos',
'position',
'deposit_percent'))) {
2633 if (in_array($value, array(
'icon',
'type_vat',
'localtax1_type',
'localtax2_type'))) {
2634 $class .=
' nowraponall';
2636 if (in_array($value, array(
'use_default',
'fk_parent',
'sortorder'))) {
2637 $class .=
' center';
2639 if ($value ==
'public') {
2640 $class .=
' center';
2642 if (in_array($value, array(
'localtax1_type',
'localtax2_type',
'note',
'note_public',
'note_private'))) {
2647 print
'<!-- field value '. $value .
' --><td class="'.$class.
'"'.($titletoshow ?
' title="'.dolPrintHTMLForAttribute($titletoshow).
'"' :
'').
'>'.$valuetoshow.
'</td>';
2653 if ($id == DICT_COUNTRY) {
2654 print
'<td class="nowraponall center">';
2657 print
'<a class="reposition" href="'.$url.
'action='.$acts[$obj->eec].
'_eec&token='.
newToken().
'">'.$actl[$obj->eec].
'</a>';
2659 print
'<span class="opacitymedium">'.$langs->trans(
"AlwaysActive").
'</span>';
2662 print
'<td class="nowraponall center">';
2665 print
'<a class="reposition" href="'.$url.
'action='.$acts[$obj->sepa].
'_sepa&token='.
newToken().
'">'.$actl[$obj->sepa].
'</a>';
2667 print
'<span class="opacitymedium">'.$langs->trans(
"AlwaysActive").
'</span>';
2670 print
'<td class="nowraponall center">';
2673 print
'<a class="reposition" href="'.$url.
'action='.$acts[$obj->favorite].
'_favorite&token='.
newToken().
'">'.$actl[$obj->favorite].
'</a>';
2675 print
'<span class="opacitymedium">'.$langs->trans(
"AlwaysActive").
'</span>';
2682 print
'<td class="nowraponall center">';
2683 if ($canbedisabled) {
2684 print
'<a class="reposition" href="'.$url.
'action='.$acts[$obj->active].
'&token='.
newToken().
'">'.$actl[$obj->active].
'</a>';
2686 if (in_array($obj->code, array(
'AC_OTH',
'AC_OTH_AUTO'))) {
2687 print $langs->trans(
"AlwaysActive");
2688 } elseif (isset($obj->type) && in_array($obj->type, array(
'systemauto')) && empty($obj->active)) {
2689 print $langs->trans(
"Deprecated");
2690 } elseif (isset($obj->type) && in_array($obj->type, array(
'system')) && !empty($obj->active) && $obj->code !=
'AC_OTH') {
2691 print $langs->trans(
"UsedOnlyWithTypeOption");
2693 print
'<span class="opacitymedium">'.$langs->trans(
"AlwaysActive").
'</span>';
2700 print
'<td class="center maxwidthsearch nowraponall">';
2702 if ($canbemodified) {
2703 print
'<a class="reposition marginleftonly paddingleft marginrightonly paddingright editfielda" href="'.$url.
'action=edit&token='.
newToken().
'">'.
img_edit().
'</a>';
2708 print
'<a class="reposition marginleftonly paddingleft marginrightonly paddingright" href="'.$url.
'action=delete&token='.
newToken().
'">'.
img_delete().
'</a>';
2719 print
'<tr><td colspan="'.$colspan.
'"><span class="opacitymedium">'.$langs->trans(
"NoRecordFound").
'</span></td></tr>';
2735 print
'<span class="opacitymedium">'.$langs->trans(
"DictionaryDesc");
2736 print
" ".$langs->trans(
"OnlyActiveElementsAreShown").
"<br>\n";
2737 print
'</span><br>';
2740 $lastlineisempty =
false;
2742 print
'<div class="div-table-responsive-no-min">';
2743 print
'<table class="noborder centpercent">';
2744 print
'<tr class="liste_titre">';
2745 print
'<td>'.$langs->trans(
"Dictionary").
'</td>';
2747 print
'<td class="hideonsmartphone"></td>';
2750 $showemptyline =
'';
2751 foreach ($taborder as $i) {
2752 if (isset($tabname[$i]) && empty($tabcond[$i])) {
2757 if ($showemptyline) {
2758 print
'<tr class="oddeven"><td></td><td></td><td class="hideonsmartphone"></td></tr>';
2763 $value = $tabname[$i];
2764 print
'<tr class="oddeven"><td class="minwidth200">';
2765 if (!empty($tabcond[$i])) {
2766 $tabnamenoprefix = preg_replace(
'/'.MAIN_DB_PREFIX.
'/',
'', $tabname[$i]);
2767 print
'<a href="'.$_SERVER[
"PHP_SELF"].
'?id='.$i;
2768 if ($i == DICT_CHARGESOCIALES) {
2769 print
'&search_country_id='.$mysoc->country_id;
2772 if (!empty($tabcomplete[$tabnamenoprefix][
'picto'])) {
2773 print
img_picto(
'', $tabcomplete[$tabnamenoprefix][
'picto'],
'class="pictofixedwidth paddingrightonly"');
2775 print $langs->trans($tablib[$i]);
2778 print $langs->trans($tablib[$i]);
2782 print
'<a class="editfielda" href="'.$_SERVER[
"PHP_SELF"].
'?id='.$i.
'">';
2786 print
'<td class="right hideonsmartphone">';
2787 print $form->textwithpicto(
'', $langs->trans(
"Table").
': '.MAIN_DB_PREFIX.$tabname[$i]);
2790 $lastlineisempty =
false;
2792 if (!$lastlineisempty) {
2794 $lastlineisempty =
true;
2822 global $langs, $db, $mysoc;
2825 global $elementList, $sourceList, $localtax_typeList, $type_vatList;
2833 foreach ($fieldlist as $field => $value) {
2834 if ($value ==
'entity' && isset($obj->$value)) {
2835 $withentity = $obj->$value;
2839 if (in_array($value, array(
'code',
'libelle',
'type')) && $tabname ==
"c_actioncomm" && isset($obj->$value) && in_array($obj->type, array(
'system',
'systemauto'))) {
2841 $hidden = (!empty($obj->{$value}) ? $obj->{$value} :
'');
2843 print
'<input type="hidden" name="'. $value .
'" value="'.$hidden.
'">';
2844 print $langs->trans($hidden);
2846 } elseif ($value ==
'country') {
2847 if (in_array(
'region_id', $fieldlist)) {
2854 $selected = (!empty($obj->country_code) ? $obj->country_code : (!empty($obj->country) ? $obj->country :
''));
2855 if (!GETPOSTISSET(
'code')) {
2856 $selected =
GETPOST(
'countryidforinsert');
2858 print $form->select_country($selected, $value,
'', 28,
'minwidth100 maxwidth150 maxwidthonsmartphone');
2860 } elseif ($value ==
'country_id') {
2861 if (!in_array(
'country', $fieldlist)) {
2862 $country_id = (!empty($obj->{$value}) ? $obj->{$value} : 0);
2863 print
'<td class="tdoverflowmax100">';
2864 print
'<input type="hidden" name="'. $value .
'" value="'.$country_id.
'">';
2867 } elseif ($value ==
'region') {
2869 $formcompany->select_region($region_id,
'region');
2871 } elseif ($value ==
'region_id') {
2872 $region_id = (!empty($obj->{$value}) ? $obj->{$value} : 0);
2874 print
'<input type="hidden" name="'. $value .
'" value="'.$region_id.
'">';
2876 } elseif ($value ==
'department_buyer') {
2878 print
'<td class="nowraponall">';
2880 $country_code = (!empty($obj->country_code) ? $obj->country_code :
'');
2881 $department_buyer_id = (!empty($obj->department_buyer_id) ? (int) $obj->department_buyer_id : 0);
2882 if ($country_code !=
'') {
2883 print $formcompany->select_state($department_buyer_id, $country_code,
'department_buyer_id',
'minwidth100 maxwidth150 maxwidthonsmartphone');
2887 } elseif ($value ==
'department_buyer_id') {
2888 if (!in_array(
'department_buyer', $fieldlist)) {
2889 $department_buyer_id = (!empty($obj->{$value}) ? $obj->{$value} : 0);
2890 print
'<td class="tdoverflowmax100">';
2891 print
'<input type="hidden" name="'.$value.
'" value="'.$department_buyer_id.
'">';
2894 } elseif ($value ==
'lang') {
2898 } elseif (in_array($value, array(
'element',
'source'))) {
2899 $tmparray = array();
2900 if ($value ==
'element') {
2901 $tmparray = $elementList;
2903 $tmparray = $sourceList;
2906 print $form->selectarray($value, $tmparray, (!empty($obj->{$value}) ? $obj->{$value} :
''), 0, 0, 0,
'', 0, 0, 0,
'',
'maxwidth250');
2908 } elseif (in_array($value, array(
'public',
'use_default'))) {
2910 print
'<td class="center">';
2912 print $form->selectyesno($value, (!empty($obj->{$value}) ? $obj->{$value} :
''), 1);
2914 } elseif ($value ==
'private') {
2917 print $form->selectyesno(
"private", (!empty($obj->{$value}) ? $obj->{$value} :
''));
2919 } elseif ($value ==
'type' && $tabname ==
"c_actioncomm") {
2920 $type = (!empty($obj->type) ? $obj->type :
'user');
2922 print $type.
'<input type="hidden" name="type" value="'.$type.
'">';
2924 } elseif ($value ==
'type' && $tabname ==
'c_paiement') {
2926 $select_list = array(0 => $langs->trans(
'PaymentTypeCustomer'), 1 => $langs->trans(
'PaymentTypeSupplier'), 2 => $langs->trans(
'PaymentTypeBoth'));
2927 print $form->selectarray($value, $select_list, (!empty($obj->{$value}) ? $obj->{$value} :
'2'));
2929 } elseif ($value ==
'recuperableonly' || $value ==
'type_cdr' || $value ==
'deductible' || $value ==
'category_type') {
2930 if ($value ==
'type_cdr') {
2931 print
'<td class="center">';
2935 if ($value ==
'type_cdr') {
2936 print $form->selectarray($value, array(0 => $langs->trans(
'None'), 1 => $langs->trans(
'AtEndOfMonth'), 2 => $langs->trans(
'CurrentNext')), (!empty($obj->{$value}) ? $obj->{$value} :
''));
2939 print $form->selectyesno($value, (!empty($obj->{$value}) ? $obj->{$value} :
''), 1);
2942 } elseif (in_array($value, array(
'nbjour',
'decalage',
'taux',
'localtax1',
'localtax2'))) {
2944 if (in_array($value, array(
'taux',
'localtax1',
'localtax2'))) {
2947 print
'<td class="'.$class.
'">';
2948 print
'<input type="text" class="flat" value="'.(isset($obj->{$value}) ? $obj->{$value} :
'').
'" size="3" name="'. $value .
'">';
2950 } elseif (in_array($value, array(
'libelle_facture'))) {
2955 if ($tabname ==
'c_payment_term') {
2956 $langs->load(
"bills");
2957 if (isset($obj->code) && !empty($obj->code)) {
2958 $transkey =
"PaymentCondition" . strtoupper($obj->code);
2959 if ($langs->trans($transkey) != $transkey) {
2961 print $form->textwithpicto($langs->trans($transkey), $langs->trans(
"GoIntoTranslationMenuToChangeThis"));
2966 print
'<textarea cols="30" rows="'.ROWS_2.
'" class="flat" name="'. $value .
'">'.(empty($obj->{$value}) ?
'' : $obj->{$value}).
'</textarea>';
2968 print
'<input type="hidden" name="'. $value .
'" value="'.$transkey.
'">';
2971 } elseif ($value ==
'price' || preg_match(
'/^amount/i', (
string) $value)) {
2972 print
'<td><input type="text" class="flat minwidth75" value="'.price((!empty($obj->{$value}) ? $obj->{$value} :
'')).
'" name="'. $value .
'"></td>';
2973 } elseif ($value ==
'code' && isset($obj->{$value})) {
2975 if ($tabname ==
'c_paiement' && in_array($obj->{$value}, array(
'LIQ',
'CB',
'CHQ',
'VIR'))) {
2977 print
'<input type="hidden" class="flat minwidth75 maxwidth100" value="'.(empty($obj->{$value}) ?
'' : $obj->{$value}).
'" name="'. $value .
'">';
2978 print $obj->{$value};
2980 print
'<input type="text" class="flat minwidth75 maxwidth100" value="'.(empty($obj->{$value}) ?
'' : $obj->{$value}).
'" name="'. $value .
'">';
2983 } elseif ($value ==
'unit') {
2986 'mm' => $langs->trans(
'SizeUnitmm'),
2987 'cm' => $langs->trans(
'SizeUnitcm'),
2988 'point' => $langs->trans(
'SizeUnitpoint'),
2989 'inch' => $langs->trans(
'SizeUnitinch')
2991 print $form->selectarray(
'unit', $units, (empty($obj->{$value}) ?
'' : $obj->{$value}), 0, 0, 0);
2993 } elseif ($value ==
'type_vat') {
2995 print
'<td class="center">';
2996 print $form->selectarray($value, $type_vatList, (empty($obj->{$value}) ?
'0' : $obj->{$value}));
2998 } elseif ($value ==
'localtax1_type' || $value ==
'localtax2_type') {
3000 print
'<td class="center">';
3001 print $form->selectarray($value, $localtax_typeList, (empty($obj->{$value}) ?
'' : $obj->{$value}));
3003 } elseif ($value ==
'accountancy_code' || $value ==
'accountancy_code_sell' || $value ==
'accountancy_code_buy') {
3005 if (isModEnabled(
'accounting')) {
3006 $fieldname = $value;
3007 $accountancy_account = (empty($obj->$fieldname) ? 0 : $obj->$fieldname);
3008 print $formaccounting->select_account($accountancy_account,
'.'. $value, 1, array(), 1, 1,
'maxwidth125 maxwidthonsmartphone');
3010 $fieldname = $value;
3011 print
'<input type="text" class="flat minwidth100" value="'.(isset($obj->$fieldname) ? $obj->$fieldname :
'').
'" name="'. $value .
'">';
3014 } elseif ($value ==
'fk_tva') {
3016 print $form->load_tva(
'fk_tva', $obj->taux, $mysoc,
new Societe($db), 0, 0,
'',
false, -1);
3018 } elseif ($value ==
'fk_c_exp_tax_cat') {
3020 print $form->selectExpenseCategories($obj->fk_c_exp_tax_cat);
3022 } elseif ($value ==
'fk_range') {
3024 print $form->selectExpenseRanges($obj->fk_range);
3026 } elseif ($value ==
'block_if_negative') {
3028 print $form->selectyesno(
"block_if_negative", (empty($obj->block_if_negative) ?
'' : $obj->block_if_negative), 1);
3030 } elseif ($value ==
'type_duration') {
3032 print $form->selectTypeDuration(
'', (empty($obj->type_duration) ?
'' : $obj->type_duration), array(
'i',
'h'));
3035 $fieldValue = isset($obj->{$value}) ? $obj->{$value} :
'';
3039 if ($value ==
'sortorder') {
3040 $fieldlist[$field] =
'position';
3043 if ($fieldlist[$field] ==
'code') {
3044 $class =
'maxwidth100';
3046 if (in_array($fieldlist[$field], array(
'deposit_percent'))) {
3048 $class =
'maxwidth50 right';
3050 if (in_array($fieldlist[$field], array(
'pos',
'position'))) {
3052 $class =
'maxwidth50 right';
3054 if (in_array($fieldlist[$field], array(
'dayrule',
'day',
'month',
'year',
'use_default',
'affect',
'delay',
'public',
'sortorder',
'sens',
'category_type',
'fk_parent'))) {
3055 $class =
'maxwidth50 center';
3057 if (in_array($fieldlist[$field], array(
'use_default',
'public',
'fk_parent'))) {
3058 $classtd =
'center';
3060 if (in_array($fieldlist[$field], array(
'libelle',
'label',
'tracking'))) {
3061 $class =
'quatrevingtpercent';
3064 if ($fieldlist[$field] ==
'fk_parent') {
3065 if (empty($fieldValue)) {
3072 if (in_array($fieldlist[$field], array(
'libelle',
'label'))) {
3075 case 'c_email_senderprofile':
3076 case 'c_forme_juridique':
3077 case 'c_holiday_types':
3078 case 'c_payment_term':
3079 case 'c_transport_mode':
3080 $maxlength =
' maxlength="255"';
3082 case 'c_email_templates':
3083 $maxlength =
' maxlength="180"';
3085 case 'c_socialnetworks':
3086 $maxlength =
' maxlength="150"';
3089 $maxlength =
' maxlength="128"';
3093 print
'<td class="'.$classtd.
'">';
3096 if (in_array($fieldlist[$field], array(
'label',
'libelle'))) {
3098 if ($tabname ==
'c_civility' && !empty($obj->code)) {
3099 $transkey =
"Civility".strtoupper($obj->code);
3101 if ($tabname ==
'c_payment_term' && !empty($obj->code)) {
3102 $langs->load(
"bills");
3103 $transkey =
"PaymentConditionShort".strtoupper($obj->code);
3105 if ($transkey && $langs->trans($transkey) != $transkey) {
3107 print $form->textwithpicto($langs->trans($transkey), $langs->trans(
"GoIntoTranslationMenuToChangeThis"));
3111 print
'<input type="text" class="flat'.($class ?
' '.$class :
'').
'"'.($maxlength ?
' '.$maxlength :
'').
' value="'.
dol_escape_htmltag($fieldValue).
'" name="'.$fieldlist[$field].
'">';
3113 print
'<input type="hidden" name="'.$fieldlist[$field].
'" value="'.$transkey.
'">';
$id
Support class for third parties, contacts, members, users or resources.
if( $user->socid > 0) if(! $user->hasRight('accounting', 'chartofaccount')) $object
length_accountg($account)
Return General accounting account with defined length (used for product and miscellaneous)
complete_dictionary_with_modules(&$taborder, &$tabname, &$tablib, &$tabsql, &$tabsqlsort, &$tabfield, &$tabfieldvalue, &$tabfieldinsert, &$tabrowid, &$tabcond, &$tabhelp, &$tabcomplete)
Add external modules to list of dictionaries.
complete_elementList_with_modules(&$elementList)
Search external modules to complete the list of contact element.
llxFooter($comment='', $zone='private', $disabledoutputofmessages=0)
Empty footer.
if(!defined('NOREQUIRESOC')) if(!defined( 'NOREQUIRETRAN')) if(!defined('NOTOKENRENEWAL')) if(!defined( 'NOREQUIREMENU')) if(!defined('NOREQUIREHTML')) if(!defined( 'NOREQUIREAJAX')) llxHeader($head='', $title='', $help_url='', $target='', $disablejs=0, $disablehead=0, $arrayofjs='', $arrayofcss='', $morequerystring='', $morecssonbody='', $replacemainareaby='', $disablenofollow=0, $disablenoindex=0)
Empty header.
Class to manage accounting accounts.
Class to manage third parties objects (customers, suppliers, prospects...)
dictFieldList($fieldlist, $obj=null, $tabname='', $context='')
Show fields in insert/edit mode.
load_fiche_titre($title, $morehtmlright='', $picto='generic', $pictoisfullpath=0, $id='', $morecssontable='', $morehtmlcenter='')
Load a title with picto.
setEventMessages($mesg, $mesgs, $style='mesgs', $messagekey='', $noduplicate=0, $attop=0)
Set event messages in dol_events session object.
print_barre_liste($title, $page, $file, $options='', $sortfield='', $sortorder='', $morehtmlcenter='', $num=-1, $totalnboflines='', $picto='generic', $pictoisfullpath=0, $morehtmlright='', $morecss='', $limit=-1, $selectlimitsuffix=0, $hidenavigation=0, $pagenavastextinput=0, $morehtmlrightbeforearrow='')
Print a title with navigation controls for pagination.
img_help($usehelpcursor=1, $usealttitle=1)
Show help logo with cursor "?".
img_picto($titlealt, $picto, $moreatt='', $pictoisfullpath=0, $srconly=0, $notitle=0, $alt='', $morecss='', $marginleftonlyshort=2, $allowothertags=array())
Show picto whatever it's its name (generic function)
img_delete($titlealt='default', $other='class="pictodelete"', $morecss='')
Show delete logo.
GETPOSTINT($paramname, $method=0)
Return the value of a $_GET or $_POST supervariable, converted into integer.
dol_get_fiche_head($links=array(), $active='', $title='', $notab=0, $picto='', $pictoisfullpath=0, $morehtmlright='', $morecss='', $limittoshow=0, $moretabssuffix='', $dragdropfile=0, $morecssdiv='')
Show tabs of a record.
price2num($amount, $rounding='', $option=0)
Function that return a number with universal decimal format (decimal separator is '.
dolGetButtonTitle($label, $helpText='', $iconClass='fa fa-file', $url='', $id='', $status=1, $params=array())
Function dolGetButtonTitle : this kind of buttons are used in title in list.
dol_get_fiche_end($notab=0)
Return tab footer of a card.
natural_search($fields, $value, $mode=0, $nofirstand=0)
Generate natural SQL search string for a criteria (this criteria can be tested on one or several fiel...
price($amount, $form=0, $outlangs='', $trunc=1, $rounding=-1, $forcerounding=-1, $currency_code='')
Function to format a value into an amount for visual output Function used into PDF and HTML pages.
getDolGlobalInt($key, $default=0)
Return a Dolibarr global constant int value.
newToken()
Return the value of token currently saved into session with name 'newtoken'.
yn($yesno, $format=1, $color=0)
Return yes or no in current language.
getTitleFieldOfList($name, $thead=0, $file="", $field="", $begin="", $moreparam="", $moreattrib="", $sortfield="", $sortorder="", $prefix="", $disablesortlink=0, $tooltip='', $forcenowrapcolumntitle=0)
Get title line of an array.
GETPOST($paramname, $check='alphanohtml', $method=0, $filter=null, $options=null, $noreplace=0)
Return value of a param into GET or POST supervariable.
dol_print_error($db=null, $error='', $errors=null)
Displays error message system with all the information to facilitate the diagnosis and the escalation...
getDolGlobalString($key, $default='')
Return a Dolibarr global constant string value.
info_admin($text, $infoonimgalt=0, $nodiv=0, $admin='1', $morecss='hideonsmartphone', $textfordropdown='', $picto='')
Show information in HTML for admin users or standard users.
img_edit($titlealt='default', $float=0, $other='')
Show logo edit/modify fiche.
getDictionaryValue($tablename, $field, $id, $checkentity=false, $rowidfield='rowid')
Return the value of a filed into a dictionary for the record $id.
dol_syslog($message, $level=LOG_INFO, $ident=0, $suffixinfilename='', $restricttologhandler='', $logcontext=null)
Write log message into outputs.
getEntity($element, $shared=1, $currentobject=null)
Get list of entity id to use.
dol_escape_htmltag($stringtoescape, $keepb=0, $keepn=0, $noescapetags='', $escapeonlyhtmltags=0, $cleanalsojavascript=0)
Returns text escaped for inclusion in HTML alt or title or value tags, or into values of HTML input f...
$context
@method int call_trigger(string $triggerName, User $user)
if(preg_match('/(crypted|dolcrypt):/i', $dolibarr_main_db_pass)||!empty($dolibarr_main_db_encrypted_pass)) $conf db type
accessforbidden($message='', $printheader=1, $printfooter=1, $showonlymessage=0, $params=null)
Show a message to say access is forbidden and stop program.