feat: Add data-entry-app for fiscal receipts with approval workflow
New application for entering fiscal receipts (bonuri fiscale) with: Backend (FastAPI + SQLModel + Alembic): - Receipt, ReceiptAttachment, AccountingEntry models - CRUD operations with async SQLite database - Workflow: DRAFT → PENDING_REVIEW → APPROVED/REJECTED - Auto-generation of accounting entries with VAT calculation - File upload support (images, PDFs) - Predefined expense types (Fuel, Materials, Office, etc.) - Nomenclature service for partners, accounts, cash registers Frontend (Vue.js 3 + PrimeVue + Pinia): - ReceiptsListView with filters and stats - ReceiptCreateView with image upload - ReceiptDetailView with accounting entries - ReceiptApprovalView for accountant approval Documentation: - REQUIREMENTS.md with functional specifications - ARCHITECTURE.md with technical decisions - CLAUDE.md for AI assistant guidance Phase 1 MVP uses SQLite, prepared for Oracle integration in Phase 2. 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
This commit is contained in:
49
data-entry-app/frontend/src/router/index.js
Normal file
49
data-entry-app/frontend/src/router/index.js
Normal file
@@ -0,0 +1,49 @@
|
||||
import { createRouter, createWebHistory } from 'vue-router'
|
||||
|
||||
const routes = [
|
||||
{
|
||||
path: '/',
|
||||
name: 'ReceiptsList',
|
||||
component: () => import('../views/receipts/ReceiptsListView.vue'),
|
||||
meta: { title: 'Lista Bonuri' }
|
||||
},
|
||||
{
|
||||
path: '/create',
|
||||
name: 'ReceiptCreate',
|
||||
component: () => import('../views/receipts/ReceiptCreateView.vue'),
|
||||
meta: { title: 'Bon Nou' }
|
||||
},
|
||||
{
|
||||
path: '/receipt/:id',
|
||||
name: 'ReceiptDetail',
|
||||
component: () => import('../views/receipts/ReceiptDetailView.vue'),
|
||||
meta: { title: 'Detalii Bon' }
|
||||
},
|
||||
{
|
||||
path: '/receipt/:id/edit',
|
||||
name: 'ReceiptEdit',
|
||||
component: () => import('../views/receipts/ReceiptCreateView.vue'),
|
||||
meta: { title: 'Editare Bon' }
|
||||
},
|
||||
{
|
||||
path: '/approval',
|
||||
name: 'ReceiptApproval',
|
||||
component: () => import('../views/receipts/ReceiptApprovalView.vue'),
|
||||
meta: { title: 'Aprobare Bonuri' }
|
||||
}
|
||||
]
|
||||
|
||||
const router = createRouter({
|
||||
history: createWebHistory(),
|
||||
routes
|
||||
})
|
||||
|
||||
// Update page title
|
||||
router.beforeEach((to, from, next) => {
|
||||
document.title = to.meta.title
|
||||
? `${to.meta.title} | Data Entry`
|
||||
: 'Data Entry - Bonuri Fiscale'
|
||||
next()
|
||||
})
|
||||
|
||||
export default router
|
||||
Reference in New Issue
Block a user