Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/devleoko/liberty-invoice
Intuitive yet powerful invoice generator for freelancers, business and everyone else
https://github.com/devleoko/liberty-invoice
invoice invoicing pdf svelte sveltekit typescript
Last synced: 16 days ago
JSON representation
Intuitive yet powerful invoice generator for freelancers, business and everyone else
- Host: GitHub
- URL: https://github.com/devleoko/liberty-invoice
- Owner: DevLeoko
- License: other
- Created: 2023-01-16T23:05:54.000Z (about 2 years ago)
- Default Branch: main
- Last Pushed: 2024-03-30T16:51:10.000Z (10 months ago)
- Last Synced: 2024-03-30T17:29:47.835Z (10 months ago)
- Topics: invoice, invoicing, pdf, svelte, sveltekit, typescript
- Language: Svelte
- Homepage: https://liberty-invoice.com
- Size: 2.85 MB
- Stars: 4
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Liberty Invoice
Liberty Invoice is an source-available tool built for intuitive yet powerful invoicing. Aimed at freelancers, businesses, and anyone else with billing needs, Liberty Invoice provides an adaptable solution to manage invoices and generate invoice PDFs. With customizable features, multi-language and multi-currency support, efficient client and product management, and more, it offers a seamless invoicing experience.
## Features
- Multilingual UI: English and German are currently supported
- Customizable Invoice Templates: Logo and text fragments can be customized
- Invoice PDF Generation
- Client-Specific Currency
- Client-Specific Language
- Configurable Tax Rates
- Client and Product Management
- Sending Invoices via Email
- WIP: Payment Logging
- WIP: Multi-User Support## Hosted Version
A hosted version of Liberty Invoice is available at https://liberty-invoice.com. The hosted version is updated regularly and includes the latest features and bug fixes. It is currently free to use. If you encounter any issues, please report them on GitHub.
## Self-Hosting
This repository is a monorepo containing both the frontend and backend code. The frontend is built with SvelteKit and the backend is a NodeJS Express server.
### Frontend
We do not use any SSR in SvelteKit, so the frontend can be hosted as a static site.
To build the frontend, you need to:1. Setup the environment variables in `frontend/.env` (see `.env.example` for an example)
2. Run `npm install` and `npm run generate` in the `backend` directory.
Note: The backend is required to build the frontend because the frontend uses the backend's tRPC types. For security reasons the backend's `.env` file should not have any sensitive data when building the frontend.
3. Run `npm install` and `npm run build` in the `frontend` directory.
4. The frontend is now built and can be hosted as a static site. The output is in the `frontend/build` directory.### Backend
1. Navigate to the `backend` directory.
2. Setup the environment variables `.env` (see `.env.example` for an example)
3. Run `npm install`, `npm run prisma-up` and `npm run generate` to setup the database and generate the Prisma client.
4. Run `npm run start` to start the backend server.## Community
Join our thriving community on [Discord](https://discord.gg/qTU4xKRv9C)! Contribute to our project, share ideas, or ask questions. Together, we shape the future of Liberty Invoice.
## Stack
Key technologies used in Liberty Invoice:
- SvelteKit
- Express
- tRPC: Type-safe API calls between frontend and backend
- Prisma: Next-generation ORM for TypeScript and Node.js
- Zod: TypeScript-first schema declaration and validation
- TanStack Query: Asynchronous state management, server-state utilities and data fetching