225 lines
15 KiB
SQL
225 lines
15 KiB
SQL
ALTER TABLE `co_contratti` ADD `idsede` INT NOT NULL AFTER `idanagrafica`;
|
|
|
|
-- Imposto conto cassa per contanti e rimesse
|
|
UPDATE `co_pagamenti` SET `idconto_vendite` = (SELECT id FROM co_pianodeiconti3 WHERE descrizione = 'Cassa'), `idconto_acquisti` = (SELECT id FROM co_pianodeiconti3 WHERE descrizione = 'Cassa') WHERE `co_pagamenti`.`descrizione` = 'Contanti' OR `co_pagamenti`.`descrizione` LIKE 'Rimessa %';
|
|
|
|
-- Imposto conto banca per tutti i bonifici e ri.ba.
|
|
UPDATE `co_pagamenti` SET `idconto_vendite` = (SELECT id FROM co_pianodeiconti3 WHERE descrizione = 'Banca C/C'), `idconto_acquisti` = (SELECT id FROM co_pianodeiconti3 WHERE descrizione = 'Banca C/C') WHERE `co_pagamenti`.`descrizione` LIKE 'Bonifico %' OR `co_pagamenti`.`descrizione` LIKE 'Ri.Ba. %';
|
|
|
|
-- Indirizzo PEC
|
|
ALTER TABLE `an_anagrafiche` ADD `pec` VARCHAR(255) NOT NULL AFTER `email`;
|
|
|
|
-- ISO 3166-1 alpha-2 code per nazioni
|
|
ALTER TABLE `an_nazioni` ADD `iso2` VARCHAR(2) NOT NULL AFTER `nome`;
|
|
|
|
-- ISO 2 per ITALIA (https://it.wikipedia.org/wiki/ISO_3166-1_alpha-2)
|
|
UPDATE `an_nazioni` SET `iso2` = 'IT' WHERE `an_nazioni`.`nome` = 'ITALIA';
|
|
|
|
-- Aggiunto name per i filtri
|
|
ALTER TABLE `zz_group_module` ADD `name` VARCHAR(255) NOT NULL AFTER `idmodule`;
|
|
|
|
UPDATE `zz_group_module` SET `name` = 'Mostra interventi ai tecnici coinvolti' WHERE `zz_group_module`.`id` = 1;
|
|
UPDATE `zz_group_module` SET `name` = 'Mostra interventi ai clienti coinvolti' WHERE `zz_group_module`.`id` = 5;
|
|
|
|
-- Abilito plugin Pianificazione fatturazione in contratti
|
|
UPDATE `zz_plugins` SET `enabled` = '1' WHERE `zz_plugins`.`name` = 'Pianificazione fatturazione';
|
|
|
|
-- Abilito widget Rate contrattuali in dashboard
|
|
UPDATE `zz_widgets` SET `enabled` = '1' WHERE `zz_widgets`.`name` = 'Rate contrattuali';
|
|
|
|
-- Help text per i plugins
|
|
ALTER TABLE `zz_plugins` ADD `help` VARCHAR(255) NOT NULL AFTER `directory`;
|
|
|
|
-- Help text per plugin Ddt del cliente
|
|
UPDATE `zz_plugins` SET `help` = 'Righe ddt del cliente. I ddt senza righe non saranno visualizzati.' WHERE `zz_plugins`.`name` = 'Ddt del cliente';
|
|
|
|
-- Creazione tablla per modelli primanota
|
|
CREATE TABLE IF NOT EXISTS `co_movimenti_modelli` (
|
|
`id` int(11) NOT NULL,
|
|
`idmastrino` int(11) NOT NULL,
|
|
`descrizione` text NOT NULL,
|
|
`idconto` int(11) NOT NULL
|
|
);
|
|
|
|
ALTER TABLE `co_movimenti_modelli` ADD PRIMARY KEY (`id`);
|
|
|
|
ALTER TABLE `co_movimenti_modelli` MODIFY `id` int(11) NOT NULL AUTO_INCREMENT;
|
|
|
|
-- Modulo modelli prima nota
|
|
INSERT INTO `zz_modules` (`id`, `name`, `title`, `directory`, `options`, `options2`, `icon`, `version`, `compatibility`, `order`, `parent`, `default`, `enabled`) VALUES (NULL, 'Modelli prima nota', 'Modelli prima nota', 'modelli_primanota', 'SELECT |select| FROM `co_movimenti_modelli` WHERE 1=1 GROUP BY `idmastrino` HAVING 2=2', '', 'fa fa-angle-right', '2.4.1', '2.4.1', '1', '40', '1', '1');
|
|
|
|
INSERT INTO `zz_views` (`id`, `id_module`, `name`, `query`, `order`, `search`, `slow`, `format`, `search_inside`, `order_by`, `enabled`, `summable`, `default`) VALUES (NULL, (SELECT id FROM zz_modules WHERE name='Modelli prima nota'), 'id', 'co_movimenti_modelli.id', '0', '1', '0', '0', NULL, NULL, '0', '0', '1');
|
|
INSERT INTO `zz_views` (`id`, `id_module`, `name`, `query`, `order`, `search`, `slow`, `format`, `search_inside`, `order_by`, `enabled`, `summable`, `default`) VALUES (NULL, (SELECT id FROM zz_modules WHERE name='Modelli prima nota'), 'Causale predefinita', 'co_movimenti_modelli.descrizione', '1', '1', '0', '0', NULL, NULL, '1', '0', '1');
|
|
|
|
INSERT INTO `zz_group_view` (`id_gruppo`, `id_vista`) VALUES
|
|
(1, (SELECT id FROM `zz_views` WHERE id_module=(SELECT id FROM zz_modules WHERE name='Modelli prima nota') AND name='id' )),
|
|
(1, (SELECT id FROM `zz_views` WHERE id_module=(SELECT id FROM zz_modules WHERE name='Modelli prima nota') AND name='Causale predefinita' )),
|
|
(2, (SELECT id FROM `zz_views` WHERE id_module=(SELECT id FROM zz_modules WHERE name='Modelli prima nota') AND name='id' )),
|
|
(2, (SELECT id FROM `zz_views` WHERE id_module=(SELECT id FROM zz_modules WHERE name='Modelli prima nota') AND name='Causale predefinita' )),
|
|
(3, (SELECT id FROM `zz_views` WHERE id_module=(SELECT id FROM zz_modules WHERE name='Modelli prima nota') AND name='id' )),
|
|
(3, (SELECT id FROM `zz_views` WHERE id_module=(SELECT id FROM zz_modules WHERE name='Modelli prima nota') AND name='Causale predefinita' )),
|
|
(4, (SELECT id FROM `zz_views` WHERE id_module=(SELECT id FROM zz_modules WHERE name='Modelli prima nota') AND name='id' )),
|
|
(4, (SELECT id FROM `zz_views` WHERE id_module=(SELECT id FROM zz_modules WHERE name='Modelli prima nota') AND name='Causale predefinita' ));
|
|
|
|
|
|
-- Widget per stampa calendario
|
|
INSERT INTO `zz_widgets` (`id`, `name`, `type`, `id_module`, `location`, `class`, `query`, `bgcolor`, `icon`, `print_link`, `more_link`, `more_link_type`, `php_include`, `text`, `enabled`, `order`, `help` ) VALUES (NULL, 'Stampa calendario', 'print', '1', 'controller_top', 'col-md-12', NULL, '#4ccc4c', 'fa fa-print', '', './modules/dashboard/widgets/stampa_calendario.dashboard.php', 'popup', '', 'Stampa calendario', '1', '7', NULL);
|
|
|
|
-- Stampa calendario
|
|
INSERT INTO `zz_prints` (`id`, `id_module`, `is_record`, `name`, `title`, `directory`, `previous`, `options`, `icon`, `version`, `compatibility`, `order`, `main`, `default`, `enabled`) VALUES (NULL, '1', '1', 'Stampa calendario', 'Stampa calendario', 'dashboard', '', '', 'fa fa-print', '', '', '0', '1', '1', '1');
|
|
|
|
-- Rimosso group by nome banche
|
|
UPDATE `zz_modules` SET `options` = 'SELECT |select| FROM `co_banche` WHERE 1=1 AND deleted = 0 HAVING 2=2' WHERE `zz_modules`.`name` = 'Banche';
|
|
|
|
|
|
-- impianti per pianificazione contratti
|
|
ALTER TABLE `co_righe_contratti` ADD `idimpianti` VARCHAR(255) NOT NULL AFTER `idsede`;
|
|
|
|
|
|
-- Struttura della tabella `co_righe_contratti_materiali`
|
|
CREATE TABLE IF NOT EXISTS `co_righe_contratti_materiali` (
|
|
`id` int(11) NOT NULL AUTO_INCREMENT,
|
|
`descrizione` varchar(255) NOT NULL,
|
|
`qta` float(12,4) NOT NULL,
|
|
`um` varchar(25) NOT NULL,
|
|
`prezzo_vendita` decimal(12,4) NOT NULL,
|
|
`prezzo_acquisto` decimal(12,4) NOT NULL,
|
|
`idiva` int(11) NOT NULL,
|
|
`desc_iva` varchar(255) NOT NULL,
|
|
`iva` decimal(12,4) NOT NULL,
|
|
`id_riga_contratto` int(11) DEFAULT NULL,
|
|
`sconto` decimal(12,4) NOT NULL,
|
|
`sconto_unitario` decimal(12,4) NOT NULL,
|
|
`tipo_sconto` enum('UNT','PRC') NOT NULL DEFAULT 'UNT',
|
|
PRIMARY KEY (`id`),
|
|
KEY `id_riga_contratto` (`id_riga_contratto`)
|
|
);
|
|
|
|
|
|
-- Struttura della tabella `co_righe_contratti_articoli`
|
|
CREATE TABLE IF NOT EXISTS `co_righe_contratti_articoli` (
|
|
`id` int(11) NOT NULL AUTO_INCREMENT,
|
|
`idarticolo` int(11) NOT NULL,
|
|
`id_riga_contratto` int(11) DEFAULT NULL,
|
|
`descrizione` varchar(255) NOT NULL,
|
|
`prezzo_acquisto` decimal(12,4) NOT NULL,
|
|
`prezzo_vendita` decimal(12,4) NOT NULL,
|
|
`sconto` decimal(12,4) NOT NULL,
|
|
`sconto_unitario` decimal(12,4) NOT NULL,
|
|
`tipo_sconto` enum('UNT','PRC') NOT NULL DEFAULT 'UNT',
|
|
`idiva` int(11) NOT NULL,
|
|
`desc_iva` varchar(255) NOT NULL,
|
|
`iva` decimal(12,4) NOT NULL,
|
|
`idautomezzo` int(11) NOT NULL,
|
|
`qta` decimal(10,2) NOT NULL,
|
|
`um` varchar(20) NOT NULL,
|
|
`abilita_serial` tinyint(1) NOT NULL DEFAULT '0',
|
|
`idimpianto` int(11) DEFAULT NULL,
|
|
PRIMARY KEY (`id`),
|
|
KEY `id_riga_contratto` (`id_riga_contratto`),
|
|
KEY `idimpianto` (`idimpianto`)
|
|
);
|
|
|
|
|
|
-- Modifica query wiget per mostrare solo quelli che non sono stati rinnovati
|
|
UPDATE `zz_widgets` SET `query` = 'SELECT COUNT(id) AS dato, co_contratti.id, DATEDIFF( data_conclusione, NOW() ) AS giorni_rimanenti FROM co_contratti WHERE idstato IN(SELECT id FROM co_staticontratti WHERE fatturabile = 1) AND rinnovabile=1 AND NOW() > DATE_ADD( data_conclusione, INTERVAL - ABS(giorni_preavviso_rinnovo) DAY) AND YEAR(data_conclusione) > 1970 HAVING ISNULL((SELECT id FROM co_contratti contratti WHERE contratti.idcontratto_prev=co_contratti.id )) ORDER BY giorni_rimanenti ASC' WHERE `zz_widgets`.`name` = 'Contratti in scadenza';
|
|
|
|
-- Aggiunto campo data su movimenti articoli
|
|
ALTER TABLE `mg_movimenti` ADD `data` DATE NOT NULL AFTER `movimento`;
|
|
|
|
-- Campo per identificare i movimenti manuali
|
|
ALTER TABLE `mg_movimenti` ADD `manuale` TINYINT(1) NOT NULL AFTER `data`;
|
|
|
|
-- Aggiunta possibilità di selezionare anche i conti in 620 Costi diversi negli acquisti
|
|
UPDATE `co_pianodeiconti2` SET `dir` = 'uscita' WHERE `co_pianodeiconti2`.`descrizione` = 'Costi diversi';
|
|
|
|
-- Supporto al valore NULL per uid e summary in in_interventi_tecnici
|
|
ALTER TABLE `in_interventi_tecnici` CHANGE `uid` `uid` VARCHAR(255), CHANGE `summary` `summary` VARCHAR(255);
|
|
UPDATE `in_interventi_tecnici` SET `uid` = NULL WHERE `uid` = '';
|
|
UPDATE `in_interventi_tecnici` SET `summary` = NULL WHERE `summary` = '';
|
|
ALTER TABLE `in_interventi_tecnici` CHANGE `uid` `uid` int(11);
|
|
|
|
|
|
-- Aggiorno campo 'Data' in 'Data movimento'
|
|
UPDATE `zz_views` SET `name` = 'Data movimento', `order` = '6' WHERE `zz_views`.`id_module` = (SELECT `id` FROM `zz_modules` WHERE `name` = 'Movimenti') AND name = 'Data';
|
|
|
|
UPDATE `zz_views` SET `query` = 'CONCAT(mg_movimenti.qta,'' '', (SELECT um FROM mg_articoli WHERE id = mg_movimenti.idarticolo) )' WHERE `zz_views`.`id_module` = (SELECT `id` FROM `zz_modules` WHERE `name` = 'Movimenti') AND name = 'Quantità';
|
|
|
|
-- Allineo anche il modulo movimenti con il nuovo campo data
|
|
INSERT INTO `zz_views` (`id_module`, `name`, `query`, `order`, `search`, `slow`, `format`, `enabled`, `default`) VALUES
|
|
((SELECT `id` FROM `zz_modules` WHERE `name` = 'Movimenti'), 'Data', 'mg_movimenti.data', 5, 1, 0, 1, 1, 1);
|
|
|
|
INSERT INTO `zz_group_view` (`id_gruppo`, `id_vista`) VALUES
|
|
(1, (SELECT id FROM `zz_views` WHERE id_module=(SELECT id FROM zz_modules WHERE name='Movimenti') AND name='Data' )),
|
|
(2, (SELECT id FROM `zz_views` WHERE id_module=(SELECT id FROM zz_modules WHERE name='Movimenti') AND name='Data' )),
|
|
(3, (SELECT id FROM `zz_views` WHERE id_module=(SELECT id FROM zz_modules WHERE name='Movimenti') AND name='Data' )),
|
|
(4, (SELECT id FROM `zz_views` WHERE id_module=(SELECT id FROM zz_modules WHERE name='Movimenti') AND name='Data' ));
|
|
|
|
-- Aggiungo colonna impianti per i contratti
|
|
INSERT INTO `zz_views` (`id_module`, `name`, `query`, `order`, `search`, `slow`, `format`, `enabled`, `default`) VALUES
|
|
((SELECT `id` FROM `zz_modules` WHERE `name` = 'Contratti'), 'Impianti', '(SELECT IF(nome = '''', GROUP_CONCAT(matricola SEPARATOR ''<br>''), GROUP_CONCAT(matricola, '' - '', nome SEPARATOR ''<br>'')) FROM my_impianti INNER JOIN my_impianti_contratti ON my_impianti.id = my_impianti_contratti.idimpianto WHERE my_impianti_contratti.idcontratto = co_contratti.id)', 4, 1, 0, 0, 0, 1);
|
|
|
|
INSERT INTO `zz_group_view` (`id_gruppo`, `id_vista`) VALUES
|
|
(1, (SELECT id FROM `zz_views` WHERE id_module=(SELECT id FROM zz_modules WHERE name='Contratti') AND name='Impianti' )),
|
|
(2, (SELECT id FROM `zz_views` WHERE id_module=(SELECT id FROM zz_modules WHERE name='Contratti') AND name='Impianti' )),
|
|
(3, (SELECT id FROM `zz_views` WHERE id_module=(SELECT id FROM zz_modules WHERE name='Contratti') AND name='Impianti' )),
|
|
(4, (SELECT id FROM `zz_views` WHERE id_module=(SELECT id FROM zz_modules WHERE name='Contratti') AND name='Impianti' ));
|
|
|
|
-- Tempo standard per attività
|
|
ALTER TABLE `in_tipiintervento` ADD `tempo_standard` DECIMAL(10,2) NULL AFTER `costo_diritto_chiamata_tecnico`;
|
|
|
|
-- Rinomino Interventi da pianificare in Promemoria contratti da pianificare
|
|
UPDATE `zz_widgets` SET `text` = 'Promemoria contratti da pianificare' WHERE `zz_widgets`.`name` = 'Interventi da pianificare';
|
|
|
|
-- Fix arrotondamenti per fatture di vendita
|
|
UPDATE `zz_views` SET `query` = '(SELECT SUM(round(subtotale,2) - round(sconto,2) + round(iva,2) + round(rivalsainps,2) - round(ritenutaacconto,2)) FROM co_righe_documenti WHERE co_righe_documenti.iddocumento=co_documenti.id GROUP BY iddocumento) + round(bollo,2) + round(iva_rivalsainps,2)' WHERE `zz_views`.`id_module` = (SELECT `id` FROM `zz_modules` WHERE `name` = 'Fatture di vendita') AND name = 'Totale';
|
|
|
|
-- Fix arrotondamenti per fatture di acquisto
|
|
UPDATE `zz_views` SET `query` = '(SELECT SUM(round(subtotale,2) - round(sconto,2) + round(iva,2) + round(rivalsainps,2) - round(ritenutaacconto,2)) FROM co_righe_documenti WHERE co_righe_documenti.iddocumento=co_documenti.id GROUP BY iddocumento ) + round(bollo,2) + round(iva_rivalsainps,2)' WHERE `zz_views`.`id_module` = (SELECT `id` FROM `zz_modules` WHERE `name` = 'Fatture di acquisto') AND name = 'Totale';
|
|
|
|
-- Aggiunta impostazioni per cambio stato automatici
|
|
INSERT INTO `zz_settings` (`idimpostazione`, `nome`, `valore`, `tipo`, `editable`, `sezione`) VALUES (NULL, 'Cambia automaticamente stato ddt fatturati', '1', 'boolean', '1', 'Ddt');
|
|
INSERT INTO `zz_settings` (`idimpostazione`, `nome`, `valore`, `tipo`, `editable`, `sezione`) VALUES (NULL, 'Cambia automaticamente stato ordini fatturati', '1', 'boolean', '1', 'Ordini');
|
|
|
|
-- Flag completato per disabilitare la modifica dei campi nei ddt
|
|
ALTER TABLE `dt_statiddt` ADD `completato` TINYINT(1) NOT NULL AFTER `icona`;
|
|
UPDATE `dt_statiddt` SET `completato` = '1' WHERE `dt_statiddt`.`descrizione` IN( 'Fatturato', 'Parzialmente fatturato', 'Evaso' );
|
|
|
|
-- Aggiungo stato parzialmente evaso
|
|
INSERT INTO `dt_statiddt` (`id`, `descrizione`, `icona`, `completato`) VALUES (NULL, 'Parzialmente evaso', 'fa fa-clock-o text-info', '1');
|
|
|
|
-- Modifico le icone degli stati ddt
|
|
UPDATE `dt_statiddt` SET `icona` = 'fa fa-truck text-success' WHERE `dt_statiddt`.`descrizione` = 'Evaso';
|
|
UPDATE `dt_statiddt` SET `icona` = 'fa fa-truck text-warning' WHERE `dt_statiddt`.`descrizione` = 'Parzialmente evaso';
|
|
UPDATE `dt_statiddt` SET `icona` = 'fa fa-file-text-o text-success' WHERE `dt_statiddt`.`descrizione` = 'Fatturato';
|
|
UPDATE `dt_statiddt` SET `icona` = 'fa fa-file-text-o text-warning' WHERE `dt_statiddt`.`descrizione` = 'Parzialmente fatturato';
|
|
|
|
-- Modifico gli stati dell'ordine
|
|
UPDATE `or_statiordine` SET `descrizione` = 'Bozza' WHERE `or_statiordine`.`descrizione` = 'Non evaso';
|
|
|
|
-- Modifico le icone degli stati ordini
|
|
UPDATE `or_statiordine` SET `icona` = 'fa fa-truck text-success' WHERE `or_statiordine`.`descrizione` = 'Evaso';
|
|
|
|
-- Inserisco due nuovi stati ordine
|
|
INSERT INTO `or_statiordine` (`id`, `descrizione`, `annullato`, `icona`) VALUES
|
|
(NULL, 'Parzialmente fatturato', 0, 'fa fa-file-text-o text-warning'),
|
|
(NULL, 'Fatturato', 0, 'fa fa-file-text-o text-success');
|
|
|
|
-- Flag completato per disabilitare la modifica dei campi negli ordini
|
|
ALTER TABLE `or_statiordine` ADD `completato` TINYINT(1) NOT NULL AFTER `icona`;
|
|
UPDATE `or_statiordine` SET `completato` = '1' WHERE `or_statiordine`.`id` IN( 2, 3, 4, 5 );
|
|
|
|
-- Campi per note aggiuntive in ddt e ordini
|
|
ALTER TABLE `or_ordini` ADD `note_aggiuntive` TEXT NOT NULL AFTER `note`;
|
|
ALTER TABLE `dt_ddt` ADD `note_aggiuntive` TEXT NOT NULL AFTER `note`;
|
|
|
|
-- Fix id_plugin (zz_files)
|
|
UPDATE `zz_files` SET `id_plugin` = NULL WHERE `id_plugin` = 0;
|
|
|
|
-- Fix id_module (zz_files)
|
|
ALTER TABLE `zz_files` CHANGE `id_module` `id_module` INT(11) NULL;
|
|
UPDATE `zz_files` SET `id_module` = NULL WHERE `id_module` = 0;
|
|
|
|
-- Totali fatture, sommabile
|
|
UPDATE `zz_views` SET `summable` = '1' WHERE `zz_views`.`id_module` = (SELECT `id` FROM `zz_modules` WHERE `name` = 'Fatture di vendita') AND name = 'Totale';
|
|
UPDATE `zz_views` SET `summable` = '1' WHERE `zz_views`.`id_module` = (SELECT `id` FROM `zz_modules` WHERE `name` = 'Fatture di acquisto') AND name = 'Totale'; |