You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
Andrew Wallo 6a5805ada4 wip 1 anno fa
.github Create FUNDING.yml 2 anni fa
app wip 1 anno fa
bootstrap wip 1 anno fa
config increase zoom for pdf 1 anno fa
database remove company id in compound index and include retained earnings 1 anno fa
public add pint and refactor 2 anni fa
resources refactor 1 anno fa
routes feat: Plaid import transaction updates 1 anno fa
storage Enhance application with Live Currency feature and Transmatic integration 1 anno fa
tests feat: Laravel 11 and Transactions 1 anno fa
.editorconfig - v1 2 anni fa
.env.example refactor: TransactionService.php 1 anno fa
.gitattributes - v1 2 anni fa
.gitignore refactor and prevent auto creation of company for Socialite User 2 anni fa
LICENSE Create LICENSE 2 anni fa
README.md update README.md 1 anno fa
artisan feat: Laravel 11 and Transactions 1 anno fa
composer.json account transactions report wip and change to snappypdf 1 anno fa
composer.lock refactor 1 anno fa
package-lock.json refactor 1 anno fa
package.json wip 1 anno fa
phpunit.xml feat: Laravel 11 and Transactions 1 anno fa
pint.json Enhance application with Live Currency feature and Transmatic integration 1 anno fa
postcss.config.js feat: Laravel 11 and Transactions 1 anno fa
vite.config.js refactor: fix ssl 1 anno fa

README.md

ERPSAAS

This repo is currently a work in progress — PRs and issues welcome!

Getting started

Installation

Please check the official laravel installation guide for server requirements before you start. Official Documentation

Clone the repository

git clone https://github.com/andrewdwallo/erpsaas.git

Switch to the repo folder

cd erpsaas

Install all the dependencies using composer and npm

composer install
npm install

Copy the example env file and make the required configuration changes in the .env file

cp .env.example .env

Generate a new application key

php artisan key:generate

Run the database migrations (Set the database connection in .env before migrating)

php artisan migrate

Build your assets & start the local development server

php artisan filament:assets
npm run build
npm run dev

Command list

git clone https://github.com/andrewdwallo/erpsaas.git
cd erpsaas
composer install
npm install
cp .env.example .env
php artisan key:generate
php artisan migrate
npm run build
npm run dev

Database seeding

You may populate the database to help you get started quickly

Open the DatabaseSeeder and set the property values as per your requirement

database/seeders/DatabaseSeeder.php

Default login information:

email: admin@gmail.com
password: password

Run the database seeder

php artisan db:seed

Note : It’s recommended to have a clean database before seeding. You can refresh your migrations at any point to clean the database by running the following command

php artisan migrate:refresh

Generating PDFs for Reports

To generate PDFs for reports, the application uses Laravel Snappy. The Laravel Snappy package is already included in the application, but you need to install Wkhtmltopdf separately.

Wkhtmltopdf Installation

  1. Download and install Wkhtmltopdf

    • Wkhtmltopdf Downloads

    • Alternatively, if you are using Homebrew on macOS, you can install it using the following command:

      brew install wkhtmltopdf
      
  2. Configure the binary paths

    • If needed, you can change the paths to the Wkhtmltopdf binaries in the Snappy configuration file (config/snappy.php).

For detailed installation instructions, refer to the Laravel Snappy documentation.

Live Currency

Overview

This application offers support for real-time currency exchange rates. This feature is disabled by default. To enable it, you must first register for an API key at ExchangeRate-API. The application uses this service due to its generous provision of up to 1,500 free API calls per month, which should be enough for development and testing purposes.

Disclaimer: There is no affiliation between this application and ExchangeRate-API.

Once you have your API key, you can enable the feature by setting the CURRENCY_API_KEY environment variable in your .env file.

Initial Setup

After setting your API key in the .env file, it is essential to prepare your database to store the currency data. Start by running a fresh database migration:

php artisan migrate:fresh

This ensures that your database is in the correct state to store the currency information. Afterward, use the following command to generate and populate the Currency List with supported currencies for the Live Currency page:

php artisan currency:init

This command fetches and stores the list of currencies supported by your configured exchange rate service.

Configuration

Of course, you may use any service you wish to retrieve currency exchange rates. If you decide to use a different service, you can update the config/services.php file with your choice:

'currency_api' => [
    'key' => env('CURRENCY_API_KEY'),
    'base_url' => 'https://v6.exchangerate-api.com/v6',
],

Then, adjust the implementation of the App\Services\CurrencyService class to use your chosen service.

Live Currency Page

Once enabled, the “Live Currency” feature provides access to a dedicated page in the application, listing all supported currencies from the configured exchange rate service. Users can view available currencies and update exchange rates for their company’s currencies as needed.

Important Information

  • To use the currency exchange rate feature, you must first obtain an API key from a service provider. This application is configured to use a service that offers a free tier suitable for development and testing purposes.
  • Your API key is sensitive information and should be kept secret. Do not commit it to your repository or share it with anyone.
  • Note that API rate limits may apply depending on the service you choose. Make sure to review the terms for your chosen service.

Automatic Translation

The application now supports automatic translation, leveraging machine translation services provided by AWS, as facilitated by the andrewdwallo/transmatic package. This integration significantly enhances the application’s accessibility for a global audience. The application currently offers support for several languages, including English, Arabic, German, Spanish, French, Indonesian, Italian, Dutch, Portuguese, Turkish, and Chinese, with English as the default language.

Configuration & Usage

To utilize this feature for additional languages or custom translations:

  1. Follow the documentation provided in the andrewdwallo/transmatic package.
  2. Configure the package with your preferred translation service credentials.
  3. Run the translation commands as per the package instructions to generate new translations.

Once you have configured the package, you may update the following method in the app/Models/Setting/Localization.php file to generate translations based on the selected language in the application UI:

Change to the following:

public static function getAllLanguages(): array
{
    return Languages::getNames(app()->getLocale());
}

Dependencies

Note : It is recommended to read the documentation for all dependencies to get yourself familiar with how the application works.

License

This project is licensed under the MIT License - see the LICENSE file for details.