gest366/modules/documenti/actions.php

2528 lines
110 KiB
PHP

<?php
// release 2.0.8
include_once(__DIR__."/../../core.php");
include_once($docroot."/modules/articoli/modutil.php");
include_once($docroot."/lib/function_fatpa.php");
include_once($docroot."/lib/function_fatpa_import.php");
$iddocumento = $id_record;
switch( $html->form('op', 'post') ){
case "add":
$idanagrafica = save( $_POST['idanagrafica'] );
// testo se nuova anagrafica
$new_anagrafica = save( $_POST['new_anagrafica'] );
if( $new_anagrafica != '' ){
$new_localita = save( $_POST['new_localita'] );
$idtipoanagrafica = $html->form( 'idtipoanagrafica', 'post', false );
$rs = $dbo->fetchArray("SELECT descrizione FROM an_tipianagrafiche WHERE idtipoanagrafica='".$idtipoanagrafica."'");
$tipoanagrafica_desc = $rs[0]['descrizione'];
//Leggo l'ultimo codice anagrafica per calcolare il successivo
$rs = $dbo->fetchArray("SELECT codice FROM an_anagrafiche ORDER BY CAST(codice AS SIGNED) DESC LIMIT 0,1");
$codice = get_next_code( $rs[0]['codice'], 1, get_var("Formato codice anagrafica") );
//Se ad aggiungere un cliente è un agente, lo imposto come agente di quel cliente
//Lettura tipologia della nuova anagrafica
$rs = $dbo->fetchArray("SELECT descrizione FROM an_tipianagrafiche WHERE idtipoanagrafica='".$idtipoanagrafica."'");
$tipoanagrafica_dst = $rs[0]['descrizione'];
//Lettura tipologia dell'utente loggato
$agente_is_logged = false;
$rs = $dbo->fetchArray("SELECT descrizione FROM an_tipianagrafiche INNER JOIN an_tipianagrafiche_anagrafiche ON an_tipianagrafiche.idtipoanagrafica=an_tipianagrafiche_anagrafiche.idtipoanagrafica WHERE idanagrafica='".$user_idanagrafica."'");
for( $i=0; $i<sizeof($rs); $i++ ){
if( $rs[$i]['descrizione']=='Agente' ){
$agente_is_logged = true;
$i = sizeof($rs);
}
}
( $agente_is_logged ) ? $idagente=$user_idanagrafica : $idagente=0;
//Inserisco l'anagrafica
$query = "INSERT INTO an_anagrafiche( ragione_sociale, codice, idagente,citta ) VALUES ( \"".$new_anagrafica."\", \"".$codice."\", \"".$idagente."\", \"".$new_localita."\" )";
$dbo->query($query);
$idanagrafica = $dbo->last_inserted_id();
//Inserisco il rapporto dell'anagrafica (cliente, tecnico, ecc)
for( $t=0; $t<sizeof($idtipoanagrafica); $t++ ){
$query = "INSERT INTO an_tipianagrafiche_anagrafiche(idanagrafica, idtipoanagrafica) VALUES (\"".$idanagrafica."\", \"".$idtipoanagrafica[$t]."\")";
$dbo->query($query);
$rs = $dbo->fetchArray("SELECT descrizione FROM an_tipianagrafiche WHERE idtipoanagrafica='".$idtipoanagrafica[$t]."'");
$tipoanagrafica_dst = $rs[0]['descrizione'];
if ($tipoanagrafica_dst=='Azienda')
array_push( $_SESSION['infos'], "Sembra che tu abbia inserito la tua anagrafica Azienda, ricordati di impostarla come predefinita dal menù ''Strumenti -> Impostazioni -> Generali''." );
}
if ( sizeof($idtipoanagrafica) == '0' ){
$query = "INSERT INTO an_tipianagrafiche_anagrafiche(idanagrafica, idtipoanagrafica) VALUES (\"".$idanagrafica."\", '1')";
$dbo->query($query);
$tipoanagrafica_dst = 'Cliente' ;
$tipoanagrafica_desc = 'Cliente' ;
}
if ( $idagente != 0 ){
$dbo->query("INSERT INTO an_anagrafiche_agenti( idanagrafica, idagente ) VALUES( \"".$idanagrafica."\", \"".$idagente."\" )");
}
//Creo il relativo conto nel partitario
if( $tipoanagrafica_dst == 'Cliente' ){
//Calcolo prossimo numero cliente
$rs = $dbo->fetchArray("SELECT MAX( CAST(co_pianodeiconti3.numero AS UNSIGNED) ) AS max_numero FROM co_pianodeiconti3 INNER JOIN co_pianodeiconti2 ON co_pianodeiconti3.idpianodeiconti2=co_pianodeiconti2.id WHERE co_pianodeiconti2.descrizione='Crediti clienti e crediti diversi'");
$new_numero = $rs[0]['max_numero'] + 1;
$new_numero = str_pad( $new_numero, 6, "0", STR_PAD_LEFT );
//Creazione conto
$dbo->query("INSERT INTO co_pianodeiconti3( numero, descrizione, idpianodeiconti2, can_delete, can_edit ) VALUES( \"".$new_numero."\", \"".$new_anagrafica."\", (SELECT id FROM co_pianodeiconti2 WHERE descrizione='Crediti clienti e crediti diversi'), 1, 1 )");
$idconto = $dbo->last_inserted_id();
//Collegamento conto
$dbo->query("UPDATE an_anagrafiche SET idconto_cliente=\"".$idconto."\" WHERE idanagrafica=\"".$idanagrafica."\"");
}
else if( $tipoanagrafica_dst == 'Fornitore' ){
//Calcolo prossimo numero cliente
$rs = $dbo->fetchArray("SELECT MAX( CAST(co_pianodeiconti3.numero AS UNSIGNED) ) AS max_numero FROM co_pianodeiconti3 INNER JOIN co_pianodeiconti2 ON co_pianodeiconti3.idpianodeiconti2=co_pianodeiconti2.id WHERE co_pianodeiconti2.descrizione='Debiti fornitori e debiti diversi'");
$new_numero = $rs[0]['max_numero'] + 1;
$new_numero = str_pad( $new_numero, 6, "0", STR_PAD_LEFT );
//Creazione conto
$dbo->query("INSERT INTO co_pianodeiconti3( numero, descrizione, idpianodeiconti2, can_delete, can_edit ) VALUES( \"".$new_numero."\", \"".$new_anagrafica."\", (SELECT id FROM co_pianodeiconti2 WHERE descrizione='Debiti fornitori e debiti diversi'), 1, 1 )");
$idconto = $dbo->last_inserted_id();
//Collegamento conto
$dbo->query("UPDATE an_anagrafiche SET idconto_fornitore=\"".$idconto."\" WHERE idanagrafica=\"".$idanagrafica."\"");
}
array_push( $_SESSION['infos'], "Aggiunta nuova anagrafica di tipo ''".$tipoanagrafica_dst."''" );
}
$data = saveDate( $_POST['data'] );
$dir = $_POST['dir'];
$idtipodocumento = save( $_POST['idtipodocumento'] );
// cerco impostazioni tipo documento
$numerazione_progressiva=get_var_tipodoc($idtipodocumento,'mod_num');
$dir=get_var_tipodoc($idtipodocumento,'dir');
$idconto=get_var_tipodoc($idtipodocumento,'idconto');
$idpagamento_new=get_var_tipodoc($idtipodocumento,'idpagamento');
// $idstato=get_var_tipodoc($idtipodocumento,'sta_apertura');
$id_gruppodoc=get_var_tipodoc($idtipodocumento,'id_gruppo_tipologia');
$suffisso=get_var_tipodoc($idtipodocumento,'txt_suffisso');
$suffisso_anno=get_var_tipodoc($idtipodocumento,'suffisso_anno');
$idstato = get_var_tipodoc($idtipodocumento,'sta_apertura');
$mod_prodotollo = get_var_tipodoc($idtipodocumento,'mod_prodotollo');
$ordine_servizio=get_var_tipodoc($idtipodocumento,'mod_ordineservizio');
$nuovo_id_protocollo=0;
$query = "SELECT esigibilita_iva , idagente , idbanca_vendite , default_ritenuta_acconto , default_rivalsa_inps FROM an_anagrafiche WHERE idanagrafica='".$idanagrafica."'";
$rs = $dbo->fetchArray($query);
$idagente = $rs[0]['idagente'];
$idbanca_vendite = $rs[0]['idbanca_vendite'];
$default_ritenuta_acconto = $rs[0]['default_ritenuta_acconto'];
$default_rivalsa_inps = $rs[0]['default_rivalsa_inps'];
$split_p='0';
if ($rs[0]['esigibilita_iva'] == 'S' ) $split_p='1';
if( $numerazione_progressiva==0) $numero = get_new_numerofattura( $data );
if( $numerazione_progressiva==1) $numero=get_new_numerofattura_multi($data,$idtipodocumento);
if( $dir=='entrata' ){
if( $numerazione_progressiva==0) $numero_esterno = get_new_numerosecondariofattura( $data,$idtipodocumento );
if( $numerazione_progressiva==1) $numero_esterno = get_new_numerosecondariofattura_multi( $data,$idtipodocumento );
}
else{
$numero_esterno = '';
$forza_numerazione=get_var_tipodoc($idtipodocumento,'forza_numerazione');
if( $forza_numerazione =='1' ){
// forzatura numero progressivo
if( $numerazione_progressiva==0) $numero_esterno = get_new_numerosecondariofattura( $data,$idtipodocumento );
if( $numerazione_progressiva==1) $numero_esterno = get_new_numerosecondariofattura_multi( $data,$idtipodocumento );
}
}
// ricerco ultimo id protocollo
if( $mod_prodotollo=='1' ){
$query = "SELECT IFNULL(MAX(id_protocollo),'0') AS max_protocollo FROM co_documenti WHERE DATE_FORMAT( data, '%Y' ) = '".date("Y", strtotime($data))."' ORDER BY CAST(id_protocollo AS UNSIGNED) DESC LIMIT 0,1";
$rs = $dbo->fetchArray($query);
$nuovo_id_protocollo = $rs[0]['max_protocollo']+1;
}
// se documento e' un ordine di servizio ricerco il contratto
$idcontratto='0';
if( $ordine_servizio=='1' ){
$query="SELECT co_contratti.id AS idcontratto, an_anagrafiche.idanagrafica, numero, nome FROM co_contratti INNER JOIN an_anagrafiche ON co_contratti.idanagrafica=an_anagrafiche.idanagrafica
WHERE an_anagrafiche.idanagrafica='".$idanagrafica."' AND idstato NOT IN (SELECT `id` FROM co_staticontratti WHERE descrizione='Bozza' OR descrizione='Rifiutato' OR descrizione='Pagato') ORDER BY id desc";
$rs = $dbo->fetchArray($query);
$idcontratto = $rs[0]['idcontratto'];
}
if( $modules_info[$module_name]["permessi"] == 'rw' ){
$numero_documento=$suffisso.$numero_esterno;
if( $suffisso_anno==1) $numero_documento = $numero_documento."_".date("Y");
//Tipo di pagamento predefinito dall'anagrafica
$query = "SELECT id FROM co_pagamenti WHERE id=(SELECT idpagamento FROM an_anagrafiche WHERE idanagrafica='".$idanagrafica."')";
$rs = $dbo->fetchArray($query);
$idpagamento = $rs[0]['id'];
// se pagaemnto non impostato cerco se pagamento impostato per default
if( $idpagamento=='') $idpagamento=$idpagamento_new;
// impostazione data protocollo
if( date ('d') <= 15){
$data_prot = date ('Y/m/15');
}else{
$data_prot = date ('Y/m/t');
}
$query = "INSERT INTO co_documenti ( split_p , idritenutaacconto,idrivalsainps,id_contratto,idbanca_vendite,id_protocollo,data_prot,idagente , numero, numero_esterno,numero_documento, id_gruppo_tipologia,idanagrafica, idconto, idtipodocumento, idpagamento, data, idstatodocumento, idsede ) VALUES
( \"".$split_p."\", \"".$default_ritenuta_acconto."\", \"".$default_rivalsa_inps."\",\"".$idcontratto."\",\"".$idbanca_vendite."\",\"".$nuovo_id_protocollo."\",\"".$data_prot."\",\"".$idagente."\", \"".$numero."\", \"".$numero_esterno."\", \"".$numero_documento."\",\"".$id_gruppodoc."\",\"".$idanagrafica."\", \"".$idconto."\", \"".$idtipodocumento."\", \"".$idpagamento."\",
\"".$data."\", \"".$idstato."\", (SELECT idsede_fatturazione FROM an_anagrafiche WHERE idanagrafica=\"".$idanagrafica."\") )";
$dbo->query($query);
$iddocumento = $dbo->last_inserted_id();
$id_record = $iddocumento;
// log anagrafiche
add_storico_doc($iddocumento,"Creazione nuovo documento");
//Collego l'intervento al contratto
if( $idcontratto != "0" ){
$query = "INSERT INTO co_righe_contratti( `idcontratto`, `idintervento` ) VALUES( \"".$idcontratto."\", \"".$iddocumento."\")";
$dbo->query( $query );
}
array_push( $_SESSION['infos'], "Aggiunto documento numero ".$numero."!" );
}
break;
case "update":
if( $modules_info[$module_name]["permessi"] == 'rw' ){
if( isset($_POST['id_record']) ){
include ($docroot . "/lib/salva_personalizzati.php");
$stato_per_chiusura = get_var_tipodoc2($iddocumento,'sta_concluso');
$dir=get_var_tipodoc2($iddocumento,'dir');
$numero_esterno = save( $_POST['numero_esterno'] );
$data = saveDate( $_POST['data'] );
$idagente = save( $_POST['idagente'] );
$note = save( $_POST['note'] );
$buono_ordine = save( $_POST['buono_ordine'] );
$note_aggiuntive = save( $_POST['note_aggiuntive'] );
$idstatodocumento = save($_POST['idstatodocumento']);
$idpagamento = save($_POST['idpagamento']);
$idcausalet = save($_POST['idcausalet']);
$idspedizione = save($_POST['idspedizione']);
$idporto = save($_POST['idporto']);
$idaspettobeni = save($_POST['idaspettobeni']);
$idvettore = save($_POST['idvettore']);
$n_colli = save($_POST['n_colli']);
$idsede = save($_POST['idsede']);
$idconto = save($_POST['idconto']);
$matricola = save($_POST['matricola']);
$numero_documento = save($_POST['numero_documento']);
$totale_imponibile = get_imponibile_fattura($iddocumento);
$totale_fattura = get_totale_fattura($iddocumento);
$idbanca_vendite=save( $_POST['idbanca_vendite']);
$idmezzo = save($_POST['idmezzo']);
$datatrasporto = saveDate( $_POST['datatrasporto'] );
$oratrasporto = save($_POST['oratrasporto']);
( $_POST['stp_prezzi'] == 'on' ) ? $stp_prezzi=1 : $stp_prezzi=0;
( $_POST['stp_sconti'] == 'on' ) ? $stp_sconti=1 : $stp_sconti=0;
( $_POST['stp_immagini'] == 'on' ) ? $stp_immagini=1 : $stp_immagini=0;
( $_POST['stp_descestesa'] == 'on' ) ? $stp_descestesa=1 : $stp_descestesa=0;
( $_POST['split_p'] == 'on' ) ? $split_p=1 : $split_p=0;
$bassegno=save( $_POST['bassegno']);
$nassegno=save( $_POST['nassegno']);
$tipo_sconto = save( $_POST['tipo_sconto_globale'] );
$sconto_globale = force_decimal($_POST['sconto_globale']);
// se era chiuso mi rileggo le variabili principali
$query = "SELECT * FROM co_documenti WHERE id='".$iddocumento."'";
$rs = $dbo->fetchArray($query);
if( $stato_per_chiusura == $rs[0]['idstatodocumento'] ) {
$idpagamento=$rs[0]['idpagamento'] ;
$idconto = $rs[0]['idconto'] ;
$idbanca_vendite = $rs[0]['idbanca_vendite'] ;
$idcausalet = $rs[0]['idcausalet'] ;
$idaspettobeni = $rs[0]['idaspettobeni'] ;
$idporto = $rs[0]['idporto'] ;
$tipo_sconto = $rs[0]['tipo_sconto_globale'] ;
$sconto_globale = $rs[0]['sconto_globale'] ;
}
$qana = "SELECT id , nome FROM my_impianti WHERE matricola='".$matricola."'";
$rs_matricola = $dbo->fetchArray($qana);
$descrizione_prev = save( $_POST['descrizione_prev'] );
$tempi_consegna = save( $_POST['tempi_consegna'] );
$validita = save($_POST['validita']);
$data_bozza = saveDate( $_POST['data_bozza'] );
$data_accettazione = saveDate( $_POST['data_accettazione'] );
$data_conclusione = saveDate( $_POST['data_conclusione'] );
$data_rifiuto = saveDate( $_POST['data_rifiuto'] );
$id_contratto=save( $_POST['id_contratto']);
// dati eventuali documento elettronico
$el_causale_1 = save( $_POST['el_causale_1'] );
$el_causale_2 = save( $_POST['el_causale_2'] );
$el_idrif = save( $_POST['el_idrif'] );
$el_rif_data = saveDate( $_POST['el_rif_data'] );
$el_id_codicecup = save( $_POST['el_id_codicecup'] );
$el_id_codicecig = save( $_POST['el_id_codicecig'] );
$el_rif_codicecommessa = save( $_POST['el_rif_codicecommessa'] );
$el_idrif_ddt1 = save( $_POST['el_idrif_ddt1'] );
$el_idrif_ddt1_data = saveDate( $_POST['el_idrif_ddt1_data'] );
$el_idrif_ddt2 = save( $_POST['el_idrif_ddt2'] );
$el_idrif_ddt2_data = saveDate( $_POST['el_idrif_ddt2_data'] );
$el_modalitapagamento = save( $_POST['el_modalitapagamento'] );
// $idritenutaacconto = get_var("Percentuale ritenuta d'acconto");
// $idrivalsainps = save($_POST['idrivalsainps']);
if( $dir=='uscita' ){
// $idrivalsainps = save($_POST['idrivalsainps']);
// $idritenutaacconto = get_var("Percentuale ritenuta d'acconto");
$bollo = save($_POST['bollo']);
}
else{
// $idrivalsainps = 0;
// $idritenutaacconto = 0;
$bollo = 0;
}
// aggiorno lo stato precedente
$query = "update co_documenti set idstatodocumento_prec = idstatodocumento where id='".$iddocumento."'";
$dbo->query($query);
//Leggo la descrizione del pagamento
$query = "SELECT descrizione , codice_modalita_pagamento_fe FROM co_pagamenti WHERE id='".$idpagamento."'";
$rs = $dbo->fetchArray($query);
$pagamento = $rs[0]['descrizione'];
$codice_modalita_pagamento_fe = $rs[0]['codice_modalita_pagamento_fe'];
//Query di aggiornamento
$query = "UPDATE co_documenti SET bassegno=\"".$bassegno."\" ,nassegno=\"".$nassegno."\" ,id_impianto=\"".$rs_matricola[0]['id']."\" ,nome_impianto=\"".$rs_matricola[0]['nome']."\" ,id_contratto=\"".$id_contratto."\" , tipo_sconto_globale=\"".$tipo_sconto."\" ,sconto_globale=\"".$sconto_globale."\" ,idbanca_vendite=\"".$idbanca_vendite."\" ,matricola=\"".$matricola."\" , numero_documento=\"".$numero_documento."\", data=\"".$data."\", idstatodocumento=\"".$idstatodocumento."\", idagente=\"".$idagente."\", idpagamento=\"".$idpagamento."\",
idcausalet=\"".$idcausalet."\", idspedizione=\"".$idspedizione."\", idporto=\"".$idporto."\", idaspettobeni=\"".$idaspettobeni."\", idvettore=\"".$idvettore."\",
n_colli=\"".$n_colli."\", idsede=\"".$idsede."\", el_causale_1=\"".$el_causale_1."\",el_causale_2=\"".$el_causale_2."\", numero_esterno=\"$numero_esterno\", note=\"$note\", note_aggiuntive=\"$note_aggiuntive\", idconto=\"$idconto\",
idmezzo=\"".$idmezzo."\", datatrasporto=\"".$datatrasporto."\", oratrasporto=\"".$oratrasporto."\",
stp_prezzi=\"".$stp_prezzi."\", stp_sconti=\"".$stp_sconti."\", stp_immagini=\"".$stp_immagini."\", stp_descestesa=\"".$stp_descestesa."\",split_p=\"".$split_p."\",
descrizione_prev=\"$descrizione_prev\", tempi_consegna=\"$tempi_consegna\", validita=\"$validita\", data_bozza=\"$data_bozza\", data_accettazione=\"$data_accettazione\", data_conclusione=\"$data_conclusione\", data_rifiuto=\"$data_rifiuto\",
el_idrif=\"".$el_idrif."\", el_rif_data=\"".$el_rif_data."\",el_id_codicecup=\"".$el_id_codicecup."\",el_id_codicecig=\"".$el_id_codicecig."\",
el_rif_codicecommessa=\"$el_rif_codicecommessa\", el_idrif_ddt1=\"$el_idrif_ddt1\", el_idrif_ddt1_data=\"$el_idrif_ddt1_data\", el_idrif_ddt2=\"$el_idrif_ddt2\", el_idrif_ddt2_data=\"$el_idrif_ddt2_data\", el_modalitapagamento=\"".$codice_modalita_pagamento_fe."\" ,
buono_ordine=\"".$buono_ordine."\", bollo=0, rivalsainps=0, ritenutaacconto=0, iva_rivalsainps=0 WHERE id=\"$iddocumento\"";
$dbo->query($query);
// log anagrafiche
add_storico_doc($iddocumento,"Eseguito salvataggio documento");
//aggiorno intervento se presente un riferimento al documento
$dbo->query( "update in_interventi SET idsede=\"".$idsede."\" WHERE idintervento='$iddocumento'" );
$query = "SELECT descrizione FROM co_statidocumento WHERE id='$idstatodocumento'";
$rs = $dbo->fetchArray($query);
//Ricalcolo inps, ritenuta e bollo (se la fattura non è stata pagata)
if( $dir=='entrata' ){
ricalcola_costiagg_fattura($iddocumento);
}
else{
ricalcola_costiagg_fattura($iddocumento, $idrivalsainps, $idritenutaacconto, $bollo);
}
aggiorna_sconto($iddocumento);
// leggo stati per piano diei conti e scadenziario
$stato_per_scadenziario = get_var_tipodoc2($iddocumento,'sta_scadenziario');
$stato_conto = get_var_tipodoc2($iddocumento,'sta_conto');
// $stato_per_chiusura = get_var_tipodoc2($iddocumento,'sta_concluso');
$query = "SELECT descrizione FROM co_statidocumento WHERE id='$stato_per_scadenziario'";
$rs_scadenziario = $dbo->fetchArray($query);
$stato_per_scadenziario=$rs_scadenziario[0]['descrizione'];
$query = "SELECT descrizione FROM co_statidocumento WHERE id='$stato_conto'";
$rs_scadenziario = $dbo->fetchArray($query);
$stato_per_conto=$rs_scadenziario[0]['descrizione'];
$query = "SELECT descrizione FROM co_statidocumento WHERE id='$stato_per_chiusura'";
$rs_scadenziario = $dbo->fetchArray($query);
$stato_per_chiusura=$rs_scadenziario[0]['descrizione'];
//Elimino la scadenza e tutti i movimenti, poi se la fattura è emessa le ricalcolo
if( $rs[0]['descrizione']<>$stato_per_chiusura ){
//Elimino la scadenza e tutti i movimenti
if( $rs[0]['descrizione']<>$stato_per_scadenziario ){
elimina_scadenza($iddocumento);
elimina_movimento($iddocumento, 0);
elimina_movimento($iddocumento, 1);
}
else if( $rs[0]['descrizione']==$stato_per_scadenziario ){
elimina_scadenza($iddocumento);
elimina_movimento($iddocumento, 0);
}
if( $rs[0]['descrizione']==$stato_per_scadenziario ){
aggiungi_scadenza($iddocumento, $pagamento);
array_push( $_SESSION['infos'], "Inserimento scadenziario pagamenti!" );
}
if( $rs[0]['descrizione']==$stato_per_conto ){
aggiungi_movimento($iddocumento, $dir);
array_push( $_SESSION['infos'], "Inserimento nel piano dei conti!" );
}
}
//testo se devo creare in automatico documento figlio
$sta_cambio =get_var_tipodoc2($iddocumento,'sta_cambio');
$doc_sucessivo =get_var_tipodoc2($iddocumento,'doc_sucessivo');
$sta_sucessivo =get_var_tipodoc2($iddocumento,'sta_sucessivo');
if ( $sta_cambio == $idstatodocumento && $doc_sucessivo<>'0' && $sta_sucessivo<>'0' ){
//genero automatico documento figlio
$new_iddocumento=doc_duplica($iddocumento,$doc_sucessivo ,$sta_sucessivo);
array_push( $_SESSION['infos'], "Documento sucessivo creato con successo!" );
}
// testo se devo inserire le posizoni dentro l'impianto
$mod_myimpianti =get_var_tipodoc2($iddocumento,'mod_myimpianti');
if ( $mod_myimpianti == $idstatodocumento && $matricola <>'' ){
inserisci_myimpianti($iddocumento , $matricola);
array_push( $_SESSION['infos'], "Inserire posizioni in impianto!" );
}
if( $matricola !='' ){
$dbo->query( "DELETE FROM my_impianti_interventi WHERE idintervento='$iddocumento'" );
$rs = $dbo->fetchArray("SELECT id FROM my_impianti WHERE matricola=\"".$matricola."\"");
$id_myimpianto= $rs[0]['id'];
$dbo->query("INSERT INTO my_impianti_interventi( idintervento, idimpianto ) VALUES( \"".$iddocumento."\", \"".$id_myimpianto."\" )");
}
array_push( $_SESSION['infos'], "Documento modificato correttamente!" );
}
}
break;
//eliminazione documento
case "delete":
if( $modules_info[$module_name]["permessi"] == 'rw' ){
// tolgo la transazione se e' un documento differito
$query = "SELECT idpadre FROM co_documenti_transazioni WHERE idfiglio='$iddocumento'";
$rs = $dbo->fetchArray($query);
for( $i=0; $i<sizeof($rs); $i++ ){
$dbo->query( "UPDATE co_documenti SET idstatodocumento = idstatodocumento_prec , id_differito=0 WHERE id='".$rs[$i]['idpadre']."'" );
}
//Se ci sono degli articoli collegati (ma non collegati a preventivi o interventi) li rimetto nel magazzino
$query = "SELECT id, idarticolo FROM co_righe_documenti WHERE iddocumento='$iddocumento'";
$rs = $dbo->fetchArray($query);
for( $i=0; $i<sizeof($rs); $i++ ){
rimuovi_articolo_dafattura( $rs[$i]['idarticolo'], $iddocumento, $rs[$i]['id'] );
}
// cerco documenti padre arrivati da transazioni precedenti
$query = "SELECT id_doc_padre FROM co_documenti WHERE id='$iddocumento'";
$rs = $dbo->fetchArray($query);
// cerco riferimento ad interventi impianto
$dbo->query( "DELETE FROM my_impianti_interventi WHERE idintervento='$iddocumento'" );
if ( cerca_modulo("HelpDesk") > 0 ) {
//scangio eventuale schede helpdesk
$dbo->query( "UPDATE ca_callcenter SET iddocumento = '0' WHERE iddocumento='".$iddocumento."'" );
}
if ( cerca_modulo("Noleggio") > 0 ) {
//scangio eventuale schede noleggio
$dbo->query( "UPDATE ms_noleggio SET idpreventivo = '0' WHERE idpreventivo='".$iddocumento."'" );
}
if ( cerca_modulo("Domini") > 0 ) {
//scangio eventuale schede dominio
$dbo->query( "UPDATE web_domini SET iddocumento = '0' WHERE iddocumento='".$iddocumento."'" );
}
if ( cerca_modulo("Laboratorio") > 0 ) {
//scangio eventuale schede laboratorio
$dbo->query( "UPDATE lb_laboratorio SET iddocumento = '0' WHERE iddocumento='".$iddocumento."'" );
$rs_test = $dbo->fetchArray("SELECT * FROM lb_laboratorio WHERE n_ddt='".$iddocumento."'");
if (sizeof($rs_test) > 0) {
$dbo->query( "UPDATE lb_laboratorio SET n_ddt = '0' , rma='' , note='' WHERE n_ddt='".$iddocumento."'" );
}
}
// svuoto collegaemnto ad eventuale documento di canone
$dbo->query( "UPDATE co_contratti SET id_documento = '0' WHERE id_documento='".$iddocumento."'" );
// testo se il documento e' stato completamente evaso
$rs_test = $dbo->fetchArray("SELECT * FROM co_righe_documenti WHERE qta <> qta_evasa and iddocumento='".$rs[0]['id_doc_padre']."'");
if (sizeof($rs_test) > 0) {
agg_doc_stato_rip($rs[0]['id_doc_padre']);
}
$dbo->query( "DELETE FROM co_documenti_transazioni WHERE idfiglio='$iddocumento'" );
$dbo->query( "DELETE FROM or_ordini_transazioni WHERE idfiglio='$iddocumento'" );
$dbo->query( "DELETE FROM co_documenti WHERE id='$iddocumento'" );
$dbo->query( "DELETE FROM co_righe_documenti WHERE iddocumento='$iddocumento'" );
$dbo->query( "DELETE FROM co_scadenziario WHERE iddocumento='$iddocumento'" );
$dbo->query( "DELETE FROM mg_movimenti WHERE iddocumento='$iddocumento'" );
// elimino eventuali pianificazioni
$dbo->query( "DELETE FROM in_interventi WHERE idintervento='$iddocumento'" );
$dbo->query( "DELETE FROM in_interventi_tecnici WHERE idintervento='$iddocumento'" );
$dbo->query( "DELETE FROM mg_articoli_interventi WHERE idintervento='$iddocumento'" );
$dbo->query( "DELETE FROM in_righe_interventi WHERE idintervento='$iddocumento'" );
// elimino allegati e progressivi al documento
$dbo->query( "DELETE FROM zz_files WHERE externalid='$iddocumento'" );
$dbo->query( "DELETE FROM co_documenti_progressivo WHERE id_documento='$iddocumento'" );
elimina_scadenza($iddocumento);
elimina_movimento($iddocumento);
array_push( $_SESSION['infos'], "Documento eliminato!" );
// log anagrafiche
add_storico_doc($iddocumento,"Eliminazione nuovo documento");
}
break;
case "reopen":
if( $modules_info[$module_name]["permessi"] == 'rw' ){
if( $id_record != '' ){
if( $dbo->query("UPDATE co_documenti SET idstatodocumento=(SELECT id FROM co_statidocumento WHERE descrizione='Bozza') WHERE id='".$id_record."'") ){
elimina_scadenza( $id_record );
elimina_movimento( $id_record , 1 );
ricalcola_costiagg_fattura( $id_record );
array_push( $_SESSION['infos'], "Fattura riaperta!" );
// log anagrafiche
add_storico_doc($id_record,"Riapertura del documento");
}
}
}
break;
case "addarticolo":
if( $modules_info[$module_name]["permessi"] == 'rw' ){
if( $iddocumento != '' && isset($_POST['idarticolo']) ){
$idarticolo = save( $_POST['idarticolo'] );
$idmagazzino = save( $_POST['idmagazzino'] );
$id_matricola = save( $_POST['id_matricola'] );
$idrivalsainps = save( $_POST['idrivalsainps'] );
$idritenutaacconto = save( $_POST['idritenutaacconto'] );
$descrizione = save( $_POST['descrizione'] );
$descrizione_art = save( $_POST['descrizione'] );
// cerco iva articoli preimpostata
$idiva=query_secca("","idiva_vendita","mg_articoli","where id ='".$idarticolo."'");
if( $idiva=='0' ){
$idiva = get_var("Iva predefinita");
}
$idconto=query_secca("","id_conto","mg_articoli","where id='".$idarticolo."'");
$qta = force_decimal( $_POST['qta'] );
$prezzo = force_decimal( $_POST['prezzo'] );
$lotto = "";
$serial = save( $_POST['serial'] );
$altro = "";
$idtiposconto = save( $_POST['idtiposconto'] );
$sconto = force_decimal($_POST['sconto']);
$sconto_extra = force_decimal($_POST['sconto_extra']);
$sconto_extra1 = force_decimal($_POST['sconto_extra1']);
$per_agente = force_decimal($_POST['per_agente']);
$ins_doppia=0;
$riga_canone=0;
$riga_canone1=0;
// cerco evantuali posizioni di contratto fisse se presente un contratto associato
if( $records[0]['id_contratto'] != "0" && $records[0]['id_contratto'] != "" ){
$qta_consumata=cerca_canone_qta($records[0]['id_contratto'],$idarticolo);
$qta_scalare=cerca_canone_qta_scalare($records[0]['id_contratto'],$idarticolo);
$prezzo_imposto=cerca_canone_prezzo($records[0]['id_contratto'],$idarticolo);
$qta_disp=$qta_scalare - $qta_consumata;
if( $qta_scalare != '' ){
$riga_canone=1;
if( $qta_disp >= $qta ){
$prezzo="0";
}else{
$qta_new=$qta - $qta_disp;;
$prezzo_new =$prezzo;
$qta=$qta_disp;
$prezzo="0";
$ins_doppia=1;
$riga_canone1=2;
$prezzo_tmp = cerca_canone_prezzo($records[0]['id_contratto'],$idarticolo);
if( $prezzo_tmp != '' ) $prezzo_new=$prezzo_tmp;
}
}else{
// la qta disponibile non presente , cerco eventuale prezzo imposto
$riga_canone1=2;
$riga_canone=2;
$prezzo_new = cerca_canone_prezzo($records[0]['id_contratto'],$idarticolo);
if( $prezzo_new != '' ) $prezzo=$prezzo_new;
if( $prezzo_new == '' ) $riga_canone=0;
}
$forza_zero=cerca_contratti_a_zero($records[0]['id_contratto']);
if( $forza_zero == '1' ){
$prezzo_new=0;
$prezzo=0;
$riga_canone1=2;
$riga_canone=2;
}
}
if($idtiposconto=='2'){
$sconto_prc = $sconto;
$sconto = ($prezzo * $sconto_prc)/100;
$sconto_new = ($prezzo_new * $sconto_prc)/100;
}else{
$sconto_prc = $sconto;
}
if($idtiposconto=='2'){
$sconto_extra = $sconto_extra;
$sconto1 = (($prezzo - $sconto) * $sconto_extra)/100;
$sconto1_new = (($prezzo_new - $sconto_new) * $sconto_extra)/100;
}else{
$sconto1 = $sconto_extra;
}
if($idtiposconto=='2'){
$sconto_extra1 = $sconto_extra1;
$sconto2 = (($prezzo - $sconto - $sconto1 ) * $sconto_extra1)/100;
$sconto2_new = (($prezzo_new - $sconto_new - $sconto1_new ) * $sconto_extra1)/100;
}else{
$sconto2 = $sconto_extra1;
}
$sconto = ( $sconto + $sconto1 + $sconto2 ) *$qta;
$sconto_new = ( $sconto_new + $sconto1_new + $sconto2_new ) *$qta_new;
if( $records[0]['id_contratto'] != "0" && $records[0]['id_contratto'] != "" && $riga_canone != '0' ){
$sconto=0;
$sconto_new=0;
$sconto_prc=0;
$sconto_extra=0;
$sconto_extra1=0;
}
add_articolo_infattura( $iddocumento, $idarticolo, $descrizione, $idiva, $qta, $prezzo*$qta, $sconto, '0', $lotto, $serial, $altro , $idconto,$idtiposconto,$sconto_prc,$sconto_extra,$sconto_extra1 ,$idmagazzino , $riga_canone ,$id_matricola,$per_agente );
if($ins_doppia=='1'){
add_articolo_infattura2( $iddocumento, $idarticolo, $descrizione, $idiva, $qta_new, $prezzo_new*$qta_new, $sconto_new, '0', $lotto, $serial, $altro , $idconto,$idtiposconto,$sconto_prc,$sconto_extra,$sconto_extra1 ,$idmagazzino , $riga_canone1 ,$id_matricola,$per_agente );
}
array_push( $_SESSION['infos'], "Articolo aggiunto!" );
if( $dir=='entrata' ){
ricalcola_costiagg_fattura($iddocumento);
}
else{
ricalcola_costiagg_fattura($iddocumento);
}
}
}
break;
case "addriga":
if( $modules_info[$module_name]["permessi"] == 'rw' ){
if( $iddocumento != '' ){
//Selezione costi da intervento
$descrizione = save( $_POST['descrizione'] );
$importo_manuale = force_decimal( $_POST['subtot'] );
$qta = force_decimal($_POST['qta']);
$idiva = save($_POST['idiva']);
$id_matricola = save( $_POST['id_matricola'] );
$um = save($_POST['um']);
$subtot = $importo_manuale*$qta;
$idconto = save( $_POST['idconto_riga'] );
$idtiposconto = save( $_POST['idtiposconto'] );
$sconto = force_decimal($_POST['sconto']);
$sconto_extra = force_decimal($_POST['sconto_extra']);
$sconto_extra1 = force_decimal($_POST['sconto_extra1']);
$per_agente = force_decimal($_POST['per_agente']);
if($idtiposconto=='2'){
$sconto_prc = $sconto;
$sconto = ($importo_manuale * $sconto_prc)/100;
}else{
$sconto_prc = $sconto;
}
if($idtiposconto=='2'){
$sconto_extra = $sconto_extra;
$sconto1 = (($importo_manuale - $sconto) * $sconto_extra)/100;
}else{
$sconto1 = $sconto_extra;
}
if($idtiposconto=='2'){
$sconto_extra1 = $sconto_extra1;
$sconto2 = (($importo_manuale - $sconto - $sconto1 ) * $sconto_extra1)/100;
}else{
$sconto2 = $sconto_extra1;
}
$sconto = ( $sconto + $sconto1 + $sconto2 ) *$qta;
// cerco dati agente
$query = "SELECT idanagrafica FROM co_documenti WHERE id='".$iddocumento."'";
$rs = $dbo->fetchArray($query);
$query = "SELECT idagente , default_ritenuta_acconto , default_rivalsa_inps FROM an_anagrafiche WHERE idanagrafica='".$rs[0]['idanagrafica']."'";
$rs = $dbo->fetchArray($query);
$default_ritenuta_acconto = $rs[0]['default_ritenuta_acconto'];
$default_rivalsa_inps = $rs[0]['default_rivalsa_inps'];
$query = "SELECT * FROM an_anagrafiche WHERE idanagrafica='".$rs[0]['idagente']."'";
$rs_agente = $dbo->fetchArray($query);
$perc_agente = $rs_agente[0]['perc_agente'];
$perc_netto = $rs_agente[0]['perc_netto'];
$perc_iva = $rs_agente[0]['perc_iva'];
if ($per_agente != '0' ) {
$perc_agente=$per_agente;
}
//calcolo percentuali agente
if($perc_netto =='1'){
$val_agente=($importo_manuale * $qta) - $sconto ;
$val_agente = ($val_agente * $perc_agente)/100;
}else{
$val_agente = (($importo_manuale * $qta) * $perc_agente)/100;
}
if( $perc_iva =='1'){
$rs2 = $dbo->fetchArray("SELECT * FROM co_iva WHERE id='".$idiva."'");
$agente_iva= ($val_agente/100)*$rs2[0]['percentuale'];
$val_agente=$val_agente + $agente_iva ;
}
//Calcolo iva
$query = "SELECT * FROM co_iva WHERE id='".$idiva."'";
$rs = $dbo->fetchArray($query);
$iva = ($subtot-$sconto)/100*$rs[0]['percentuale'];
$iva_indetraibile = $iva/100*$rs[0]['indetraibile'];
$desc_iva = $rs[0]['descrizione'];
//Calcolo rivalsa inps
$query = "SELECT * FROM co_rivalsainps WHERE id='".$html->form('idrivalsainps', 'post')."'";
$rs = $dbo->fetchArray($query);
$rivalsainps = $importo_manuale * $qta / 100 * $rs[0]['percentuale'];
$idrivalsainps=$html->form('idrivalsainps', 'post');
//Calcolo ritenuta d'acconto
$query = "SELECT * FROM co_ritenutaacconto WHERE id='".$html->form('idritenutaacconto', 'post')."'";
$rs = $dbo->fetchArray($query);
$ritenutaacconto = (($importo_manuale*$qta) + $rivalsainps) / 100 * $rs[0]['percentuale'];
$idritenutaacconto=$html->form('idritenutaacconto', 'post');
if( $default_rivalsa_inps != "0" ){
$idrivalsainps=$default_rivalsa_inps;
$query = "SELECT * FROM co_rivalsainps WHERE id='".$default_rivalsa_inps."'";
$rs = $dbo->fetchArray($query);
$rivalsainps = $importo_manuale * $qta / 100 * $rs[0]['percentuale'];
}
if( $default_ritenuta_acconto != "0" ){
$idritenutaacconto=$default_ritenuta_acconto;
//Calcolo ritenuta d'acconto
$query = "SELECT * FROM co_ritenutaacconto WHERE id='".$default_ritenuta_acconto."'";
$rs = $dbo->fetchArray($query);
$ritenutaacconto = (($importo_manuale*$qta) + $rivalsainps) / 100 * $rs[0]['percentuale'];
}
// Info matricola
$qana = "SELECT * FROM my_impianti WHERE matricola='".$id_matricola."'";
$rs_matricola = $dbo->fetchArray($qana);
$matricola_impianto=$rs_matricola[0]['id'];
//Aggiunta riga generica sul documento
$query = "INSERT INTO co_righe_documenti( id_impianto , matricola_impianto , iddocumento, idiva, desc_iva, iva, iva_indetraibile, descrizione, subtotale, sconto, um, qta, idrivalsainps, rivalsainps, idritenutaacconto, ritenutaacconto,idconto,tipo_sconto,sconto_primo,sconto_extra ,sconto_extra1,importo_agente,importo_iva_agente,perc_agente)
VALUES( '".$matricola_impianto."','".$id_matricola."',\"$iddocumento\", \"".$idiva."\", \"$desc_iva\", \"$iva\", \"$iva_indetraibile\", \"$descrizione\", \"$subtot\", \"$sconto\", \"$um\", \"$qta\", \"".$idrivalsainps."\",
\"".$rivalsainps."\", \"".$idritenutaacconto."\", \"".$ritenutaacconto."\" , \"".$idconto."\", \"".$idtiposconto."\", \"".$sconto_prc."\",\"".$sconto_extra."\",\"".$sconto_extra1."\",\"".$val_agente."\",\"".$agente_iva."\",\"".$perc_agente."\" )";
if( $dbo->query($query) ){
array_push( $_SESSION['infos'], "Riga aggiunta!" );
// log anagrafiche
add_storico_doc($iddocumento,"Aggiunto articolo generico ".$descrizione." con quantità = ".$qta);
//Ricalcolo inps, ritenuta e bollo
if( $dir=='entrata' ){
ricalcola_costiagg_fattura($iddocumento);
}
else{
ricalcola_costiagg_fattura($iddocumento);
}
}
}
}
break;
case "addriga_g":
if( $modules_info[$module_name]["permessi"] == 'rw' ){
if( $iddocumento != '' ){
$descrizione = save( $_POST['descrizione'] );
//Aggiunta riga generica sul documento
$query = "INSERT INTO co_righe_documenti( iddocumento, descrizione , riga_varia)
VALUES( \"$iddocumento\", \"$descrizione\", '1' )";
if( $dbo->query($query) ){
array_push( $_SESSION['infos'], "Riga aggiunta!" );
// log anagrafiche
add_storico_doc($iddocumento,"Aggiunto commento ".$descrizione);
}
}
}
break;
case "editriga":
if( $modules_info[$module_name]["permessi"] == 'rw' ){
if( isset($_POST['idriga']) ){
//Selezione costi da intervento
$ins_doppia=0;
$idriga = $html->form('idriga', 'post');
$idmagazzino = save( $_POST['idmagazzino'] );
$id_matricola = save( $_POST['id_matricola'] );
$descrizione = save( $_POST['descrizione'] );
$importo_manuale = save( $_POST['subtot'] );
$importo_manuale = str_replace( ",", ".", $importo_manuale );
$prezzo = force_decimal( $_POST['subtot'] );
$qta = save($_POST['qta']);
$qta = str_replace( ",", ".", $qta );
$idiva = save($_POST['idiva']);
$um = save($_POST['um']);
$idconto = save( $_POST['idconto_riga'] );
$subtot = $importo_manuale*$qta;
$idtiposconto = save( $_POST['idtiposconto'] );
$sconto = force_decimal($_POST['sconto']);
$sconto_extra = force_decimal($_POST['sconto_extra']);
$sconto_extra1 = force_decimal($_POST['sconto_extra1']);
$idmagazzino_old=query_secca("","id_magazzino_e","co_righe_documenti","where id='".$idriga."'");
$per_agente = force_decimal($_POST['per_agente']);
// Info matricola
$qana = "SELECT * FROM my_impianti WHERE matricola='".$id_matricola."'";
$rs_matricola = $dbo->fetchArray($qana);
$matricola_impianto=$rs_matricola[0]['id'];
// cerco evantuali posizioni di contratto fisse se presente un contratto associato
if( $records[0]['id_contratto'] != "0" && $records[0]['id_contratto'] != "" ){
$query = "SELECT idarticolo , qta , riga_canone FROM co_righe_documenti WHERE id='".$idriga."'";
$rs = $dbo->fetchArray($query);
if( $rs[0]['idarticolo'] != '0' ){
$qta_consumata=cerca_canone_qta($records[0]['id_contratto'],$rs[0]['idarticolo']);
$qta_scalare=cerca_canone_qta_scalare($records[0]['id_contratto'],$rs[0]['idarticolo']);
$prezzo_imposto=cerca_canone_prezzo($records[0]['id_contratto'],$rs[0]['idarticolo']);
$qta_disp=$qta_scalare - $qta_consumata + $rs[0]['qta'];
if( ( $qta_scalare != '' ) && ( $rs[0]['riga_canone'] == '1')){
if( $qta_disp >= $qta ){
$importo_manuale="0";
}else{
$qta_new=$qta - $qta_disp;;
$prezzo_new =$importo_manuale;
$qta=$qta_disp;
$importo_manuale="0";
$ins_doppia=1;
$prezzo_tmp = cerca_canone_prezzo($records[0]['id_contratto'],$rs[0]['idarticolo']);
if( $prezzo_tmp != '' ) $prezzo_new=$prezzo_tmp;
}
}else{
// la qta disponibile non presente , cerco eventuale prezzo imposto
$prezzo_new = cerca_canone_prezzo($records[0]['id_contratto'],$idarticolo);
if( $prezzo_new != '' ) $importo_manuale=$prezzo_new;
}
}
}
if($idtiposconto=='2'){
$sconto_prc = $sconto;
$sconto = ($importo_manuale*$sconto_prc)/100;
$sconto_new = ($prezzo_new * $sconto_prc)/100;
}else{
$sconto_prc = $sconto;
}
if($idtiposconto=='2'){
$sconto_extra = $sconto_extra;
$sconto1 = (($importo_manuale - $sconto) * $sconto_extra)/100;
$sconto1_new = (($importo_manuale - $sconto_new) * $sconto_extra)/100;
}else{
$sconto1 = $sconto_extra;
}
if($idtiposconto=='2'){
$sconto_extra1 = $sconto_extra1;
$sconto2 = (($importo_manuale - $sconto - $sconto1) * $sconto_extra1)/100;
$sconto2_new = (($importo_manuale - $sconto_new - $sconto1_new) * $sconto_extra1)/100;
}else{
$sconto2 = $sconto_extra1;
}
$sconto = ( $sconto + $sconto1 + $sconto2 ) *$qta;
$sconto_new = ( $sconto_new + $sconto1_new + $sconto2_new ) *$qta;
// impostazioni documento$esegue_movimento=get_var_tipodoc2($iddocumento,"mod_mov");
$esegue_movimento=get_var_tipodoc2($iddocumento,"mod_mov");
$esegue_giacenza = get_var_tipodoc2($iddocumento,"mod_mag");
$id_magazzino_e = get_var_tipodoc2($iddocumento,"id_magazzino_e");
$id_magazzino_u = get_var_tipodoc2($iddocumento,"id_magazzino_u");
$id_tipo_u = get_var_tipodoc2($iddocumento,"id_tipo_u");
$dir = get_var_tipodoc2($iddocumento,"dir");
$agg_prezzo_e = get_var_tipodoc2($iddocumento,"agg_prezzo_e");
$agg_prezzo_u = get_var_tipodoc2($iddocumento,"agg_prezzo_u");
if ( $idmagazzino >= '0' ) $id_magazzino_e=$idmagazzino;
// cerco dati agente
$query = "SELECT idanagrafica FROM co_documenti WHERE id='".$iddocumento."'";
$rs = $dbo->fetchArray($query);
$query = "SELECT idagente , default_ritenuta_acconto , default_rivalsa_inps FROM an_anagrafiche WHERE idanagrafica='".$rs[0]['idanagrafica']."'";
$rs = $dbo->fetchArray($query);
$default_ritenuta_acconto = $rs[0]['default_ritenuta_acconto'];
$default_rivalsa_inps = $rs[0]['default_rivalsa_inps'];
$query = "SELECT * FROM an_anagrafiche WHERE idanagrafica='".$rs[0]['idagente']."'";
$rs_agente = $dbo->fetchArray($query);
$perc_agente = $rs_agente[0]['perc_agente'];
$perc_netto = $rs_agente[0]['perc_netto'];
$perc_iva = $rs_agente[0]['perc_iva'];
if ($per_agente != '0' ) {
$perc_agente=$per_agente;
}
//calcolo percentuali agente
if($perc_netto =='1'){
$val_agente=($importo_manuale * $qta) - $sconto ;
$val_agente = ($val_agente * $perc_agente)/100;
}else{
$val_agente = (($importo_manuale * $qta) * $perc_agente)/100;
}
if( $perc_iva =='1'){
$rs2 = $dbo->fetchArray("SELECT * FROM co_iva WHERE id='".$idiva."'");
$agente_iva= ($val_agente/100)*$rs2[0]['percentuale'];
$val_agente=$val_agente + $agente_iva ;
}
//Lettura idarticolo dalla riga documento
$rs = $dbo->fetchArray("SELECT idarticolo, qta FROM co_righe_documenti WHERE id=\"".$idriga."\"");
$idarticolo = $rs[0]['idarticolo'];
$old_qta = $rs[0]['qta'];
$subtot = $importo_manuale*$qta;
//Calcolo iva
$query = "SELECT * FROM co_iva WHERE id='".$idiva."'";
$rs = $dbo->fetchArray($query);
$iva = ($subtot-$sconto)/100*$rs[0]['percentuale'];
$iva_indetraibile = $iva/100*$rs[0]['indetraibile'];
$desc_iva = $rs[0]['descrizione'];
//Calcolo rivalsa inps
$query = "SELECT * FROM co_rivalsainps WHERE id='".$html->form('idrivalsainps', 'post')."'";
$rs = $dbo->fetchArray($query);
$rivalsainps = $importo_manuale*$qta / 100 * $rs[0]['percentuale'];
//Calcolo ritenuta d'acconto
$query = "SELECT * FROM co_ritenutaacconto WHERE id='".$html->form('idritenutaacconto', 'post')."'";
$rs = $dbo->fetchArray($query);
$ritenutaacconto = (($importo_manuale*$qta) + $rivalsainps) / 100 * $rs[0]['percentuale'];
$idrivalsainps=$html->form('idrivalsainps', 'post');
$idritenutaacconto=$html->form('idritenutaacconto', 'post');
if( $default_rivalsa_inps != "0" ){
$idrivalsainps=$default_rivalsa_inps;
$query = "SELECT * FROM co_rivalsainps WHERE id='".$default_rivalsa_inps."'";
$rs = $dbo->fetchArray($query);
$rivalsainps = $importo_manuale * $qta / 100 * $rs[0]['percentuale'];
}
if( $default_ritenuta_acconto != "0" ){
$idritenutaacconto=$default_ritenuta_acconto;
//Calcolo ritenuta d'acconto
$query = "SELECT * FROM co_ritenutaacconto WHERE id='".$default_ritenuta_acconto."'";
$rs = $dbo->fetchArray($query);
$ritenutaacconto = (($importo_manuale*$qta) + $rivalsainps) / 100 * $rs[0]['percentuale'];
}
//Modifica riga generica sul documento
$query = "UPDATE co_righe_documenti SET matricola_impianto=\"".$id_matricola."\", id_impianto=\"".$matricola_impianto."\", id_magazzino_e=\"".$id_magazzino_e."\", idconto=\"".$idconto."\", idiva=\"".$idiva."\", desc_iva=\"".$desc_iva."\", iva=\"".$iva."\", iva_indetraibile=\"".$iva_indetraibile."\", descrizione=\"".$descrizione."\",
subtotale=\"".$subtot."\", sconto=\"".$sconto."\", tipo_sconto=\"".$idtiposconto."\", sconto_primo=\"".$sconto_prc."\", sconto_extra=\"".$sconto_extra."\", sconto_extra1=\"".$sconto_extra1."\",
um=\"".$um."\", qta=\"".$qta."\", idritenutaacconto=\"".$idritenutaacconto."\",
ritenutaacconto=\"".$ritenutaacconto."\", idrivalsainps=\"".$idrivalsainps."\", rivalsainps=\"".$rivalsainps."\" ,
importo_agente=\"".$val_agente."\",importo_iva_agente=\"".$agente_iva."\",perc_agente=\"".$perc_agente."\" WHERE id=\"".$idriga."\"";
if( $dbo->query($query) ){
// log anagrafiche
add_storico_doc($iddocumento,"Modificato articolo ".$descrizione." con quantità = ".$qta);
if($ins_doppia=='1'){
add_articolo_infattura2( $iddocumento, $idarticolo, $descrizione, $idiva, $qta_new, $prezzo_new*$qta_new, $sconto_new, '0', $lotto, $serial, $altro , $idconto,$idtiposconto,$sconto_prc,$sconto_extra,$sconto_extra1 ,$idmagazzino ,$id_matricola);
}
//Se ho movimentato una riga collegata ad un articolo di magazzino, movimento il magazzino
if( $idarticolo != '' ){
( $dir == 'entrata' ) ? $sign='-' : $sign='+';
if( $esegue_movimento== 1 ) {
//Lettura dati del movimento in magazzino per poterlo modificare
$rs = $dbo->fetchArray("SELECT id, qta FROM mg_movimenti WHERE idarticolo=\"".$idarticolo."\" AND qta=\"".$sign.$old_qta."\" AND iddocumento=\"".$iddocumento."\"");
$idmovimento = $rs[0]['id'];
//Aggiorno il movimento del magazzino
$query = "UPDATE mg_movimenti SET qta=\"".$sign.$qta."\" WHERE id=\"".$idmovimento."\"";
$dbo->query( $query );
}
//Aggiorno la quantità articolo (qtà_attuale - qtà_precedentemente_movimentata + nuova_qtà)
if( $esegue_giacenza== 1 ) {
if ( $idmagazzino_old == $id_magazzino_e ){
if( $id_magazzino_e == 0 ) {
$tabella=" mg_articoli ";
$where =" WHERE id='".$idarticolo."'";
} else{
$tabella=" mg_articoli_magazzini ";
$where =" WHERE idarticolo='".$idarticolo."' and idmagazzino='".$id_magazzino_e."' ";
}
if( $dir == "entrata" ){
$query = "UPDATE ".$tabella." SET qta= qta +".$old_qta.$sign.$qta.$where;
}
else{
$query = "UPDATE ".$tabella." SET qta=qta -".$old_qta.$sign.$qta.$where;
}
$dbo->query( $query );
}
else{
// ripristino giacenza prima di cambio magazzino
if( $idmagazzino_old == 0 ) {
$tabella=" mg_articoli ";
$where =" WHERE id='".$idarticolo."'";
} else{
$tabella=" mg_articoli_magazzini ";
$where =" WHERE idarticolo='".$idarticolo."' and idmagazzino='".$idmagazzino_old."' ";
}
if( $dir == "entrata" ){
$query = "UPDATE ".$tabella." SET qta= qta +".$old_qta.$where;
}
else{
$query = "UPDATE ".$tabella." SET qta=qta -".$old_qta.$where;
}
$dbo->query( $query );
// ricalcolo nuova giacenza su mahazzino nupvo
if( $id_magazzino_e == 0 ) {
$tabella=" mg_articoli ";
$where =" WHERE id='".$idarticolo."'";
} else{
$tabella=" mg_articoli_magazzini ";
$where =" WHERE idarticolo='".$idarticolo."' and idmagazzino='".$id_magazzino_e."' ";
}
if( $dir == "entrata" ){
$query = "UPDATE ".$tabella." SET qta= qta ".$sign.$qta.$where;
}
else{
$query = "UPDATE ".$tabella." SET qta=qta ".$sign.$qta.$where;
}
$dbo->query( $query );
}
}
// testo se devo fare movimenti su altri magazzini
if( $id_magazzino_u != 0 ) {
( $id_tipo_u == '1' ) ? $sign='+' : $sign='-';
$tabella=" mg_articoli_magazzini ";
$where =" WHERE idarticolo='".$idarticolo."' and idmagazzino='".$id_magazzino_u."' ";
if( $id_tipo_u == "1" ){
$query = "UPDATE ".$tabella." SET qta= qta -".$old_qta.$sign.$qta.$where;
}
else{
$query = "UPDATE ".$tabella." SET qta=qta +".$old_qta.$sign.$qta.$where;
}
$dbo->query( $query );
}
if( $agg_prezzo_e == 1 ) { // aggiornaemnto prezzo di aquisto
$dbo->query( "UPDATE mg_articoli SET prezzo_acquisto=".$importo_manuale." WHERE id='".$idarticolo."'");
}
if( $agg_prezzo_u == 1 ) { // aggiornaemnto prezzo di vendita
$dbo->query( "UPDATE mg_articoli SET prezzo_vendita=".$importo_manuale." WHERE id='".$idarticolo."'");
}
}
array_push( $_SESSION['infos'], "Riga modificata!" );
//Ricalcolo inps, ritenuta e bollo
if( $dir=='entrata' )
ricalcola_costiagg_fattura($iddocumento);
else
ricalcola_costiagg_fattura($iddocumento);
}
}
}
break;
case "editriga_canone":
$idriga = $html->form('idriga', 'post');
$idtiposconto = save( $_POST['idtipoassistenza'] );
if ( $idtiposconto =='2' ) {
$query = "UPDATE co_righe_documenti SET riga_canone='0' WHERE id=\"".$idriga."\"";
if( $dbo->query($query) ){
array_push( $_SESSION['infos'], "Condizione posizione modificata" );
// log anagrafiche
add_storico_doc($iddocumento,"Condizione posizione modificata");
}
}
break;
//Scollegamento articolo da documento
case "unlink_articolo":
if( $modules_info[$module_name]["permessi"] == 'rw' ){
if( $iddocumento != '' && isset($_POST['idarticolo']) ){
$idriga = $html->form( 'idriga', 'post' );
$idarticolo = $html->form( 'idarticolo', 'post' );
rimuovi_articolo_dafattura( $idarticolo, $iddocumento, $idriga );
// rimuovo eventuali seriali associato
$dbo->query("update mg_prodotti set id_riga_documento='0' WHERE id_riga_documento='".$idriga."'");
if( $dbo->query("DELETE FROM co_righe_documenti WHERE iddocumento='".$iddocumento."' AND id='".$idriga."'") ){
//Ricalcolo inps, ritenuta e bollo
if( $dir=='entrata' ){
ricalcola_costiagg_fattura($iddocumento);
}
else{
ricalcola_costiagg_fattura($iddocumento, 0, 0, 0);
}
array_push( $_SESSION['infos'], "Articolo rimosso!" );
}
}
}
break;
//Scollegamento riga generica da documento
case "unlink_riga":
if( $modules_info[$module_name]["permessi"] == 'rw' ){
if( isset($_POST['idriga']) ){
$idriga = $html->form('idriga', 'post');
//Se la riga è stata creata da un ordine, devo riportare la quantità evasa nella tabella degli ordini
//al valore di prima, riaggiungendo la quantità che sto togliendo
$rs = $dbo->fetchArray( "SELECT qta, descrizione, idarticolo, idordine, idiva FROM co_righe_documenti WHERE iddocumento=\"".$iddocumento."\" AND id=\"".$idriga."\"" );
//Rimpiazzo la quantità negli ordini
$dbo->query( "UPDATE or_righe_ordini SET qta_evasa=qta_evasa-".$rs[0]['qta']." WHERE descrizione=\"".$rs[0]['descrizione']."\" AND idarticolo=\"".$rs[0]['idarticolo']."\" AND idordine=\"".$rs[0]['idordine']."\" AND idiva=\"".$rs[0]['idiva']."\"" );
//Se la riga è stata creata da un ddt, devo riportare la quantità evasa nella tabella dei ddt
//al valore di prima, riaggiungendo la quantità che sto togliendo
$rs = $dbo->fetchArray( "SELECT qta, descrizione, idarticolo, idddt, idiva FROM co_righe_documenti WHERE iddocumento=\"".$iddocumento."\" AND id=\"".$idriga."\"" );
//Rimpiazzo la quantità nei ddt
$dbo->query( "UPDATE dt_righe_ddt SET qta_evasa=qta_evasa-".$rs[0]['qta']." WHERE descrizione=\"".$rs[0]['descrizione']."\" AND idarticolo=\"".$rs[0]['idarticolo']."\" AND idddt=\"".$rs[0]['idddt']."\" AND idiva=\"".$rs[0]['idiva']."\"" );
$query = "DELETE FROM co_righe_documenti WHERE iddocumento=\"$iddocumento\" AND id=\"$idriga\"";
// log anagrafiche
add_storico_doc($iddocumento,"Rimozione riga ".$rs[0]['descrizione']);
if( $dbo->query($query) ){
//Ricalcolo inps, ritenuta e bollo
if( $dir=='entrata' ){
ricalcola_costiagg_fattura($iddocumento);
}
else{
ricalcola_costiagg_fattura($iddocumento, 0, 0, 0);
}
array_push( $_SESSION['infos'], "Riga rimossa!" );
}
}
}
break;
//ordino righe in fattura
case "sortrows":
$id = $html->form('id', 'post');
$iddocumento = $html->form('iddocumento', 'post');
$ordine = $html->form('ordine', 'post');
$dbo->query("UPDATE co_righe_documenti SET ordine=".$ordine." WHERE id=".$id."");
array_push( $_SESSION['infos'], "Ordine aggiornato!" );
exit;
break;
case 'add_serial':
$idriga = save( $_POST['idriga'] );
$idarticolo = save( $_POST['idarticolo'] );
// cerco qta riga
$n_qta=query_secca("","qta","co_righe_documenti","where id ='".$idriga."'");
// svuoto eventuali associazioni precedenti
$dbo->query("UPDATE mg_prodotti SET id_riga_documento='0' WHERE idarticolo=".$idarticolo." and id_riga_documento='".$idriga."'");
// ciclo sui seriali passati
for( $i=0; $i<sizeof($_POST['serial']); $i++ ){
$serial = save( $_POST['serial'][$i] );
if ($i < $n_qta ) {
$dbo->query("UPDATE mg_prodotti SET id_riga_documento=".$idriga." WHERE idarticolo=".$idarticolo." and serial='".$serial."'");
}
}
array_push( $_SESSION['infos'], "Abbinamento seriali terminato!" );
break;
case "add_transazione":
$idtipodocumento = save( $_POST['idintervento'] );
if ( $idtipodocumento <> '' ) {
// cerco impostazioni tipo documento
$idanagrafica=get_var_tipodoc2($iddocumento ,'idanagrafica');
$idagente=get_var_tipodoc2($iddocumento ,'idagente');
$idbanca_vendite=get_var_tipodoc2($iddocumento ,'idbanca_vendite');
$idsede=get_var_tipodoc2($iddocumento ,'idsede');
$numerazione_progressiva=get_var_tipodoc($idtipodocumento,'mod_num');
$dir=get_var_tipodoc($idtipodocumento,'dir');
$idconto=get_var_tipodoc($idtipodocumento,'idconto');
$matricola=get_var_documento($iddocumento ,'matricola');
$idpagamento_new=get_var_tipodoc($idtipodocumento,'idpagamento');
$idstato=get_var_tipodoc($idtipodocumento,'sta_apertura');
$id_gruppodoc=get_var_tipodoc($idtipodocumento,'id_gruppo_tipologia');
$suffisso=get_var_tipodoc($idtipodocumento,'txt_suffisso');
$suffisso_anno=get_var_tipodoc($idtipodocumento,'suffisso_anno');
$ordine_servizio=get_var_tipodoc($idtipodocumento,'mod_ordineservizio');
$idmagazzino=get_var_tipodoc($idtipodocumento,'id_magazzino_e');
$data=date("Y-m-d");
if( $numerazione_progressiva==0) $numero = get_new_numerofattura( $data );
if( $numerazione_progressiva==1) $numero=get_new_numerofattura_multi($data,$idtipodocumento);
if( $dir=='entrata' ){
if( $numerazione_progressiva==0) $numero_esterno = get_new_numerosecondariofattura( $data,$idtipodocumento );
if( $numerazione_progressiva==1) $numero_esterno = get_new_numerosecondariofattura_multi( $data,$idtipodocumento );
}
else{
$numero_esterno = '';
$forza_numerazione=get_var_tipodoc($idtipodocumento,'forza_numerazione');
if( $forza_numerazione =='1' ){
// forzatura numero progressivo
if( $numerazione_progressiva==0) $numero_esterno = get_new_numerosecondariofattura( $data,$idtipodocumento );
if( $numerazione_progressiva==1) $numero_esterno = get_new_numerosecondariofattura_multi( $data,$idtipodocumento );
}
}
$numero_documento=$suffisso.$numero_esterno;
if( $suffisso_anno==1) $numero_documento = $numero_documento."_".date("Y");
//Creazione nuovo documento
//Tipo di pagamento predefinito dall'anagrafica
$query = "SELECT id FROM co_pagamenti WHERE id=(SELECT idpagamento FROM an_anagrafiche WHERE idanagrafica='".$idanagrafica."')";
$rs = $dbo->fetchArray($query);
$idpagamento = $rs[0]['id'];
$tab_testata=" co_documenti ";
$tab_righe=" co_righe_documenti ";
$tab_transazione=" co_documenti_transazioni ";
// testo se devo inserire il protocollo
$nuovo_id_protocollo=0;
$mod_prodotollo = get_var_tipodoc($idtipodocumento,'mod_prodotollo');
if( $mod_prodotollo=='1' ){
$query = "SELECT IFNULL(MAX(id_protocollo),'0') AS max_protocollo FROM co_documenti WHERE DATE_FORMAT( data, '%Y' ) = '".date("Y", strtotime($data))."' ORDER BY CAST(id_protocollo AS UNSIGNED) DESC LIMIT 0,1";
$rs = $dbo->fetchArray($query);
$nuovo_id_protocollo = $rs[0]['max_protocollo']+1;
}
// impostazione data protocollo
if( date ('d') <= 15){
$data_prot = date ('Y/m/15');
}else{
$data_prot = date ('Y/m/t');
}
//Se la fattura è di vendita e non è stato associato un pagamento predefinito al cliente leggo il pagamento dalle impostazioni
if( $dir=='entrata' && $idpagamento=='' ) $idpagamento = $idpagamento_new;
$query = "INSERT INTO ".$tab_testata." ( id_protocollo,data_prot,idbanca_vendite,idagente , numero, numero_esterno,numero_documento, id_gruppo_tipologia,idanagrafica, idconto, idtipodocumento, idpagamento, data, idstatodocumento, idsede , matricola) VALUES
( \"".$nuovo_id_protocollo."\",\"".$data_prot."\",\"".$idbanca_vendite."\",\"".$idagente."\",\"".$numero."\", \"".$numero_esterno."\", \"".$numero_documento."\",\"".$id_gruppodoc."\",\"".$idanagrafica."\", \"".$idconto."\", \"".$idtipodocumento."\", \"".$idpagamento."\", NOW() ,
\"".$idstato."\",\"".$idsede."\",\"".$matricola."\")";
$dbo->query($query);
$iddocumento_new = $dbo->last_inserted_id();
// aggiorno id_doc_padre
$query="update ".$tab_testata." set id_doc_padre = '".$id_record."' where id='".$iddocumento_new."'";
$dbo->query($query);
// genero storico transazione
$query="Insert into ".$tab_transazione." (idpadre,idfiglio,data_transazione,idutente) values (\"".$iddocumento."\", \"".$iddocumento_new."\",NOW(), '".$_SESSION['idutente']."')";
$dbo->query($query);
//Processo solo le righe con qta da evadere maggiore di zero
for( $i=0; $i<sizeof($_POST['qta_da_evadere']); $i++ ){
$qta = save( $_POST['qta_da_evadere'][$i] );
if( $qta > '0' ){
$idrigadocumento = save( $_POST['idrigadocumento'][$i] );
$idarticolo = save( $_POST['idarticolo'][$i] );
$descrizione = save( $_POST['descrizione'][$i] );
$qta = save( $_POST['qta_da_evadere'][$i] );
// $qta_e = save( $_POST['qta_da_evadere'][$i] );
$qta = str_replace( ",", ".", $qta );
$um = save( $_POST['um'][$i] );
// $subtot = save( $_POST['subtot'][$i] * $qta );
$idiva = save( $_POST['idiva'][$i] );
$iva = save( $_POST['iva'][$i]*$qta );
// cerco dati della riga
$query = "SELECT * FROM co_righe_documenti WHERE id='".$idrigadocumento."'";
$rs_riga = $dbo->fetchArray($query);
$idiva = $rs_riga[0]['idiva'];
$desc_iva = $rs_riga[0]['desc_iva'];
$tipo_sconto=$rs_riga[0]['tipo_sconto'];
$sconto_primo=$rs_riga[0]['sconto_primo'];
$sconto_extra=$rs_riga[0]['sconto_extra'];
$sconto_extra1=$rs_riga[0]['sconto_extra1'];
$subtot=$rs_riga[0]['subtotale'] / $rs_riga[0]['qta'];
//Se sto aggiungendo un articolo uso la funzione per inserirlo e incrementare la giacenza
if( $idarticolo != '0' ){
// ricalcolo gli sconti in base alla qta evasa
if($tipo_sconto=='2'){
$sconto = ($subtot*$sconto_primo)/100;
}else{
$sconto = $sconto_primo;
}
if($tipo_sconto=='2'){
$sconto1 = (($subtot - $sconto) * $sconto_extra)/100;
}else{
$sconto1 = $sconto_extra;
}
if($tipo_sconto=='2'){
$sconto2 = (($subtot - $sconto - $sconto1) * $sconto_extra1)/100;
}else{
$sconto2 = $sconto_extra1;
}
$sconto = ( $sconto + $sconto1 + $sconto2 ) * $qta ;
$subtot=$subtot * $qta;
$idriga = add_articolo_infattura( $iddocumento_new, $idarticolo, $descrizione, $idiva, $qta, $subtot, $sconto, '0', '', '', '' ,$rs_riga[0]['idconto'],$tipo_sconto,$sconto_primo,$sconto_extra,$sconto_extra1,$idmagazzino,'','','' );
//Imposto la provenienza del documento e la qta ottenuta dalla transazione
$dbo->query( "UPDATE co_righe_documenti SET id_impianto='".$rs_riga[0]['id_impianto']."' ,matricola_impianto='".$rs_riga[0]['matricola_impianto']."' ,id_riferimento='".$idrigadocumento."' , qta_da_transazione='".$qta."' WHERE id=\"".$idriga."\"" );
}
//Inserimento riga normale
else{
// ricalcolo gli sconti in base alla qta evasa
if($tipo_sconto=='2'){
$sconto = ($subtot*$sconto_primo)/100;
}else{
$sconto = $sconto_primo;
}
if($tipo_sconto=='2'){
$sconto1 = (($subtot - $sconto) * $sconto_extra)/100;
}else{
$sconto1 = $sconto_extra;
}
if($tipo_sconto=='2'){
$sconto2 = (($subtot - $sconto - $sconto1) * $sconto_extra1)/100;
}else{
$sconto2 = $sconto_extra1;
}
$sconto = ( $sconto + $sconto1 + $sconto2 ) * $qta ;
// cerco dati agente
$query = "SELECT idanagrafica FROM co_documenti WHERE id='".$iddocumento."'";
$rs = $dbo->fetchArray($query);
$query = "SELECT idagente FROM an_anagrafiche WHERE idanagrafica='".$rs[0]['idanagrafica']."'";
$rs = $dbo->fetchArray($query);
$query = "SELECT * FROM an_anagrafiche WHERE idanagrafica='".$rs[0]['idagente']."'";
$rs_agente = $dbo->fetchArray($query);
$perc_agente = $rs_agente[0]['perc_agente'];
$perc_netto = $rs_agente[0]['perc_netto'];
$perc_iva = $rs_agente[0]['perc_iva'];
//calcolo percentuali agente
if($perc_netto =='1'){
$val_agente=($subtot * $qta) - $sconto ;
$val_agente = ($val_agente * $perc_agente)/100;
}else{
$val_agente = (($subtot * $qta) * $perc_agente)/100;
}
if( $perc_iva =='1'){
$rs2 = $dbo->fetchArray("SELECT * FROM co_iva WHERE id='".$idiva."'");
$agente_iva= ($val_agente/100)*$rs2[0]['percentuale'];
$val_agente=$val_agente + $agente_iva ;
}
$subtot=$subtot * $qta;
$dbo->query( "INSERT INTO co_righe_documenti( id_impianto,matricola_impianto, iddocumento, idarticolo, idordine, idiva, desc_iva, iva, iva_indetraibile, descrizione, subtotale, sconto, um, qta,tipo_sconto,sconto_primo,sconto_extra,sconto_extra1 ,importo_agente,importo_iva_agente,perc_agente )
VALUES(\"".$rs_riga[0]['id_impianto']."\",\"".$rs_riga[0]['matricola_impianto']."\", \"$iddocumento_new\", \"$idarticolo\", \"".$idordine."\", \"".$idiva."\", \"".$desc_iva."\", \"$iva\", \"$iva_indetraibile\", \"".$descrizione."\", \"$subtot\", \"$sconto\",
\"$um\", \"$qta\",\"$tipo_sconto\",\"$sconto_primo\",\"$sconto_extra\",\"$sconto_extra1\",\"".$val_agente."\",\"".$agente_iva."\",\"".$perc_agente."\" )" );
$idriga = $dbo->last_inserted_id();
$dbo->query( "UPDATE co_righe_documenti SET id_riferimento=\"".$idrigadocumento."\" , qta_da_transazione='".$qta."' WHERE id=\"".$idriga."\"" );
}
//Scalo la quantità dal documento
$dbo->query("UPDATE co_righe_documenti SET qta_evasa = qta_evasa+".$qta." WHERE id='".$idrigadocumento."'");
}
}
// testo se il docuemnto e' stato completamente evaso
$rs_test = $dbo->fetchArray("SELECT * FROM co_righe_documenti WHERE qta <> qta_evasa and iddocumento='".$iddocumento."'");
if (sizeof($rs_test) > 0) {
}
else {
$stato_transazione_concluso = get_var_tipodoc2($iddocumento,'stato_transazione_concluso');
$stato_attuale = get_var_documento($iddocumento,'idstatodocumento');
if (sizeof($stato_transazione_concluso) > 0) {
agg_doc_stato($iddocumento,$stato_attuale,$stato_transazione_concluso);
array_push( $_SESSION['infos'], "Cambio stato documento in automatico secondo le impostazioni immesse!" );
}
}
array_push( $_SESSION['infos'], "Aggiunto documento numero ".$numero_documento."!" );
add_storico_doc($iddocumento,"Creata transazione successiva");
add_storico_doc($iddocumento_new,"Creazione documento da transazione");
}
//array_push( $_SESSION['infos'], $idtipodocumento );
break;
case "fattpaimport":
$f = pathinfo( $_FILES['filexml']['name'] );
$filename = $f['filename'];
$tmp = $_FILES['file_xml']['tmp_name'];
$upload_dir = $docroot."/files/upload_pa";
array_push( $_SESSION['infos'], $f['filename'] );
break;
case "delete_xml":
$nome_file=$records[0]['nome_file_xml'];
$module_name_path = get_var("Percorso XML");
if( @unlink($docroot."/files/".$module_name_path."/".$nome_file) ){
$dbo->query("UPDATE co_documenti SET codice_xml='' , nome_file_xml='' WHERE id=\"".$iddocumento."\"");
$dbo->query( "delete from zz_files where nome='".$nome_file."' and filename='".$nome_file."' and module='".$module_name_path."'");
add_storico_doc($iddocumento,"Eliminazione file XML fattura elettronica");
}
array_push( $_SESSION['infos'], $nome_file );
break;
case "fattpa":
$file=crea_fatturapa($id_record);
$rs = $dbo->fetchArray( "SELECT module_dir,name FROM zz_modules WHERE id=\"".$id_module."\"" );
$module_dir = $rs[0]['module_dir'];
$externalid=$iddocumento;
$module_name_path = get_var("Percorso XML");
$originale = $nfile = $docroot."/files/pa/".$file;
$copia = $nfile = $docroot."/files/".$module_name_path."/".$file;
$dst_dir = $nfile = $docroot."/files/".$module_name_path;
if( !is_dir($dst_dir) ){
if( !mkdir($dst_dir) ){
}
}
//aggiorno in co_documenti
$dbo->query( "UPDATE co_documenti SET nome_file_xml='".$file."' WHERE id=\"".$iddocumento."\"" );
if ( copy($originale,$copia) ){
$dbo->query( "delete from zz_files where nome='".$file."' and filename='".$file."' and module='".$module_name_path."'");
$rs = $dbo->query("INSERT INTO `zz_files`( nome, data, filename, module, externalid,categoria ) VALUES( \"".$file."\", NOW(), \"".$file."\", \"".$module_name_path."\", \"".$externalid."\",'Fattura elettronica' )");
array_push( $_SESSION['infos'], "File caricato correttamente!" );
array_push( $_SESSION['infos'],"Creato documento ".$file);
add_storico_doc($iddocumento,"Creazione file XML fattura elettronica");
}
break;
case "add_newordfornitore":
$qta_or = save( $_POST['qta_or'] );
$idriga = save( $_POST['idriga'] );
$idnewdocumento = save( $_POST['idnewdocumento'] );
$query = "SELECT * FROM co_righe_documenti WHERE id='".$idriga."'";
$rs_ord = $dbo->fetchArray($query);
$descrizione = $rs_ord[0]['descrizione'];
$idarticolo = $rs_ord[0]['idarticolo'];
$idiva = $rs_ord[0]['idiva'];
$query = "SELECT prezzo_acquisto , idfornitore FROM mg_articoli WHERE id='".$idarticolo."'";
$rs_art = $dbo->fetchArray($query);
$prezzo_vendita = $rs_art[0]['prezzo_acquisto'];
$idanagrafica=$rs_art[0]['idfornitore'];
if( $idnewdocumento != '' ){
$idrif_ordine=$idnewdocumento ;
$lotto = "";
$serial = "";
$altro = "";
$qta = force_decimal( $html->form('qta_or', 'post') );
$sconto = "";
$tipo_sconto = "EUR";
$sconto_prc = '';
$sconto = '';
add_articolo_inordine( $id_record,$idriga,$idnewdocumento, $idarticolo, $descrizione, $idiva, $qta, $prezzo_vendita*$qta, $sconto, $sconto_prc, $tipo_sconto, $lotto, $serial, $altro );
array_push( $_SESSION['infos'], "Articolo aggiunto ad ordine fornitore!" );
}else{
$dir="uscita";
$idtipoordine = '1';
// $data = date(Now);
if( $idanagrafica <> '' ){
$numero = get_new_numeroordine( $data );
$numero_esterno = get_new_numerosecondarioordine( $data );
//Tipo di pagamento predefinito dall'anagrafica fornitore
$query = "SELECT id FROM co_pagamenti WHERE id=(SELECT idpagamento FROM an_anagrafiche WHERE idanagrafica='".$idanagrafica."')";
$rs = $dbo->fetchArray($query);
$idpagamento = $rs[0]['id'];
//Se l'ordine è un ordine cliente e non è stato associato un pagamento predefinito al cliente leggo il pagamento dalle impostazioni
if( $dir=='entrata' && $idpagamento=='' )
$idpagamento = get_var("Tipo di pagamento predefinito");
$query = "INSERT INTO or_ordini( numero, numero_esterno, idanagrafica, idtipoordine, idpagamento, data, idstatoordine ) VALUES ( \"".$numero."\", \"".$numero_esterno."\", '$idanagrafica', '$idtipoordine', '$idpagamento', NOW(), (SELECT `id` FROM `or_statiordine` WHERE `descrizione`='Non evaso') )";
$id_record_new = $dbo->query($query);
$idrif_ordine=$id_record_new ;
//aggiungo articolo
$lotto = "";
$serial = "";
$altro = "";
$qta = force_decimal( $html->form('qta_or', 'post') );
$sconto = "";
$tipo_sconto = "EUR";
$sconto_prc = '';
$sconto = '';
add_articolo_inordine($id_record,$idriga,$id_record_new, $idarticolo, $descrizione, $idiva, $qta, $prezzo_vendita*$qta, $sconto, $sconto_prc, $tipo_sconto, $lotto, $serial, $altro );
array_push( $_SESSION['infos'], "Aggiunto ordine numero ".$numero."!" );
}else{
array_push( $_SESSION['infos'], "Non e' presente il fornitore in anagrafica articolo: Ordine non creato" );
}
}
// aggiorno riferimento idordine della riga documento
$dbo->query( "UPDATE co_righe_documenti SET idordine='".$idrif_ordine."' WHERE id=\"".$idriga."\"" );
break;
//Creazione documento da ordine
case "documento_da_ordine":
$totale_fattura = 0.00;
$data = saveDate( $_POST['data'] );
$idanagrafica = intval( $_POST['idanagrafica'] );
$idarticolo = intval( $_POST['idarticolo'] );
$idpagamento = intval( $_POST['idpagamento'] );
$idconto = intval( $_POST['idconto'] );
$idordine = intval( $_POST['idordine'] );
$idtipodocumento = save( $_POST['idnewdocumento'] );
$n_doc_sec = save( $_POST['n_doc_sec'] );
// ricerca se la numerazione e' progressiva o propria
$query = "SELECT mod_num , dir , idconto , idpagamento , sta_apertura ,descrizione , id_gruppo_tipologia FROM co_tipidocumento WHERE id='".$idtipodocumento."'";
$rs_parametri = $dbo->fetchArray($query);
$numerazione_progressiva = $rs_parametri[0]['mod_num'];
$dir = $rs_parametri[0]['dir'];
// $idconto = $rs_parametri[0]['idconto'];
$idpagamento_new = $rs_parametri[0]['idpagamento'];
$idstato = $rs_parametri[0]['sta_apertura'];
$id_gruppodoc=$rs_parametri[0]['id_gruppo_tipologia'];
$tipo_documento=$rs_parametri[0]['descrizione'];
if( $numerazione_progressiva==0) $numero = get_new_numerofattura( $data );
if( $numerazione_progressiva==1) $numero=get_new_numerofattura_multi($data,$idtipodocumento);
if( $dir=='entrata' ){
if( $numerazione_progressiva==0) $numero_esterno = get_new_numerosecondariofattura( $data,$idtipodocumento );
if( $numerazione_progressiva==1) $numero_esterno = get_new_numerosecondariofattura_multi( $data,$idtipodocumento );
}
else{
$numero_esterno = $n_doc_sec;
$forza_numerazione=get_var_tipodoc($idtipodocumento,'forza_numerazione');
if( $forza_numerazione =='1' ){
// forzatura numero progressivo
if( $numerazione_progressiva==0) $numero_esterno = get_new_numerosecondariofattura( $data,$idtipodocumento );
if( $numerazione_progressiva==1) $numero_esterno = get_new_numerosecondariofattura_multi( $data,$idtipodocumento );
}
}
//Creazione nuovo documento
$dbo->query( "INSERT INTO co_documenti( numero, numero_documento,numero_esterno, data, idanagrafica, idtipodocumento, idstatodocumento, idpagamento, idconto , id_gruppo_tipologia , id_ordine_padre ) VALUES( \"".$numero."\", \"".$n_doc_sec."\", \"".$numero."\", \"".$data."\", \"".$idanagrafica."\", (SELECT id FROM co_tipidocumento WHERE descrizione='".$tipo_documento."'), (SELECT id FROM co_statidocumento WHERE descrizione='Bozza'), \"".$idpagamento."\", \"".$idconto."\" ,\"".$id_gruppodoc."\",\"".$idordine."\" )" );
$iddocumento = $dbo->last_inserted_id();
$id_record = $iddocumento;
add_storico_doc($iddocumento,"Creazione documento da Ordine");
//Lettura di tutte le righe della tabella in arrivo
for( $i=0; $i<sizeof($_POST['qta_da_evadere']); $i++ ){
//Processo solo le righe da evadere
if( $_POST['evadere'][$i]=='on' ){
$idrigaordine = save( $_POST['idrigaordine'][$i] );
$idarticolo = save( $_POST['idarticolo'][$i] );
$descrizione = save( $_POST['descrizione'][$i] );
$qta = save( $_POST['qta_da_evadere'][$i] );
$qta = str_replace( ",", ".", $qta );
$um = save( $_POST['um'][$i] );
$subtot = save( $_POST['subtot'][$i]*$qta );
$idiva = save( $_POST['idiva'][$i] );
$iva = save( $_POST['iva'][$i]*$qta );
$sconto = save( $_POST['sconto'][$i] );
$sconto = str_replace( ",", ".", $sconto );
$sconto = $sconto*$qta;
$qprc = "SELECT tipo_sconto, sconto_primo,sconto_extra,sconto_extra1 ,serial FROM or_righe_ordini WHERE id=".$idrigaordine;
$rsprc = $dbo->fetchArray($qprc);
$sconto_primo = $rsprc[0]['sconto_primo'];
$tipo_sconto = $rsprc[0]['tipo_sconto'];
$sconto_extra = $rsprc[0]['sconto_extra'];
$sconto_extra1 = $rsprc[0]['sconto_extra1'];
$serial = $rsprc[0]['serial'];
//Calcolo l'iva indetraibile
$q = "SELECT indetraibile FROM co_iva WHERE id='".$idiva."'";
$rs = $dbo->fetchArray($q);
$iva_indetraibile = $iva/100*$rs[0]['indetraibile'];
//Leggo la descrizione iva
$query = "SELECT * FROM co_iva WHERE id='".$idiva."'";
$rs = $dbo->fetchArray($query);
$desc_iva = $rs[0]['descrizione'];
//Lettura lotto, serial, altro dalla riga dell'ordine
// $q = "SELECT lotto, serial, altro, descrizione FROM or_righe_ordini WHERE id='".$idrigaordine."'";
// $rs = $dbo->fetchArray($q);
$idconto=0;
//Se sto aggiungendo un articolo uso la funzione per inserirlo e incrementare la giacenza
if( $idarticolo != '0' ){
$idiva_acquisto = $idiva;
$prezzo_acquisto = $subtot;
$idriga = add_articolo_infattura( $iddocumento, $idarticolo, $descrizione, $idiva, $qta, $prezzo_acquisto, $sconto, '0' ,'', $serial, '' , $idconto,$tipo_sconto,$sconto_primo,$sconto_extra,$sconto_extra1,'','','','' );
// $idriga=add_articolo_infattura( $iddocumento, $idarticolo, $descrizione, $idiva, $qta, $prezzo*$qta, $sconto, '0', $lotto, $serial, $altro , $idconto,$idtiposconto,$sconto_prc,$sconto_extra,$sconto_extra1 );
//Imposto la provenienza dell'ordine
$dbo->query( "UPDATE co_righe_documenti SET idordine=\"".$idordine."\" , id_riferimento_riga_ordine=\"".$idrigaordine."\" WHERE id=\"".$idriga."\"" );
}
//Inserimento riga normale
else{
$dbo->query( "INSERT INTO co_righe_documenti( id_riferimento_riga_ordine,iddocumento, idarticolo, idordine, idiva, desc_iva, iva, iva_indetraibile, descrizione, subtotale, sconto, tipo_sconto, um, qta , sconto_primo,sconto_extra,sconto_extra1)
VALUES( \"$idrigaordine\",\"$iddocumento\", \"$idarticolo\", \"".$idordine."\", \"".$idiva."\", \"".$desc_iva."\", \"$iva\", \"$iva_indetraibile\", \"".$descrizione."\", \"$subtot\", \"$sconto\", \"$tipo_sconto\", \"$um\", \"$qta\"
,\"$sconto_primo\" ,\"$sconto_extra\" ,\"$sconto_extra1\" )" );
$idriga = $dbo->last_inserted_id();
add_storico_doc($iddocumento,"Inserimento riga generica da Ordine");
}
//Scalo la quantità dall'ordine
$dbo->query("UPDATE or_righe_ordini SET qta_evasa = qta_evasa+".$qta." , id_documento_figlio = ".$iddocumento." WHERE id='".$idrigaordine."'");
}
}
// genero storico transazione
$query="Insert into or_ordini_transazioni (idpadre,idfiglio,data_transazione,idutente) values (\"".$idordine."\", \"".$iddocumento."\",NOW(), '".$_SESSION['idutente']."')";
$dbo->query($query);
// testo righe evasione dell'ordine
$rs_testostato = $dbo->fetchArray("SELECT * FROM or_righe_ordini WHERE qta <> qta_evasa and idordine='".$idordine."'");
if( sizeof($rs_testostato) > 0 ){
$dbo->query( "UPDATE or_ordini SET idstatoordine = 3 where id='".$idordine."'");
}
else{
$dbo->query( "UPDATE or_ordini SET idstatoordine = 2 where id='".$idordine."'");
}
ricalcola_costiagg_fattura($iddocumento);
array_push( $_SESSION['infos'], "Creato nuovo documento da ordine fornitore!" );
break;
case "sendemail_rapportino":
$from_address = str_replace( ",", ".", get_var("Indirizzo per le email in uscita") );
$oggetto = html_entity_decode($_POST['oggetto']);
$allegato = $_POST['allegato'];
$testo_email = html_entity_decode($_POST['body'], ENT_QUOTES);
$destinatario=$_POST['destinatario'];
$messaggio = new PHPmailer(str_replace( ",", ".", get_var("Indirizzo per le email in uscita") ));
$messaggio->FromName = str_replace( ",", ".", get_var("Nome Form Mail") );
$messaggio->From = str_replace( ",", ".", get_var("Indirizzo per le email in uscita") );
$messaggio->AddAddress($destinatario);
$mail_cc=str_replace( ",", ".", get_var("Destinatario fisso in copia (campo CC)"));
if ($mail_cc != ""){
$messaggio->AddCC($mail_cc);
}
$messaggio->Subject=($oggetto);
$testo_email=str_replace("<p>","",$testo_email);
$testo_email=str_replace("</p>","",$testo_email);
$messaggio->CharSet = "UTF-8";
$messaggio->Body=strip_tags($testo_email);
$messaggio->AddAttachment( $allegato );
if(!$messaggio->Send()){
array_push( $_SESSION['infos'], $messaggio->ErrorInfo );
}else{
array_push( $_SESSION['infos'], "Email inviata correttamente" );
add_storico_doc($id_record,"Documento inviato a mezzo mail a:".$destinatario);
}
break;
case "sendemail":
$from_address = str_replace( ",", ".", get_var("Indirizzo per le email in uscita") );
$oggetto = html_entity_decode($_POST['oggetto']);
$allegato = $_POST['allegato'];
$allegato_xml = $_POST['allegato_xml'];
$testo_email = html_entity_decode($_POST['body'], ENT_QUOTES);
$destinatario=$_POST['destinatario'];
$messaggio = new PHPmailer(str_replace( ",", ".", get_var("Indirizzo per le email in uscita") ));
$messaggio->FromName = str_replace( ",", ".", get_var("Nome Form Mail") );
$messaggio->From = str_replace( ",", ".", get_var("Indirizzo per le email in uscita") );
$messaggio->AddAddress($destinatario);
$mail_cc=str_replace( ",", ".", get_var("Destinatario fisso in copia (campo CC)"));
if ($mail_cc != ""){
$messaggio->AddCC($mail_cc);
}
$messaggio->Subject=($oggetto);
$testo_email=str_replace("<p>","",$testo_email);
$testo_email=str_replace("</p>","",$testo_email);
$messaggio->CharSet = "UTF-8";
$messaggio->Body=strip_tags($testo_email);
$messaggio->AddAttachment( $allegato );
if (file_exists($allegato_xml)) {
$messaggio->AddAttachment( $allegato_xml );
}
if(!$messaggio->Send()){
array_push( $_SESSION['infos'], $messaggio->ErrorInfo );
}else{
array_push( $_SESSION['infos'], "Email inviata correttamente" );
add_storico_doc($id_record,"Documento inviato a mezzo mail a:".$destinatario);
}
break;
case"edit_pianifica":
// lettura documento attuale
$query = "SELECT * FROM co_documenti WHERE id='".$iddocumento."'";
$rs_doc= $dbo->fetchArray($query);
$idtecnico = intval( $_POST['idanagrafica'] );
$idstatointervento = save( $_POST['idstatointervento'] );
$idtipointervento = save( $_POST['idtipointervento'] );
$descrizione = save( $_POST['descrizione'] );
$id_matricola = save( $_POST['id_matricola'] );
$idriga = save( $_POST['idriga'] );
$periodo = saveDate( $_POST['data'] );
$periodo_f = saveDate( $_POST['data_f'] );
$orario = savetime( $_POST['orario'] );
$orario_fine = savetime( $_POST['orario_fine'] );
$or=date("H:i", strtotime($orario));
$or_f=date("H:i", strtotime($orario_fine));
$qta = save( $_POST['qta'] );
$qta_min = save( $_POST['qta_min'] );
$qta_min_calcolo = save( $_POST['qta_min'] );
$idsede=$rs_doc[0]['idsede'];
$richiesta=$rs_doc[0]['note'];
$query = "SELECT * FROM in_interventi WHERE idintervento='".$iddocumento."'";
$rs_int= $dbo->fetchArray($query);
$test_da=date("Y-m-d", strtotime($periodo))." ".$or.":00";
$test_a=date("Y-m-d", strtotime($periodo_f))." ".$or_f.":00";
$qana = "SELECT * FROM my_impianti WHERE nome='".$id_matricola."'";
$rs_matricola = $dbo->fetchArray($qana);
$inserisci="1";
$query_s = "SELECT * FROM in_interventi_tecnici WHERE idintervento='".$rs_doc[0]['id']."' and idtecnico='".$idtecnico."'";
$rs_test= $dbo->fetchArray($query_s);
for( $i=0; $i<sizeof($rs_test); $i++ ){
$or_in=$rs_test[$i]['orario_inizio'];
$or_fi=$rs_test[$i]['orario_fine'];
if (( $test_da > $or_in ) && ( $test_da < $or_fi )) {
$inserisci="0";
}
if (( $test_a > $or_in ) && ( $test_a < $or_fi )) {
$inserisci="0";
}
if( $inserisci == '1' ){
if (( $test_da < $or_in ) || ( $test_da < $or_fi )) {
$inserisci="0";
if ( $test_a < $or_fi ) {
$inserisci="1";
}
}
}
}
if( $inserisci == '0' ){
array_push( $_SESSION['errors'], "Pianificazione gia presente per questo tecnico e periodo" );
}
else{
if( sizeof($rs_int) > 0 ){
}
else{
$dbo->query("INSERT INTO in_interventi( idintervento, idanagrafica, idtipointervento, idstatointervento, idsede, data_richiesta ) VALUES
(\"".$rs_doc[0]['id']."\", \"".$rs_doc[0]['idanagrafica']."\", \"".$idtipointervento."\", \"".$idstatointervento."\", \"".$idsede."\", \"".$periodo."\" )" );
}
$dbo->query("INSERT INTO in_interventi_tecnici( id_riga_riferimento_documento,id_impianto,matricola_impianto,descrizione_att ,idintervento, idtecnico, idtipointervento, idstatointervento,km, orario_inizio, orario_fine )
VALUES( \"".$idriga."\",\"".$rs_matricola[0]['id']."\",\"".$rs_matricola[0]['matricola']."\",\"".$descrizione."\",\"".$rs_doc[0]['id']."\", \"".$idtecnico."\", \"".$idtipointervento."\", \"".$idstatointervento."\", \"".$km."\", \"".( date("Y-m-d", strtotime($periodo)) )." ".$or."\", \"".( date("Y-m-d", strtotime($periodo_f)) )." ".$or_f."\")" );
array_push( $_SESSION['infos'], "Pianificazione inserita" );
add_storico_doc($id_record,"Eseguita pianificazione attivita");
}
break;
case "modifica_pianifica":
// lettura documento attuale
$query = "SELECT id FROM co_documenti WHERE id='".$iddocumento."'";
$rs_doc= $dbo->fetchArray($query);
$idtecnico = intval( $_POST['idanagrafica'] );
$idstatointervento = save( $_POST['idstatointervento'] );
$idtipointervento = save( $_POST['idtipointervento'] );
$descrizione = save( $_POST['descrizione1'] );
$idriga = save( $_POST['idriga'] );
$id_matricola = save( $_POST['id_matricola'] );
$periodo = saveDate( $_POST['data'] );
$periodo_f = saveDate( $_POST['data_f'] );
$orario = savetime( $_POST['orario'] );
$orario_fine = savetime( $_POST['orario_fine'] );
$or=date("H:i", strtotime($orario));
$or_f=date("H:i", strtotime($orario_fine));
$test_da=date("Y-m-d", strtotime($periodo))." ".$or.":00";
$test_a=date("Y-m-d", strtotime($periodo_f))." ".$or_f.":00";
$inserisci="1";
$query_s = "SELECT * FROM in_interventi_tecnici WHERE idintervento='".$rs_doc[0]['id']."' and idtecnico='".$idtecnico."'";
$rs_test= $dbo->fetchArray($query_s);
// Info matricola
$qana = "SELECT * FROM my_impianti WHERE matricola='".$id_matricola."'";
$rs_matricola = $dbo->fetchArray($qana);
for( $i=0; $i<sizeof($rs_test); $i++ ){
$or_in=$rs_test[$i]['orario_inizio'];
$or_fi=$rs_test[$i]['orario_fine'];
$id_r=$rs_test[$i]['id'];
if (( $test_da > $or_in ) && ( $test_da < $or_fi ) ) {
if ( $idriga != $id_r ) $inserisci="0";
}
if (( $test_a > $or_in ) && ( $test_a < $or_fi ) ) {
if ( $idriga != $id_r ) $inserisci="0";
}
if( $inserisci == '1' ){
if (( $test_da < $or_in ) || ( $test_da < $or_fi ) ) {
if ( $idriga != $id_r ) $inserisci="0";
if ( $test_a < $or_fi ) {
$inserisci="1";
}
}
}
}
if( $inserisci == '0' ){
array_push( $_SESSION['errors'], "Pianificazione gia presente per questo tecnico e periodo" );
}
else{
// prelevo eventuale firMa e poi elimino old record
$query = "SELECT id , id_riga_riferimento_documento, firma_file , firma_data FROM in_interventi_tecnici WHERE id='".$idriga."'";
$rs_firma= $dbo->fetchArray($query);
$firma_file=$rs_firma[0]['firma_file'];
$firma_data=$rs_firma[0]['firma_data'];
$id_old=$rs_firma[0]['id'];
$id_riga_riferimento_documento=$rs_firma[0]['id_riga_riferimento_documento'];
$dbo->query( "DELETE FROM in_interventi_tecnici WHERE id='$idriga'" );
$qta = save( $_POST['qta'] );
$qta_min = save( $_POST['qta_min'] );
$qta_min_calcolo = save( $_POST['qta_min'] );
$idsede="0";
$dbo->query("INSERT INTO in_interventi_tecnici( id,id_riga_riferimento_documento, id_impianto,matricola_impianto,firma_file,firma_data,descrizione_att,idintervento, idtecnico, idtipointervento, idstatointervento,km, orario_inizio, orario_fine )
VALUES( \"".$id_old."\" , \"".$id_riga_riferimento_documento."\" , \"".$rs_matricola[0]['id']."\",\"".$rs_matricola[0]['matricola']."\" , \"".$firma_file."\",\"".$firma_data."\",\"".$descrizione."\",\"".$rs_doc[0]['id']."\", \"".$idtecnico."\", \"".$idtipointervento."\", \"".$idstatointervento."\", \"".$km."\", \"".( date("Y-m-d", strtotime($periodo)) )." ".$or."\", \"".( date("Y-m-d", strtotime($periodo_f)) )." ".$or_f."\")" );
array_push( $_SESSION['infos'], "Pianificazione modificata" );
add_storico_doc($id_record,"Eseguita modifica pianificazione attivita");
}
break;
case "unlink_pianifica":
$idriga = $_SESSION['idriga_pianificazione'] ;
if( sizeof($idriga) > 0 ){
$dbo->query( "DELETE FROM in_interventi_tecnici WHERE id='$idriga'" );
array_push( $_SESSION['infos'], "Pianificazione eliminata" );
add_storico_doc($id_record,"Rimossa pianificazione attivita");
$_SESSION['idriga_pianificazione'] ="";
}
break;
case "documento_differito";
$iddocumento_padre = save( $_POST['id_documentopadre'] );
doc_differito_crea($id_record,$iddocumento_padre,'0' );
array_push( $_SESSION['infos'], "Creato nuovo documento!" );
add_storico_doc($id_record,"Creazione documento differito");
break;
case "firma":
if( $modules_info[$module_name]["permessi"] == 'rw' ){
$query = "SELECT id , idintervento FROM in_interventi_tecnici WHERE id='".$id_record."'";
$rs_doc= $dbo->fetchArray($query);
$id_record=$rs_doc[0]['idintervento'];
$id_riga=$rs_doc[0]['id'];
$directory_exists = false;
if( !file_exists($docroot."/files/interventi") ){
if( @mkdir($docroot."/files/interventi") ){
$directory_exists = true;
}
}
else{
$directory_exists = true;
}
if( $directory_exists ){
if( $html->form('firma_base64', 'post') != '' ){
//Salvataggio firma
$firma_file = "firma_".time().".png";
$firma_nome = $_POST['firma_nome'];
$ifp = @fopen( $docroot."/files/interventi/".$firma_file, "wb" );
$data = explode(',', $html->form('firma_base64', 'post') );
@fwrite( $ifp, base64_decode($data[1]) );
@fclose( $ifp );
if( $dbo->query("UPDATE in_interventi_tecnici SET firma_file=\"".$firma_file."\", firma_data=NOW(), firma_nome = \"".$firma_nome."\" WHERE id=\"".$id_riga."\"") ){
array_push( $_SESSION['infos'], "Firma salvata correttamente!" );
add_storico_doc($id_record,"Eseguita firma attivita");
}
else{
array_push( $_SESSION['errors'], "Errore durante il salvataggio della firma nel database!" );
}
}
else{
array_push( $_SESSION['errors'], "Errore durante il salvataggio della firma! La firma risulta vuota..." );
}
}
else{
array_push( $_SESSION['errors'], "Non è stato possibile creare la cartella <b>/files/interventi</b> per salvare l'immagine della firma!" );
}
}
break;
case "addriga_spese_pianifica":
$idintervento = $html->form('idintervento', 'post');
$idriga = $html->form('idriga', 'post');
$data_mov = saveDate( $_POST['data_mov'] );
$descrizione = $html->form('descrizione', 'post');
$qta = force_decimal( $html->form('qta', 'post') );
$um = "";
$prezzo_vendita = force_decimal( $html->form('prezzo_vendita', 'post') );
$prezzo_acquisto= "0";
$sconto_prc = "0";
$sconto = "0";
$dbo->query("INSERT INTO in_righe_interventi( data_movimento ,idriga_pianifica,descrizione, qta, um, prezzo_vendita, prezzo_acquisto, sconto, sconto_prc, idintervento ) VALUES
( \"".$data_mov."\",\"".$idriga."\",\"".$descrizione."\", \"".$qta."\", \"".$um."\", \"".$prezzo_vendita."\", \"".$prezzo_acquisto."\", \"".$sconto."\", \"".$sconto_prc."\",\"".$idintervento."\" )");
break;
case "delriga":
$idriga = $html->form('idriga', 'post');
$dbo->query("DELETE FROM in_righe_interventi WHERE id='".$idriga."'");
break;
case "delrigaart":
$idriga = $html->form('idriga', 'post');
$dbo->query("DELETE FROM mg_articoli_interventi WHERE id='".$idriga."'");
break;
case "inserisco_riga_come_posizione":
$query = "SELECT * FROM in_righe_interventi WHERE idintervento='".$iddocumento."'";
$rs_riga = $dbo->fetchArray($query);
//Processo solo le righe con qta da evadere maggiore di zero
for( $i=0; $i<sizeof($rs_riga); $i++ ){
$idarticolo=$rs_riga[$i]['idarticolo'];
$idconto=query_secca("","id_conto","mg_articoli","where id='".$idarticolo."'");
$qta = $rs_riga[$i]['qta'];
$prezzo = $rs_riga[$i]['prezzo_vendita'];
$ins_doppia=0;
//Calcolo iva
$idiva = get_var("Iva predefinita");
$query = "SELECT * FROM co_iva WHERE id='".$idiva."'";
$rs = $dbo->fetchArray($query);
$iva = ($prezzo-$sconto)/100*$rs[0]['percentuale'];
$iva_indetraibile = $iva/100*$rs[0]['indetraibile'];
$desc_iva = $rs[0]['descrizione'];
$idconto=get_var_documento($iddocumento,'idconto');
//Aggiunta riga generica sul documento
$query = "INSERT INTO co_righe_documenti( iddocumento, idiva, desc_iva, iva, iva_indetraibile, descrizione, subtotale, sconto, um, qta, idrivalsainps,
rivalsainps, idritenutaacconto, ritenutaacconto,idconto)
VALUES( \"$iddocumento\", \"".$idiva."\", \"$desc_iva\", \"$iva\", \"$iva_indetraibile\", '".$rs_riga[$i]['descrizione']."', \"$prezzo\", \"$sconto\", \"$um\", \"$qta\", '',
'', '', '' , \"".$idconto."\" )";
$dbo->query($query);
}
array_push( $_SESSION['infos'], "Inserito righe come posizioni" );
break;
case "inserisco_art_come_posizione":
$query = "SELECT * FROM mg_articoli_interventi WHERE idintervento='".$iddocumento."'";
$rs_riga = $dbo->fetchArray($query);
//Processo solo le righe con qta da evadere maggiore di zero
$id_magazzino_e = get_var_tipodoc2($iddocumento,"id_magazzino_e");
for( $i=0; $i<sizeof($rs_riga); $i++ ){
$idarticolo=$rs_riga[$i]['idarticolo'];
$idconto=query_secca("","id_conto","mg_articoli","where id='".$idarticolo."'");
$qta = $rs_riga[$i]['qta'];
$prezzo = $rs_riga[$i]['prezzo_vendita'];
$ins_doppia=0;
$riga_canone=0;
$riga_canone1=0;
// cerco evantuali posizioni di contratto fisse se presente un contratto associato
if( $records[0]['id_contratto'] != "0" && $records[0]['id_contratto'] != "" ){
$qta_consumata=cerca_canone_qta($records[0]['id_contratto'],$idarticolo);
$qta_scalare=cerca_canone_qta_scalare($records[0]['id_contratto'],$idarticolo);
$prezzo_imposto=cerca_canone_prezzo($records[0]['id_contratto'],$idarticolo);
$qta_disp=$qta_scalare - $qta_consumata;
if( $qta_scalare != '' ){
$riga_canone=1;
if( $qta_disp >= $qta ){
$prezzo="0";
}else{
$qta_new=$qta - $qta_disp;;
$prezzo_new =$prezzo;
$qta=$qta_disp;
$prezzo="0";
$ins_doppia=1;
$riga_canone1=2;
$prezzo_tmp = cerca_canone_prezzo($records[0]['id_contratto'],$idarticolo);
if( $prezzo_tmp != '' ) $prezzo_new=$prezzo_tmp;
}
}else{
// la qta disponibile non presente , cerco eventuale prezzo imposto
$riga_canone1=2;
$riga_canone=2;
$prezzo_new = cerca_canone_prezzo($records[0]['id_contratto'],$idarticolo);
if( $prezzo_new != '' ) $prezzo=$prezzo_new;
if( $prezzo_new == '' ) $riga_canone=0;
}
$forza_zero=cerca_contratti_a_zero($records[0]['id_contratto']);
if( $forza_zero == '1' ){
$prezzo_new=0;
$prezzo=0;
$riga_canone=2;
$riga_canone1=2;
}
}
$idriga = add_articolo_infattura( $iddocumento, $idarticolo, $rs_riga[$i]['descrizione'], $rs_riga[$i]['idiva_vendita'], $qta, $prezzo, 0, '0', '', '', '' ,$idconto,'',0,0,0,$idmagazzino,$riga_canone);
//Imposto la provenienza del documento e la qta ottenuta dalla transazione
$qana = "SELECT matricola FROM my_impianti WHERE id='".$records[0]['id_impianto']."'";
$rs_matricola = $dbo->fetchArray($qana);
$matricola=$rs_matricola[0]['matricola'];
$dbo->query( "UPDATE co_righe_documenti SET inserito_posizione_idriga ='".$rs_riga[$i]['idarticolo']."', id_impianto='".$records[0]['id_impianto']."' ,matricola_impianto='".$matricola."' WHERE id=\"".$idriga."\"" );
if($ins_doppia=='1'){
$idriga = add_articolo_infattura2( $iddocumento, $idarticolo, $rs_riga[$i]['descrizione'], $idiva, $qta_new, $prezzo_new*$qta_new, $sconto_new, '0', '', '', '' , $idconto,'','','','' ,$idmagazzino , $riga_canone1 );
$dbo->query( "UPDATE co_righe_documenti SET inserito_posizione_idriga ='".$rs_riga[$i]['idarticolo']."', id_impianto='".$records[0]['id_impianto']."' ,matricola_impianto='".$matricola."' WHERE id=\"".$idriga."\"" );
}
}
array_push( $_SESSION['infos'], "Inserito articoli come posizioni" );
break;
case "addarticolo_p":
$idarticolo = $html->form('idarticolo', 'post');
$idriga = $html->form('idriga', 'post');
$data_mov = saveDate( $_POST['data_mov'] );
$idintervento = $html->form('idintervento', 'post');
$descrizione = $html->form('descrizione', 'post');
$idimpianto = $html->form('idimpianto', 'post');
$lotto = $html->form('lotto', 'post');
$serial = $html->form('serial', 'post');
$altro = $html->form('altro', 'post');
$qta = $html->form('qta', 'post', true, 'decimal');
$um = query_secca("","idum","mg_articoli","where id ='".$idarticolo."'");
$um = query_secca("","valore","mg_unitamisura","where id ='".$um."'");
$prezzo_acquisto= "0";
$prezzo_vendita = $html->form('prezzo_vendita', 'post', true, 'decimal');
$sconto_unitario= "0";
$sconto_prc = "0";
//Aggiunto il collegamento fra l'articolo e l'intervento
$dbo->query("INSERT INTO mg_articoli_interventi( data_movimento ,idriga_pianifica,idarticolo, idintervento, idimpianto, idautomezzo, descrizione, lotto, serial, altro, prezzo_vendita, prezzo_acquisto, sconto, sconto_prc, idiva_vendita, qta, um ) VALUES
( \"".$data_mov."\",\"".$idriga."\",'".$idarticolo."', '".$idintervento."', '".$idimpianto."', '".$idautomezzo."', \"".$descrizione."\", \"".$lotto."\", \"".$serial."\", \"".$altro."\", \"".$prezzo_vendita."\", \"".$prezzo_acquisto."\", \"".$sconto_unitario."\", \"".$sconto_prc."\", (SELECT idiva_vendita FROM mg_articoli WHERE id=\"".$idarticolo."\"), \"".$qta."\", \"".$um."\" )");
break;
case "editnumero":
$new_numero = $html->form('new_numero', 'post');
$tipo_documento=get_var_tipodoc2($iddocumento,'idtipodocumento');
$query = "SELECT numero_esterno FROM co_documenti WHERE numero_esterno='".$new_numero."' and idtipodocumento='".$tipo_documento."'";
$rs = $dbo->fetchArray($query);
if (sizeof($rs) > 0) {
array_push( $_SESSION['errors'], "Il numero documento ".$new_numero." gia presente in archivio" );
}
else{
$suffisso=get_var_tipodoc2($iddocumento,'txt_suffisso');
$suffisso_anno=get_var_tipodoc2($iddocumento,'suffisso_anno');
$numero_documento=$suffisso.$new_numero;
if( $suffisso_anno==1) $numero_documento = $numero_documento."_".date("Y");
$dbo->query( "UPDATE co_documenti SET numero_esterno = '".$new_numero."' , numero_documento = '".$numero_documento."' WHERE id='".$iddocumento."'" );
array_push( $_SESSION['infos'], "Modifica numero documento salvata" );
add_storico_doc($iddocumento,"Modificato numero documento");
}
break;
case "editnumero_protocollo":
$new_numero = $html->form('new_numero', 'post');
$query = "SELECT numero_esterno FROM co_documenti WHERE id_protocollo='".$new_numero."'";
$rs = $dbo->fetchArray($query);
if (sizeof($rs) > 0) {
array_push( $_SESSION['errors'], "Il numero protoccolo ".$new_numero." gia presente in archivio" );
}
else{
$dbo->query( "UPDATE co_documenti SET id_protocollo = '".$new_numero."' WHERE id='".$iddocumento."'" );
array_push( $_SESSION['infos'], "Modifica numero portocollo salvata" );
add_storico_doc($iddocumento,"Modificato numero protocollo");
}
break;
case "editanagrafica":
$new_anagrafica = $html->form('idanagrafica_new', 'post');
$idagente=query_secca("","idagente","an_anagrafiche","where idanagrafica ='".$new_anagrafica."'");
$idbanca_vendite=query_secca("","idagente","an_anagrafiche","where idanagrafica ='".$new_anagrafica."'");
$dbo->query( "UPDATE co_documenti SET idanagrafica = '".$new_anagrafica."' , idbanca_vendite='".$idbanca_vendite."' , idagente='".$idagente."' , idsede='0' , matricola='' WHERE id='".$iddocumento."'" );
array_push( $_SESSION['infos'], "Modifica anagrafica documento salvata" );
add_storico_doc($iddocumento,"Modificato anagrafica documento");
break;
case "add_duplica":
$idtipodocumento = save( $_POST['idintervento'] );
$idanagrafica = save( $_POST['idanagrafica'] );
if ( $idtipodocumento <> '' ) {
// cerco impostazioni tipo documento
$idagente=query_secca("","idagente","an_anagrafiche","where idanagrafica ='".$idanagrafica."'");
$idbanca_vendite=query_secca("","idagente","an_anagrafiche","where idanagrafica ='".$new_anagrafica."'");
$idsede=get_var_tipodoc2($iddocumento ,'idsede');
$numerazione_progressiva=get_var_tipodoc($idtipodocumento,'mod_num');
$dir=get_var_tipodoc($idtipodocumento,'dir');
$idconto=get_var_tipodoc($idtipodocumento,'idconto');
$matricola=get_var_documento($iddocumento ,'matricola');
$idpagamento_new=get_var_tipodoc($idtipodocumento,'idpagamento');
$idstato=get_var_tipodoc($idtipodocumento,'sta_apertura');
$id_gruppodoc=get_var_tipodoc($idtipodocumento,'id_gruppo_tipologia');
$suffisso=get_var_tipodoc($idtipodocumento,'txt_suffisso');
$suffisso_anno=get_var_tipodoc($idtipodocumento,'suffisso_anno');
$ordine_servizio=get_var_tipodoc($idtipodocumento,'mod_ordineservizio');
$idmagazzino=get_var_tipodoc($idtipodocumento,'id_magazzino_e');
$data=date("Y-m-d");
if( $numerazione_progressiva==0) $numero = get_new_numerofattura( $data );
if( $numerazione_progressiva==1) $numero=get_new_numerofattura_multi($data,$idtipodocumento);
if( $dir=='entrata' ){
if( $numerazione_progressiva==0) $numero_esterno = get_new_numerosecondariofattura( $data,$idtipodocumento );
if( $numerazione_progressiva==1) $numero_esterno = get_new_numerosecondariofattura_multi( $data,$idtipodocumento );
}
else{
$numero_esterno = '';
$forza_numerazione=get_var_tipodoc($idtipodocumento,'forza_numerazione');
if( $forza_numerazione =='1' ){
// forzatura numero progressivo
if( $numerazione_progressiva==0) $numero_esterno = get_new_numerosecondariofattura( $data,$idtipodocumento );
if( $numerazione_progressiva==1) $numero_esterno = get_new_numerosecondariofattura_multi( $data,$idtipodocumento );
}
}
$numero_documento=$suffisso.$numero_esterno;
if( $suffisso_anno==1) $numero_documento = $numero_documento."_".date("Y");
//Creazione nuovo documento
//Tipo di pagamento predefinito dall'anagrafica
$query = "SELECT id FROM co_pagamenti WHERE id=(SELECT idpagamento FROM an_anagrafiche WHERE idanagrafica='".$idanagrafica."')";
$rs = $dbo->fetchArray($query);
$idpagamento = $rs[0]['id'];
$tab_testata=" co_documenti ";
$tab_righe=" co_righe_documenti ";
$tab_transazione=" co_documenti_transazioni ";
// testo se devo inserire il protocollo
$nuovo_id_protocollo=0;
$mod_prodotollo = get_var_tipodoc($idtipodocumento,'mod_prodotollo');
if( $mod_prodotollo=='1' ){
$query = "SELECT IFNULL(MAX(id_protocollo),'0') AS max_protocollo FROM co_documenti WHERE DATE_FORMAT( data, '%Y' ) = '".date("Y", strtotime($data))."' ORDER BY CAST(id_protocollo AS UNSIGNED) DESC LIMIT 0,1";
$rs = $dbo->fetchArray($query);
$nuovo_id_protocollo = $rs[0]['max_protocollo']+1;
}
// impostazione data protocollo
if( date ('d') <= 15){
$data_prot = date ('Y/m/15');
}else{
$data_prot = date ('Y/m/t');
}
//Se la fattura è di vendita e non è stato associato un pagamento predefinito al cliente leggo il pagamento dalle impostazioni
if( $dir=='entrata' && $idpagamento=='' ) $idpagamento = $idpagamento_new;
$query = "INSERT INTO ".$tab_testata." ( id_protocollo,data_prot,idbanca_vendite,idagente , numero, numero_esterno,numero_documento, id_gruppo_tipologia,idanagrafica, idconto, idtipodocumento, idpagamento, data, idstatodocumento, idsede , matricola) VALUES
( \"".$nuovo_id_protocollo."\",\"".$data_prot."\",\"".$idbanca_vendite."\",\"".$idagente."\",\"".$numero."\", \"".$numero_esterno."\", \"".$numero_documento."\",\"".$id_gruppodoc."\",\"".$idanagrafica."\", \"".$idconto."\", \"".$idtipodocumento."\", \"".$idpagamento."\", NOW() ,
\"".$idstato."\",\"".$idsede."\",\"".$matricola."\")";
$dbo->query($query);
$iddocumento_new = $dbo->last_inserted_id();
$query = "SELECT * FROM co_righe_documenti WHERE iddocumento='".$iddocumento."' order by id";
$rs_riga = $dbo->fetchArray($query);
for( $ri=0; $ri<sizeof($rs_riga); $ri++ ){
if( $rs_riga[$ri]['riga_varia'] == '1' ){
$query = "INSERT INTO co_righe_documenti( iddocumento, descrizione , riga_varia) VALUES( '".$iddocumento_new."','".$rs_riga[$ri]['descrizione']."', '1' )";
$dbo->fetchArray($query);
}else{
if( $rs_riga[$ri]['idarticolo'] == '0' ){
$query = "INSERT INTO co_righe_documenti( iddocumento, idiva, desc_iva, iva, iva_indetraibile, descrizione, subtotale, sconto, um, qta, idrivalsainps, rivalsainps,
idritenutaacconto, ritenutaacconto,idconto,tipo_sconto,sconto_primo,sconto_extra ,sconto_extra1,importo_agente,importo_iva_agente,perc_agente)
VALUES( \"$iddocumento_new\", '".$rs_riga[$ri]['idiva']."','".$rs_riga[$ri]['desc_iva']."','".$rs_riga[$ri]['iva']."','".$rs_riga[$ri]['iva_indetraibile']."','".$rs_riga[$ri]['descrizione']."','
".$rs_riga[$ri]['subtotale']."','".$rs_riga[$ri]['sconto']."','".$rs_riga[$ri]['um']."','".$rs_riga[$ri]['qta']."','".$rs_riga[$ri]['idrivalsainps']."','
".$rs_riga[$ri]['rivalsainps']."','".$rs_riga[$ri]['idritenutaacconto']."','".$rs_riga[$ri]['ritenutaacconto']."','".$rs_riga[$ri]['idconto']."','".$rs_riga[$ri]['tipo_sconto']."',
'".$rs_riga[$ri]['sconto_primo']."','".$rs_riga[$ri]['sconto_extra']."','".$rs_riga[$ri]['sconto_extra1']."','".$rs_riga[$ri]['importo_agente']."','".$rs_riga[$ri]['importo_iva_agente']."','".$rs_riga[$ri]['perc_agente']."')";
$dbo->fetchArray($query);
}else{
$idriga = add_articolo_infattura( $iddocumento_new, $rs_riga[$ri]['idarticolo'], $rs_riga[$ri]['descrizione'], $rs_riga[$ri]['idiva'], $rs_riga[$ri]['qta'], $rs_riga[$ri]['subtotale'],$rs_riga[$ri]['sconto'], '0', '', '', '' ,
$rs_riga[$ri]['idconto'],$rs_riga[$ri]['tipo_sconto'],$rs_riga[$ri]['sconto_primo'],$rs_riga[$ri]['sconto_extra'],$rs_riga[$ri]['sconto_extra1'],$rs_riga[$ri]['id_magazzino'],'','','' );
}
}
}
array_push( $_SESSION['infos'], "Aggiunto documento numero ".$numero_documento."!" );
add_storico_doc($iddocumento,"Generato nuovo documento con la funzione duplica");
add_storico_doc($iddocumento_new,"Documento generato da Duplica");
}
break;
case "edit_stato_invio_xml":
$id_progressivo = save( $_POST['id_progressivo'] );
$id_stato_invio = save( $_POST['idintervento'] );
$data_invio_xml = saveDate( $_POST['data_invio_xml'] );
$orario = savetime( $_POST['orario'] );
$or=date("H:i", strtotime($orario));
$data_invio_xml=date("Y-m-d", strtotime($data_invio_xml))." ".$or.":00";
if ( $id_progressivo <> '' ) {
$dbo->query( "UPDATE co_documenti_progressivo SET inviato = '".$id_stato_invio."' , data_invio='".$data_invio_xml."' WHERE id='".$id_progressivo."'" );
array_push( $_SESSION['infos'], "Stato invio modificato" );
}
break;
case "edit_esito_invio_xml":
$id_progressivo = save( $_POST['id_progressivo'] );
$id_stato_invio = save( $_POST['idintervento'] );
$data_invio_xml = saveDate( $_POST['data_invio_xml'] );
$orario = savetime( $_POST['orario'] );
$or=date("H:i", strtotime($orario));
$data_invio_xml=date("Y-m-d", strtotime($data_invio_xml))." ".$or.":00";
if ( $id_progressivo <> '' ) {
$dbo->query( "UPDATE co_documenti_progressivo SET esito = '".$id_stato_invio."' , data_esito='".$data_invio_xml."' WHERE id='".$id_progressivo."'" );
array_push( $_SESSION['infos'], "Stato invio modificato" );
}
break;
case "edit_link_xml":
$id_link = save( $_POST['id_link'] );
$iddocumento = save( $_POST['iddocumento'] );
$query="Insert into co_documenti_transazioni (idpadre,idfiglio,data_transazione,idutente) values (\"".$id_link."\", \"".$iddocumento."\",NOW(), '".$_SESSION['idutente']."')";
$dbo->query($query);
break;
case "add_qta":
$idriga = save( $_POST['idriga'] );
mod_riga($idriga,"A") ;
break;
case "del_qta":
$idriga = save( $_POST['idriga'] );
mod_riga($idriga,"S") ;
break;
case "firma_totale":
if( $modules_info[$module_name]["permessi"] == 'rw' ){
$directory_exists = false;
if( !file_exists($docroot."/files/interventi_complessivo") ){
if( @mkdir($docroot."/files/interventi_complessivo") ){
$directory_exists = true;
}
}
else{
$directory_exists = true;
}
if( $directory_exists ){
if( $html->form('firma_base64', 'post') != '' ){
//Salvataggio firma
$firma_file = "firma_".time().".png";
$firma_nome = $_POST['firma_nome'];
$ifp = @fopen( $docroot."/files/interventi_complessivo/".$firma_file, "wb" );
$data = explode(',', $html->form('firma_base64', 'post') );
@fwrite( $ifp, base64_decode($data[1]) );
@fclose( $ifp );
if( $dbo->query("UPDATE in_interventi SET firma_file=\"".$firma_file."\", firma_data=NOW(), firma_nome = \"".$firma_nome."\" WHERE idintervento=\"".$id_record."\"") ){
$dbo->query("UPDATE co_documenti SET firma_file=\"".$firma_file."\", firma_data=NOW(), firma_nome = \"".$firma_nome."\" WHERE id=\"".$id_record."\"");
array_push( $_SESSION['infos'], "Firma salvata correttamente!" );
}
else{
array_push( $_SESSION['errors'], "Errore durante il salvataggio della firma nel database!" );
}
}
else{
array_push( $_SESSION['errors'], "Errore durante il salvataggio della firma! La firma risulta vuota..." );
}
}
else{
array_push( $_SESSION['errors'], "Non è stato possibile creare la cartella <b>/files/interventi</b> per salvare l'immagine della firma!" );
}
}
break;
}
?>