fix correction fonction fec
This commit is contained in:
parent
ebd98b58d2
commit
54f80a72f4
@ -2277,26 +2277,33 @@ class PageController extends Controller
|
|||||||
// //$file = $userFolder->get('myfile2.txt');
|
// //$file = $userFolder->get('myfile2.txt');
|
||||||
}
|
}
|
||||||
/**
|
/**
|
||||||
* @NoAdminRequired
|
* @NoAdminRequired
|
||||||
* @NoCSRFRequired
|
* @NoCSRFRequired
|
||||||
*/
|
*/
|
||||||
public function apiReloadFec() {
|
public function apiReloadFec()
|
||||||
$this->reloadFec();
|
{
|
||||||
return new DataResponse("", 200, ['Content-Type' => 'application/json']);
|
$this->reloadFec();
|
||||||
}
|
return new DataResponse("", 200, ['Content-Type' => 'application/json']);
|
||||||
|
}
|
||||||
|
|
||||||
private function reloadFec(){
|
private function reloadFec()
|
||||||
$current_config = json_decode($this->myDb->getConfiguration($this->idNextcloud));
|
{
|
||||||
$clean_folder = html_entity_decode($current_config[0]->path).'/';
|
$current_config = json_decode($this->myDb->getConfiguration($this->idNextcloud));
|
||||||
|
$clean_folder = html_entity_decode($current_config[0]->path).'/';
|
||||||
|
|
||||||
try {
|
try {
|
||||||
try {
|
try {
|
||||||
$data_factures = array();
|
$data_factures = array();
|
||||||
$factures = json_decode($this->myDb->getFacturesListWithDependencies());
|
$factures = json_decode($this->myDb->getFacturesListWithDependencies());
|
||||||
|
|
||||||
foreach ($factures as $key => $facture) {
|
foreach ($factures as $key => $facture) {
|
||||||
$factureIsSingle = $facture->facture_type == FactureTypeConstant::TYPE_SINGLE;
|
$factureIsSingle = $facture->facture_type == FactureTypeConstant::TYPE_SINGLE;
|
||||||
|
|
||||||
|
// Logique TVA : si tva = 0 alors 0%, si tva = 1 alors taux par défaut
|
||||||
|
$tva_rate = 0; // Par défaut
|
||||||
|
if (isset($facture->tva) && $facture->tva == 1) {
|
||||||
|
$tva_rate = isset($current_config[0]->tva_default) ? floatval($current_config[0]->tva_default) : 0;
|
||||||
|
}
|
||||||
|
|
||||||
$facture_temp = array(
|
$facture_temp = array(
|
||||||
'num' => $facture->num,
|
'num' => $facture->num,
|
||||||
@ -2306,41 +2313,29 @@ class PageController extends Controller
|
|||||||
'date_facture' => $facture->date_paiement,
|
'date_facture' => $facture->date_paiement,
|
||||||
'defunt' => $facture->nom_defunt,
|
'defunt' => $facture->nom_defunt,
|
||||||
'montant_htc' => 0,
|
'montant_htc' => 0,
|
||||||
'tva' => $current_config[0]->tva_default,
|
'tva' => $tva_rate, // Utiliser le taux calculé
|
||||||
'montant_tva' => 0,
|
'montant_tva' => 0,
|
||||||
'montant_ttc' => 0,
|
'montant_ttc' => 0,
|
||||||
);
|
);
|
||||||
|
|
||||||
if($factureIsSingle) {
|
if($factureIsSingle) {
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
$produits = json_decode($this->getProduitsById($facture->id_devis));
|
$produits = json_decode($this->getProduitsById($facture->id_devis));
|
||||||
foreach ($produits as $key => $produit) {
|
if ($produits) {
|
||||||
$htPrice = $produit->prix_unitaire;
|
foreach ($produits as $key => $produit) {
|
||||||
if($facture->fk_client_group_id != null || $facture->fk_client_group_id != 0) {
|
$htPrice = isset($produit->prix_unitaire) ? floatval($produit->prix_unitaire) : 0;
|
||||||
$price = $this->myDb->getProductPriceByClientGroupId($facture->fk_client_group_id, $produit->id);
|
if($facture->fk_client_group_id != null || $facture->fk_client_group_id != 0) {
|
||||||
if($price != null) {
|
$price = $this->myDb->getProductPriceByClientGroupId($facture->fk_client_group_id, $produit->id);
|
||||||
$htPrice = $price;
|
if($price != null) {
|
||||||
|
$htPrice = floatval($price);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
$quantite = isset($produit->quantite) ? floatval($produit->quantite) : 0;
|
||||||
|
$facture_temp['montant_htc'] += $htPrice * $quantite;
|
||||||
}
|
}
|
||||||
$facture_temp['montant_htc'] += $htPrice * $produit->quantite;
|
}
|
||||||
};
|
|
||||||
$facture_temp['montant_tva'] = ($facture_temp['montant_htc'] * $facture_temp['tva']) / 100;
|
$facture_temp['montant_tva'] = ($facture_temp['montant_htc'] * $facture_temp['tva']) / 100;
|
||||||
$facture_temp['montant_ttc'] = $facture_temp['montant_tva'] + $facture_temp['montant_htc'];
|
$facture_temp['montant_ttc'] = $facture_temp['montant_tva'] + $facture_temp['montant_htc'];
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
$devis = $this->myDb->getDevisByFkFactureId($facture->id);
|
$devis = $this->myDb->getDevisByFkFactureId($facture->id);
|
||||||
$factureGroupIsRelatedToAnyDevis = $devis != null;
|
$factureGroupIsRelatedToAnyDevis = $devis != null;
|
||||||
$mentionFilters = [
|
$mentionFilters = [
|
||||||
@ -2348,7 +2343,6 @@ class PageController extends Controller
|
|||||||
DevisMentionConstant::FACTURED_FORMATTED
|
DevisMentionConstant::FACTURED_FORMATTED
|
||||||
];
|
];
|
||||||
|
|
||||||
|
|
||||||
$isFactureGroupForSingleClient = $facture->facture_client_id != null && $facture->facture_client_id != 0;
|
$isFactureGroupForSingleClient = $facture->facture_client_id != null && $facture->facture_client_id != 0;
|
||||||
if($isFactureGroupForSingleClient) {
|
if($isFactureGroupForSingleClient) {
|
||||||
$facture_temp["client"] = $facture->facture_client_entreprise;
|
$facture_temp["client"] = $facture->facture_client_entreprise;
|
||||||
@ -2383,190 +2377,194 @@ class PageController extends Controller
|
|||||||
$devisList = $this->myDb->getDevisByClientIdByFactureId($facture->id, $mentionFilters);
|
$devisList = $this->myDb->getDevisByClientIdByFactureId($facture->id, $mentionFilters);
|
||||||
}
|
}
|
||||||
|
|
||||||
foreach($devisList as $currentDevis) {
|
if (isset($devisList)) {
|
||||||
|
foreach($devisList as $currentDevis) {
|
||||||
|
$produits = json_decode($this->getProduitsById($currentDevis['id']));
|
||||||
|
if ($produits) {
|
||||||
|
foreach ($produits as $key => $produit) {
|
||||||
|
$htPrice = isset($produit->prix_unitaire) ? floatval($produit->prix_unitaire) : 0;
|
||||||
|
if($currentDevis["fk_client_group_id"] != null || $currentDevis["fk_client_group_id"] != 0) {
|
||||||
|
$price = $this->myDb->getProductPriceByClientGroupId($currentDevis["fk_client_group_id"], $produit->id);
|
||||||
|
if($price != null) {
|
||||||
$produits = json_decode($this->getProduitsById($currentDevis['id']));
|
$htPrice = floatval($price);
|
||||||
foreach ($produits as $key => $produit) {
|
}
|
||||||
$htPrice = $produit->prix_unitaire;
|
}
|
||||||
if($currentDevis["fk_client_group_id"] != null || $currentDevis["fk_client_group_id"] != 0) {
|
$quantite = isset($produit->quantite) ? floatval($produit->quantite) : 0;
|
||||||
$price = $this->myDb->getProductPriceByClientGroupId($currentDevis["fk_client_group_id"], $produit->id);
|
$facture_temp['montant_htc'] += $htPrice * $quantite;
|
||||||
if($price != null) {
|
|
||||||
$htPrice = $price;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
$facture_temp['montant_htc'] += $htPrice * $produit->quantite;
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
};
|
|
||||||
}
|
}
|
||||||
$facture_temp['montant_tva'] = ($facture_temp['montant_htc'] * $facture_temp['tva']) / 100;
|
$facture_temp['montant_tva'] = ($facture_temp['montant_htc'] * $facture_temp['tva']) / 100;
|
||||||
$facture_temp['montant_ttc'] = $facture_temp['montant_tva'] + $facture_temp['montant_htc'];
|
$facture_temp['montant_ttc'] = $facture_temp['montant_tva'] + $facture_temp['montant_htc'];
|
||||||
}
|
}
|
||||||
|
|
||||||
array_push($data_factures, $facture_temp);
|
array_push($data_factures, $facture_temp);
|
||||||
};
|
}
|
||||||
|
|
||||||
$data_temp = array();
|
$data_temp = array();
|
||||||
foreach ($data_factures as $key => $facture) {
|
foreach ($data_factures as $key => $facture) {
|
||||||
$datesplit = explode('-', $facture['date_facture']);
|
if (isset($facture['date_facture']) && !empty($facture['date_facture'])) {
|
||||||
if($data_temp[strval($datesplit[0])] == null) {
|
$datesplit = explode('-', $facture['date_facture']);
|
||||||
$data_temp[strval($datesplit[0])][strval($datesplit[1])] = array(0 => $facture);
|
if (count($datesplit) >= 2) {
|
||||||
} else {
|
$annee = strval($datesplit[0]);
|
||||||
if($data_temp[strval($datesplit[0])][strval($datesplit[1])] == null) {
|
$mois = strval($datesplit[1]);
|
||||||
$data_temp[strval($datesplit[0])][strval($datesplit[1])] = array(0 => $facture);
|
|
||||||
} else {
|
if($data_temp[$annee] == null) {
|
||||||
array_push($data_temp[strval($datesplit[0])][strval($datesplit[1])], $facture);
|
$data_temp[$annee][$mois] = array(0 => $facture);
|
||||||
|
} else {
|
||||||
|
if($data_temp[$annee][$mois] == null) {
|
||||||
|
$data_temp[$annee][$mois] = array(0 => $facture);
|
||||||
|
} else {
|
||||||
|
array_push($data_temp[$annee][$mois], $facture);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
$fec_headers_txt = [
|
|
||||||
utf8_decode('JOURNALCODE'),
|
|
||||||
utf8_decode('JOURNALLIB'),
|
|
||||||
utf8_decode('ECRITURENUM'),
|
|
||||||
utf8_decode('ECRITUREDATE'),
|
|
||||||
utf8_decode('COMPTENUM'),
|
|
||||||
utf8_decode('COMPTELIB'),
|
|
||||||
utf8_decode('COMPAUXLIB'),
|
|
||||||
utf8_decode('COMPAUXNUM'),
|
|
||||||
utf8_decode('PIECEREF'),
|
|
||||||
utf8_decode('PIECEDATE'),
|
|
||||||
utf8_decode('ECRITURELIB'),
|
|
||||||
utf8_decode('DEBIT'),
|
|
||||||
utf8_decode('CREDIT'),
|
|
||||||
utf8_decode('ECRITURELET'),
|
|
||||||
utf8_decode('DATELET'),
|
|
||||||
utf8_decode('VALIDDATE'),
|
|
||||||
utf8_decode('MONTANTDEVISE'),
|
|
||||||
utf8_decode('IDEVISE'),
|
|
||||||
];
|
|
||||||
//parcours annee
|
|
||||||
foreach ($data_temp as $key_annee => $annee) {
|
|
||||||
//parcours annee
|
|
||||||
$_clean_folder = $clean_folder.'FEC/'.$key_annee.'/';
|
|
||||||
try {
|
|
||||||
$this->storage->newFolder($_clean_folder);
|
|
||||||
} catch(\OCP\Files\NotPermittedException $e) { }
|
|
||||||
foreach ($annee as $key_mois => $mois) {
|
|
||||||
// Initialize FEC headers
|
|
||||||
|
|
||||||
$fec_temp_txt = implode(TAB1, $fec_headers_txt) . PHP_EOL . PHP_EOL;
|
$fec_headers_txt = [
|
||||||
$fec_temp = implode(';', $fec_headers_txt) . "\n\n";
|
utf8_decode('JOURNALCODE'),
|
||||||
|
utf8_decode('JOURNALLIB'),
|
||||||
|
utf8_decode('ECRITURENUM'),
|
||||||
|
utf8_decode('ECRITUREDATE'),
|
||||||
|
utf8_decode('COMPTENUM'),
|
||||||
|
utf8_decode('COMPTELIB'),
|
||||||
|
utf8_decode('COMPAUXLIB'),
|
||||||
|
utf8_decode('COMPAUXNUM'),
|
||||||
|
utf8_decode('PIECEREF'),
|
||||||
|
utf8_decode('PIECEDATE'),
|
||||||
|
utf8_decode('ECRITURELIB'),
|
||||||
|
utf8_decode('DEBIT'),
|
||||||
|
utf8_decode('CREDIT'),
|
||||||
|
utf8_decode('ECRITURELET'),
|
||||||
|
utf8_decode('DATELET'),
|
||||||
|
utf8_decode('VALIDDATE'),
|
||||||
|
utf8_decode('MONTANTDEVISE'),
|
||||||
|
utf8_decode('IDEVISE'),
|
||||||
|
];
|
||||||
|
|
||||||
foreach ($mois as $key => $facture) {
|
//parcours annee
|
||||||
// Define FEC entry data
|
foreach ($data_temp as $key_annee => $annee) {
|
||||||
$fec_entries = [
|
//parcours annee
|
||||||
[
|
$_clean_folder = $clean_folder.'FEC/'.$key_annee.'/';
|
||||||
'journal' => 'VT',
|
try {
|
||||||
'journal_lib' => 'VENTES',
|
$this->storage->newFolder($_clean_folder);
|
||||||
'ecriturenum' => '',
|
} catch(\OCP\Files\NotPermittedException $e) {
|
||||||
'date' => $facture['date_facture'],
|
}
|
||||||
'compte' => $facture['client'],
|
|
||||||
'libelle_compte' => $facture['client'],
|
|
||||||
'compauxlib' => '',
|
|
||||||
'compauxnum' => '',
|
|
||||||
'piece' => $facture['num'],
|
|
||||||
'piece_date' => '',
|
|
||||||
'libelle_ecriture' => $facture['nom_client'],
|
|
||||||
'debit' => $facture['montant_ttc'],
|
|
||||||
'credit' => '0',
|
|
||||||
'ecriture_lettrage' => '',
|
|
||||||
'date_lettrage' => '',
|
|
||||||
'valid_date' => '',
|
|
||||||
'montant_devise' => '',
|
|
||||||
'devise' => 'EUR',
|
|
||||||
],
|
|
||||||
[
|
|
||||||
'journal' => 'VT',
|
|
||||||
'journal_lib' => 'VENTES',
|
|
||||||
'ecriturenum' => '',
|
|
||||||
'date' => $facture['date_facture'],
|
|
||||||
'compte' => '706000',
|
|
||||||
'libelle_compte' => 'VENTES DE MARCHANDISES',
|
|
||||||
'compauxlib' => '',
|
|
||||||
'compauxnum' => '',
|
|
||||||
'piece' => $facture['num'],
|
|
||||||
'piece_date' => '',
|
|
||||||
'libelle_ecriture' => $facture['client'],
|
|
||||||
'debit' => '0',
|
|
||||||
'credit' => $facture['montant_htc'],
|
|
||||||
'ecriture_lettrage' => '',
|
|
||||||
'date_lettrage' => '',
|
|
||||||
'valid_date' => '',
|
|
||||||
'montant_devise' => '',
|
|
||||||
'devise' => 'EUR',
|
|
||||||
],
|
|
||||||
[
|
|
||||||
'journal' => 'VT',
|
|
||||||
'journal_lib' => 'VENTES',
|
|
||||||
'ecriturenum' => '',
|
|
||||||
'date' => $facture['date_facture'],
|
|
||||||
'compte' => '445710',
|
|
||||||
'compauxlib' => '',
|
|
||||||
'compauxnum' => '',
|
|
||||||
'libelle_compte' => '',
|
|
||||||
'piece' => $facture['num'],
|
|
||||||
'piece_date' => '',
|
|
||||||
'libelle_ecriture' => $facture['client'],
|
|
||||||
'debit' => '',
|
|
||||||
'credit' => $facture['montant_tva'],
|
|
||||||
'ecriture_lettrage' => '',
|
|
||||||
'date_lettrage' => '',
|
|
||||||
'valid_date' => '',
|
|
||||||
'montant_devise' => '',
|
|
||||||
'devise' => 'EUR',
|
|
||||||
]
|
|
||||||
];
|
|
||||||
|
|
||||||
// Generate FEC entries
|
foreach ($annee as $key_mois => $mois) {
|
||||||
foreach ($fec_entries as $entry) {
|
// Initialize FEC headers
|
||||||
$fec_line_txt = [
|
$fec_temp_txt = implode(TAB1, $fec_headers_txt) . PHP_EOL . PHP_EOL;
|
||||||
$entry['journal'], $entry['journal_lib'], $entry['ecriturenum'], $entry['date'],
|
$fec_temp = implode(';', $fec_headers_txt) . "\n\n";
|
||||||
$entry['compte'], $entry['libelle_compte'],
|
|
||||||
$entry['compauxlib'], $entry['compauxnum'],
|
|
||||||
$entry['piece'], $entry['piece_date'],
|
|
||||||
$entry['libelle_ecriture'], $entry['debit'],$entry['credit'],$entry['ecriture_lettrage'],
|
|
||||||
$entry['date_lettrage'], $entry['valid_date'], $entry['montant_devise'], $entry['devise']
|
|
||||||
];
|
|
||||||
|
|
||||||
$fec_line_csv = [
|
foreach ($mois as $key => $facture) {
|
||||||
$entry['journal'], $entry['journal_lib'], $entry['ecriturenum'], $entry['date'],
|
// Define FEC entry data
|
||||||
$entry['compte'], $entry['libelle_compte'],
|
$fec_entries = [
|
||||||
$entry['compauxlib'], $entry['compauxnum'],
|
[
|
||||||
$entry['piece'], $entry['piece_date'],
|
'journal' => 'VT',
|
||||||
$entry['libelle_ecriture'], $entry['debit'],$entry['credit'],$entry['ecriture_lettrage'],
|
'journal_lib' => 'VENTES',
|
||||||
$entry['date_lettrage'], $entry['valid_date'], $entry['montant_devise'], $entry['devise']
|
'ecriturenum' => '',
|
||||||
];
|
'date' => $facture['date_facture'],
|
||||||
|
'compte' => $facture['client'],
|
||||||
|
'libelle_compte' => $facture['client'],
|
||||||
|
'compauxlib' => '',
|
||||||
|
'compauxnum' => '',
|
||||||
|
'piece' => $facture['num'],
|
||||||
|
'piece_date' => '',
|
||||||
|
'libelle_ecriture' => $facture['nom_client'],
|
||||||
|
'debit' => $facture['montant_ttc'],
|
||||||
|
'credit' => '0',
|
||||||
|
'ecriture_lettrage' => '',
|
||||||
|
'date_lettrage' => '',
|
||||||
|
'valid_date' => '',
|
||||||
|
'montant_devise' => '',
|
||||||
|
'devise' => 'EUR',
|
||||||
|
],
|
||||||
|
[
|
||||||
|
'journal' => 'VT',
|
||||||
|
'journal_lib' => 'VENTES',
|
||||||
|
'ecriturenum' => '',
|
||||||
|
'date' => $facture['date_facture'],
|
||||||
|
'compte' => '706000',
|
||||||
|
'libelle_compte' => 'VENTES DE MARCHANDISES',
|
||||||
|
'compauxlib' => '',
|
||||||
|
'compauxnum' => '',
|
||||||
|
'piece' => $facture['num'],
|
||||||
|
'piece_date' => '',
|
||||||
|
'libelle_ecriture' => $facture['client'],
|
||||||
|
'debit' => '0',
|
||||||
|
'credit' => $facture['montant_htc'],
|
||||||
|
'ecriture_lettrage' => '',
|
||||||
|
'date_lettrage' => '',
|
||||||
|
'valid_date' => '',
|
||||||
|
'montant_devise' => '',
|
||||||
|
'devise' => 'EUR',
|
||||||
|
],
|
||||||
|
[
|
||||||
|
'journal' => 'VT',
|
||||||
|
'journal_lib' => 'VENTES',
|
||||||
|
'ecriturenum' => '',
|
||||||
|
'date' => $facture['date_facture'],
|
||||||
|
'compte' => '445710',
|
||||||
|
'compauxlib' => '',
|
||||||
|
'compauxnum' => '',
|
||||||
|
'libelle_compte' => '',
|
||||||
|
'piece' => $facture['num'],
|
||||||
|
'piece_date' => '',
|
||||||
|
'libelle_ecriture' => $facture['client'],
|
||||||
|
'debit' => '',
|
||||||
|
'credit' => $facture['montant_tva'],
|
||||||
|
'ecriture_lettrage' => '',
|
||||||
|
'date_lettrage' => '',
|
||||||
|
'valid_date' => '',
|
||||||
|
'montant_devise' => '',
|
||||||
|
'devise' => 'EUR',
|
||||||
|
]
|
||||||
|
];
|
||||||
|
|
||||||
$fec_temp_txt .= implode(TAB1, $fec_line_txt) . PHP_EOL . PHP_EOL;
|
// Generate FEC entries
|
||||||
$fec_temp .= implode(';', $fec_line_csv) . "\n\n";
|
foreach ($fec_entries as $entry) {
|
||||||
}
|
$fec_line_txt = [
|
||||||
}
|
$entry['journal'], $entry['journal_lib'], $entry['ecriturenum'], $entry['date'],
|
||||||
$ff = $_clean_folder.'FEC_'.$key_mois.'_'.$key_annee.'.csv';
|
$entry['compte'], $entry['libelle_compte'],
|
||||||
$this->storage->newFile($ff);
|
$entry['compauxlib'], $entry['compauxnum'],
|
||||||
$file = $this->storage->get($ff);
|
$entry['piece'], $entry['piece_date'],
|
||||||
$file->putContent($fec_temp);
|
$entry['libelle_ecriture'], $entry['debit'],$entry['credit'],$entry['ecriture_lettrage'],
|
||||||
|
$entry['date_lettrage'], $entry['valid_date'], $entry['montant_devise'], $entry['devise']
|
||||||
|
];
|
||||||
|
|
||||||
$ff_txt = $_clean_folder.'FEC_'.$key_mois.'_'.$key_annee.'.txt';
|
$fec_line_csv = [
|
||||||
$this->storage->newFile($ff_txt);
|
$entry['journal'], $entry['journal_lib'], $entry['ecriturenum'], $entry['date'],
|
||||||
$file_txt = $this->storage->get($ff_txt);
|
$entry['compte'], $entry['libelle_compte'],
|
||||||
$file_txt->putContent($fec_temp_txt);
|
$entry['compauxlib'], $entry['compauxnum'],
|
||||||
// $file->putContent(implode(';', array('Jane Smith', 'janesmith@example.com', '555-5678')) . "\n");
|
$entry['piece'], $entry['piece_date'],
|
||||||
}
|
$entry['libelle_ecriture'], $entry['debit'],$entry['credit'],$entry['ecriture_lettrage'],
|
||||||
}
|
$entry['date_lettrage'], $entry['valid_date'], $entry['montant_devise'], $entry['devise']
|
||||||
|
];
|
||||||
|
|
||||||
} catch(\OCP\Files\NotFoundException $e) { }
|
$fec_temp_txt .= implode(TAB1, $fec_line_txt) . PHP_EOL . PHP_EOL;
|
||||||
|
$fec_temp .= implode(';', $fec_line_csv) . "\n\n";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
$ff = $_clean_folder.'FEC_'.$key_mois.'_'.$key_annee.'.csv';
|
||||||
|
$this->storage->newFile($ff);
|
||||||
|
$file = $this->storage->get($ff);
|
||||||
|
$file->putContent($fec_temp);
|
||||||
|
|
||||||
} catch(\OCP\Files\NotPermittedException $e) { }
|
$ff_txt = $_clean_folder.'FEC_'.$key_mois.'_'.$key_annee.'.txt';
|
||||||
}
|
$this->storage->newFile($ff_txt);
|
||||||
|
$file_txt = $this->storage->get($ff_txt);
|
||||||
|
$file_txt->putContent($fec_temp_txt);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
} catch(\OCP\Files\NotFoundException $e) {
|
||||||
|
}
|
||||||
|
|
||||||
|
} catch(\OCP\Files\NotPermittedException $e) {
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
private function refreshFEC()
|
private function refreshFEC()
|
||||||
{
|
{
|
||||||
|
|||||||
@ -488,6 +488,13 @@ class Bdd
|
|||||||
client.adresse as adresse_cli,client.mail as mail_cli,
|
client.adresse as adresse_cli,client.mail as mail_cli,
|
||||||
client.telephone as telephone_cli,client.legal_one as legalone_cli,
|
client.telephone as telephone_cli,client.legal_one as legalone_cli,
|
||||||
client.fk_client_group_id as fk_client_group_id,
|
client.fk_client_group_id as fk_client_group_id,
|
||||||
|
COALESCE(
|
||||||
|
client.is_tva,
|
||||||
|
CASE
|
||||||
|
WHEN facture.fk_client_group_facturation_id IS NOT NULL THEN client_group_tva.is_tva
|
||||||
|
ELSE facture_client.is_tva
|
||||||
|
END
|
||||||
|
) as tva,
|
||||||
defunt.id as id_defunt,
|
defunt.id as id_defunt,
|
||||||
defunt.nom as nom_defunt,
|
defunt.nom as nom_defunt,
|
||||||
lieu.id as lid,
|
lieu.id as lid,
|
||||||
@ -502,6 +509,7 @@ class Bdd
|
|||||||
LEFT JOIN ".$this->tableprefix."facture_status as facture_status on facture.fk_facture_status_key = facture_status.facture_status_key
|
LEFT JOIN ".$this->tableprefix."facture_status as facture_status on facture.fk_facture_status_key = facture_status.facture_status_key
|
||||||
LEFT JOIN ".$this->tableprefix."client as facture_client on facture.fk_client_id = facture_client.id
|
LEFT JOIN ".$this->tableprefix."client as facture_client on facture.fk_client_id = facture_client.id
|
||||||
LEFT JOIN ".$this->tableprefix."client_group_facturation as facture_client_group_facturation on facture.fk_client_group_facturation_id = facture_client_group_facturation.id
|
LEFT JOIN ".$this->tableprefix."client_group_facturation as facture_client_group_facturation on facture.fk_client_group_facturation_id = facture_client_group_facturation.id
|
||||||
|
LEFT JOIN ".$this->tableprefix."client as client_group_tva ON facture.fk_client_group_facturation_id = client_group_tva.fk_client_group_facturation_id
|
||||||
ORDER BY facture.id DESC, facture.date_paiement DESC";
|
ORDER BY facture.id DESC, facture.date_paiement DESC";
|
||||||
$result = $this->execSQL($sql, array());
|
$result = $this->execSQL($sql, array());
|
||||||
return $result;
|
return $result;
|
||||||
@ -5510,21 +5518,22 @@ COMMENTAIRES: ".$comment;
|
|||||||
return $devisList;
|
return $devisList;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function getDevisIdsGroupByFactureId($factureId,$mentionFilters = []){
|
public function getDevisIdsGroupByFactureId($factureId, $mentionFilters = [])
|
||||||
|
{
|
||||||
$sql = "SELECT devis.id
|
$sql = "SELECT devis.id
|
||||||
FROM ".$this->tableprefix."devis as devis
|
FROM ".$this->tableprefix."devis as devis
|
||||||
WHERE devis.fk_facture_id = ? ";
|
WHERE devis.fk_facture_id = ? ";
|
||||||
|
|
||||||
$conditions = [$factureId];
|
$conditions = [$factureId];
|
||||||
if(!empty($mentionFilters)){
|
if(!empty($mentionFilters)) {
|
||||||
$mentionsFilterPlaceholders = implode(',', array_fill(0, count($mentionFilters), '?'));
|
$mentionsFilterPlaceholders = implode(',', array_fill(0, count($mentionFilters), '?'));
|
||||||
$sql .= " AND devis.mentions IN ($mentionsFilterPlaceholders)";
|
$sql .= " AND devis.mentions IN ($mentionsFilterPlaceholders)";
|
||||||
$conditions = array_merge($conditions, $mentionFilters);
|
$conditions = array_merge($conditions, $mentionFilters);
|
||||||
}
|
}
|
||||||
$sql.= ";";
|
$sql .= ";";
|
||||||
$devisList = $this->execSQLNoJsonReturn($sql,$conditions);
|
$devisList = $this->execSQLNoJsonReturn($sql, $conditions);
|
||||||
$devisIds = [];
|
$devisIds = [];
|
||||||
foreach($devisList as $devis){
|
foreach($devisList as $devis) {
|
||||||
$devisIds[] = $devis['id'];
|
$devisIds[] = $devis['id'];
|
||||||
}
|
}
|
||||||
return $devisIds;
|
return $devisIds;
|
||||||
@ -6093,7 +6102,7 @@ COMMENTAIRES: ".$comment;
|
|||||||
private function getProductsTotalPrices($products)
|
private function getProductsTotalPrices($products)
|
||||||
{
|
{
|
||||||
$configs = json_decode($this->getConfiguration(BddConstant::DEFAULT_ADMIN_ID_NEXTCLOUD));
|
$configs = json_decode($this->getConfiguration(BddConstant::DEFAULT_ADMIN_ID_NEXTCLOUD));
|
||||||
$currentConfig = $configs[0];
|
$currentConfig = $configs[0];
|
||||||
$totalHt = 0;
|
$totalHt = 0;
|
||||||
$totalTtc = 0;
|
$totalTtc = 0;
|
||||||
foreach ($products as $product) {
|
foreach ($products as $product) {
|
||||||
@ -6109,11 +6118,12 @@ COMMENTAIRES: ".$comment;
|
|||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
|
||||||
private function getDevisIdsListByFactureId($factureId){
|
private function getDevisIdsListByFactureId($factureId)
|
||||||
|
{
|
||||||
$factureData = $this->getFactureByFactureId(factureId: $factureId);
|
$factureData = $this->getFactureByFactureId(factureId: $factureId);
|
||||||
$isFactureGroupOfDevis = $factureData["facture_type"] == FactureTypeConstant::TYPE_GROUP;
|
$isFactureGroupOfDevis = $factureData["facture_type"] == FactureTypeConstant::TYPE_GROUP;
|
||||||
$factureDevisIdsList = [];
|
$factureDevisIdsList = [];
|
||||||
if($isFactureGroupOfDevis){
|
if($isFactureGroupOfDevis) {
|
||||||
$isFactureForSingleClient = $factureData['fk_client_id'] != null && $factureData['fk_client_id'] != 0;
|
$isFactureForSingleClient = $factureData['fk_client_id'] != null && $factureData['fk_client_id'] != 0;
|
||||||
$devisMentionFilters = [
|
$devisMentionFilters = [
|
||||||
DevisMentionConstant::FACTURED_FORMATTED,
|
DevisMentionConstant::FACTURED_FORMATTED,
|
||||||
@ -6122,24 +6132,25 @@ COMMENTAIRES: ".$comment;
|
|||||||
$devis = $this->getDevisByFkFactureId($factureId);
|
$devis = $this->getDevisByFkFactureId($factureId);
|
||||||
$factureGroupIsRelatedToAnyDevis = $devis != null;
|
$factureGroupIsRelatedToAnyDevis = $devis != null;
|
||||||
if (!$factureGroupIsRelatedToAnyDevis) {
|
if (!$factureGroupIsRelatedToAnyDevis) {
|
||||||
if($isFactureForSingleClient){
|
if($isFactureForSingleClient) {
|
||||||
$factureDevisIdsList = $this->getDevisIdsByClientIdAndMonthYear(
|
$factureDevisIdsList = $this->getDevisIdsByClientIdAndMonthYear(
|
||||||
$factureData['fk_client_id'],
|
$factureData['fk_client_id'],
|
||||||
$factureData['month'],
|
$factureData['month'],
|
||||||
$factureData['year'],$devisMentionFilters
|
$factureData['year'],
|
||||||
|
$devisMentionFilters
|
||||||
);
|
);
|
||||||
}else{
|
} else {
|
||||||
$factureDevisIdsList = $this->getDevisIdsByClientGroupFacturationIdAndMonthYear(
|
$factureDevisIdsList = $this->getDevisIdsByClientGroupFacturationIdAndMonthYear(
|
||||||
$factureData['fk_client_group_facturation_id'],
|
$factureData['fk_client_group_facturation_id'],
|
||||||
$factureData['month'],
|
$factureData['month'],
|
||||||
$factureData['year'],$devisMentionFilters
|
$factureData['year'],
|
||||||
|
$devisMentionFilters
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
}else{
|
} else {
|
||||||
$factureDevisIdsList = $this->getDevisIdsGroupByFactureId($factureId, $devisMentionFilters );
|
$factureDevisIdsList = $this->getDevisIdsGroupByFactureId($factureId, $devisMentionFilters);
|
||||||
}
|
}
|
||||||
}
|
} else {
|
||||||
else{
|
|
||||||
$factureDevisIdsList = $factureData['id_devis'] ? [$factureData['id_devis']] : [];
|
$factureDevisIdsList = $factureData['id_devis'] ? [$factureData['id_devis']] : [];
|
||||||
}
|
}
|
||||||
return $factureDevisIdsList;
|
return $factureDevisIdsList;
|
||||||
@ -6151,8 +6162,8 @@ COMMENTAIRES: ".$comment;
|
|||||||
$totalHt = 0;
|
$totalHt = 0;
|
||||||
$totalTtc = 0;
|
$totalTtc = 0;
|
||||||
$tva = 0;
|
$tva = 0;
|
||||||
foreach($factureDevisIds as $devisId){
|
foreach($factureDevisIds as $devisId) {
|
||||||
$clientTvaStatus = $this->getClientTvaStatus($devisId,BddConstant::DEFAULT_ADMIN_ID_NEXTCLOUD);
|
$clientTvaStatus = $this->getClientTvaStatus($devisId, BddConstant::DEFAULT_ADMIN_ID_NEXTCLOUD);
|
||||||
$products = $this->getDevisProduits($devisId);
|
$products = $this->getDevisProduits($devisId);
|
||||||
$totalPrices = $this->getProductsTotalPrices($products);
|
$totalPrices = $this->getProductsTotalPrices($products);
|
||||||
$totalHt += $totalPrices["total_ht"];
|
$totalHt += $totalPrices["total_ht"];
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user