projet de comptabilité personnel simplifié et 100% local
Find a file
le king fu a45e5c3cd0 feat(balance): add LinkTransfersModal + return columns in accounts table
Issue #142 / Bilan #4 — UI for transfer linking + per-account returns.

- New `LinkTransfersModal.tsx`: portal modal with date-range / category /
  free-text filters, multi-select with auto-proposed direction (`in` for
  negative bank amounts, `out` for positive — flippable per row).
  Submits via sequential `linkTransfer` calls; reports per-row failures
  inline (most common case: `transfer_already_linked` on a re-submit).
- `BalanceAccountsTable.tsx`: 4 new columns rendered side-by-side —
  3M / 1A / Since-inception (Modified Dietz via `compute_account_return`)
  + Unadjusted (`(V_end - V_start) / V_start`). Returns load lazily
  after mount via `Promise.all` over (account × horizon); per-cell
  failure leaves the slot at "—" without blocking the rest of the
  table. The actions menu gains a *Link transfers* item that bubbles
  the request up to the parent page. New props:
  `sinceCreationDate` (anchors the since-inception horizon) and
  `onLinkTransfers` (modal opener).
- `BalancePage.tsx`: hosts the new modal, loads the categories list
  once on mount for the filter dropdown, fetches the union of
  `listAccountTransfers` per account so the chart can render markers,
  and threads the earliest snapshot date down to the table. Reload
  is triggered after the modal reports at least one successful link.
- `balance.service.ts`: dropped the unused `BalanceAccountTransfer`
  import to satisfy `tsc --noUnusedLocals`.

`npm run build` clean. `npm test` → 429 passed. Manual sanity check:
the table renders "…" placeholders during the per-row return load,
then resolves to either a percentage or a "—" with the partial
tooltip when the underlying snapshot endpoint is missing.

Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
2026-04-25 16:38:24 -04:00
.claude chore(claude): add project rules and release skill, ignore local state 2026-04-20 20:44:49 -04:00
.forgejo/workflows ci: install libdbus-1-dev for keyring build, drop appimage target (#79) 2026-04-13 20:27:14 -04:00
.github/workflows ci: add PR validation workflow (#60) 2026-04-09 09:21:20 -04:00
config Initial project scaffold: Tauri v2 + React + TypeScript + TailwindCSS v4 2026-02-07 11:05:11 +00:00
docs test(categories): complete test coverage for migration flow (#123) 2026-04-21 19:25:13 -04:00
public fix: address reviewer feedback (#37) 2026-03-11 14:04:34 -04:00
src feat(balance): add LinkTransfersModal + return columns in accounts table 2026-04-25 16:38:24 -04:00
src-tauri fix(balance): use transactions.date column (not transaction_date) 2026-04-25 16:24:13 -04:00
tasks docs: update lessons learned from recent sessions 2026-02-15 13:40:06 +00:00
.gitignore chore(claude): add project rules and release skill, ignore local state 2026-04-20 20:44:49 -04:00
CHANGELOG.fr.md feat(balance): i18n + CHANGELOG for /balance page 2026-04-25 16:08:10 -04:00
CHANGELOG.md feat(balance): i18n + CHANGELOG for /balance page 2026-04-25 16:08:10 -04:00
CLAUDE.md ci: add PR validation workflow (#60) 2026-04-09 09:21:20 -04:00
index.html Initial project scaffold: Tauri v2 + React + TypeScript + TailwindCSS v4 2026-02-07 11:05:11 +00:00
LICENSE Add GPL-3.0 license 2026-03-01 10:10:43 -05:00
package-lock.json chore: release v0.8.4 2026-04-21 19:32:44 -04:00
package.json chore: release v0.8.4 2026-04-21 19:32:44 -04:00
README.md docs: update README for v0.3.7 with new features and Linux support 2026-02-18 07:29:51 -05:00
spec-decisions-refonte-seed-categories-ipc.md docs: add spec decisions and plan for categories IPC seed refactor 2026-04-19 15:35:15 -04:00
spec-issue-66-oauth-keychain.md docs: add WIP specs for OAuth keychain, monetisation, reports, and web 2026-04-20 20:41:00 -04:00
spec-monetisation.md docs: add WIP specs for OAuth keychain, monetisation, reports, and web 2026-04-20 20:41:00 -04:00
spec-plan-refonte-seed-categories-ipc.md docs: add spec decisions and plan for categories IPC seed refactor 2026-04-19 15:35:15 -04:00
spec-refonte-rapports.md docs: add WIP specs for OAuth keychain, monetisation, reports, and web 2026-04-20 20:41:00 -04:00
spec-simpl-resultat-web.md docs: add WIP specs for OAuth keychain, monetisation, reports, and web 2026-04-20 20:41:00 -04:00
tsconfig.json Initial project scaffold: Tauri v2 + React + TypeScript + TailwindCSS v4 2026-02-07 11:05:11 +00:00
tsconfig.node.json Initial project scaffold: Tauri v2 + React + TypeScript + TailwindCSS v4 2026-02-07 11:05:11 +00:00
vite.config.ts fix: address reviewer feedback (#37) 2026-03-11 14:04:34 -04:00

Simpl'Résultat

Application de bureau 100 % locale pour importer, catégoriser et analyser vos transactions financières personnelles ou d'entreprise. Aucune donnée ne quitte votre ordinateur.

Version Windows Linux

Fonctionnalités

  • Import CSV — Importez vos relevés bancaires depuis plusieurs sources avec auto-détection des colonnes et modèles d'import réutilisables
  • Tableau de bord — Vue d'ensemble avec KPIs, répartition par catégorie et dernières transactions
  • Transactions — Parcourez, recherchez et filtrez avec sélection rapide de période
  • Catégorisation automatique — Attribution automatique par mots-clés, avec ajustement manuel
  • Split de transactions — Répartissez une transaction sur plusieurs catégories
  • Budgets — Grille budgétaire 12 mois par catégorie avec modèles et rapport Budget vs Réel
  • Ajustements — Ajustements ponctuels ou récurrents par catégorie
  • Rapports — Tendances mensuelles, répartition par catégorie, évolution dans le temps, budget vs réel
  • Graphiques interactifs — Motifs SVG, menu contextuel (clic droit), détail des transactions par catégorie
  • Profils multiples — Bases de données séparées avec protection PIN optionnelle
  • Export / Import de données — Sauvegarde complète avec chiffrement AES-256-GCM optionnel
  • Mode sombre — Thème sombre avec palette gris chaud
  • Bilingue — Interface disponible en français et en anglais
  • Guide utilisateur intégré — Documentation complète accessible depuis les paramètres, imprimable en PDF
  • Mise à jour automatique — Notifications et installation des nouvelles versions depuis l'application

Installation

Windows

  1. Rendez-vous sur la page Releases
  2. Téléchargez le fichier .exe (installateur NSIS)
  3. Lancez le fichier téléchargé

Note : Windows SmartScreen peut afficher un avertissement car l'application n'est pas signée numériquement. Cliquez sur « Informations complémentaires » puis « Exécuter quand même » pour continuer.

Linux

  1. Rendez-vous sur la page Releases
  2. Téléchargez le format adapté à votre distribution :
    • .deb pour Debian / Ubuntu
    • .rpm pour Fedora / openSUSE
    • .AppImage pour toute distribution (exécutable universel)
  3. Installez le paquet ou lancez l'AppImage directement

Démarrage rapide

1. Choisir ou créer un profil

Au premier lancement, un profil par défaut est créé. Vous pouvez ajouter d'autres profils (chacun avec sa propre base de données) et les protéger par un PIN.

2. Configurer le dossier d'import

Organisez vos fichiers CSV dans un dossier avec un sous-dossier par source :

Documents/
  Comptabilité/
    Desjardins/
      releve-2024-01.csv
      releve-2024-02.csv
    Autre banque/
      export.csv

3. Importer des transactions

  • Allez dans Import
  • Sélectionnez le dossier source et les fichiers CSV
  • Configurez le mappage des colonnes (ou utilisez un modèle d'import sauvegardé)
  • Vérifiez les doublons puis lancez l'import

4. Consulter le tableau de bord

Le tableau de bord affiche automatiquement :

  • Les KPIs du mois (revenus, dépenses, solde)
  • La répartition des dépenses par catégorie
  • Les dernières transactions

5. Parcourir et catégoriser les transactions

  • Utilisez la recherche et les filtres (date, catégorie, source, période rapide)
  • Modifiez la catégorie d'une transaction en cliquant dessus
  • Ajoutez des mots-clés pour automatiser les futures catégorisations
  • Scindez une transaction sur plusieurs catégories si nécessaire

6. Gérer les budgets

  • Définissez un budget mensuel par catégorie sur une grille 12 mois
  • Créez des modèles budgétaires réutilisables
  • Consultez le rapport Budget vs Réel pour suivre vos écarts

7. Analyser les rapports

  • Tendances — Évolution mensuelle des revenus et dépenses
  • Catégories — Répartition détaillée par catégorie (clic droit pour masquer ou voir le détail)
  • Évolution — Suivi dans le temps par catégorie
  • Budget vs Réel — Comparaison mensuelle et cumul annuel

8. Guide utilisateur

Un guide complet est accessible via Paramètres → Guide utilisateur. Il couvre toutes les fonctionnalités et peut être imprimé ou exporté en PDF.

Développement

Prérequis

Lancer en mode développement

npm install
npm run tauri dev

Compiler l'application

npm run tauri build

Les installateurs sont générés dans src-tauri/target/release/bundle/.

Publier une nouvelle version

  1. Mettez à jour la version dans src-tauri/tauri.conf.json et package.json
  2. Committez les changements
  3. Créez et poussez un tag :
git tag v0.3.7
git push origin v0.3.7

Le workflow GitHub Actions compile automatiquement l'application pour Windows et Linux, puis publie les installateurs dans une nouvelle Release.

Technologies

Technologie Rôle
Tauri v2 Framework desktop (Rust backend)
React 19 Interface utilisateur
SQLite Base de données locale
Tailwind CSS v4 Styles
Recharts Graphiques
react-i18next Internationalisation
PapaParse Parsing CSV