Overview
Comment: | Mise à jour du modèle, passer de journal à mouvements |
---|---|
Downloads: | Tarball | ZIP archive | SQL archive |
Timelines: | family | ancestors | descendants | both | dev |
Files: | files | file ages | folders |
SHA1: |
bde8f826e829a68ab7e12486a4e1be8c |
User & Date: | bohwaz on 2020-01-29 15:32:01 |
Other Links: | branch diff | manifest | tags |
Context
2020-01-29
| ||
15:32 | Suppression de la cotisation obligatoire pour les catégories check-in: 84710d146c user: bohwaz tags: dev | |
15:32 | Mise à jour du modèle, passer de journal à mouvements check-in: bde8f826e8 user: bohwaz tags: dev | |
15:31 | Référencer le bon namespace check-in: 98ab6988f4 user: bohwaz tags: dev | |
Changes
Modified src/include/lib/Garradin/Compta/Journal.php from [88e9a2c624] to [6361a8ebe9].
︙ | ︙ | |||
31 32 33 34 35 36 37 | { if (is_null($id)) return true; return DB::getInstance()->test('compta_exercices', 'cloture = 0 AND id = ?', (int)$id); } | | < < < < | > | < > | < | < | < < < | | 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 | { if (is_null($id)) return true; return DB::getInstance()->test('compta_exercices', 'cloture = 0 AND id = ?', (int)$id); } public function getSolde(int $id_compte, ?int $id_exercice = null): int { $db = DB::getInstance(); $solide = (int) $db->firstColumn('SELECT SUM(credit) - SUM(debit) FROM compta_mouvements_lignes AS l INNER JOIN compta_mouvements AS m ON m.id = l.id_mouvement WHERE compte = ? AND m.id_exercice = ?;', $id_compte, $id_exercice); $position = $db->firstColumn('SELECT position FROM compta_comptes WHERE id = ?;', $id_compte); // L'actif augmente au débit, le passif au crédit if (($position & Comptes::ACTIF) || ($position & Comptes::CHARGE)) { $solde = -$solde; } return $solde; } public function getJournalCompte($compte, $inclure_sous_comptes = false, $exercice = null) { $db = DB::getInstance(); $position = $db->firstColumn('SELECT position FROM compta_comptes WHERE id = ?;', $compte); |
︙ | ︙ | |||
167 168 169 170 171 172 173 | public function get($id) { $db = DB::getInstance(); return $db->first('SELECT *, strftime(\'%s\', date) AS date FROM compta_journal WHERE id = ?;', $id); } /** | | | | 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 | public function get($id) { $db = DB::getInstance(); return $db->first('SELECT *, strftime(\'%s\', date) AS date FROM compta_journal WHERE id = ?;', $id); } /** * Compte le nombre d'écritures créées par un membre * @param integer $id Numéro de membre * @return integer Nombre d'écritures liées */ public function countForMember($id) { $db = DB::getInstance(); return $db->count('compta_mouvements', $db->where('id_auteur', $id)); } /** * Lister les écritures liées à un membre * @param integer $id Identifiant de membre * @param integer $exercice Identifiant d'exercice * @return array Liste des écritures liées |
︙ | ︙ |
Modified src/include/lib/Garradin/Compta/Stats.php from [5104b17973] to [2aec4ff612].
︙ | ︙ | |||
43 44 45 46 47 48 49 | } public function depenses() { return $this->_parType(Categories::DEPENSES); } | | < < < < < < < < < | | < < < < < < < < | < | | | 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 | } public function depenses() { return $this->_parType(Categories::DEPENSES); } public function soldeCompte(int $compte, ?int $id_exercice = null) { $db = DB::getInstance(); $stats = $this->getAssoc('SELECT strftime(\'%Y%m\', m.date), SUM(credit) - SUM(debit) FROM compta_mouvements_lignes AS l INNER JOIN compta_mouvements AS m ON m.id = l.id_mouvement WHERE compte = ? AND id_exercice = ? GROUP BY strftime(\'%Y%m\', m.date) ORDER BY m.date;'); $c = 0; foreach ($stats as $k=>$v) { $c += $v; $stats[$k] = $c; } |
︙ | ︙ |