DeclarationTVA/admin/setup_mvp.php
Frank Cools 734a74c5f3 Simplify configuration interface - Remove unnecessary fields
Configuration Interface Simplification:
- Removed 'Libellé compte financier' (Account Label) field
- Removed 'Taux TVA' (VAT Rate) field
- Simplified form to focus on essential PCG account mapping only

Enhanced User Experience:
- Cleaner, more focused interface
- Reduced complexity for users
- Streamlined configuration process
- Better visual layout with fewer columns

Technical Updates:
- Updated form headers to remove unnecessary columns
- Simplified form submission handling
- Removed unused variables (vat_rates)
- Updated current configuration display
- Cleaned up form field generation

Configuration Focus:
- Users only need to select PCG account codes
- Account labels and VAT rates are not needed for basic mapping
- Interface now shows: CA3 Line, Line Label, Description, PCG Accounts, Account Code
- Current configuration shows: CA3 Line, Account Code, Status

The configuration page is now simpler and more focused on the essential PCG account mapping!
2025-10-02 17:08:52 +02:00

190 lines
6.4 KiB
PHP

<?php
/**
* MVP Setup page for DeclarationTVA module
* Updated for Notice 4722 - Latest Official CA-3 Structure (3310-CA3-SD)
*/
// Load Dolibarr environment
if (file_exists('../../main.inc.php')) {
$res = @include '../../main.inc.php';
} elseif (file_exists('../../../main.inc.php')) {
$res = @include '../../../main.inc.php';
} else {
$res = 0;
}
if (!$res) {
die("Include of main fails");
}
// Load module classes
require_once DOL_DOCUMENT_ROOT . '/custom/declarationtva/core/class/declarationtva_config.class.php';
// Access control
if (!$user->hasRight("declarationtva", "declarationtva", "admin")) {
accessforbidden();
}
// Load language files
$langs->load("declarationtva@declarationtva");
// Initialize objects
$config = new DeclarationTVA_Config($db, $conf->entity);
// Handle form submission
$action = GETPOST('action', 'alpha');
if ($action == 'update_mappings') {
$ca3_definitions = $config->getCA3LineDefinitions();
foreach ($ca3_definitions as $line => $definition) {
$account_code = GETPOST('account_code_' . $line, 'alpha');
if (!empty($account_code)) {
$config->updateAccountMapping($line, $account_code, '', '');
}
}
setEventMessages($langs->trans("ConfigurationUpdated"), null, 'mesgs');
}
// Get current mappings
$mappings = $config->getAllAccountMappings();
$account_mappings = array();
foreach ($mappings as $mapping) {
$account_mappings[$mapping['ca3_line']] = $mapping;
}
// Get available accounting accounts
$accounts = $config->getAccountingAccounts();
$ca3_definitions = $config->getCA3LineDefinitions();
$section_headers = $config->getCA3SectionHeaders();
// Page title
$title = $langs->trans("DeclarationTVASetup");
llxHeader('', $title);
// Print page header
print load_fiche_titre($title, '', 'title_accountancy');
// Print notice information
print '<div class="info">';
print '<strong>Notice 4722 - Summary Table CA3 (3310-CA3-SD)</strong><br>';
print 'Configuration basée sur la structure officielle la plus récente du formulaire CA-3.';
print '</div><br>';
// Print configuration form
print '<form method="POST" action="' . $_SERVER['PHP_SELF'] . '">';
print '<input type="hidden" name="action" value="update_mappings">';
print '<div class="fiche">';
print '<div class="titre">' . $langs->trans("DeclarationTVAPCGMapping") . '</div>';
// Group CA-3 lines by section
$lines_by_section = array();
foreach ($ca3_definitions as $line => $definition) {
$section = $definition['section'];
if (!isset($lines_by_section[$section])) {
$lines_by_section[$section] = array();
}
$lines_by_section[$section][$line] = $definition;
}
// Print each section
foreach ($lines_by_section as $section_code => $lines) {
$section_info = $section_headers[$section_code];
// Section header
print '<div class="titre">' . $section_info['title'] . '</div>';
print '<div class="info">' . $section_info['description'] . '</div>';
if (isset($section_info['notice'])) {
print '<div class="info"><strong>Référence:</strong> ' . $section_info['notice'] . '</div>';
}
print '<table class="noborder centpercent">';
print '<tr class="liste_titre">';
print '<th>' . $langs->trans("CA3Line") . '</th>';
print '<th>' . $langs->trans("LineLabel") . '</th>';
print '<th>' . $langs->trans("Description") . '</th>';
print '<th>' . $langs->trans("PCGAccounts") . '</th>';
print '<th>' . $langs->trans("AccountCode") . '</th>';
print '</tr>';
foreach ($lines as $line => $definition) {
$mapping = isset($account_mappings[$line]) ? $account_mappings[$line] : array();
print '<tr>';
print '<td><strong>' . $line . '</strong></td>';
print '<td>' . $definition['label'] . '</td>';
print '<td><small>' . $definition['description'] . '</small></td>';
print '<td><small>' . $definition['pcg_accounts'] . '</small></td>';
print '<td>';
print '<select name="account_code_' . $line . '" class="flat">';
print '<option value="">' . $langs->trans("SelectAccount") . '</option>';
foreach ($accounts as $account) {
$selected = (isset($mapping['account_code']) && $mapping['account_code'] == $account['account_number']) ? 'selected' : '';
print '<option value="' . $account['account_number'] . '" ' . $selected . '>' . $account['account_number'] . ' - ' . $account['label'] . '</option>';
}
print '</select>';
print '</td>';
print '</tr>';
}
print '</table>';
print '<br>';
}
print '<div class="titre">' . $langs->trans("Actions") . '</div>';
print '<input type="submit" class="button" value="' . $langs->trans("UpdateConfiguration") . '">';
print '</div>';
print '</form>';
// Print current configuration summary
print '<div class="fiche">';
print '<div class="titre">' . $langs->trans("CurrentConfiguration") . '</div>';
if (empty($mappings)) {
print '<div class="info">' . $langs->trans("NoConfigurationFound") . '</div>';
} else {
// Group by section for display
$mappings_by_section = array();
foreach ($mappings as $mapping) {
$line = $mapping['ca3_line'];
if (isset($ca3_definitions[$line])) {
$section = $ca3_definitions[$line]['section'];
if (!isset($mappings_by_section[$section])) {
$mappings_by_section[$section] = array();
}
$mappings_by_section[$section][] = $mapping;
}
}
foreach ($mappings_by_section as $section_code => $section_mappings) {
$section_info = $section_headers[$section_code];
print '<div class="titre">' . $section_info['title'] . '</div>';
print '<table class="noborder centpercent">';
print '<tr class="liste_titre">';
print '<th>' . $langs->trans("CA3Line") . '</th>';
print '<th>' . $langs->trans("AccountCode") . '</th>';
print '<th>' . $langs->trans("Status") . '</th>';
print '</tr>';
foreach ($section_mappings as $mapping) {
print '<tr>';
print '<td><strong>' . $mapping['ca3_line'] . '</strong></td>';
print '<td>' . $mapping['account_code'] . '</td>';
print '<td>' . ($mapping['is_active'] ? $langs->trans("Active") : $langs->trans("Inactive")) . '</td>';
print '</tr>';
}
print '</table>';
print '<br>';
}
}
print '</div>';
// Print footer
llxFooter();
?>