38471-vm/pages/accounting_logic.php
2026-05-03 02:57:40 +00:00

103 lines
4.9 KiB
PHP

<?php
if (function_exists('ensureAccountingSchema')) {
ensureAccountingSchema();
}
if ($_SERVER['REQUEST_METHOD'] !== 'POST' && function_exists('seedDefaultAccountingAccounts')) {
seedDefaultAccountingAccounts();
}
if ($_SERVER['REQUEST_METHOD'] === 'POST') {
if (isset($_POST['seed_default_accounts'])) {
$added = function_exists('seedDefaultAccountingAccounts') ? seedDefaultAccountingAccounts() : 0;
$message = $added > 0
? "Main chart of accounts seeded successfully! {$added} account(s) added."
: 'Main chart of accounts already exists. Parent links were checked.';
redirectWithMessage($message, 'index.php?page=accounting&view=coa');
}
if (isset($_POST['add_account'])) {
$parentId = isset($_POST['parent_id']) && $_POST['parent_id'] !== '' ? (int)$_POST['parent_id'] : null;
$result = createAccountingAccount(
$_POST['code'] ?? '',
$_POST['name_en'] ?? '',
$_POST['name_ar'] ?? '',
$_POST['type'] ?? '',
$parentId
);
if (!empty($result['success'])) {
redirectWithMessage('Account added successfully!', 'index.php?page=accounting&view=coa');
}
redirectWithMessage((string)($result['error'] ?? 'Unable to save the account right now.'), 'index.php?page=accounting&view=coa');
}
}
if (isset($_GET['action']) && $_GET['action'] === 'get_entry_details') {
header('Content-Type: application/json');
$id = (int)($_GET['id'] ?? 0);
$stmt = db()->prepare(
"SELECT l.*, a.name_en, a.code FROM acc_ledger l JOIN acc_accounts a ON l.account_id = a.id WHERE l.journal_entry_id = ?"
);
$stmt->execute([$id]);
echo json_encode($stmt->fetchAll());
exit;
}
$page_num = isset($_GET['p']) && is_numeric($_GET['p']) ? (int)$_GET['p'] : 1;
$limit = 50;
$offset = ($page_num - 1) * $limit;
$total_entries = (int)db()->query("SELECT COUNT(*) FROM acc_journal_entries")->fetchColumn();
$data['total_pages'] = max(1, (int)ceil($total_entries / $limit));
$data['current_page'] = $page_num;
$data['journal_entries'] = db()->query("SELECT je.*,
(SELECT SUM(debit) FROM acc_ledger WHERE journal_entry_id = je.id) as total_debit
FROM acc_journal_entries je
ORDER BY je.entry_date DESC, je.id DESC LIMIT $limit OFFSET $offset")->fetchAll();
$data['accounts'] = db()->query("SELECT * FROM acc_accounts ORDER BY code ASC")->fetchAll();
if (isset($_GET['view']) && $_GET['view'] === 'trial_balance') {
$data['trial_balance'] = db()->query("SELECT a.code, a.name_en, SUM(l.debit) as total_debit, SUM(l.credit) as total_credit
FROM acc_accounts a
LEFT JOIN acc_ledger l ON a.id = l.account_id
GROUP BY a.id
HAVING total_debit > 0 OR total_credit > 0
ORDER BY a.code ASC")->fetchAll();
}
if (isset($_GET['view']) && $_GET['view'] === 'profit_loss') {
$data['revenue_accounts'] = db()->query("SELECT code, name_en, name_ar FROM acc_accounts WHERE type = 'revenue' AND parent_id IS NOT NULL ORDER BY code ASC")->fetchAll();
$data['expense_accounts'] = db()->query("SELECT code, name_en, name_ar FROM acc_accounts WHERE type = 'expense' AND parent_id IS NOT NULL ORDER BY code ASC")->fetchAll();
}
if (isset($_GET['view']) && $_GET['view'] === 'balance_sheet') {
$data['asset_accounts'] = db()->query("SELECT code, name_en, name_ar FROM acc_accounts WHERE type = 'asset' AND parent_id IS NOT NULL ORDER BY code ASC")->fetchAll();
$data['liability_accounts'] = db()->query("SELECT code, name_en, name_ar FROM acc_accounts WHERE type = 'liability' AND parent_id IS NOT NULL ORDER BY code ASC")->fetchAll();
$data['equity_accounts'] = db()->query("SELECT code, name_en, name_ar FROM acc_accounts WHERE type = 'equity' AND parent_id IS NOT NULL ORDER BY code ASC")->fetchAll();
}
if (isset($_GET['view']) && $_GET['view'] === 'vat_report') {
$start = $_GET['start_date'] ?? date('Y-m-01');
$end = $_GET['end_date'] ?? date('Y-m-d');
$data['vat_report'] = getVatReport($start, $end);
$data['start_date'] = $start;
$data['end_date'] = $end;
}
if (isset($_GET['view']) && $_GET['view'] === 'coa') {
$data['coa'] = db()->query("SELECT a.*, p.name_en as parent_name
FROM acc_accounts a
LEFT JOIN acc_accounts p ON a.parent_id = p.id
ORDER BY a.code ASC")->fetchAll();
$data['coa_summary'] = [
'total' => count($data['coa']),
'parents' => count(array_filter($data['coa'], static fn($account) => empty($account['parent_id']))),
'children' => count(array_filter($data['coa'], static fn($account) => !empty($account['parent_id']))),
];
}