mirror of
				https://github.com/crater-invoice/crater.git
				synced 2025-11-04 06:23:17 -05:00 
			
		
		
		
	Compare commits
	
		
			42 Commits
		
	
	
		
			e5afc93efa
			...
			dark-base-
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| b1e42cfe6a | |||
| 604aafe520 | |||
| ddd4ed77dc | |||
| 15f3f566e3 | |||
| 98196194e2 | |||
| 7447cc24f9 | |||
| 889d22d92c | |||
| bc8f2cd484 | |||
| 4e47f58bad | |||
| d8c429912e | |||
| df04fd9e53 | |||
| 0aaf0e7e75 | |||
| 3d0b89bb4d | |||
| 38c4b9ebce | |||
| 7be59e78e0 | |||
| 189c51cdf4 | |||
| 204483836a | |||
| 33bc9ded65 | |||
| 4271ef451e | |||
| 6eb44fba93 | |||
| 96e7300583 | |||
| a479d966d1 | |||
| bd5f0fe5cf | |||
| 787619b907 | |||
| fd70ab9a99 | |||
| 33315638df | |||
| bba14bf51a | |||
| ea41989034 | |||
| 3f3f83a00a | |||
| adc5962071 | |||
| c4c00002d7 | |||
| a7c1e12db6 | |||
| 32949d1eec | |||
| 7718f77f3d | |||
| a9e54981bf | |||
| ef35293f8a | |||
| 5c63770b6b | |||
| d130e20c92 | |||
| 586fb1ae10 | |||
| 20c2502e31 | |||
| 0e31f85c18 | |||
| e7301eb7a3 | 
							
								
								
									
										162
									
								
								.github/workflows/uffizzi-build.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										162
									
								
								.github/workflows/uffizzi-build.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							@ -0,0 +1,162 @@
 | 
			
		||||
name: Build PR Image
 | 
			
		||||
on:
 | 
			
		||||
  pull_request:
 | 
			
		||||
    types: [opened,synchronize,reopened,closed]
 | 
			
		||||
 | 
			
		||||
jobs:
 | 
			
		||||
 | 
			
		||||
  build-application:
 | 
			
		||||
    name: Build and Push `application`
 | 
			
		||||
    runs-on: ubuntu-latest
 | 
			
		||||
    if: ${{ github.event_name != 'pull_request' || github.event.action != 'closed' }}
 | 
			
		||||
    outputs:
 | 
			
		||||
      tags: ${{ steps.meta.outputs.tags }}
 | 
			
		||||
    steps:
 | 
			
		||||
      - name: Checkout git repo
 | 
			
		||||
        uses: actions/checkout@v3
 | 
			
		||||
      - name: Set up Docker Buildx
 | 
			
		||||
        uses: docker/setup-buildx-action@v2        
 | 
			
		||||
      - name: Generate UUID image name
 | 
			
		||||
        id: uuid
 | 
			
		||||
        run: echo "UUID_TAG_APP=$(uuidgen)" >> $GITHUB_ENV
 | 
			
		||||
      - name: Docker metadata
 | 
			
		||||
        id: meta
 | 
			
		||||
        uses: docker/metadata-action@v3
 | 
			
		||||
        with:
 | 
			
		||||
          images: registry.uffizzi.com/${{ env.UUID_TAG_APP }}
 | 
			
		||||
          tags: type=raw,value=60d
 | 
			
		||||
      - name: Build and Push Image to registry.uffizzi.com ephemeral registry
 | 
			
		||||
        uses: docker/build-push-action@v2
 | 
			
		||||
        with:
 | 
			
		||||
          push: true
 | 
			
		||||
          context: ./
 | 
			
		||||
          tags: ${{ steps.meta.outputs.tags }}
 | 
			
		||||
          labels: ${{ steps.meta.outputs.labels }}
 | 
			
		||||
          file: ./uffizzi/Dockerfile
 | 
			
		||||
          cache-from: type=gha
 | 
			
		||||
          cache-to: type=gha,mode=max
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
  build-nginx:
 | 
			
		||||
    name: Build and Push `nginx`
 | 
			
		||||
    runs-on: ubuntu-latest
 | 
			
		||||
    if: ${{ github.event_name != 'pull_request' || github.event.action != 'closed' }}
 | 
			
		||||
    outputs:
 | 
			
		||||
      tags: ${{ steps.meta.outputs.tags }}
 | 
			
		||||
    steps:
 | 
			
		||||
      - name: Checkout git repo
 | 
			
		||||
        uses: actions/checkout@v3
 | 
			
		||||
      - name: Set up Docker Buildx
 | 
			
		||||
        uses: docker/setup-buildx-action@v2        
 | 
			
		||||
      - name: Generate UUID image name
 | 
			
		||||
        id: uuid
 | 
			
		||||
        run: echo "UUID_TAG_NGINX=$(uuidgen)" >> $GITHUB_ENV
 | 
			
		||||
      - name: Docker metadata
 | 
			
		||||
        id: meta
 | 
			
		||||
        uses: docker/metadata-action@v3
 | 
			
		||||
        with:
 | 
			
		||||
          images: registry.uffizzi.com/${{ env.UUID_TAG_NGINX }}
 | 
			
		||||
          tags: type=raw,value=60d
 | 
			
		||||
      - name: Build and Push Image to Uffizzi ephemeral registry
 | 
			
		||||
        uses: docker/build-push-action@v2
 | 
			
		||||
        with:
 | 
			
		||||
          push: true
 | 
			
		||||
          context: ./
 | 
			
		||||
          tags: ${{ steps.meta.outputs.tags }}
 | 
			
		||||
          labels: ${{ steps.meta.outputs.labels }}
 | 
			
		||||
          file: ./uffizzi/nginx/Dockerfile
 | 
			
		||||
          cache-from: type=gha
 | 
			
		||||
          cache-to: type=gha,mode=max
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
  build-crond:
 | 
			
		||||
    name: Build and Push `crond`
 | 
			
		||||
    runs-on: ubuntu-latest
 | 
			
		||||
    if: ${{ github.event_name != 'pull_request' || github.event.action != 'closed' }}
 | 
			
		||||
    outputs:
 | 
			
		||||
      tags: ${{ steps.meta.outputs.tags }}
 | 
			
		||||
    steps:
 | 
			
		||||
      - name: Checkout git repo
 | 
			
		||||
        uses: actions/checkout@v3
 | 
			
		||||
      - name: Set up Docker Buildx
 | 
			
		||||
        uses: docker/setup-buildx-action@v2        
 | 
			
		||||
      - name: Generate UUID image name
 | 
			
		||||
        id: uuid
 | 
			
		||||
        run: echo "UUID_TAG_CROND=$(uuidgen)" >> $GITHUB_ENV
 | 
			
		||||
      - name: Docker metadata
 | 
			
		||||
        id: meta
 | 
			
		||||
        uses: docker/metadata-action@v3
 | 
			
		||||
        with:
 | 
			
		||||
          images: registry.uffizzi.com/${{ env.UUID_TAG_CROND }}
 | 
			
		||||
          tags: type=raw,value=60d
 | 
			
		||||
      - name: Build and Push Image to registry.uffizzi.com ephemeral registry
 | 
			
		||||
        uses: docker/build-push-action@v2
 | 
			
		||||
        with:
 | 
			
		||||
          push: true
 | 
			
		||||
          context: ./
 | 
			
		||||
          tags: ${{ steps.meta.outputs.tags }}
 | 
			
		||||
          labels: ${{ steps.meta.outputs.labels }}
 | 
			
		||||
          file: ./uffizzi/crond/Dockerfile      
 | 
			
		||||
          cache-from: type=gha
 | 
			
		||||
          cache-to: type=gha,mode=max
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
  render-compose-file:
 | 
			
		||||
    name: Render Docker Compose File
 | 
			
		||||
    # Pass output of this workflow to another triggered by `workflow_run` event.
 | 
			
		||||
    runs-on: ubuntu-latest
 | 
			
		||||
    outputs:
 | 
			
		||||
      compose-file-cache-key: ${{ steps.hash.outputs.hash }}
 | 
			
		||||
    needs: 
 | 
			
		||||
      - build-application
 | 
			
		||||
      - build-nginx
 | 
			
		||||
      - build-crond
 | 
			
		||||
    steps:
 | 
			
		||||
      - name: Checkout git repo
 | 
			
		||||
        uses: actions/checkout@v3
 | 
			
		||||
      - name: Render Compose File
 | 
			
		||||
        run: |
 | 
			
		||||
          APP_IMAGE=$(echo ${{ needs.build-application.outputs.tags }})
 | 
			
		||||
          export APP_IMAGE
 | 
			
		||||
          NGINX_IMAGE=$(echo ${{ needs.build-nginx.outputs.tags }})
 | 
			
		||||
          export NGINX_IMAGE
 | 
			
		||||
          CROND_IMAGE=$(echo ${{ needs.build-crond.outputs.tags }})
 | 
			
		||||
          export CROND_IMAGE
 | 
			
		||||
          # Render simple template from environment variables.
 | 
			
		||||
          envsubst < ./uffizzi/docker-compose.uffizzi.yml > docker-compose.rendered.yml
 | 
			
		||||
          cat docker-compose.rendered.yml
 | 
			
		||||
      - name: Upload Rendered Compose File as Artifact
 | 
			
		||||
        uses: actions/upload-artifact@v3
 | 
			
		||||
        with:
 | 
			
		||||
          name: preview-spec
 | 
			
		||||
          path: docker-compose.rendered.yml
 | 
			
		||||
          retention-days: 2
 | 
			
		||||
      - name: Serialize PR Event to File
 | 
			
		||||
        run:  |
 | 
			
		||||
          cat << EOF > event.json
 | 
			
		||||
          ${{ toJSON(github.event) }} 
 | 
			
		||||
          
 | 
			
		||||
          EOF
 | 
			
		||||
      - name: Upload PR Event as Artifact
 | 
			
		||||
        uses: actions/upload-artifact@v3
 | 
			
		||||
        with:
 | 
			
		||||
          name: preview-spec
 | 
			
		||||
          path: event.json
 | 
			
		||||
          retention-days: 2
 | 
			
		||||
 | 
			
		||||
  delete-preview:
 | 
			
		||||
    name: Call for Preview Deletion
 | 
			
		||||
    runs-on: ubuntu-latest
 | 
			
		||||
    if: ${{ github.event.action == 'closed' }}
 | 
			
		||||
    steps:
 | 
			
		||||
      # If this PR is closing, we will not render a compose file nor pass it to the next workflow.
 | 
			
		||||
      - name: Serialize PR Event to File
 | 
			
		||||
        run: echo '${{ toJSON(github.event) }}' > event.json
 | 
			
		||||
      - name: Upload PR Event as Artifact
 | 
			
		||||
        uses: actions/upload-artifact@v3
 | 
			
		||||
        with:
 | 
			
		||||
          name: preview-spec
 | 
			
		||||
          path: event.json
 | 
			
		||||
          retention-days: 2
 | 
			
		||||
 | 
			
		||||
							
								
								
									
										84
									
								
								.github/workflows/uffizzi-preview.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										84
									
								
								.github/workflows/uffizzi-preview.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							@ -0,0 +1,84 @@
 | 
			
		||||
name: Deploy Uffizzi Preview
 | 
			
		||||
 | 
			
		||||
on:
 | 
			
		||||
  workflow_run:
 | 
			
		||||
    workflows:
 | 
			
		||||
      - "Build PR Image"
 | 
			
		||||
    types:
 | 
			
		||||
      - completed
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
jobs:
 | 
			
		||||
  cache-compose-file:
 | 
			
		||||
    name: Cache Compose File
 | 
			
		||||
    runs-on: ubuntu-latest
 | 
			
		||||
    outputs:
 | 
			
		||||
      compose-file-cache-key: ${{ env.COMPOSE_FILE_HASH }}
 | 
			
		||||
      pr-number: ${{ env.PR_NUMBER }}
 | 
			
		||||
    steps:
 | 
			
		||||
      - name: 'Download artifacts'
 | 
			
		||||
        # Fetch output (zip archive) from the workflow run that triggered this workflow.
 | 
			
		||||
        uses: actions/github-script@v6
 | 
			
		||||
        with:
 | 
			
		||||
          script: |
 | 
			
		||||
            let allArtifacts = await github.rest.actions.listWorkflowRunArtifacts({
 | 
			
		||||
               owner: context.repo.owner,
 | 
			
		||||
               repo: context.repo.repo,
 | 
			
		||||
               run_id: context.payload.workflow_run.id,
 | 
			
		||||
            });
 | 
			
		||||
            let matchArtifact = allArtifacts.data.artifacts.filter((artifact) => {
 | 
			
		||||
              return artifact.name == "preview-spec"
 | 
			
		||||
            })[0];
 | 
			
		||||
            let download = await github.rest.actions.downloadArtifact({
 | 
			
		||||
               owner: context.repo.owner,
 | 
			
		||||
               repo: context.repo.repo,
 | 
			
		||||
               artifact_id: matchArtifact.id,
 | 
			
		||||
               archive_format: 'zip',
 | 
			
		||||
            });
 | 
			
		||||
            let fs = require('fs');
 | 
			
		||||
            fs.writeFileSync(`${process.env.GITHUB_WORKSPACE}/preview-spec.zip`, Buffer.from(download.data));
 | 
			
		||||
      - name: 'Unzip artifact'
 | 
			
		||||
        run: unzip preview-spec.zip
 | 
			
		||||
      - name: Read Event into ENV
 | 
			
		||||
        run: |
 | 
			
		||||
          echo 'EVENT_JSON<<EOF' >> $GITHUB_ENV
 | 
			
		||||
          cat event.json >> $GITHUB_ENV
 | 
			
		||||
          echo 'EOF' >> $GITHUB_ENV
 | 
			
		||||
      - name: Hash Rendered Compose File
 | 
			
		||||
        id: hash
 | 
			
		||||
        # If the previous workflow was triggered by a PR close event, we will not have a compose file artifact.
 | 
			
		||||
        if: ${{ fromJSON(env.EVENT_JSON).action != 'closed' }}
 | 
			
		||||
        run: echo "COMPOSE_FILE_HASH=$(md5sum docker-compose.rendered.yml | awk '{ print $1 }')" >> $GITHUB_ENV
 | 
			
		||||
      - name: Cache Rendered Compose File
 | 
			
		||||
        if: ${{ fromJSON(env.EVENT_JSON).action != 'closed' }}
 | 
			
		||||
        uses: actions/cache@v3
 | 
			
		||||
        with:
 | 
			
		||||
          path: docker-compose.rendered.yml
 | 
			
		||||
          key: ${{ env.COMPOSE_FILE_HASH }}
 | 
			
		||||
 | 
			
		||||
      - name: Read PR Number From Event Object
 | 
			
		||||
        id: pr
 | 
			
		||||
        run: echo "PR_NUMBER=${{ fromJSON(env.EVENT_JSON).number }}" >> $GITHUB_ENV
 | 
			
		||||
 | 
			
		||||
      - name: DEBUG - Print Job Outputs
 | 
			
		||||
        if: ${{ runner.debug }}
 | 
			
		||||
        run: |
 | 
			
		||||
          echo "PR number: ${{ env.PR_NUMBER }}"
 | 
			
		||||
          echo "Compose file hash: ${{ env.COMPOSE_FILE_HASH }}"
 | 
			
		||||
          cat event.json
 | 
			
		||||
  deploy-uffizzi-preview:
 | 
			
		||||
    name: Use Remote Workflow to Preview on Uffizzi
 | 
			
		||||
    needs:
 | 
			
		||||
      - cache-compose-file
 | 
			
		||||
    uses: UffizziCloud/preview-action/.github/workflows/reusable.yaml@v2.6.1
 | 
			
		||||
    with:
 | 
			
		||||
      # If this workflow was triggered by a PR close event, cache-key will be an empty string
 | 
			
		||||
      # and this reusable workflow will delete the preview deployment.
 | 
			
		||||
      compose-file-cache-key: ${{ needs.cache-compose-file.outputs.compose-file-cache-key }}
 | 
			
		||||
      compose-file-cache-path: docker-compose.rendered.yml
 | 
			
		||||
      server: https://app.uffizzi.com/
 | 
			
		||||
      pr-number: ${{ needs.cache-compose-file.outputs.pr-number }}
 | 
			
		||||
    permissions:
 | 
			
		||||
      contents: read
 | 
			
		||||
      pull-requests: write
 | 
			
		||||
      id-token: write
 | 
			
		||||
							
								
								
									
										1
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							@ -16,3 +16,4 @@ Homestead.yaml
 | 
			
		||||
.gitkeep
 | 
			
		||||
/public/docs
 | 
			
		||||
/.scribe
 | 
			
		||||
!storage/fonts/.gitkeep
 | 
			
		||||
@ -1,4 +1,4 @@
 | 
			
		||||
FROM php:7.4-fpm
 | 
			
		||||
FROM php:8.1-fpm
 | 
			
		||||
 | 
			
		||||
# Arguments defined in docker-compose.yml
 | 
			
		||||
ARG user
 | 
			
		||||
 | 
			
		||||
@ -103,6 +103,7 @@ class CustomerStatsController extends Controller
 | 
			
		||||
        )
 | 
			
		||||
            ->whereCompany()
 | 
			
		||||
            ->whereCustomer($customer->id)
 | 
			
		||||
            ->where('status', '<>', Invoice::STATUS_DRAFT)
 | 
			
		||||
            ->sum('total');
 | 
			
		||||
        $totalReceipts = Payment::whereBetween(
 | 
			
		||||
            'payment_date',
 | 
			
		||||
 | 
			
		||||
@ -104,6 +104,7 @@ class DashboardController extends Controller
 | 
			
		||||
            'invoice_date',
 | 
			
		||||
            [$startDate->format('Y-m-d'), $start->format('Y-m-d')]
 | 
			
		||||
        )
 | 
			
		||||
            ->where('status', '<>', Invoice::STATUS_DRAFT)
 | 
			
		||||
            ->whereCompany()
 | 
			
		||||
            ->sum('base_total');
 | 
			
		||||
 | 
			
		||||
@ -141,6 +142,7 @@ class DashboardController extends Controller
 | 
			
		||||
        $recent_due_invoices = Invoice::with('customer')
 | 
			
		||||
            ->whereCompany()
 | 
			
		||||
            ->where('base_due_amount', '>', 0)
 | 
			
		||||
            ->where('status', '<>', Invoice::STATUS_DRAFT)
 | 
			
		||||
            ->take(5)
 | 
			
		||||
            ->latest()
 | 
			
		||||
            ->get();
 | 
			
		||||
 | 
			
		||||
@ -24,6 +24,7 @@ class InvoicesController extends Controller
 | 
			
		||||
        $limit = $request->has('limit') ? $request->limit : 10;
 | 
			
		||||
 | 
			
		||||
        $invoices = Invoice::whereCompany()
 | 
			
		||||
            ->whereTabFilters($request->tab_status)
 | 
			
		||||
            ->join('customers', 'customers.id', '=', 'invoices.customer_id')
 | 
			
		||||
            ->applyFilters($request->all())
 | 
			
		||||
            ->select('invoices.*', 'customers.name')
 | 
			
		||||
 | 
			
		||||
@ -2,14 +2,15 @@
 | 
			
		||||
 | 
			
		||||
namespace Crater\Http\Controllers\V1\Admin\Report;
 | 
			
		||||
 | 
			
		||||
use PDF;
 | 
			
		||||
use Carbon\Carbon;
 | 
			
		||||
use Crater\Http\Controllers\Controller;
 | 
			
		||||
use Crater\Models\Company;
 | 
			
		||||
use Crater\Models\CompanySetting;
 | 
			
		||||
use Crater\Models\Currency;
 | 
			
		||||
use Crater\Models\Customer;
 | 
			
		||||
use Illuminate\Http\Request;
 | 
			
		||||
use Crater\Models\CompanySetting;
 | 
			
		||||
use Illuminate\Support\Facades\App;
 | 
			
		||||
use PDF;
 | 
			
		||||
use Crater\Http\Controllers\Controller;
 | 
			
		||||
 | 
			
		||||
class CustomerSalesReportController extends Controller
 | 
			
		||||
{
 | 
			
		||||
@ -56,6 +57,7 @@ class CustomerSalesReportController extends Controller
 | 
			
		||||
        $dateFormat = CompanySetting::getSetting('carbon_date_format', $company->id);
 | 
			
		||||
        $from_date = Carbon::createFromFormat('Y-m-d', $request->from_date)->format($dateFormat);
 | 
			
		||||
        $to_date = Carbon::createFromFormat('Y-m-d', $request->to_date)->format($dateFormat);
 | 
			
		||||
        $currency = Currency::findOrFail(CompanySetting::getSetting('currency', $company->id));
 | 
			
		||||
 | 
			
		||||
        $colors = [
 | 
			
		||||
            'primary_text_color',
 | 
			
		||||
@ -80,6 +82,7 @@ class CustomerSalesReportController extends Controller
 | 
			
		||||
            'company' => $company,
 | 
			
		||||
            'from_date' => $from_date,
 | 
			
		||||
            'to_date' => $to_date,
 | 
			
		||||
            'currency' => $currency,
 | 
			
		||||
        ]);
 | 
			
		||||
 | 
			
		||||
        $pdf = PDF::loadView('app.pdf.reports.sales-customers');
 | 
			
		||||
 | 
			
		||||
@ -2,14 +2,15 @@
 | 
			
		||||
 | 
			
		||||
namespace Crater\Http\Controllers\V1\Admin\Report;
 | 
			
		||||
 | 
			
		||||
use Carbon\Carbon;
 | 
			
		||||
use Crater\Http\Controllers\Controller;
 | 
			
		||||
use Crater\Models\Company;
 | 
			
		||||
use Crater\Models\CompanySetting;
 | 
			
		||||
use Crater\Models\Expense;
 | 
			
		||||
use Illuminate\Http\Request;
 | 
			
		||||
use Illuminate\Support\Facades\App;
 | 
			
		||||
use PDF;
 | 
			
		||||
use Carbon\Carbon;
 | 
			
		||||
use Crater\Models\Company;
 | 
			
		||||
use Crater\Models\Expense;
 | 
			
		||||
use Crater\Models\Currency;
 | 
			
		||||
use Illuminate\Http\Request;
 | 
			
		||||
use Crater\Models\CompanySetting;
 | 
			
		||||
use Illuminate\Support\Facades\App;
 | 
			
		||||
use Crater\Http\Controllers\Controller;
 | 
			
		||||
 | 
			
		||||
class ExpensesReportController extends Controller
 | 
			
		||||
{
 | 
			
		||||
@ -43,6 +44,7 @@ class ExpensesReportController extends Controller
 | 
			
		||||
        $dateFormat = CompanySetting::getSetting('carbon_date_format', $company->id);
 | 
			
		||||
        $from_date = Carbon::createFromFormat('Y-m-d', $request->from_date)->format($dateFormat);
 | 
			
		||||
        $to_date = Carbon::createFromFormat('Y-m-d', $request->to_date)->format($dateFormat);
 | 
			
		||||
        $currency = Currency::findOrFail(CompanySetting::getSetting('currency', $company->id));
 | 
			
		||||
 | 
			
		||||
        $colors = [
 | 
			
		||||
            'primary_text_color',
 | 
			
		||||
@ -66,6 +68,7 @@ class ExpensesReportController extends Controller
 | 
			
		||||
            'company' => $company,
 | 
			
		||||
            'from_date' => $from_date,
 | 
			
		||||
            'to_date' => $to_date,
 | 
			
		||||
            'currency' => $currency,
 | 
			
		||||
        ]);
 | 
			
		||||
        $pdf = PDF::loadView('app.pdf.reports.expenses');
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
@ -2,14 +2,15 @@
 | 
			
		||||
 | 
			
		||||
namespace Crater\Http\Controllers\V1\Admin\Report;
 | 
			
		||||
 | 
			
		||||
use Carbon\Carbon;
 | 
			
		||||
use Crater\Http\Controllers\Controller;
 | 
			
		||||
use Crater\Models\Company;
 | 
			
		||||
use Crater\Models\CompanySetting;
 | 
			
		||||
use Crater\Models\InvoiceItem;
 | 
			
		||||
use Illuminate\Http\Request;
 | 
			
		||||
use Illuminate\Support\Facades\App;
 | 
			
		||||
use PDF;
 | 
			
		||||
use Carbon\Carbon;
 | 
			
		||||
use Crater\Models\Company;
 | 
			
		||||
use Crater\Models\Currency;
 | 
			
		||||
use Illuminate\Http\Request;
 | 
			
		||||
use Crater\Models\InvoiceItem;
 | 
			
		||||
use Crater\Models\CompanySetting;
 | 
			
		||||
use Illuminate\Support\Facades\App;
 | 
			
		||||
use Crater\Http\Controllers\Controller;
 | 
			
		||||
 | 
			
		||||
class ItemSalesReportController extends Controller
 | 
			
		||||
{
 | 
			
		||||
@ -43,6 +44,7 @@ class ItemSalesReportController extends Controller
 | 
			
		||||
        $dateFormat = CompanySetting::getSetting('carbon_date_format', $company->id);
 | 
			
		||||
        $from_date = Carbon::createFromFormat('Y-m-d', $request->from_date)->format($dateFormat);
 | 
			
		||||
        $to_date = Carbon::createFromFormat('Y-m-d', $request->to_date)->format($dateFormat);
 | 
			
		||||
        $currency = Currency::findOrFail(CompanySetting::getSetting('currency', $company->id));
 | 
			
		||||
 | 
			
		||||
        $colors = [
 | 
			
		||||
            'primary_text_color',
 | 
			
		||||
@ -66,6 +68,7 @@ class ItemSalesReportController extends Controller
 | 
			
		||||
            'company' => $company,
 | 
			
		||||
            'from_date' => $from_date,
 | 
			
		||||
            'to_date' => $to_date,
 | 
			
		||||
            'currency' => $currency,
 | 
			
		||||
        ]);
 | 
			
		||||
        $pdf = PDF::loadView('app.pdf.reports.sales-items');
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
@ -2,15 +2,16 @@
 | 
			
		||||
 | 
			
		||||
namespace Crater\Http\Controllers\V1\Admin\Report;
 | 
			
		||||
 | 
			
		||||
use PDF;
 | 
			
		||||
use Carbon\Carbon;
 | 
			
		||||
use Crater\Http\Controllers\Controller;
 | 
			
		||||
use Crater\Models\Company;
 | 
			
		||||
use Crater\Models\CompanySetting;
 | 
			
		||||
use Crater\Models\Expense;
 | 
			
		||||
use Crater\Models\Payment;
 | 
			
		||||
use Crater\Models\Currency;
 | 
			
		||||
use Illuminate\Http\Request;
 | 
			
		||||
use Crater\Models\CompanySetting;
 | 
			
		||||
use Illuminate\Support\Facades\App;
 | 
			
		||||
use PDF;
 | 
			
		||||
use Crater\Http\Controllers\Controller;
 | 
			
		||||
 | 
			
		||||
class ProfitLossReportController extends Controller
 | 
			
		||||
{
 | 
			
		||||
@ -49,6 +50,8 @@ class ProfitLossReportController extends Controller
 | 
			
		||||
        $dateFormat = CompanySetting::getSetting('carbon_date_format', $company->id);
 | 
			
		||||
        $from_date = Carbon::createFromFormat('Y-m-d', $request->from_date)->format($dateFormat);
 | 
			
		||||
        $to_date = Carbon::createFromFormat('Y-m-d', $request->to_date)->format($dateFormat);
 | 
			
		||||
        $currency = Currency::findOrFail(CompanySetting::getSetting('currency', $company->id));
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
        $colors = [
 | 
			
		||||
            'primary_text_color',
 | 
			
		||||
@ -74,6 +77,7 @@ class ProfitLossReportController extends Controller
 | 
			
		||||
            'company' => $company,
 | 
			
		||||
            'from_date' => $from_date,
 | 
			
		||||
            'to_date' => $to_date,
 | 
			
		||||
            'currency' => $currency,
 | 
			
		||||
        ]);
 | 
			
		||||
        $pdf = PDF::loadView('app.pdf.reports.profit-loss');
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
@ -2,14 +2,15 @@
 | 
			
		||||
 | 
			
		||||
namespace Crater\Http\Controllers\V1\Admin\Report;
 | 
			
		||||
 | 
			
		||||
use Carbon\Carbon;
 | 
			
		||||
use Crater\Http\Controllers\Controller;
 | 
			
		||||
use Crater\Models\Company;
 | 
			
		||||
use Crater\Models\CompanySetting;
 | 
			
		||||
use Crater\Models\Tax;
 | 
			
		||||
use Illuminate\Http\Request;
 | 
			
		||||
use Illuminate\Support\Facades\App;
 | 
			
		||||
use PDF;
 | 
			
		||||
use Carbon\Carbon;
 | 
			
		||||
use Crater\Models\Tax;
 | 
			
		||||
use Crater\Models\Company;
 | 
			
		||||
use Crater\Models\Currency;
 | 
			
		||||
use Illuminate\Http\Request;
 | 
			
		||||
use Crater\Models\CompanySetting;
 | 
			
		||||
use Illuminate\Support\Facades\App;
 | 
			
		||||
use Crater\Http\Controllers\Controller;
 | 
			
		||||
 | 
			
		||||
class TaxSummaryReportController extends Controller
 | 
			
		||||
{
 | 
			
		||||
@ -44,6 +45,8 @@ class TaxSummaryReportController extends Controller
 | 
			
		||||
        $dateFormat = CompanySetting::getSetting('carbon_date_format', $company->id);
 | 
			
		||||
        $from_date = Carbon::createFromFormat('Y-m-d', $request->from_date)->format($dateFormat);
 | 
			
		||||
        $to_date = Carbon::createFromFormat('Y-m-d', $request->to_date)->format($dateFormat);
 | 
			
		||||
        $currency = Currency::findOrFail(CompanySetting::getSetting('currency', $company->id));
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
        $colors = [
 | 
			
		||||
            'primary_text_color',
 | 
			
		||||
@ -68,6 +71,7 @@ class TaxSummaryReportController extends Controller
 | 
			
		||||
            'company' => $company,
 | 
			
		||||
            'from_date' => $from_date,
 | 
			
		||||
            'to_date' => $to_date,
 | 
			
		||||
            'currency' => $currency,
 | 
			
		||||
        ]);
 | 
			
		||||
 | 
			
		||||
        $pdf = PDF::loadView('app.pdf.reports.tax-summary');
 | 
			
		||||
 | 
			
		||||
@ -3,7 +3,6 @@
 | 
			
		||||
namespace Crater\Http\Requests;
 | 
			
		||||
 | 
			
		||||
use Illuminate\Foundation\Http\FormRequest;
 | 
			
		||||
use Illuminate\Support\Str;
 | 
			
		||||
use Illuminate\Validation\Rule;
 | 
			
		||||
 | 
			
		||||
class CompaniesRequest extends FormRequest
 | 
			
		||||
@ -34,6 +33,10 @@ class CompaniesRequest extends FormRequest
 | 
			
		||||
            'currency' => [
 | 
			
		||||
                'required'
 | 
			
		||||
            ],
 | 
			
		||||
            'slug' => [
 | 
			
		||||
                'required',
 | 
			
		||||
                Rule::unique('companies')
 | 
			
		||||
            ],
 | 
			
		||||
            'address.name' => [
 | 
			
		||||
                'nullable',
 | 
			
		||||
            ],
 | 
			
		||||
@ -68,11 +71,11 @@ class CompaniesRequest extends FormRequest
 | 
			
		||||
    {
 | 
			
		||||
        return collect($this->validated())
 | 
			
		||||
            ->only([
 | 
			
		||||
                'name'
 | 
			
		||||
                'name',
 | 
			
		||||
                'slug'
 | 
			
		||||
            ])
 | 
			
		||||
            ->merge([
 | 
			
		||||
                'owner_id' => $this->user()->id,
 | 
			
		||||
                'slug' => Str::slug($this->name)
 | 
			
		||||
                'owner_id' => $this->user()->id
 | 
			
		||||
            ])
 | 
			
		||||
            ->toArray();
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
@ -30,7 +30,8 @@ class CompanyRequest extends FormRequest
 | 
			
		||||
                Rule::unique('companies')->ignore($this->header('company'), 'id'),
 | 
			
		||||
            ],
 | 
			
		||||
            'slug' => [
 | 
			
		||||
                'nullable'
 | 
			
		||||
                'required',
 | 
			
		||||
                Rule::unique('companies')->ignore($this->header('company'), 'id'),
 | 
			
		||||
            ],
 | 
			
		||||
            'address.country_id' => [
 | 
			
		||||
                'required',
 | 
			
		||||
 | 
			
		||||
@ -23,7 +23,7 @@ class EstimateResource extends JsonResource
 | 
			
		||||
            'reference_number' => $this->reference_number,
 | 
			
		||||
            'tax_per_item' => $this->tax_per_item,
 | 
			
		||||
            'discount_per_item' => $this->discount_per_item,
 | 
			
		||||
            'notes' => $this->getNotes(),
 | 
			
		||||
            'notes' => $this->notes,
 | 
			
		||||
            'discount' => $this->discount,
 | 
			
		||||
            'discount_type' => $this->discount_type,
 | 
			
		||||
            'discount_val' => $this->discount_val,
 | 
			
		||||
 | 
			
		||||
@ -18,7 +18,7 @@ class PaymentResource extends JsonResource
 | 
			
		||||
            'id' => $this->id,
 | 
			
		||||
            'payment_number' => $this->payment_number,
 | 
			
		||||
            'payment_date' => $this->payment_date,
 | 
			
		||||
            'notes' => $this->getNotes(),
 | 
			
		||||
            'notes' => $this->notes,
 | 
			
		||||
            'amount' => $this->amount,
 | 
			
		||||
            'unique_hash' => $this->unique_hash,
 | 
			
		||||
            'invoice_id' => $this->invoice_id,
 | 
			
		||||
 | 
			
		||||
@ -217,7 +217,7 @@ class Company extends Model implements HasMedia
 | 
			
		||||
            'estimate_billing_address_format' => $billingAddressFormat,
 | 
			
		||||
            'payment_company_address_format' => $companyAddressFormat,
 | 
			
		||||
            'payment_from_customer_address_format' => $paymentFromCustomerAddress,
 | 
			
		||||
            'currency' => request()->currency ?? 13,
 | 
			
		||||
            'currency' => request()->currency ?? 1,
 | 
			
		||||
            'time_zone' => 'Asia/Kolkata',
 | 
			
		||||
            'language' => 'en',
 | 
			
		||||
            'fiscal_year' => '1-12',
 | 
			
		||||
 | 
			
		||||
@ -483,7 +483,8 @@ class Estimate extends Model implements HasMedia
 | 
			
		||||
            '{ESTIMATE_DATE}' => $this->formattedEstimateDate,
 | 
			
		||||
            '{ESTIMATE_EXPIRY_DATE}' => $this->formattedExpiryDate,
 | 
			
		||||
            '{ESTIMATE_NUMBER}' => $this->estimate_number,
 | 
			
		||||
            '{ESTIMATE_REF_NUMBER}' => $this->reference_number,
 | 
			
		||||
            '{PDF_LINK}' => $this->estimatePdfUrl,
 | 
			
		||||
            '{TOTAL_AMOUNT}' => format_money_pdf($this->total, $this->customer->currency)
 | 
			
		||||
        ];
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
@ -240,7 +240,7 @@ class Expense extends Model implements HasMedia
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        if ($request->hasFile('attachment_receipt')) {
 | 
			
		||||
            $expense->addMediaFromRequest('attachment_receipt')->toMediaCollection('receipts');
 | 
			
		||||
            $expense->addMediaFromRequest('attachment_receipt')->toMediaCollection('receipts', 'local');
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        if ($request->customFields) {
 | 
			
		||||
@ -262,12 +262,12 @@ class Expense extends Model implements HasMedia
 | 
			
		||||
            ExchangeRateLog::addExchangeRateLog($this);
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        if (isset($request->is_attachment_receipt_removed) && (bool) $request->is_attachment_receipt_removed) {
 | 
			
		||||
        if (isset($request->is_attachment_receipt_removed) && $request->is_attachment_receipt_removed == "true") {
 | 
			
		||||
            $this->clearMediaCollection('receipts');
 | 
			
		||||
        }
 | 
			
		||||
        if ($request->hasFile('attachment_receipt')) {
 | 
			
		||||
            $this->clearMediaCollection('receipts');
 | 
			
		||||
            $this->addMediaFromRequest('attachment_receipt')->toMediaCollection('receipts');
 | 
			
		||||
            $this->addMediaFromRequest('attachment_receipt')->toMediaCollection('receipts', 'local');
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        if ($request->customFields) {
 | 
			
		||||
 | 
			
		||||
@ -187,16 +187,6 @@ class Invoice extends Model implements HasMedia
 | 
			
		||||
        return Carbon::parse($this->invoice_date)->format($dateFormat);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    public function scopeWhereStatus($query, $status)
 | 
			
		||||
    {
 | 
			
		||||
        return $query->where('invoices.status', $status);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    public function scopeWherePaidStatus($query, $status)
 | 
			
		||||
    {
 | 
			
		||||
        return $query->where('invoices.paid_status', $status);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    public function scopeWhereDueStatus($query, $status)
 | 
			
		||||
    {
 | 
			
		||||
        return $query->whereIn('invoices.paid_status', [
 | 
			
		||||
@ -234,6 +224,40 @@ class Invoice extends Model implements HasMedia
 | 
			
		||||
        $query->orderBy($orderByField, $orderBy);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    public function scopeWhereStatus($query, $status)
 | 
			
		||||
    {
 | 
			
		||||
        return $query->where('invoices.status', $status);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    public function scopeWherePaidStatus($query, $status)
 | 
			
		||||
    {
 | 
			
		||||
        return $query->where('invoices.paid_status', $status);
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    public function scopeWhereTabFilters($query, $status)
 | 
			
		||||
    {
 | 
			
		||||
        if ($status == "DRAFT") {
 | 
			
		||||
            return $query->where('invoices.status', $status);
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        if ($status == "SENT") {
 | 
			
		||||
            return $query->whereIn('invoices.status', [
 | 
			
		||||
                self::STATUS_SENT,
 | 
			
		||||
                self::STATUS_VIEWED,
 | 
			
		||||
                self::STATUS_COMPLETED
 | 
			
		||||
            ]);
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        if ($status == 'DUE') {
 | 
			
		||||
            return $query->whereIn('invoices.paid_status', [
 | 
			
		||||
                self::STATUS_UNPAID,
 | 
			
		||||
                self::STATUS_PARTIALLY_PAID,
 | 
			
		||||
            ]);
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        return ;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    public function scopeApplyFilters($query, array $filters)
 | 
			
		||||
    {
 | 
			
		||||
        $filters = collect($filters);
 | 
			
		||||
@ -249,17 +273,11 @@ class Invoice extends Model implements HasMedia
 | 
			
		||||
                $filters->get('status') == self::STATUS_PAID
 | 
			
		||||
            ) {
 | 
			
		||||
                $query->wherePaidStatus($filters->get('status'));
 | 
			
		||||
            } elseif ($filters->get('status') == 'DUE') {
 | 
			
		||||
                $query->whereDueStatus($filters->get('status'));
 | 
			
		||||
            } else {
 | 
			
		||||
                $query->whereStatus($filters->get('status'));
 | 
			
		||||
            }
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        if ($filters->get('paid_status')) {
 | 
			
		||||
            $query->wherePaidStatus($filters->get('status'));
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        if ($filters->get('invoice_id')) {
 | 
			
		||||
            $query->whereInvoice($filters->get('invoice_id'));
 | 
			
		||||
        }
 | 
			
		||||
@ -651,7 +669,9 @@ class Invoice extends Model implements HasMedia
 | 
			
		||||
            '{INVOICE_DATE}' => $this->formattedInvoiceDate,
 | 
			
		||||
            '{INVOICE_DUE_DATE}' => $this->formattedDueDate,
 | 
			
		||||
            '{INVOICE_NUMBER}' => $this->invoice_number,
 | 
			
		||||
            '{INVOICE_REF_NUMBER}' => $this->reference_number,
 | 
			
		||||
            '{PDF_LINK}' => $this->invoicePdfUrl,
 | 
			
		||||
            '{DUE_AMOUNT}' => format_money_pdf($this->due_amount, $this->customer->currency),
 | 
			
		||||
            '{TOTAL_AMOUNT}' => format_money_pdf($this->total, $this->customer->currency)
 | 
			
		||||
        ];
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
@ -435,7 +435,8 @@ class Payment extends Model implements HasMedia
 | 
			
		||||
            '{PAYMENT_DATE}' => $this->formattedPaymentDate,
 | 
			
		||||
            '{PAYMENT_MODE}' => $this->paymentMethod ? $this->paymentMethod->name : null,
 | 
			
		||||
            '{PAYMENT_NUMBER}' => $this->payment_number,
 | 
			
		||||
            '{PAYMENT_AMOUNT}' => $this->reference_number,
 | 
			
		||||
            '{PDF_LINK}' => $this->paymentPdfUrl,
 | 
			
		||||
            '{PAYMENT_AMOUNT}' => format_money_pdf($this->amount, $this->customer->currency)
 | 
			
		||||
        ];
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
@ -38,15 +38,15 @@
 | 
			
		||||
    "barryvdh/laravel-ide-helper": "^2.6",
 | 
			
		||||
    "beyondcode/laravel-dump-server": "^1.0",
 | 
			
		||||
    "facade/ignition": "^2.3.6",
 | 
			
		||||
    "friendsofphp/php-cs-fixer": "^3.0",
 | 
			
		||||
    "fzaninotto/faker": "^1.9.1",
 | 
			
		||||
    "friendsofphp/php-cs-fixer": "^3.8",
 | 
			
		||||
    "fakerphp/faker": "^1.9.1",
 | 
			
		||||
    "mockery/mockery": "^1.3.1",
 | 
			
		||||
    "nunomaduro/collision": "^5.0",
 | 
			
		||||
    "pestphp/pest": "^1.0",
 | 
			
		||||
    "pestphp/pest-plugin-faker": "^1.0",
 | 
			
		||||
    "pestphp/pest-plugin-laravel": "^1.0",
 | 
			
		||||
    "pestphp/pest-plugin-parallel": "^0.2.1",
 | 
			
		||||
    "phpunit/phpunit": "^9.0"
 | 
			
		||||
    "phpunit/phpunit": "^9.3"
 | 
			
		||||
  },
 | 
			
		||||
  "autoload": {
 | 
			
		||||
    "psr-4": {
 | 
			
		||||
@ -81,7 +81,10 @@
 | 
			
		||||
  "config": {
 | 
			
		||||
    "optimize-autoloader": true,
 | 
			
		||||
    "preferred-install": "dist",
 | 
			
		||||
    "sort-packages": true
 | 
			
		||||
    "sort-packages": true,
 | 
			
		||||
    "allow-plugins": {
 | 
			
		||||
      "pestphp/pest-plugin": true
 | 
			
		||||
    }
 | 
			
		||||
  },
 | 
			
		||||
  "extra": {
 | 
			
		||||
    "laravel": {
 | 
			
		||||
 | 
			
		||||
							
								
								
									
										2347
									
								
								composer.lock
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										2347
									
								
								composer.lock
									
									
									
										generated
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							@ -71,6 +71,7 @@ return [
 | 
			
		||||
        ["code" => "cs", "name" => "Czech"],
 | 
			
		||||
        ["code" => "el", "name" => "Greek"],
 | 
			
		||||
        ["code" => "hr", "name" => "Crotian"],
 | 
			
		||||
        ["code" => "th", "name" => "ไทย"],
 | 
			
		||||
    ],
 | 
			
		||||
 | 
			
		||||
    /*
 | 
			
		||||
 | 
			
		||||
@ -170,7 +170,7 @@ class CountriesTableSeeder extends Seeder
 | 
			
		||||
        ['id' => 152,'code' => 'NR','name' => "Nauru",'phonecode' => 674],
 | 
			
		||||
        ['id' => 153,'code' => 'NP','name' => "Nepal",'phonecode' => 977],
 | 
			
		||||
        ['id' => 154,'code' => 'AN','name' => "Netherlands Antilles",'phonecode' => 599],
 | 
			
		||||
        ['id' => 155,'code' => 'NL','name' => "Netherlands The",'phonecode' => 31],
 | 
			
		||||
        ['id' => 155,'code' => 'NL','name' => "Netherlands",'phonecode' => 31],
 | 
			
		||||
        ['id' => 156,'code' => 'NC','name' => "New Caledonia",'phonecode' => 687],
 | 
			
		||||
        ['id' => 157,'code' => 'NZ','name' => "New Zealand",'phonecode' => 64],
 | 
			
		||||
        ['id' => 158,'code' => 'NI','name' => "Nicaragua",'phonecode' => 505],
 | 
			
		||||
 | 
			
		||||
@ -1,7 +1,7 @@
 | 
			
		||||
FROM php:7.4-fpm-alpine
 | 
			
		||||
FROM php:8.0-fpm-alpine
 | 
			
		||||
 | 
			
		||||
RUN apk add --no-cache \
 | 
			
		||||
    php7-bcmath
 | 
			
		||||
    php8-bcmath
 | 
			
		||||
 | 
			
		||||
RUN docker-php-ext-install pdo pdo_mysql bcmath
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
@ -27,7 +27,7 @@
 | 
			
		||||
    "vite": "^2.6.1"
 | 
			
		||||
  },
 | 
			
		||||
  "dependencies": {
 | 
			
		||||
    "@headlessui/vue": "^1.4.0",
 | 
			
		||||
    "@headlessui/vue": "^1.5.0",
 | 
			
		||||
    "@heroicons/vue": "^1.0.1",
 | 
			
		||||
    "@popperjs/core": "^2.9.2",
 | 
			
		||||
    "@stripe/stripe-js": "^1.21.2",
 | 
			
		||||
@ -48,7 +48,8 @@
 | 
			
		||||
    "mini-svg-data-uri": "^1.3.3",
 | 
			
		||||
    "moment": "^2.29.1",
 | 
			
		||||
    "pinia": "^2.0.4",
 | 
			
		||||
    "v-money3": "^3.13.5",
 | 
			
		||||
    "v-calendar": "3.0.0-alpha.8",
 | 
			
		||||
    "v-money3": "3.16.1",
 | 
			
		||||
    "v-tooltip": "^4.0.0-alpha.1",
 | 
			
		||||
    "vue": "^3.2.0-beta.5",
 | 
			
		||||
    "vue-flatpickr-component": "^9.0.3",
 | 
			
		||||
 | 
			
		||||
@ -64,7 +64,7 @@ function mergeExistingValues() {
 | 
			
		||||
  if (props.isEdit) {
 | 
			
		||||
    props.store[props.storeProp].fields.forEach((field) => {
 | 
			
		||||
      const existingIndex = props.store[props.storeProp].customFields.findIndex(
 | 
			
		||||
        (f) => f.id === field.custom_field_id
 | 
			
		||||
        (f) => f.id == field.custom_field_id
 | 
			
		||||
      )
 | 
			
		||||
 | 
			
		||||
      if (existingIndex > -1) {
 | 
			
		||||
 | 
			
		||||
@ -9,7 +9,7 @@ import { computed } from 'vue'
 | 
			
		||||
const props = defineProps({
 | 
			
		||||
  modelValue: {
 | 
			
		||||
    type: String,
 | 
			
		||||
    default: moment().format('YYYY-MM-DD hh:MM'),
 | 
			
		||||
    default: moment().format('YYYY-MM-DD HH:mm'),
 | 
			
		||||
  },
 | 
			
		||||
})
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
@ -17,18 +17,7 @@
 | 
			
		||||
            <td class="px-5 py-4 text-left align-top">
 | 
			
		||||
              <div class="flex justify-start">
 | 
			
		||||
                <div
 | 
			
		||||
                  class="
 | 
			
		||||
                    flex
 | 
			
		||||
                    items-center
 | 
			
		||||
                    justify-center
 | 
			
		||||
                    w-5
 | 
			
		||||
                    h-5
 | 
			
		||||
                    mt-2
 | 
			
		||||
                    text-gray-300
 | 
			
		||||
                    cursor-move
 | 
			
		||||
                    handle
 | 
			
		||||
                    mr-2
 | 
			
		||||
                  "
 | 
			
		||||
                  class="flex items-center justify-center w-5 h-5 mt-2 mr-2 text-gray-300 cursor-move  handle"
 | 
			
		||||
                >
 | 
			
		||||
                  <DragIcon />
 | 
			
		||||
                </div>
 | 
			
		||||
@ -108,7 +97,7 @@
 | 
			
		||||
 | 
			
		||||
                          <BaseIcon
 | 
			
		||||
                            name="ChevronDownIcon"
 | 
			
		||||
                            class="w-4 h-4 text-gray-500 ml-1"
 | 
			
		||||
                            class="w-4 h-4 ml-1 text-gray-500"
 | 
			
		||||
                          />
 | 
			
		||||
                        </span>
 | 
			
		||||
                      </BaseButton>
 | 
			
		||||
@ -155,7 +144,7 @@
 | 
			
		||||
              <BaseContentPlaceholders v-if="loading">
 | 
			
		||||
                <BaseContentPlaceholdersText
 | 
			
		||||
                  :lines="1"
 | 
			
		||||
                  class="w-24 h-8 rounded-md border"
 | 
			
		||||
                  class="w-24 h-8 border rounded-md"
 | 
			
		||||
                />
 | 
			
		||||
              </BaseContentPlaceholders>
 | 
			
		||||
 | 
			
		||||
@ -175,6 +164,7 @@
 | 
			
		||||
                :ability="abilities.CREATE_INVOICE"
 | 
			
		||||
                :store="store"
 | 
			
		||||
                :store-prop="storeProp"
 | 
			
		||||
                :discount="discount"
 | 
			
		||||
                @update="updateTax"
 | 
			
		||||
              />
 | 
			
		||||
            </td>
 | 
			
		||||
 | 
			
		||||
@ -30,24 +30,13 @@
 | 
			
		||||
        <template v-if="userStore.hasAbilities(ability)" #action>
 | 
			
		||||
          <button
 | 
			
		||||
            type="button"
 | 
			
		||||
            class="
 | 
			
		||||
              flex
 | 
			
		||||
              items-center
 | 
			
		||||
              justify-center
 | 
			
		||||
              w-full
 | 
			
		||||
              px-2
 | 
			
		||||
              cursor-pointer
 | 
			
		||||
              py-2
 | 
			
		||||
              bg-gray-200
 | 
			
		||||
              border-none
 | 
			
		||||
              outline-none
 | 
			
		||||
            "
 | 
			
		||||
            class="flex items-center justify-center w-full px-2 py-2 bg-gray-200 border-none outline-none cursor-pointer "
 | 
			
		||||
            @click="openTaxModal"
 | 
			
		||||
          >
 | 
			
		||||
            <BaseIcon name="CheckCircleIcon" class="h-5 text-primary-400" />
 | 
			
		||||
 | 
			
		||||
            <label
 | 
			
		||||
              class="ml-2 text-sm leading-none text-primary-400 cursor-pointer"
 | 
			
		||||
              class="ml-2 text-sm leading-none cursor-pointer text-primary-400"
 | 
			
		||||
              >{{ $t('invoices.add_new_tax') }}</label
 | 
			
		||||
            >
 | 
			
		||||
          </button>
 | 
			
		||||
@ -115,6 +104,10 @@ const props = defineProps({
 | 
			
		||||
    type: Number,
 | 
			
		||||
    default: 0,
 | 
			
		||||
  },
 | 
			
		||||
  discountedTotal: {
 | 
			
		||||
    type: Number,
 | 
			
		||||
    default: 0,
 | 
			
		||||
  },
 | 
			
		||||
  currency: {
 | 
			
		||||
    type: [Object, String],
 | 
			
		||||
    required: true,
 | 
			
		||||
@ -153,19 +146,19 @@ const filteredTypes = computed(() => {
 | 
			
		||||
})
 | 
			
		||||
 | 
			
		||||
const taxAmount = computed(() => {
 | 
			
		||||
  if (localTax.compound_tax && props.total) {
 | 
			
		||||
    return ((props.total + props.totalTax) * localTax.percent) / 100
 | 
			
		||||
  if (localTax.compound_tax && props.discountedTotal) {
 | 
			
		||||
    return ((props.discountedTotal + props.totalTax) * localTax.percent) / 100
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  if (props.total && localTax.percent) {
 | 
			
		||||
    return (props.total * localTax.percent) / 100
 | 
			
		||||
  if (props.discountedTotal && localTax.percent) {
 | 
			
		||||
    return (props.discountedTotal * localTax.percent) / 100
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  return 0
 | 
			
		||||
})
 | 
			
		||||
 | 
			
		||||
watch(
 | 
			
		||||
  () => props.total,
 | 
			
		||||
  () => props.discountedTotal,
 | 
			
		||||
  () => {
 | 
			
		||||
    updateRowTax()
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
@ -29,14 +29,7 @@
 | 
			
		||||
 | 
			
		||||
      <label
 | 
			
		||||
        v-else
 | 
			
		||||
        class="
 | 
			
		||||
          flex
 | 
			
		||||
          items-center
 | 
			
		||||
          justify-center
 | 
			
		||||
          m-0
 | 
			
		||||
          text-lg text-black
 | 
			
		||||
          uppercase
 | 
			
		||||
        "
 | 
			
		||||
        class="flex items-center justify-center m-0 text-lg text-black uppercase "
 | 
			
		||||
      >
 | 
			
		||||
        <BaseFormatMoney
 | 
			
		||||
          :amount="store.getSubTotal"
 | 
			
		||||
@ -66,14 +59,7 @@
 | 
			
		||||
 | 
			
		||||
      <label
 | 
			
		||||
        v-else-if="store[storeProp].tax_per_item === 'YES'"
 | 
			
		||||
        class="
 | 
			
		||||
          flex
 | 
			
		||||
          items-center
 | 
			
		||||
          justify-center
 | 
			
		||||
          m-0
 | 
			
		||||
          text-lg text-black
 | 
			
		||||
          uppercase
 | 
			
		||||
        "
 | 
			
		||||
        class="flex items-center justify-center m-0 text-lg text-black uppercase "
 | 
			
		||||
      >
 | 
			
		||||
        <BaseFormatMoney :amount="tax.amount" :currency="defaultCurrency" />
 | 
			
		||||
      </label>
 | 
			
		||||
@ -98,7 +84,7 @@
 | 
			
		||||
      <BaseContentPlaceholders v-if="isLoading">
 | 
			
		||||
        <BaseContentPlaceholdersText
 | 
			
		||||
          :lines="1"
 | 
			
		||||
          class="w-24 h-8 rounded-md border"
 | 
			
		||||
          class="w-24 h-8 border rounded-md"
 | 
			
		||||
        />
 | 
			
		||||
      </BaseContentPlaceholders>
 | 
			
		||||
      <div v-else class="flex" style="width: 140px" role="group">
 | 
			
		||||
@ -114,7 +100,7 @@
 | 
			
		||||
        <BaseDropdown position="bottom-end">
 | 
			
		||||
          <template #activator>
 | 
			
		||||
            <BaseButton
 | 
			
		||||
              class="rounded-tr-md rounded-br-md p-2 rounded-none"
 | 
			
		||||
              class="p-2 rounded-none rounded-tr-md rounded-br-md"
 | 
			
		||||
              type="button"
 | 
			
		||||
              variant="white"
 | 
			
		||||
            >
 | 
			
		||||
@ -127,7 +113,7 @@
 | 
			
		||||
 | 
			
		||||
                <BaseIcon
 | 
			
		||||
                  name="ChevronDownIcon"
 | 
			
		||||
                  class="w-4 h-4 text-gray-500 ml-1"
 | 
			
		||||
                  class="w-4 h-4 ml-1 text-gray-500"
 | 
			
		||||
                />
 | 
			
		||||
              </span>
 | 
			
		||||
            </BaseButton>
 | 
			
		||||
@ -180,15 +166,7 @@
 | 
			
		||||
    </div>
 | 
			
		||||
 | 
			
		||||
    <div
 | 
			
		||||
      class="
 | 
			
		||||
        flex
 | 
			
		||||
        items-center
 | 
			
		||||
        justify-between
 | 
			
		||||
        w-full
 | 
			
		||||
        pt-2
 | 
			
		||||
        mt-5
 | 
			
		||||
        border-t border-gray-200 border-solid
 | 
			
		||||
      "
 | 
			
		||||
      class="flex items-center justify-between w-full pt-2 mt-5 border-t border-gray-200 border-solid "
 | 
			
		||||
    >
 | 
			
		||||
      <BaseContentPlaceholders v-if="isLoading">
 | 
			
		||||
        <BaseContentPlaceholdersText :lines="1" class="w-16 h-5" />
 | 
			
		||||
@ -204,14 +182,7 @@
 | 
			
		||||
      </BaseContentPlaceholders>
 | 
			
		||||
      <label
 | 
			
		||||
        v-else
 | 
			
		||||
        class="
 | 
			
		||||
          flex
 | 
			
		||||
          items-center
 | 
			
		||||
          justify-center
 | 
			
		||||
          text-lg
 | 
			
		||||
          uppercase
 | 
			
		||||
          text-primary-400
 | 
			
		||||
        "
 | 
			
		||||
        class="flex items-center justify-center text-lg uppercase  text-primary-400"
 | 
			
		||||
      >
 | 
			
		||||
        <BaseFormatMoney :amount="store.getTotal" :currency="defaultCurrency" />
 | 
			
		||||
      </label>
 | 
			
		||||
@ -334,6 +305,7 @@ function selectPercentage() {
 | 
			
		||||
 | 
			
		||||
function onSelectTax(selectedTax) {
 | 
			
		||||
  let amount = 0
 | 
			
		||||
 | 
			
		||||
  if (selectedTax.compound_tax && props.store.getSubtotalWithDiscount) {
 | 
			
		||||
    amount = Math.round(
 | 
			
		||||
      ((props.store.getSubtotalWithDiscount + props.store.getTotalSimpleTax) *
 | 
			
		||||
 | 
			
		||||
@ -48,6 +48,24 @@
 | 
			
		||||
            />
 | 
			
		||||
          </BaseInputGroup>
 | 
			
		||||
 | 
			
		||||
          <BaseInputGroup
 | 
			
		||||
            :label="$tc('settings.company_info.company_slug')"
 | 
			
		||||
            :help-text="$t('settings.company_info.company_slug_help_text')"
 | 
			
		||||
            :error="
 | 
			
		||||
              v$.newCompanyForm.slug.$error &&
 | 
			
		||||
              v$.newCompanyForm.slug.$errors[0].$message
 | 
			
		||||
            "
 | 
			
		||||
            :content-loading="isFetchingInitialData"
 | 
			
		||||
            required
 | 
			
		||||
          >
 | 
			
		||||
            <BaseInput
 | 
			
		||||
              v-model="newCompanyForm.slug"
 | 
			
		||||
              :invalid="v$.newCompanyForm.slug.$error"
 | 
			
		||||
              :content-loading="isFetchingInitialData"
 | 
			
		||||
              @input="v$.newCompanyForm.slug.$touch()"
 | 
			
		||||
            />
 | 
			
		||||
          </BaseInputGroup>
 | 
			
		||||
 | 
			
		||||
          <BaseInputGroup
 | 
			
		||||
            :content-loading="isFetchingInitialData"
 | 
			
		||||
            :label="$tc('settings.company_info.country')"
 | 
			
		||||
@ -130,7 +148,7 @@
 | 
			
		||||
 | 
			
		||||
<script setup>
 | 
			
		||||
import { useModalStore } from '@/scripts/stores/modal'
 | 
			
		||||
import { computed, onMounted, ref, reactive } from 'vue'
 | 
			
		||||
import { computed, onMounted, ref, reactive, watch } from 'vue'
 | 
			
		||||
import { useI18n } from 'vue-i18n'
 | 
			
		||||
import { required, minLength, helpers } from '@vuelidate/validators'
 | 
			
		||||
import { useVuelidate } from '@vuelidate/core'
 | 
			
		||||
@ -152,6 +170,7 @@ let companyLogoName = ref(null)
 | 
			
		||||
 | 
			
		||||
const newCompanyForm = reactive({
 | 
			
		||||
  name: null,
 | 
			
		||||
  slug: null,
 | 
			
		||||
  currency: '',
 | 
			
		||||
  address: {
 | 
			
		||||
    country_id: null,
 | 
			
		||||
@ -162,6 +181,9 @@ const modalActive = computed(() => {
 | 
			
		||||
  return modalStore.active && modalStore.componentName === 'CompanyModal'
 | 
			
		||||
})
 | 
			
		||||
 | 
			
		||||
const slugValidator = (value) => {
 | 
			
		||||
  return value == slugify(value)
 | 
			
		||||
}
 | 
			
		||||
const rules = {
 | 
			
		||||
  newCompanyForm: {
 | 
			
		||||
    name: {
 | 
			
		||||
@ -171,6 +193,17 @@ const rules = {
 | 
			
		||||
        minLength(3)
 | 
			
		||||
      ),
 | 
			
		||||
    },
 | 
			
		||||
    slug: {
 | 
			
		||||
      required: helpers.withMessage(t('validation.required'), required),
 | 
			
		||||
      minLength: helpers.withMessage(
 | 
			
		||||
        t('validation.name_min_length', { count: 3 }),
 | 
			
		||||
        minLength(3)
 | 
			
		||||
      ),
 | 
			
		||||
      slugValidator: helpers.withMessage(
 | 
			
		||||
        t('validation.invalid_slug'),
 | 
			
		||||
        slugValidator
 | 
			
		||||
      ),
 | 
			
		||||
    },
 | 
			
		||||
    address: {
 | 
			
		||||
      country_id: {
 | 
			
		||||
        required: helpers.withMessage(t('validation.required'), required),
 | 
			
		||||
@ -243,6 +276,7 @@ async function submitCompanyData() {
 | 
			
		||||
 | 
			
		||||
function resetNewCompanyForm() {
 | 
			
		||||
  newCompanyForm.name = ''
 | 
			
		||||
  newCompanyForm.slug = ''
 | 
			
		||||
  newCompanyForm.currency = ''
 | 
			
		||||
  newCompanyForm.address.country_id = ''
 | 
			
		||||
 | 
			
		||||
@ -257,4 +291,24 @@ function closeCompanyModal() {
 | 
			
		||||
    v$.value.$reset()
 | 
			
		||||
  }, 300)
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// watcher for if change company name then auto fill company slug value
 | 
			
		||||
watch(
 | 
			
		||||
  () => newCompanyForm.name,
 | 
			
		||||
  (currentValue) => {
 | 
			
		||||
    newCompanyForm.slug = slugify(currentValue)
 | 
			
		||||
  }
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
function slugify(string) {
 | 
			
		||||
  return string
 | 
			
		||||
    .toString()
 | 
			
		||||
    .trim()
 | 
			
		||||
    .toLowerCase()
 | 
			
		||||
    .replace(/\s+/g, '-')
 | 
			
		||||
    .replace(/[^\w\-]+/g, '')
 | 
			
		||||
    .replace(/\-\-+/g, '-')
 | 
			
		||||
    .replace(/^-+/, '')
 | 
			
		||||
    .replace(/-+$/, '')
 | 
			
		||||
}
 | 
			
		||||
</script>
 | 
			
		||||
 | 
			
		||||
@ -15,6 +15,13 @@
 | 
			
		||||
      bg-gradient-to-r
 | 
			
		||||
      from-primary-500
 | 
			
		||||
      to-primary-400
 | 
			
		||||
      dark:from-gray-700/70 dark:to-gray-800/70
 | 
			
		||||
      bg-primary-500
 | 
			
		||||
      dark:bg-transparent
 | 
			
		||||
      dark:backdrop-blur-xl
 | 
			
		||||
      dark:shadow-glass
 | 
			
		||||
      dark:border
 | 
			
		||||
      dark:border-white/10
 | 
			
		||||
    "
 | 
			
		||||
  >
 | 
			
		||||
    <router-link
 | 
			
		||||
@ -53,6 +60,7 @@
 | 
			
		||||
        cursor-pointer
 | 
			
		||||
        md:hidden md:ml-0
 | 
			
		||||
        hover:bg-gray-100
 | 
			
		||||
        dark:bg-gray-800 dark:border-gray-500 dark:border
 | 
			
		||||
      "
 | 
			
		||||
      @click.prevent="onToggle"
 | 
			
		||||
    >
 | 
			
		||||
@ -143,7 +151,7 @@
 | 
			
		||||
          <template #activator>
 | 
			
		||||
            <img
 | 
			
		||||
              :src="previewAvatar"
 | 
			
		||||
              class="block w-8 h-8 rounded md:h-9 md:w-9"
 | 
			
		||||
              class="block w-8 h-8 rounded md:h-9 md:w-9 object-cover"
 | 
			
		||||
            />
 | 
			
		||||
          </template>
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
@ -15,7 +15,9 @@
 | 
			
		||||
        leave-from="opacity-100"
 | 
			
		||||
        leave-to="opacity-0"
 | 
			
		||||
      >
 | 
			
		||||
        <DialogOverlay class="fixed inset-0 bg-gray-600 bg-opacity-75" />
 | 
			
		||||
        <DialogOverlay
 | 
			
		||||
          class="fixed inset-0 bg-gray-600 bg-opacity-75 dark:bg-gray-900/90"
 | 
			
		||||
        />
 | 
			
		||||
      </TransitionChild>
 | 
			
		||||
 | 
			
		||||
      <TransitionChild
 | 
			
		||||
@ -27,7 +29,9 @@
 | 
			
		||||
        leave-from="translate-x-0"
 | 
			
		||||
        leave-to="-translate-x-full"
 | 
			
		||||
      >
 | 
			
		||||
        <div class="relative flex flex-col flex-1 w-full max-w-xs bg-white">
 | 
			
		||||
        <div
 | 
			
		||||
          class="relative flex flex-col flex-1 w-full max-w-xs bg-white dark:bg-gray-800"
 | 
			
		||||
        >
 | 
			
		||||
          <TransitionChild
 | 
			
		||||
            as="template"
 | 
			
		||||
            enter="ease-in-out duration-300"
 | 
			
		||||
@ -50,8 +54,7 @@
 | 
			
		||||
                focus:outline-none
 | 
			
		||||
                focus:ring-2
 | 
			
		||||
                focus:ring-inset
 | 
			
		||||
                  focus:ring-white
 | 
			
		||||
                "
 | 
			
		||||
                focus:ring-white"
 | 
			
		||||
                @click="globalStore.setSidebarVisibility(false)"
 | 
			
		||||
              >
 | 
			
		||||
                <span class="sr-only">Close sidebar</span>
 | 
			
		||||
@ -82,8 +85,8 @@
 | 
			
		||||
                :to="item.link"
 | 
			
		||||
                :class="[
 | 
			
		||||
                  hasActiveUrl(item.link)
 | 
			
		||||
                    ? 'text-primary-500 border-primary-500 bg-gray-100 '
 | 
			
		||||
                    : 'text-black',
 | 
			
		||||
                    ? 'text-primary-500 border-primary-500 bg-gray-100 dark:shadow-glass dark:backdrop-blur-xl dark:hover:bg-gray-700  dark:bg-gray-700/50 dark:text-primary-400 dark:font-medium'
 | 
			
		||||
                    : 'text-black dark:text-gray-300',
 | 
			
		||||
                  'cursor-pointer px-0 pl-4 py-3 border-transparent flex items-center border-l-4 border-solid text-sm not-italic font-medium',
 | 
			
		||||
                ]"
 | 
			
		||||
                @click="globalStore.setSidebarVisibility(false)"
 | 
			
		||||
@ -100,6 +103,10 @@
 | 
			
		||||
                />
 | 
			
		||||
                {{ $t(item.title) }}
 | 
			
		||||
              </router-link>
 | 
			
		||||
              <LightDarkSwitch
 | 
			
		||||
                :show-label="false"
 | 
			
		||||
                class="absolute right-6 top-6 !w-auto"
 | 
			
		||||
              />
 | 
			
		||||
            </nav>
 | 
			
		||||
          </div>
 | 
			
		||||
        </div>
 | 
			
		||||
@ -116,14 +123,13 @@
 | 
			
		||||
    hidden
 | 
			
		||||
    w-56
 | 
			
		||||
    h-screen
 | 
			
		||||
      pb-32
 | 
			
		||||
      overflow-y-auto
 | 
			
		||||
    bg-white
 | 
			
		||||
    border-r border-gray-200 border-solid
 | 
			
		||||
    xl:w-64
 | 
			
		||||
    md:fixed md:flex md:flex-col md:inset-y-0
 | 
			
		||||
    pt-16
 | 
			
		||||
    "
 | 
			
		||||
    dark:border-gray-800
 | 
			
		||||
    dark:bg-gray-800/80"
 | 
			
		||||
  >
 | 
			
		||||
    <div
 | 
			
		||||
      v-for="menu in globalStore.menuGroups"
 | 
			
		||||
@ -136,8 +142,8 @@
 | 
			
		||||
        :to="item.link"
 | 
			
		||||
        :class="[
 | 
			
		||||
          hasActiveUrl(item.link)
 | 
			
		||||
            ? 'text-primary-500 border-primary-500 bg-gray-100 '
 | 
			
		||||
            : 'text-black',
 | 
			
		||||
            ? 'text-primary-500 border-primary-500 bg-gray-100 dark:border-primary-400 dark:shadow-glass dark:backdrop-blur-xl dark:hover:bg-gray-700 dark:bg-gray-700/50 dark:text-primary-400 dark:font-medium'
 | 
			
		||||
            : 'text-black dark:hover:bg-transparent dark:hover:text-white dark:text-gray-300',
 | 
			
		||||
          'cursor-pointer px-0 pl-6 hover:bg-gray-50 py-3 group flex items-center border-l-4 border-solid border-transparent text-sm not-italic font-medium',
 | 
			
		||||
        ]"
 | 
			
		||||
      >
 | 
			
		||||
@ -145,8 +151,8 @@
 | 
			
		||||
          :name="item.icon"
 | 
			
		||||
          :class="[
 | 
			
		||||
            hasActiveUrl(item.link)
 | 
			
		||||
              ? 'text-primary-500 group-hover:text-primary-500 '
 | 
			
		||||
              : 'text-gray-400 group-hover:text-black',
 | 
			
		||||
              ? 'text-primary-500 group-hover:text-primary-500 dark:text-primary-400 dark:group-hover:text-primary-500 '
 | 
			
		||||
              : 'text-gray-400 group-hover:text-black dark:text-gray-400 dark:group-hover:text-white',
 | 
			
		||||
            'mr-4 shrink-0 h-5 w-5 ',
 | 
			
		||||
          ]"
 | 
			
		||||
        />
 | 
			
		||||
@ -154,6 +160,9 @@
 | 
			
		||||
        {{ $t(item.title) }}
 | 
			
		||||
      </router-link>
 | 
			
		||||
    </div>
 | 
			
		||||
    <LightDarkSwitch
 | 
			
		||||
      class="absolute bottom-0 py-4 border-t border-gray-200 dark:border-gray-700"
 | 
			
		||||
    />
 | 
			
		||||
  </div>
 | 
			
		||||
</template>
 | 
			
		||||
 | 
			
		||||
@ -169,6 +178,7 @@ import {
 | 
			
		||||
 | 
			
		||||
import { useRoute } from 'vue-router'
 | 
			
		||||
import { useGlobalStore } from '@/scripts/admin/stores/global'
 | 
			
		||||
import LightDarkSwitch from '@/scripts/components/LightDarkSwitcher.vue'
 | 
			
		||||
 | 
			
		||||
const route = useRoute()
 | 
			
		||||
const globalStore = useGlobalStore()
 | 
			
		||||
 | 
			
		||||
@ -184,6 +184,20 @@ export const useCompanyStore = (useWindow = false) => {
 | 
			
		||||
      setDefaultCurrency(data) {
 | 
			
		||||
        this.defaultCurrency = data.currency
 | 
			
		||||
      },
 | 
			
		||||
 | 
			
		||||
      checkCompanyHasCurrencyTransactions() {
 | 
			
		||||
        return new Promise((resolve, reject) => {
 | 
			
		||||
          axios
 | 
			
		||||
            .get(`/api/v1/company/has-transactions`)
 | 
			
		||||
            .then((response) => {
 | 
			
		||||
              resolve(response)
 | 
			
		||||
            })
 | 
			
		||||
            .catch((err) => {
 | 
			
		||||
              handleError(err)
 | 
			
		||||
              reject(err)
 | 
			
		||||
            })
 | 
			
		||||
        })
 | 
			
		||||
      },
 | 
			
		||||
    },
 | 
			
		||||
  })()
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
@ -34,6 +34,7 @@ export const useGlobalStore = (useWindow = false) => {
 | 
			
		||||
      isAppLoaded: false,
 | 
			
		||||
      isSidebarOpen: false,
 | 
			
		||||
      areCurrenciesLoading: false,
 | 
			
		||||
      isDarkModeOn: false,
 | 
			
		||||
 | 
			
		||||
      downloadReport: null,
 | 
			
		||||
    }),
 | 
			
		||||
 | 
			
		||||
@ -32,6 +32,8 @@
 | 
			
		||||
          :content-loading="isLoading"
 | 
			
		||||
          :calendar-button="true"
 | 
			
		||||
          calendar-button-icon="calendar"
 | 
			
		||||
          :show-extra-options="true"
 | 
			
		||||
          :source-date="estimateStore.newEstimate.estimate_date"
 | 
			
		||||
        />
 | 
			
		||||
      </BaseInputGroup>
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
@ -34,6 +34,24 @@
 | 
			
		||||
          />
 | 
			
		||||
        </BaseInputGroup>
 | 
			
		||||
 | 
			
		||||
        <BaseInputGroup
 | 
			
		||||
          :label="$tc('wizard.company_slug')"
 | 
			
		||||
          :help-text="$t('wizard.company_slug_help_text')"
 | 
			
		||||
          :error="
 | 
			
		||||
            v$.companyForm.slug.$error &&
 | 
			
		||||
            v$.companyForm.slug.$errors[0].$message
 | 
			
		||||
          "
 | 
			
		||||
          required
 | 
			
		||||
        >
 | 
			
		||||
          <BaseInput
 | 
			
		||||
            v-model="companyForm.slug"
 | 
			
		||||
            :invalid="v$.companyForm.slug.$error"
 | 
			
		||||
            type="text"
 | 
			
		||||
            name="slug"
 | 
			
		||||
            @input="v$.companyForm.slug.$touch()"
 | 
			
		||||
          />
 | 
			
		||||
        </BaseInputGroup>
 | 
			
		||||
 | 
			
		||||
        <BaseInputGroup
 | 
			
		||||
          :label="$t('wizard.country')"
 | 
			
		||||
          :error="
 | 
			
		||||
@ -57,9 +75,7 @@
 | 
			
		||||
            track-by="name"
 | 
			
		||||
          />
 | 
			
		||||
        </BaseInputGroup>
 | 
			
		||||
      </div>
 | 
			
		||||
 | 
			
		||||
      <div class="grid grid-cols-1 gap-4 mb-4 md:grid-cols-2 md:mb-6">
 | 
			
		||||
        <BaseInputGroup :label="$t('wizard.state')">
 | 
			
		||||
          <BaseInput
 | 
			
		||||
            v-model="companyForm.address.state"
 | 
			
		||||
@ -144,9 +160,9 @@
 | 
			
		||||
</template>
 | 
			
		||||
 | 
			
		||||
<script setup>
 | 
			
		||||
import { ref, computed, onMounted, reactive } from 'vue'
 | 
			
		||||
import { ref, computed, onMounted, reactive, watch } from 'vue'
 | 
			
		||||
import { useI18n } from 'vue-i18n'
 | 
			
		||||
import { required, maxLength, helpers } from '@vuelidate/validators'
 | 
			
		||||
import { required, minLength, maxLength, helpers } from '@vuelidate/validators'
 | 
			
		||||
import { useVuelidate } from '@vuelidate/core'
 | 
			
		||||
import { useGlobalStore } from '@/scripts/admin/stores/global'
 | 
			
		||||
import { useCompanyStore } from '@/scripts/admin/stores/company'
 | 
			
		||||
@ -162,6 +178,7 @@ let logoFileName = ref(null)
 | 
			
		||||
 | 
			
		||||
const companyForm = reactive({
 | 
			
		||||
  name: null,
 | 
			
		||||
  slug: null,
 | 
			
		||||
  address: {
 | 
			
		||||
    address_street_1: '',
 | 
			
		||||
    address_street_2: '',
 | 
			
		||||
@ -188,10 +205,28 @@ onMounted(async () => {
 | 
			
		||||
  })?.id
 | 
			
		||||
})
 | 
			
		||||
 | 
			
		||||
const slugValidator = (value) => {
 | 
			
		||||
  return value == slugify(value)
 | 
			
		||||
}
 | 
			
		||||
const rules = {
 | 
			
		||||
  companyForm: {
 | 
			
		||||
    name: {
 | 
			
		||||
      required: helpers.withMessage(t('validation.required'), required),
 | 
			
		||||
      minLength: helpers.withMessage(
 | 
			
		||||
        t('validation.name_min_length', { count: 3 }),
 | 
			
		||||
        minLength(3)
 | 
			
		||||
      ),
 | 
			
		||||
    },
 | 
			
		||||
    slug: {
 | 
			
		||||
      required: helpers.withMessage(t('validation.required'), required),
 | 
			
		||||
      minLength: helpers.withMessage(
 | 
			
		||||
        t('validation.name_min_length', { count: 3 }),
 | 
			
		||||
        minLength(3)
 | 
			
		||||
      ),
 | 
			
		||||
      slugValidator: helpers.withMessage(
 | 
			
		||||
        t('validation.invalid_slug'),
 | 
			
		||||
        slugValidator
 | 
			
		||||
      ),
 | 
			
		||||
    },
 | 
			
		||||
    address: {
 | 
			
		||||
      country_id: {
 | 
			
		||||
@ -249,4 +284,24 @@ async function next() {
 | 
			
		||||
    emit('next', 7)
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
// watcher for if change company name then auto fill company slug value
 | 
			
		||||
watch(
 | 
			
		||||
  () => companyForm.name,
 | 
			
		||||
  (currentValue) => {
 | 
			
		||||
    companyForm.slug = slugify(currentValue)
 | 
			
		||||
  }
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
function slugify(string) {
 | 
			
		||||
  return string
 | 
			
		||||
    .toString()
 | 
			
		||||
    .trim()
 | 
			
		||||
    .toLowerCase()
 | 
			
		||||
    .replace(/\s+/g, '-')
 | 
			
		||||
    .replace(/[^\w\-]+/g, '')
 | 
			
		||||
    .replace(/\-\-+/g, '-')
 | 
			
		||||
    .replace(/^-+/, '')
 | 
			
		||||
    .replace(/-+$/, '')
 | 
			
		||||
}
 | 
			
		||||
</script>
 | 
			
		||||
 | 
			
		||||
@ -56,7 +56,7 @@
 | 
			
		||||
        <BaseMultiselect
 | 
			
		||||
          v-model="filters.status"
 | 
			
		||||
          :groups="true"
 | 
			
		||||
          :options="status"
 | 
			
		||||
          :options="invoiceStatus"
 | 
			
		||||
          searchable
 | 
			
		||||
          :placeholder="$t('general.select_a_status')"
 | 
			
		||||
          @update:modelValue="setActiveTab"
 | 
			
		||||
@ -130,11 +130,27 @@
 | 
			
		||||
        "
 | 
			
		||||
      >
 | 
			
		||||
        <!-- Tabs -->
 | 
			
		||||
        <BaseTabGroup class="-mb-5" @change="setStatusFilter">
 | 
			
		||||
          <BaseTab :title="$t('general.all')" filter="" />
 | 
			
		||||
          <BaseTab :title="$t('general.draft')" filter="DRAFT" />
 | 
			
		||||
          <BaseTab :title="$t('general.sent')" filter="SENT" />
 | 
			
		||||
          <BaseTab :title="$t('general.due')" filter="DUE" />
 | 
			
		||||
        <BaseTabGroup
 | 
			
		||||
          class="-mb-5"
 | 
			
		||||
          :selected-index="selectedIndex"
 | 
			
		||||
          @change="changeTabStatus"
 | 
			
		||||
        >
 | 
			
		||||
          <BaseTab
 | 
			
		||||
            :title="invoiceTabStatus[0].title"
 | 
			
		||||
            :tab-status="invoiceTabStatus[0].value"
 | 
			
		||||
          />
 | 
			
		||||
          <BaseTab
 | 
			
		||||
            :title="invoiceTabStatus[1].title"
 | 
			
		||||
            :tab-status="invoiceTabStatus[1].value"
 | 
			
		||||
          />
 | 
			
		||||
          <BaseTab
 | 
			
		||||
            :title="invoiceTabStatus[2].title"
 | 
			
		||||
            :tab-status="invoiceTabStatus[2].value"
 | 
			
		||||
          />
 | 
			
		||||
          <BaseTab
 | 
			
		||||
            :title="invoiceTabStatus[3].title"
 | 
			
		||||
            :tab-status="invoiceTabStatus[3].value"
 | 
			
		||||
          />
 | 
			
		||||
        </BaseTabGroup>
 | 
			
		||||
 | 
			
		||||
        <BaseDropdown
 | 
			
		||||
@ -289,10 +305,10 @@ const utils = inject('$utils')
 | 
			
		||||
const table = ref(null)
 | 
			
		||||
const showFilters = ref(false)
 | 
			
		||||
 | 
			
		||||
const status = ref([
 | 
			
		||||
const invoiceStatus = ref([
 | 
			
		||||
  {
 | 
			
		||||
    label: 'Status',
 | 
			
		||||
    options: ['DRAFT', 'DUE', 'SENT', 'VIEWED', 'COMPLETED'],
 | 
			
		||||
    options: ['DRAFT', 'SENT', 'VIEWED', 'COMPLETED'],
 | 
			
		||||
  },
 | 
			
		||||
  {
 | 
			
		||||
    label: 'Paid Status',
 | 
			
		||||
@ -300,10 +316,29 @@ const status = ref([
 | 
			
		||||
  },
 | 
			
		||||
  ,
 | 
			
		||||
])
 | 
			
		||||
 | 
			
		||||
const invoiceTabStatus = {
 | 
			
		||||
  0: {
 | 
			
		||||
    title: t('general.all'),
 | 
			
		||||
    value: '',
 | 
			
		||||
  },
 | 
			
		||||
  1: {
 | 
			
		||||
    title: t('general.draft'),
 | 
			
		||||
    value: 'DRAFT',
 | 
			
		||||
  },
 | 
			
		||||
  2: {
 | 
			
		||||
    title: t('general.sent'),
 | 
			
		||||
    value: 'SENT',
 | 
			
		||||
  },
 | 
			
		||||
  3: {
 | 
			
		||||
    title: t('general.due'),
 | 
			
		||||
    value: 'DUE',
 | 
			
		||||
  },
 | 
			
		||||
}
 | 
			
		||||
const isRequestOngoing = ref(true)
 | 
			
		||||
const activeTab = ref('general.draft')
 | 
			
		||||
const router = useRouter()
 | 
			
		||||
const userStore = useUserStore()
 | 
			
		||||
const selectedIndex = ref(0)
 | 
			
		||||
 | 
			
		||||
let filters = reactive({
 | 
			
		||||
  customer_id: '',
 | 
			
		||||
@ -311,6 +346,7 @@ let filters = reactive({
 | 
			
		||||
  from_date: '',
 | 
			
		||||
  to_date: '',
 | 
			
		||||
  invoice_number: '',
 | 
			
		||||
  tab_status: '',
 | 
			
		||||
})
 | 
			
		||||
 | 
			
		||||
const showEmptyScreen = computed(
 | 
			
		||||
@ -401,6 +437,7 @@ async function fetchData({ page, filter, sort }) {
 | 
			
		||||
    from_date: filters.from_date,
 | 
			
		||||
    to_date: filters.to_date,
 | 
			
		||||
    invoice_number: filters.invoice_number,
 | 
			
		||||
    tab_status: filters.tab_status,
 | 
			
		||||
    orderByField: sort.fieldName || 'created_at',
 | 
			
		||||
    orderBy: sort.order || 'desc',
 | 
			
		||||
    page,
 | 
			
		||||
@ -423,29 +460,9 @@ async function fetchData({ page, filter, sort }) {
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
function setStatusFilter(val) {
 | 
			
		||||
  if (activeTab.value == val.title) {
 | 
			
		||||
    return true
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  activeTab.value = val.title
 | 
			
		||||
 | 
			
		||||
  switch (val.title) {
 | 
			
		||||
    case t('general.draft'):
 | 
			
		||||
      filters.status = 'DRAFT'
 | 
			
		||||
      break
 | 
			
		||||
    case t('general.sent'):
 | 
			
		||||
      filters.status = 'SENT'
 | 
			
		||||
      break
 | 
			
		||||
 | 
			
		||||
    case t('general.due'):
 | 
			
		||||
      filters.status = 'DUE'
 | 
			
		||||
      break
 | 
			
		||||
 | 
			
		||||
    default:
 | 
			
		||||
      filters.status = ''
 | 
			
		||||
      break
 | 
			
		||||
  }
 | 
			
		||||
function changeTabStatus(val, index) {
 | 
			
		||||
  filters.tab_status = val['tab-status']
 | 
			
		||||
  selectedIndex.value = index
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
function setFilters() {
 | 
			
		||||
@ -463,8 +480,6 @@ function clearFilter() {
 | 
			
		||||
  filters.from_date = ''
 | 
			
		||||
  filters.to_date = ''
 | 
			
		||||
  filters.invoice_number = ''
 | 
			
		||||
 | 
			
		||||
  activeTab.value = t('general.all')
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
async function removeMultipleInvoices() {
 | 
			
		||||
@ -505,39 +520,21 @@ function toggleFilter() {
 | 
			
		||||
function setActiveTab(val) {
 | 
			
		||||
  switch (val) {
 | 
			
		||||
    case 'DRAFT':
 | 
			
		||||
      activeTab.value = t('general.draft')
 | 
			
		||||
      selectedIndex.value = 1
 | 
			
		||||
      break
 | 
			
		||||
 | 
			
		||||
    case 'SENT':
 | 
			
		||||
      activeTab.value = t('general.sent')
 | 
			
		||||
      break
 | 
			
		||||
 | 
			
		||||
    case 'DUE':
 | 
			
		||||
      activeTab.value = t('general.due')
 | 
			
		||||
      break
 | 
			
		||||
 | 
			
		||||
    case 'VIEWED':
 | 
			
		||||
    case 'COMPLETED':
 | 
			
		||||
      activeTab.value = t('invoices.completed')
 | 
			
		||||
      break
 | 
			
		||||
 | 
			
		||||
    case 'PAID':
 | 
			
		||||
      activeTab.value = t('invoices.paid')
 | 
			
		||||
      selectedIndex.value = 2
 | 
			
		||||
      break
 | 
			
		||||
 | 
			
		||||
    case 'UNPAID':
 | 
			
		||||
      activeTab.value = t('invoices.unpaid')
 | 
			
		||||
      break
 | 
			
		||||
 | 
			
		||||
    case 'PARTIALLY_PAID':
 | 
			
		||||
      activeTab.value = t('invoices.partially_paid')
 | 
			
		||||
      break
 | 
			
		||||
 | 
			
		||||
    case 'VIEWED':
 | 
			
		||||
      activeTab.value = t('invoices.viewed')
 | 
			
		||||
      break
 | 
			
		||||
 | 
			
		||||
    default:
 | 
			
		||||
      activeTab.value = t('general.all')
 | 
			
		||||
      selectedIndex.value = 3
 | 
			
		||||
      break
 | 
			
		||||
  }
 | 
			
		||||
  filters.tab_status = invoiceTabStatus[selectedIndex.value].value
 | 
			
		||||
}
 | 
			
		||||
</script>
 | 
			
		||||
 | 
			
		||||
@ -32,6 +32,8 @@
 | 
			
		||||
          :content-loading="isLoading"
 | 
			
		||||
          :calendar-button="true"
 | 
			
		||||
          calendar-button-icon="calendar"
 | 
			
		||||
          :show-extra-options="true"
 | 
			
		||||
          :source-date="invoiceStore.newInvoice.invoice_date"
 | 
			
		||||
        />
 | 
			
		||||
      </BaseInputGroup>
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
@ -54,8 +54,6 @@
 | 
			
		||||
              label="name"
 | 
			
		||||
              :options="itemStore.itemUnits"
 | 
			
		||||
              value-prop="id"
 | 
			
		||||
              :can-deselect="false"
 | 
			
		||||
              :can-clear="false"
 | 
			
		||||
              :placeholder="$t('items.select_a_unit')"
 | 
			
		||||
              searchable
 | 
			
		||||
              track-by="name"
 | 
			
		||||
 | 
			
		||||
@ -82,9 +82,9 @@
 | 
			
		||||
            required
 | 
			
		||||
          >
 | 
			
		||||
            <BaseCustomerSelectInput
 | 
			
		||||
              v-if="!isLoadingContent"
 | 
			
		||||
              v-model="paymentStore.currentPayment.customer_id"
 | 
			
		||||
              :content-loading="isLoadingContent"
 | 
			
		||||
              v-if="!isLoadingContent"
 | 
			
		||||
              :invalid="v$.currentPayment.customer_id.$error"
 | 
			
		||||
              :placeholder="$t('customers.select_a_customer')"
 | 
			
		||||
              show-action
 | 
			
		||||
@ -423,7 +423,7 @@ function onCustomerChange(customer_id) {
 | 
			
		||||
  if (customer_id) {
 | 
			
		||||
    let data = {
 | 
			
		||||
      customer_id: customer_id,
 | 
			
		||||
      status: 'DUE',
 | 
			
		||||
      tab_status: 'DUE',
 | 
			
		||||
      limit: 'all',
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
@ -446,7 +446,11 @@ function onCustomerChange(customer_id) {
 | 
			
		||||
          paymentStore.currentPayment.selectedCustomer = res2.data.data
 | 
			
		||||
          paymentStore.currentPayment.customer = res2.data.data
 | 
			
		||||
          paymentStore.currentPayment.currency = res2.data.data.currency
 | 
			
		||||
          if(isEdit.value && !customerStore.editCustomer && paymentStore.currentPayment.customer_id) {
 | 
			
		||||
          if (
 | 
			
		||||
            isEdit.value &&
 | 
			
		||||
            !customerStore.editCustomer &&
 | 
			
		||||
            paymentStore.currentPayment.customer_id
 | 
			
		||||
          ) {
 | 
			
		||||
            customerStore.editCustomer = res2.data.data
 | 
			
		||||
          }
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
@ -28,6 +28,19 @@
 | 
			
		||||
          />
 | 
			
		||||
        </BaseInputGroup>
 | 
			
		||||
 | 
			
		||||
        <BaseInputGroup
 | 
			
		||||
          :label="$tc('settings.company_info.company_slug')"
 | 
			
		||||
          :help-text="$t('settings.company_info.company_slug_help_text')"
 | 
			
		||||
          :error="v$.slug.$error && v$.slug.$errors[0].$message"
 | 
			
		||||
          required
 | 
			
		||||
        >
 | 
			
		||||
          <BaseInput
 | 
			
		||||
            v-model="companyForm.slug"
 | 
			
		||||
            :invalid="v$.slug.$error"
 | 
			
		||||
            @blur="v$.slug.$touch()"
 | 
			
		||||
          />
 | 
			
		||||
        </BaseInputGroup>
 | 
			
		||||
 | 
			
		||||
        <BaseInputGroup :label="$tc('settings.company_info.phone')">
 | 
			
		||||
          <BaseInput v-model="companyForm.address.phone" />
 | 
			
		||||
        </BaseInputGroup>
 | 
			
		||||
@ -160,6 +173,7 @@ let isSaving = ref(false)
 | 
			
		||||
 | 
			
		||||
const companyForm = reactive({
 | 
			
		||||
  name: null,
 | 
			
		||||
  slug: null,
 | 
			
		||||
  logo: null,
 | 
			
		||||
  address: {
 | 
			
		||||
    address_street_1: '',
 | 
			
		||||
@ -193,7 +207,14 @@ const rules = computed(() => {
 | 
			
		||||
    name: {
 | 
			
		||||
      required: helpers.withMessage(t('validation.required'), required),
 | 
			
		||||
      minLength: helpers.withMessage(
 | 
			
		||||
        t('validation.name_min_length'),
 | 
			
		||||
        t('validation.name_min_length', { count: 3 }),
 | 
			
		||||
        minLength(3)
 | 
			
		||||
      ),
 | 
			
		||||
    },
 | 
			
		||||
    slug: {
 | 
			
		||||
      required: helpers.withMessage(t('validation.required'), required),
 | 
			
		||||
      minLength: helpers.withMessage(
 | 
			
		||||
        t('validation.name_min_length', { count: 3 }),
 | 
			
		||||
        minLength(3)
 | 
			
		||||
      ),
 | 
			
		||||
    },
 | 
			
		||||
 | 
			
		||||
@ -8,7 +8,11 @@
 | 
			
		||||
        <BaseInputGroup
 | 
			
		||||
          :content-loading="isFetchingInitialData"
 | 
			
		||||
          :label="$tc('settings.preferences.currency')"
 | 
			
		||||
          :help-text="$t('settings.preferences.company_currency_unchangeable')"
 | 
			
		||||
          :help-text="
 | 
			
		||||
            isCurrencyDisabled
 | 
			
		||||
              ? $t('settings.preferences.company_currency_unchangeable')
 | 
			
		||||
              : ''
 | 
			
		||||
          "
 | 
			
		||||
          :error="v$.currency.$error && v$.currency.$errors[0].$message"
 | 
			
		||||
          required
 | 
			
		||||
        >
 | 
			
		||||
@ -21,7 +25,7 @@
 | 
			
		||||
            :searchable="true"
 | 
			
		||||
            track-by="name"
 | 
			
		||||
            :invalid="v$.currency.$error"
 | 
			
		||||
            disabled
 | 
			
		||||
            :disabled="isCurrencyDisabled"
 | 
			
		||||
            class="w-full"
 | 
			
		||||
          >
 | 
			
		||||
          </BaseMultiselect>
 | 
			
		||||
@ -187,6 +191,7 @@ const { t, tm } = useI18n()
 | 
			
		||||
let isSaving = ref(false)
 | 
			
		||||
let isDataSaving = ref(false)
 | 
			
		||||
let isFetchingInitialData = ref(false)
 | 
			
		||||
let isCurrencyDisabled = ref(true)
 | 
			
		||||
 | 
			
		||||
const settingsForm = reactive({ ...companyStore.selectedCompanySettings })
 | 
			
		||||
 | 
			
		||||
@ -282,10 +287,14 @@ setInitialData()
 | 
			
		||||
async function setInitialData() {
 | 
			
		||||
  isFetchingInitialData.value = true
 | 
			
		||||
  Promise.all([
 | 
			
		||||
    companyStore.checkCompanyHasCurrencyTransactions(),
 | 
			
		||||
    globalStore.fetchCurrencies(),
 | 
			
		||||
    globalStore.fetchDateFormats(),
 | 
			
		||||
    globalStore.fetchTimeZones(),
 | 
			
		||||
  ]).then(([res1]) => {
 | 
			
		||||
    if (res1.data?.has_transactions == false) {
 | 
			
		||||
      isCurrencyDisabled.value = false
 | 
			
		||||
    }
 | 
			
		||||
    isFetchingInitialData.value = false
 | 
			
		||||
  })
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
							
								
								
									
										101
									
								
								resources/scripts/components/LightDarkSwitcher.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										101
									
								
								resources/scripts/components/LightDarkSwitcher.vue
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,101 @@
 | 
			
		||||
<!-- This example requires Tailwind CSS v2.0+ -->
 | 
			
		||||
<script lang="ts" setup>
 | 
			
		||||
import { Switch, SwitchGroup, SwitchLabel } from '@headlessui/vue'
 | 
			
		||||
import { useGlobalStore } from '@/scripts/admin/stores/global'
 | 
			
		||||
import { computed, ref } from 'vue'
 | 
			
		||||
defineProps({
 | 
			
		||||
  showLabel: {
 | 
			
		||||
    type: Boolean,
 | 
			
		||||
    default: true,
 | 
			
		||||
  },
 | 
			
		||||
  vertical: {
 | 
			
		||||
    type: Boolean,
 | 
			
		||||
    default: false,
 | 
			
		||||
  },
 | 
			
		||||
})
 | 
			
		||||
 | 
			
		||||
const globalStore = useGlobalStore()
 | 
			
		||||
 | 
			
		||||
const enabled = ref(
 | 
			
		||||
  localStorage.getItem('theme') === 'dark' ||
 | 
			
		||||
    document.documentElement.classList.contains('dark')
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
globalStore.isDarkModeOn = enabled
 | 
			
		||||
 | 
			
		||||
function onChange(val) {
 | 
			
		||||
  if (val) {
 | 
			
		||||
    localStorage.theme = 'dark'
 | 
			
		||||
    document.documentElement.classList.add('dark')
 | 
			
		||||
    document.documentElement.style.setProperty('color-scheme', 'dark')
 | 
			
		||||
    globalStore.isDarkModeOn = true
 | 
			
		||||
  } else {
 | 
			
		||||
    localStorage.theme = 'light'
 | 
			
		||||
    document.documentElement.classList.remove('dark')
 | 
			
		||||
    document.documentElement.style.setProperty('color-scheme', 'light')
 | 
			
		||||
    globalStore.isDarkModeOn = false
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
</script>
 | 
			
		||||
 | 
			
		||||
<template>
 | 
			
		||||
  <div class="w-full flex justify-center">
 | 
			
		||||
    <SwitchGroup
 | 
			
		||||
      as="div"
 | 
			
		||||
      class="flex items-center"
 | 
			
		||||
      :class="vertical ? 'flex-col justify-center' : 'flex-row'"
 | 
			
		||||
    >
 | 
			
		||||
      <Switch
 | 
			
		||||
        v-model="enabled"
 | 
			
		||||
        class="relative inline-flex flex-shrink-0 h-6 w-11 border-2 border-transparent rounded-full cursor-pointer transition-colors ease-in-out duration-200 focus:outline-none focus:ring-2 focus:ring-offset-2 focus:ring-primary-500 dark:ring-offset-gray-700"
 | 
			
		||||
        :class="[enabled ? 'bg-primary-600' : 'bg-gray-200']"
 | 
			
		||||
        @update:modelValue="onChange"
 | 
			
		||||
      >
 | 
			
		||||
        <span class="sr-only">Use setting</span>
 | 
			
		||||
        <span
 | 
			
		||||
          class="pointer-events-none relative inline-block h-5 w-5 rounded-full bg-white shadow transform ring-0 transition ease-in-out duration-200"
 | 
			
		||||
          :class="[enabled ? 'translate-x-5' : 'translate-x-0']"
 | 
			
		||||
        >
 | 
			
		||||
          <span
 | 
			
		||||
            class="absolute inset-0 h-full w-full flex items-center justify-center transition-opacity"
 | 
			
		||||
            :class="[
 | 
			
		||||
              enabled
 | 
			
		||||
                ? 'opacity-0 ease-out duration-100'
 | 
			
		||||
                : 'opacity-100 ease-in duration-200',
 | 
			
		||||
            ]"
 | 
			
		||||
            aria-hidden="true"
 | 
			
		||||
          >
 | 
			
		||||
            <BaseIcon class="h-3 w-3 text-yellow-500" name="SunIcon" />
 | 
			
		||||
          </span>
 | 
			
		||||
          <span
 | 
			
		||||
            class="absolute inset-0 h-full w-full flex items-center justify-center transition-opacity"
 | 
			
		||||
            :class="[
 | 
			
		||||
              enabled
 | 
			
		||||
                ? 'opacity-100 ease-in duration-200'
 | 
			
		||||
                : 'opacity-0 ease-out duration-100',
 | 
			
		||||
            ]"
 | 
			
		||||
            aria-hidden="true"
 | 
			
		||||
          >
 | 
			
		||||
            <BaseIcon class="h-3 w-3 text-primary-500" name="MoonIcon" />
 | 
			
		||||
          </span>
 | 
			
		||||
        </span>
 | 
			
		||||
      </Switch>
 | 
			
		||||
      <SwitchLabel
 | 
			
		||||
        v-if="showLabel"
 | 
			
		||||
        as="span"
 | 
			
		||||
        class="cursor-pointer"
 | 
			
		||||
        :class="vertical ? 'px-1 text-center mt-2' : 'ml-3'"
 | 
			
		||||
      >
 | 
			
		||||
        <span
 | 
			
		||||
          v-if="enabled"
 | 
			
		||||
          class="text-sm font-medium text-gray-500 dark:text-gray-400"
 | 
			
		||||
        >
 | 
			
		||||
          Dark Mode
 | 
			
		||||
        </span>
 | 
			
		||||
        <span v-else class="text-sm font-medium text-gray-500">
 | 
			
		||||
          Light Mode
 | 
			
		||||
        </span>
 | 
			
		||||
      </SwitchLabel>
 | 
			
		||||
    </SwitchGroup>
 | 
			
		||||
  </div>
 | 
			
		||||
</template>
 | 
			
		||||
@ -126,7 +126,7 @@ onMounted(() => {
 | 
			
		||||
})
 | 
			
		||||
 | 
			
		||||
const value = computed({
 | 
			
		||||
  get: () => props.modelValue,
 | 
			
		||||
  get: () => (props.modelValue ? props.modelValue : ''),
 | 
			
		||||
  set: (value) => {
 | 
			
		||||
    emit('update:modelValue', value)
 | 
			
		||||
  },
 | 
			
		||||
@ -195,7 +195,9 @@ async function getFields() {
 | 
			
		||||
          { label: 'Date', value: 'INVOICE_DATE' },
 | 
			
		||||
          { label: 'Due Date', value: 'INVOICE_DUE_DATE' },
 | 
			
		||||
          { label: 'Number', value: 'INVOICE_NUMBER' },
 | 
			
		||||
          { label: 'Ref Number', value: 'INVOICE_REF_NUMBER' },
 | 
			
		||||
          { label: 'PDF Link', value: 'PDF_LINK' },
 | 
			
		||||
          { label: 'Due Amount', value: 'DUE_AMOUNT' },
 | 
			
		||||
          { label: 'Total Amount', value: 'TOTAL_AMOUNT' },
 | 
			
		||||
          ...invoiceFields.value.map((i) => ({
 | 
			
		||||
            label: i.label,
 | 
			
		||||
            value: i.slug,
 | 
			
		||||
@ -211,7 +213,8 @@ async function getFields() {
 | 
			
		||||
          { label: 'Date', value: 'ESTIMATE_DATE' },
 | 
			
		||||
          { label: 'Expiry Date', value: 'ESTIMATE_EXPIRY_DATE' },
 | 
			
		||||
          { label: 'Number', value: 'ESTIMATE_NUMBER' },
 | 
			
		||||
          { label: 'Ref Number', value: 'ESTIMATE_REF_NUMBER' },
 | 
			
		||||
          { label: 'PDF Link', value: 'PDF_LINK' },
 | 
			
		||||
          { label: 'Total Amount', value: 'TOTAL_AMOUNT' },
 | 
			
		||||
          ...estimateFields.value.map((i) => ({
 | 
			
		||||
            label: i.label,
 | 
			
		||||
            value: i.slug,
 | 
			
		||||
@ -228,6 +231,7 @@ async function getFields() {
 | 
			
		||||
          { label: 'Number', value: 'PAYMENT_NUMBER' },
 | 
			
		||||
          { label: 'Mode', value: 'PAYMENT_MODE' },
 | 
			
		||||
          { label: 'Amount', value: 'PAYMENT_AMOUNT' },
 | 
			
		||||
          { label: 'PDF Link', value: 'PDF_LINK' },
 | 
			
		||||
          ...paymentFields.value.map((i) => ({
 | 
			
		||||
            label: i.label,
 | 
			
		||||
            value: i.slug,
 | 
			
		||||
 | 
			
		||||
@ -7,7 +7,33 @@
 | 
			
		||||
    />
 | 
			
		||||
  </BaseContentPlaceholders>
 | 
			
		||||
 | 
			
		||||
  <div v-else :class="computedContainerClass" class="relative flex flex-row">
 | 
			
		||||
  <div v-else :class="computedContainerClass">
 | 
			
		||||
    <date-picker
 | 
			
		||||
      ref="vCalendar"
 | 
			
		||||
      v-model="date"
 | 
			
		||||
      :mode="mode"
 | 
			
		||||
      :is24hr="time24hr"
 | 
			
		||||
      class="w-full"
 | 
			
		||||
      color="indigo"
 | 
			
		||||
      :input-debounce="500"
 | 
			
		||||
      :update-on-input="false"
 | 
			
		||||
      :is-range="false"
 | 
			
		||||
      trim-weeks
 | 
			
		||||
      :is-required="isRequired"
 | 
			
		||||
      :popover="{
 | 
			
		||||
        visibility: disabled ? 'hidden' : 'focus',
 | 
			
		||||
        showDelay: 0,
 | 
			
		||||
        hideDelay: 1,
 | 
			
		||||
      }"
 | 
			
		||||
      :attributes="attrs"
 | 
			
		||||
      :model-config="config"
 | 
			
		||||
      :masks="masks"
 | 
			
		||||
      :locale="global.locale"
 | 
			
		||||
    >
 | 
			
		||||
      <template
 | 
			
		||||
        #default="{ inputValue, inputEvents, togglePopover, hidePopover }"
 | 
			
		||||
      >
 | 
			
		||||
        <!-- calendar icon -->
 | 
			
		||||
        <svg
 | 
			
		||||
          v-if="showCalendarIcon && !hasIconSlot"
 | 
			
		||||
          viewBox="0 0 20 20"
 | 
			
		||||
@ -24,7 +50,7 @@
 | 
			
		||||
            text-gray-400
 | 
			
		||||
            cursor-pointer
 | 
			
		||||
          "
 | 
			
		||||
      @click="onClickDp"
 | 
			
		||||
          @click="togglePopover()"
 | 
			
		||||
        >
 | 
			
		||||
          <path
 | 
			
		||||
            fill-rule="evenodd"
 | 
			
		||||
@ -35,24 +61,54 @@
 | 
			
		||||
 | 
			
		||||
        <slot v-if="showCalendarIcon && hasIconSlot" name="icon" />
 | 
			
		||||
 | 
			
		||||
    <FlatPickr
 | 
			
		||||
      ref="dp"
 | 
			
		||||
      v-model="date"
 | 
			
		||||
      v-bind="$attrs"
 | 
			
		||||
      :disabled="disabled"
 | 
			
		||||
      :config="config"
 | 
			
		||||
        <input
 | 
			
		||||
          :value="inputValue"
 | 
			
		||||
          :class="[defaultInputClass, inputInvalidClass, inputDisabledClass]"
 | 
			
		||||
          readonly
 | 
			
		||||
          v-on="inputEvents"
 | 
			
		||||
          @blur="hidePopover()"
 | 
			
		||||
        />
 | 
			
		||||
      </template>
 | 
			
		||||
 | 
			
		||||
      <template v-if="showExtraOptions" #footer>
 | 
			
		||||
        <div
 | 
			
		||||
          class="bg-gray-100 grid grid-cols-3 gap-2 p-2 border-t rounded-b-lg"
 | 
			
		||||
        >
 | 
			
		||||
          <button type="button" class="extra-button" @click="moveToDate(sourceDate)">
 | 
			
		||||
            {{ global.t('date_picker.same_day') }}
 | 
			
		||||
          </button>
 | 
			
		||||
 | 
			
		||||
          <button type="button" class="extra-button" @click="withInDays(7)">
 | 
			
		||||
            {{ global.t('date_picker.within_7_days') }}
 | 
			
		||||
          </button>
 | 
			
		||||
 | 
			
		||||
          <button type="button" class="extra-button" @click="withInDays(15)">
 | 
			
		||||
            {{ global.t('date_picker.within_15_days') }}
 | 
			
		||||
          </button>
 | 
			
		||||
 | 
			
		||||
          <button type="button" class="extra-button" @click="withInDays(30)">
 | 
			
		||||
            {{ global.t('date_picker.within_30_days') }}
 | 
			
		||||
          </button>
 | 
			
		||||
 | 
			
		||||
          <button type="button" class="extra-button" @click="withInDays(45)">
 | 
			
		||||
            {{ global.t('date_picker.within_45_days') }}
 | 
			
		||||
          </button>
 | 
			
		||||
 | 
			
		||||
          <button type="button" class="extra-button" @click="withInDays(60)">
 | 
			
		||||
            {{ global.t('date_picker.within_60_days') }}
 | 
			
		||||
          </button>
 | 
			
		||||
        </div>
 | 
			
		||||
      </template>
 | 
			
		||||
    </date-picker>
 | 
			
		||||
  </div>
 | 
			
		||||
</template>
 | 
			
		||||
 | 
			
		||||
<script type="text/babel" setup>
 | 
			
		||||
import FlatPickr from 'vue-flatpickr-component'
 | 
			
		||||
import 'flatpickr/dist/flatpickr.css'
 | 
			
		||||
import { Calendar, DatePicker } from 'v-calendar'
 | 
			
		||||
import 'v-calendar/dist/style.css'
 | 
			
		||||
import { computed, reactive, watch, ref, useSlots } from 'vue'
 | 
			
		||||
import { useCompanyStore } from '@/scripts/admin/stores/company'
 | 
			
		||||
 | 
			
		||||
const dp = ref(null)
 | 
			
		||||
import moment from 'moment'
 | 
			
		||||
 | 
			
		||||
const props = defineProps({
 | 
			
		||||
  modelValue: {
 | 
			
		||||
@ -90,36 +146,31 @@ const props = defineProps({
 | 
			
		||||
  defaultInputClass: {
 | 
			
		||||
    type: String,
 | 
			
		||||
    default:
 | 
			
		||||
      'font-base pl-8 py-2 outline-none focus:ring-primary-400 focus:outline-none focus:border-primary-400 block w-full sm:text-sm border-gray-200 rounded-md text-black',
 | 
			
		||||
      'border-2 font-base pl-8 py-2 outline-none focus:ring-primary-400 focus:outline-none focus:border-primary-400 block w-full sm:text-sm border-gray-200 rounded-md text-black',
 | 
			
		||||
  },
 | 
			
		||||
  time24hr: {
 | 
			
		||||
    type: Boolean,
 | 
			
		||||
    default: false,
 | 
			
		||||
  },
 | 
			
		||||
  isRequired: {
 | 
			
		||||
    type: Boolean,
 | 
			
		||||
    default: false,
 | 
			
		||||
  },
 | 
			
		||||
  showExtraOptions: {
 | 
			
		||||
    type: Boolean,
 | 
			
		||||
    default: false,
 | 
			
		||||
  },
 | 
			
		||||
  sourceDate: {
 | 
			
		||||
    type: [String, Date],
 | 
			
		||||
    default: () => new Date(),
 | 
			
		||||
  }
 | 
			
		||||
})
 | 
			
		||||
 | 
			
		||||
const emit = defineEmits(['update:modelValue'])
 | 
			
		||||
 | 
			
		||||
const slots = useSlots()
 | 
			
		||||
 | 
			
		||||
const companyStore = useCompanyStore()
 | 
			
		||||
 | 
			
		||||
let config = reactive({
 | 
			
		||||
  altInput: true,
 | 
			
		||||
  enableTime: props.enableTime,
 | 
			
		||||
  time_24hr: props.time24hr,
 | 
			
		||||
})
 | 
			
		||||
 | 
			
		||||
const date = computed({
 | 
			
		||||
  get: () => props.modelValue,
 | 
			
		||||
  set: (value) => {
 | 
			
		||||
    emit('update:modelValue', value)
 | 
			
		||||
  },
 | 
			
		||||
})
 | 
			
		||||
 | 
			
		||||
const carbonFormat = computed(() => {
 | 
			
		||||
  return companyStore.selectedCompanySettings?.carbon_date_format
 | 
			
		||||
})
 | 
			
		||||
const { global } = window.i18n
 | 
			
		||||
const vCalendar = ref(null)
 | 
			
		||||
 | 
			
		||||
const hasIconSlot = computed(() => {
 | 
			
		||||
  return !!slots.icon
 | 
			
		||||
@ -135,7 +186,6 @@ const inputInvalidClass = computed(() => {
 | 
			
		||||
  if (props.invalid) {
 | 
			
		||||
    return 'border-red-400 ring-red-400 focus:ring-red-400 focus:border-red-400'
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  return ''
 | 
			
		||||
})
 | 
			
		||||
 | 
			
		||||
@ -143,35 +193,97 @@ const inputDisabledClass = computed(() => {
 | 
			
		||||
  if (props.disabled) {
 | 
			
		||||
    return 'border border-solid rounded-md outline-none input-field box-border-2 base-date-picker-input placeholder-gray-400 bg-gray-200 text-gray-600 border-gray-200'
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  return ''
 | 
			
		||||
})
 | 
			
		||||
 | 
			
		||||
function onClickDp(params) {
 | 
			
		||||
  dp.value.fp.open()
 | 
			
		||||
// to convert YYYY-MM-DD | YYYY-MM-DD HH:mm format
 | 
			
		||||
function convertYMDFormat(date) {
 | 
			
		||||
  let format = props.enableTime ? 'YYYY-MM-DD HH:mm' : 'YYYY-MM-DD'
 | 
			
		||||
  return date ? moment(date).format(format) : date
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
watch(
 | 
			
		||||
  () => props.enableTime,
 | 
			
		||||
  (val) => {
 | 
			
		||||
    if (props.enableTime) {
 | 
			
		||||
      config.enableTime = props.enableTime
 | 
			
		||||
    }
 | 
			
		||||
const date = computed({
 | 
			
		||||
  get: () => props.modelValue,
 | 
			
		||||
  set: (value) => {
 | 
			
		||||
    emit('update:modelValue', value)
 | 
			
		||||
  },
 | 
			
		||||
  { immediate: true }
 | 
			
		||||
)
 | 
			
		||||
})
 | 
			
		||||
 | 
			
		||||
const mode = computed(() => {
 | 
			
		||||
  return props.enableTime ? 'dateTime' : 'date'
 | 
			
		||||
})
 | 
			
		||||
 | 
			
		||||
const config = reactive({
 | 
			
		||||
  type: 'string',
 | 
			
		||||
  mask: 'YYYY-MM-DD', // Uses 'iso' if missing
 | 
			
		||||
  //timeAdjust: '00:00:00',
 | 
			
		||||
})
 | 
			
		||||
 | 
			
		||||
const masks = reactive({
 | 
			
		||||
  input: null,
 | 
			
		||||
  inputDateTime: null,
 | 
			
		||||
  inputDateTime24hr: null,
 | 
			
		||||
})
 | 
			
		||||
 | 
			
		||||
const attrs = reactive([
 | 
			
		||||
  {
 | 
			
		||||
    dates: new Date(),
 | 
			
		||||
    highlight: {
 | 
			
		||||
      fillMode: 'outline',
 | 
			
		||||
    },
 | 
			
		||||
    /* popover: {
 | 
			
		||||
      label: 'Today Date',
 | 
			
		||||
      visibility: 'hover',
 | 
			
		||||
    }, */
 | 
			
		||||
  },
 | 
			
		||||
])
 | 
			
		||||
 | 
			
		||||
const carbonFormat = computed(() => {
 | 
			
		||||
  return companyStore.selectedCompanySettings?.moment_date_format
 | 
			
		||||
})
 | 
			
		||||
 | 
			
		||||
watch(
 | 
			
		||||
  () => carbonFormat,
 | 
			
		||||
  () => {
 | 
			
		||||
    if (!props.enableTime) {
 | 
			
		||||
      config.altFormat = carbonFormat.value ? carbonFormat.value : 'd M Y'
 | 
			
		||||
      masks.input = carbonFormat.value ? carbonFormat.value : 'DD MMM YYYY'
 | 
			
		||||
      config.mask = 'YYYY-MM-DD'
 | 
			
		||||
    } else {
 | 
			
		||||
      config.altFormat = carbonFormat.value
 | 
			
		||||
        ? `${carbonFormat.value} H:i `
 | 
			
		||||
        : 'd M Y H:i'
 | 
			
		||||
      let timeFormat = 'HH:mm'
 | 
			
		||||
      if (props.time24hr) {
 | 
			
		||||
        masks.inputDateTime24hr = carbonFormat.value
 | 
			
		||||
          ? `${carbonFormat.value} ${timeFormat}`
 | 
			
		||||
          : `DD MMM YYYY ${timeFormat}`
 | 
			
		||||
      } else {
 | 
			
		||||
        masks.inputDateTime = carbonFormat.value
 | 
			
		||||
          ? `${carbonFormat.value} ${timeFormat}`
 | 
			
		||||
          : `DD MMM YYYY ${timeFormat}`
 | 
			
		||||
      }
 | 
			
		||||
      config.mask = `YYYY-MM-DD ${timeFormat}`
 | 
			
		||||
    }
 | 
			
		||||
  },
 | 
			
		||||
  { immediate: true }
 | 
			
		||||
)
 | 
			
		||||
 | 
			
		||||
async function moveToDate(_date) {
 | 
			
		||||
  const calendar = vCalendar.value
 | 
			
		||||
  _date = _date ? _date : convertYMDFormat(new Date())
 | 
			
		||||
  date.value = _date
 | 
			
		||||
  // await calendar.move(_date)
 | 
			
		||||
  calendar.hidePopover()
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
async function withInDays(noOfDays) {
 | 
			
		||||
  if (!noOfDays) return false
 | 
			
		||||
 | 
			
		||||
  let newDate = moment(props.sourceDate).add(noOfDays, 'days').toDate()
 | 
			
		||||
  newDate = convertYMDFormat(newDate)
 | 
			
		||||
  moveToDate(newDate)
 | 
			
		||||
}
 | 
			
		||||
</script>
 | 
			
		||||
 | 
			
		||||
<style scoped>
 | 
			
		||||
.extra-button {
 | 
			
		||||
  @apply bg-primary-500 text-white text-sm font-semibold px-2 py-1 rounded hover:bg-primary-700;
 | 
			
		||||
}
 | 
			
		||||
</style>
 | 
			
		||||
 | 
			
		||||
@ -1,6 +1,10 @@
 | 
			
		||||
<template>
 | 
			
		||||
  <div>
 | 
			
		||||
    <TabGroup :default-index="defaultIndex" @change="onChange">
 | 
			
		||||
    <TabGroup
 | 
			
		||||
      :selected-index="selectedIndex"
 | 
			
		||||
      :default-index="defaultIndex"
 | 
			
		||||
      @change="onChange"
 | 
			
		||||
    >
 | 
			
		||||
      <TabList
 | 
			
		||||
        :class="[
 | 
			
		||||
          'flex border-b border-grey-light',
 | 
			
		||||
@ -54,6 +58,10 @@ const props = defineProps({
 | 
			
		||||
    type: Number,
 | 
			
		||||
    default: 0,
 | 
			
		||||
  },
 | 
			
		||||
  selectedIndex: {
 | 
			
		||||
    type: Number,
 | 
			
		||||
    default: 0,
 | 
			
		||||
  },
 | 
			
		||||
  filter: {
 | 
			
		||||
    type: String,
 | 
			
		||||
    default: null,
 | 
			
		||||
@ -67,6 +75,6 @@ const slots = useSlots()
 | 
			
		||||
const tabs = computed(() => slots.default().map((tab) => tab.props))
 | 
			
		||||
 | 
			
		||||
function onChange(d) {
 | 
			
		||||
  emit('change', tabs.value[d])
 | 
			
		||||
  emit('change', tabs.value[d], d)
 | 
			
		||||
}
 | 
			
		||||
</script>
 | 
			
		||||
 | 
			
		||||
@ -7,11 +7,18 @@
 | 
			
		||||
            relative
 | 
			
		||||
            overflow-hidden
 | 
			
		||||
            bg-white
 | 
			
		||||
            border-b border-gray-200
 | 
			
		||||
            border-b
 | 
			
		||||
            border-gray-200
 | 
			
		||||
            shadow
 | 
			
		||||
            sm:rounded-lg
 | 
			
		||||
            dark:shadow-glass
 | 
			
		||||
            dark:border
 | 
			
		||||
            dark:border-white/10
 | 
			
		||||
            dark:bg-gray-800/70
 | 
			
		||||
            "
 | 
			
		||||
        >
 | 
			
		||||
          <BaseDarkHighlight v-if="darkHighlight" class="z-[-1]" />
 | 
			
		||||
 | 
			
		||||
          <slot name="header" />
 | 
			
		||||
          <table :class="tableClass">
 | 
			
		||||
            <thead :class="theadClass">
 | 
			
		||||
@ -51,7 +58,11 @@
 | 
			
		||||
              <tr
 | 
			
		||||
                v-for="placeRow in placeholderCount"
 | 
			
		||||
                :key="placeRow"
 | 
			
		||||
                :class="placeRow % 2 === 0 ? 'bg-white' : 'bg-gray-50'"
 | 
			
		||||
                :class="
 | 
			
		||||
                  placeRow % 2 === 0
 | 
			
		||||
                    ? 'bg-white dark:bg-gray-800'
 | 
			
		||||
                    : 'bg-gray-50 dark:bg-gray-800'
 | 
			
		||||
                "
 | 
			
		||||
              >
 | 
			
		||||
                <td
 | 
			
		||||
                  v-for="column in columns"
 | 
			
		||||
@ -75,7 +86,11 @@
 | 
			
		||||
              <tr
 | 
			
		||||
                v-for="(row, index) in sortedRows"
 | 
			
		||||
                :key="index"
 | 
			
		||||
                :class="index % 2 === 0 ? 'bg-white' : 'bg-gray-50'"
 | 
			
		||||
                :class="
 | 
			
		||||
                  index % 2 === 0
 | 
			
		||||
                    ? 'bg-white dark:bg-transparent'
 | 
			
		||||
                    : 'bg-gray-50 dark:bg-gray-700/20 dark:border-y dark:border-gray-600'
 | 
			
		||||
                "
 | 
			
		||||
              >
 | 
			
		||||
                <td
 | 
			
		||||
                  v-for="column in columns"
 | 
			
		||||
@ -103,7 +118,10 @@
 | 
			
		||||
              justify-center
 | 
			
		||||
              w-full
 | 
			
		||||
              h-full
 | 
			
		||||
              bg-white bg-opacity-60
 | 
			
		||||
              bg-white
 | 
			
		||||
              bg-opacity-60
 | 
			
		||||
              dark:bg-gray-700
 | 
			
		||||
              dark:bg-opacity-60
 | 
			
		||||
            "
 | 
			
		||||
          >
 | 
			
		||||
            <SpinnerIcon class="w-10 h-10 text-primary-500" />
 | 
			
		||||
@ -163,9 +181,12 @@ const props = defineProps({
 | 
			
		||||
  sortOrder: { type: String, default: '' },
 | 
			
		||||
  tableClass: {
 | 
			
		||||
    type: String,
 | 
			
		||||
    default: 'min-w-full divide-y divide-gray-200',
 | 
			
		||||
    default: 'min-w-full divide-y divide-gray-200 dark:divide-gray-600',
 | 
			
		||||
  },
 | 
			
		||||
  theadClass: {
 | 
			
		||||
    type: String,
 | 
			
		||||
    default: 'bg-gray-50 dark:bg-gray-800 dark:text-white',
 | 
			
		||||
  },
 | 
			
		||||
  theadClass: { type: String, default: 'bg-gray-50' },
 | 
			
		||||
  tbodyClass: { type: String, default: '' },
 | 
			
		||||
  noResultsMessage: {
 | 
			
		||||
    type: String,
 | 
			
		||||
@ -186,6 +207,10 @@ const props = defineProps({
 | 
			
		||||
    type: Number,
 | 
			
		||||
    default: 3,
 | 
			
		||||
  },
 | 
			
		||||
  darkHighlight: {
 | 
			
		||||
    type: Boolean,
 | 
			
		||||
    default: false,
 | 
			
		||||
  },
 | 
			
		||||
})
 | 
			
		||||
 | 
			
		||||
let rows = reactive([])
 | 
			
		||||
@ -236,7 +261,7 @@ function getColumn(columnName) {
 | 
			
		||||
 | 
			
		||||
function getThClass(column) {
 | 
			
		||||
  let classes =
 | 
			
		||||
    'whitespace-nowrap px-6 py-3 text-left text-xs font-medium text-gray-500 uppercase tracking-wider'
 | 
			
		||||
    'whitespace-nowrap px-6 py-3 text-left text-xs font-medium text-gray-500 uppercase tracking-wider dark:text-white'
 | 
			
		||||
 | 
			
		||||
  if (column.defaultThClass) {
 | 
			
		||||
    classes = column.defaultThClass
 | 
			
		||||
@ -256,7 +281,8 @@ function getThClass(column) {
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
function getTdClass(column) {
 | 
			
		||||
  let classes = 'px-6 py-4 text-sm text-gray-500 whitespace-nowrap'
 | 
			
		||||
  let classes =
 | 
			
		||||
    'px-6 py-4 text-sm text-gray-500 whitespace-nowrap dark:text-gray-300'
 | 
			
		||||
 | 
			
		||||
  if (column.defaultTdClass) {
 | 
			
		||||
    classes = column.defaultTdClass
 | 
			
		||||
@ -309,6 +335,7 @@ function changeSorting(column) {
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  if (!usesLocalData.value) {
 | 
			
		||||
    if (pagination.value) pagination.value.currentPage = 1
 | 
			
		||||
    mapDataToRows()
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
@ -326,7 +353,9 @@ async function pageChange(page) {
 | 
			
		||||
  await mapDataToRows()
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
async function refresh() {
 | 
			
		||||
async function refresh(isPreservePage = false) {
 | 
			
		||||
  if (pagination.value && !isPreservePage) pagination.value.currentPage = 1
 | 
			
		||||
 | 
			
		||||
  await mapDataToRows()
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
@ -7,12 +7,12 @@ export function usePopper(options) {
 | 
			
		||||
  let popper = ref(null)
 | 
			
		||||
 | 
			
		||||
  onMounted(() => {
 | 
			
		||||
    watchEffect(onInvalidate => {
 | 
			
		||||
    watchEffect((onInvalidate) => {
 | 
			
		||||
      if (!container.value) return
 | 
			
		||||
      if (!activator.value) return
 | 
			
		||||
 | 
			
		||||
      let containerEl = container.value.el || container.value
 | 
			
		||||
      let activatorEl = activator.value.el || activator.value
 | 
			
		||||
      let activatorEl = activator.value.$el || activator.value
 | 
			
		||||
 | 
			
		||||
      if (!(activatorEl instanceof HTMLElement)) return
 | 
			
		||||
      if (!(containerEl instanceof HTMLElement)) return
 | 
			
		||||
 | 
			
		||||
@ -4,7 +4,7 @@
 | 
			
		||||
    "customers": "العملاء",
 | 
			
		||||
    "items": "بضائع/خدمات",
 | 
			
		||||
    "invoices": "الفواتير",
 | 
			
		||||
    "recurring-invoices": "الفواتير المتكررة",
 | 
			
		||||
    "recurring-invoices": "Recurring Invoices",
 | 
			
		||||
    "expenses": "النفقات",
 | 
			
		||||
    "estimates": "التقديرات",
 | 
			
		||||
    "payments": "الدفوعات",
 | 
			
		||||
@ -12,7 +12,7 @@
 | 
			
		||||
    "settings": "الإعدادات",
 | 
			
		||||
    "logout": "تسجيل الخروج",
 | 
			
		||||
    "users": "المستخدمون",
 | 
			
		||||
    "modules": "الإضافات"
 | 
			
		||||
    "modules": "Modules"
 | 
			
		||||
  },
 | 
			
		||||
  "general": {
 | 
			
		||||
    "add_company": "أضف شركة",
 | 
			
		||||
@ -29,9 +29,9 @@
 | 
			
		||||
    "to_date": "إلى تاريخ",
 | 
			
		||||
    "from": "من",
 | 
			
		||||
    "to": "إلى",
 | 
			
		||||
    "ok": "حسناً",
 | 
			
		||||
    "yes": "نعم",
 | 
			
		||||
    "no": "لا",
 | 
			
		||||
    "ok": "Ok",
 | 
			
		||||
    "yes": "Yes",
 | 
			
		||||
    "no": "No",
 | 
			
		||||
    "sort_by": "ترتيب حسب",
 | 
			
		||||
    "ascending": "تصاعدي",
 | 
			
		||||
    "descending": "تنازلي",
 | 
			
		||||
@ -39,7 +39,7 @@
 | 
			
		||||
    "body": "الجسم",
 | 
			
		||||
    "message": "رسالة",
 | 
			
		||||
    "send": "إرسال",
 | 
			
		||||
    "preview": "معاينة",
 | 
			
		||||
    "preview": "Preview",
 | 
			
		||||
    "go_back": "إلى الخلف",
 | 
			
		||||
    "back_to_login": "العودة إلى تسجيل الدخول؟",
 | 
			
		||||
    "home": "الرئيسية",
 | 
			
		||||
@ -65,7 +65,7 @@
 | 
			
		||||
    "sent": "ارسلت",
 | 
			
		||||
    "all": "الكل",
 | 
			
		||||
    "select_all": "تحديد الكل",
 | 
			
		||||
    "select_template": "تحديد القالب",
 | 
			
		||||
    "select_template": "Select Template",
 | 
			
		||||
    "choose_file": "اضغط هنا لاختيار ملف",
 | 
			
		||||
    "choose_template": "اختيار القالب",
 | 
			
		||||
    "choose": "اختر",
 | 
			
		||||
@ -93,14 +93,14 @@
 | 
			
		||||
    "no_note_found": "لم يتم العثور على الملاحظة",
 | 
			
		||||
    "insert_note": "أدخل ملاحظة",
 | 
			
		||||
    "copied_pdf_url_clipboard": "تم نسخ رابط PDF إلى الحافظة!",
 | 
			
		||||
    "copied_url_clipboard": "تم نسخ الرابط إلى الحافظة!",
 | 
			
		||||
    "docs": "المستندات",
 | 
			
		||||
    "do_you_wish_to_continue": "هل ترغب في المتابعة؟",
 | 
			
		||||
    "note": "ملاحظة",
 | 
			
		||||
    "pay_invoice": "سدد الفاتورة",
 | 
			
		||||
    "login_successfully": "تم تسجيل الدخول بنجاح!",
 | 
			
		||||
    "logged_out_successfully": "تم تسجيل الخروج",
 | 
			
		||||
    "mark_as_default": "تحديد كافتراضي"
 | 
			
		||||
    "copied_url_clipboard": "Copied url to clipboard!",
 | 
			
		||||
    "docs": "Docs",
 | 
			
		||||
    "do_you_wish_to_continue": "Do you wish to continue?",
 | 
			
		||||
    "note": "Note",
 | 
			
		||||
    "pay_invoice": "Pay Invoice",
 | 
			
		||||
    "login_successfully": "Logged in successfully!",
 | 
			
		||||
    "logged_out_successfully": "Logged out successfully",
 | 
			
		||||
    "mark_as_default": "Mark as default"
 | 
			
		||||
  },
 | 
			
		||||
  "dashboard": {
 | 
			
		||||
    "select_year": "اختر السنة",
 | 
			
		||||
@ -109,7 +109,7 @@
 | 
			
		||||
      "customers": "العملاء",
 | 
			
		||||
      "invoices": "الفواتير",
 | 
			
		||||
      "estimates": "التقديرات",
 | 
			
		||||
      "payments": "المدفوعات"
 | 
			
		||||
      "payments": "Payments"
 | 
			
		||||
    },
 | 
			
		||||
    "chart_info": {
 | 
			
		||||
      "total_sales": "المبيعات",
 | 
			
		||||
@ -151,27 +151,27 @@
 | 
			
		||||
    "no_results_found": "لم يتم العثور على نتائج"
 | 
			
		||||
  },
 | 
			
		||||
  "company_switcher": {
 | 
			
		||||
    "label": "تبديل الشركة",
 | 
			
		||||
    "no_results_found": "لا توجد نتائج",
 | 
			
		||||
    "add_new_company": "إضافة شركة جديدة",
 | 
			
		||||
    "new_company": "شركة جديدة",
 | 
			
		||||
    "created_message": "تم إنشاء الشركة بنجاح"
 | 
			
		||||
    "label": "SWITCH COMPANY",
 | 
			
		||||
    "no_results_found": "No Results Found",
 | 
			
		||||
    "add_new_company": "Add new company",
 | 
			
		||||
    "new_company": "New company",
 | 
			
		||||
    "created_message": "Company created successfully"
 | 
			
		||||
  },
 | 
			
		||||
  "dateRange": {
 | 
			
		||||
    "today": "اليوم",
 | 
			
		||||
    "this_week": "هذا الاسبوع",
 | 
			
		||||
    "this_month": "هذا الشهر",
 | 
			
		||||
    "this_quarter": "هذا الربع",
 | 
			
		||||
    "this_year": "هذه السنة",
 | 
			
		||||
    "previous_week": "الأسبوع السابق",
 | 
			
		||||
    "previous_month": "الشهر الماضي",
 | 
			
		||||
    "previous_quarter": "الربع السابق",
 | 
			
		||||
    "previous_year": "السنة الماضية",
 | 
			
		||||
    "custom": "مخصص"
 | 
			
		||||
    "today": "Today",
 | 
			
		||||
    "this_week": "This Week",
 | 
			
		||||
    "this_month": "This Month",
 | 
			
		||||
    "this_quarter": "This Quarter",
 | 
			
		||||
    "this_year": "This Year",
 | 
			
		||||
    "previous_week": "Previous Week",
 | 
			
		||||
    "previous_month": "Previous Month",
 | 
			
		||||
    "previous_quarter": "Previous Quarter",
 | 
			
		||||
    "previous_year": "Previous Year",
 | 
			
		||||
    "custom": "Custom"
 | 
			
		||||
  },
 | 
			
		||||
  "customers": {
 | 
			
		||||
    "title": "العملاء",
 | 
			
		||||
    "prefix": "البادئة",
 | 
			
		||||
    "prefix": "Prefix",
 | 
			
		||||
    "add_customer": "إضافة عميل",
 | 
			
		||||
    "contacts_list": "قائمة العملاء",
 | 
			
		||||
    "name": "الاسم",
 | 
			
		||||
@ -186,9 +186,9 @@
 | 
			
		||||
    "phone": "الهاتف",
 | 
			
		||||
    "website": "موقع الإنترنت",
 | 
			
		||||
    "overview": "استعراض",
 | 
			
		||||
    "invoice_prefix": "بادئة الفاتورة",
 | 
			
		||||
    "estimate_prefix": "بادئة رقم التقدير",
 | 
			
		||||
    "payment_prefix": "بادئة رقم الدفعة",
 | 
			
		||||
    "invoice_prefix": "Invoice Prefix",
 | 
			
		||||
    "estimate_prefix": "Estimate Prefix",
 | 
			
		||||
    "payment_prefix": "Payment Prefix",
 | 
			
		||||
    "enable_portal": "تفعيل البوابة",
 | 
			
		||||
    "country": "الدولة",
 | 
			
		||||
    "state": "الولاية/المنطقة",
 | 
			
		||||
@ -197,7 +197,7 @@
 | 
			
		||||
    "added_on": "أضيف في",
 | 
			
		||||
    "action": "إجراء",
 | 
			
		||||
    "password": "كلمة المرور",
 | 
			
		||||
    "confirm_password": "تأكيد كلمة المرور",
 | 
			
		||||
    "confirm_password": "Confirm Password",
 | 
			
		||||
    "street_number": "رقم الشارع",
 | 
			
		||||
    "primary_currency": "العملة الرئيسية",
 | 
			
		||||
    "description": "الوصف",
 | 
			
		||||
@ -208,10 +208,10 @@
 | 
			
		||||
    "new_customer": "عميل جديد",
 | 
			
		||||
    "edit_customer": "تعديل عميل",
 | 
			
		||||
    "basic_info": "معلوات أساسية",
 | 
			
		||||
    "portal_access": "الوصول إلى بوابة العملاء",
 | 
			
		||||
    "portal_access_text": "هل تريد السماح لهذا العميل بتسجيل الدخول إلى بوابة العملاء؟",
 | 
			
		||||
    "portal_access_url": "رابط بوابة العملاء",
 | 
			
		||||
    "portal_access_url_help": "يرجى نسخ وإعادة إرسال عنوان URL أعلاه إلى الزبون لتوفير الوصول.",
 | 
			
		||||
    "portal_access": "Portal Access",
 | 
			
		||||
    "portal_access_text": "Would you like to allow this customer to login to the Customer Portal?",
 | 
			
		||||
    "portal_access_url": "Customer Portal Login URL",
 | 
			
		||||
    "portal_access_url_help": "Please copy & forward the above given URL to your customer for providing access.",
 | 
			
		||||
    "billing_address": "عنوان الفوترة",
 | 
			
		||||
    "shipping_address": "عنوان الشحن",
 | 
			
		||||
    "copy_billing_address": "نسخ من عنوان الفوترة",
 | 
			
		||||
@ -231,9 +231,9 @@
 | 
			
		||||
    "confirm_delete": "لن تتمكن من استرداد هذا العميل وجميع الفواتير والتقديرات والمدفوعات ذات الصلة. | لن تتمكن من استرداد هؤلاء العملاء وجميع الفواتير والتقديرات والمدفوعات ذات الصلة.",
 | 
			
		||||
    "created_message": "تم إنشاء العملاء بنجاح",
 | 
			
		||||
    "updated_message": "تم تحديث العملاء بنجاح",
 | 
			
		||||
    "address_updated_message": "تم تحديث العنوان بنجاح",
 | 
			
		||||
    "address_updated_message": "Address Information Updated succesfully",
 | 
			
		||||
    "deleted_message": "تم حذف العملاء بنجاح | تم حذف العميل بنجاح",
 | 
			
		||||
    "edit_currency_not_allowed": "لا يمكن تغيير العملة بمجرد إنشاء معاملة."
 | 
			
		||||
    "edit_currency_not_allowed": "Cannot change currency once transactions created."
 | 
			
		||||
  },
 | 
			
		||||
  "items": {
 | 
			
		||||
    "title": "الأصناف",
 | 
			
		||||
@ -265,8 +265,8 @@
 | 
			
		||||
  },
 | 
			
		||||
  "estimates": {
 | 
			
		||||
    "title": "التقديرات",
 | 
			
		||||
    "accept_estimate": "قبول التقدير",
 | 
			
		||||
    "reject_estimate": "رفض التقدير",
 | 
			
		||||
    "accept_estimate": "Accept Estimate",
 | 
			
		||||
    "reject_estimate": "Reject Estimate",
 | 
			
		||||
    "estimate": "تقدير | تقديرات",
 | 
			
		||||
    "estimates_list": "قائمة التقديرات",
 | 
			
		||||
    "days": "{days} أيام",
 | 
			
		||||
@ -318,10 +318,10 @@
 | 
			
		||||
    },
 | 
			
		||||
    "accepted": "مقبول",
 | 
			
		||||
    "rejected": "مرفوض",
 | 
			
		||||
    "expired": "انتهت مدة الصلاحية",
 | 
			
		||||
    "expired": "Expired",
 | 
			
		||||
    "sent": "مرسل",
 | 
			
		||||
    "draft": "مسودة",
 | 
			
		||||
    "viewed": "تمت المشاهدة",
 | 
			
		||||
    "viewed": "Viewed",
 | 
			
		||||
    "declined": "مرفوض",
 | 
			
		||||
    "new_estimate": "تقدير جديد",
 | 
			
		||||
    "add_new_estimate": "إضافة تقدير جديد",
 | 
			
		||||
@ -355,14 +355,14 @@
 | 
			
		||||
      "select_an_item": "اكتب أو اختر الصنف",
 | 
			
		||||
      "type_item_description": "اكتب وصف الصنف (اختياري)"
 | 
			
		||||
    },
 | 
			
		||||
    "mark_as_default_estimate_template_description": "في حالة التعفيل، سيتم اختيار القالب المحدد تلقائياً للتقديرات الجديدة."
 | 
			
		||||
    "mark_as_default_estimate_template_description": "If enabled, the selected template will be automatically selected for new estimates."
 | 
			
		||||
  },
 | 
			
		||||
  "invoices": {
 | 
			
		||||
    "title": "الفواتير",
 | 
			
		||||
    "download": "تحميل",
 | 
			
		||||
    "pay_invoice": "سدد الفاتورة",
 | 
			
		||||
    "download": "Download",
 | 
			
		||||
    "pay_invoice": "Pay Invoice",
 | 
			
		||||
    "invoices_list": "قائمة الفواتير",
 | 
			
		||||
    "invoice_information": "معلومات الفاتورة",
 | 
			
		||||
    "invoice_information": "Invoice Information",
 | 
			
		||||
    "days": "{days} أيام",
 | 
			
		||||
    "months": "{months} أشهر",
 | 
			
		||||
    "years": "{years} سنوات",
 | 
			
		||||
@ -397,13 +397,13 @@
 | 
			
		||||
    "send_invoice": "إرسال الفاتورة",
 | 
			
		||||
    "resend_invoice": "إعادة إرسال الفاتورة",
 | 
			
		||||
    "invoice_template": "قالب الفاتورة",
 | 
			
		||||
    "conversion_message": "تم استنساخ الفاتورة بنجاح",
 | 
			
		||||
    "conversion_message": "Invoice cloned successful",
 | 
			
		||||
    "template": "قالب",
 | 
			
		||||
    "mark_as_sent": "تحديد كمرسل",
 | 
			
		||||
    "confirm_send_invoice": "سيتم إرسال هذه الفاتورة بالبريد الألكتروني إلى العميل",
 | 
			
		||||
    "invoice_mark_as_sent": "سيتم تحديد هذه الفاتورة كمرسلة",
 | 
			
		||||
    "confirm_mark_as_accepted": "سيتم تحديد هذه الفاتورة كمقبولة",
 | 
			
		||||
    "confirm_mark_as_rejected": "سيتم تحديد هذه الفاتورة كمرفوضة",
 | 
			
		||||
    "confirm_mark_as_accepted": "This invoice will be marked as Accepted",
 | 
			
		||||
    "confirm_mark_as_rejected": "This invoice will be marked as Rejected",
 | 
			
		||||
    "confirm_send": "سيتم إرسال هذه الفاتورة بالبريد الألكتروني إلى العميل",
 | 
			
		||||
    "invoice_date": "تاريخ الفاتورة",
 | 
			
		||||
    "record_payment": "تسجيل مدفوعات",
 | 
			
		||||
@ -415,13 +415,13 @@
 | 
			
		||||
    "update_invoice": "تحديث الفاتورة",
 | 
			
		||||
    "add_new_tax": "إضافة ضريبة جديدة",
 | 
			
		||||
    "no_invoices": "لا يوجد فواتير حتى الآن!",
 | 
			
		||||
    "mark_as_rejected": "تحديد كمرفوض",
 | 
			
		||||
    "mark_as_accepted": "تحديد كمقبول",
 | 
			
		||||
    "mark_as_rejected": "Mark as rejected",
 | 
			
		||||
    "mark_as_accepted": "Mark as accepted",
 | 
			
		||||
    "list_of_invoices": "قائمة الفواتير .",
 | 
			
		||||
    "select_invoice": "اختر الفاتورة",
 | 
			
		||||
    "no_matching_invoices": "لا يوجد فواتير مطابقة!",
 | 
			
		||||
    "mark_as_sent_successfully": "تم تحديد الفاتورة كمرسلة بنجاح",
 | 
			
		||||
    "invoice_sent_successfully": "تم إرسال الفاتورة بنجاح",
 | 
			
		||||
    "invoice_sent_successfully": "Invoice sent successfully",
 | 
			
		||||
    "cloned_successfully": "تم استنساخ الفاتورة بنجاح",
 | 
			
		||||
    "clone_invoice": "استنساخ الفاتورة",
 | 
			
		||||
    "confirm_clone": "سيتم استنساخ هذه الفاتورة في فاتورة جديدة",
 | 
			
		||||
@ -447,14 +447,14 @@
 | 
			
		||||
    "marked_as_sent_message": "تم إرسال الفاتورة بنجاح",
 | 
			
		||||
    "something_went_wrong": "خطأ غير معروف!",
 | 
			
		||||
    "invalid_due_amount_message": "المبلغ النهائي للفاتورة لا يمكن أن يكون أقل من المبلغ المطلوب لها. رجاءاً حدث الفاتورة أو قم بحذف المدفوعات المرتبطة بها للاستمرار.",
 | 
			
		||||
    "mark_as_default_invoice_template_description": "في حالة التفعيل، سيتم اختيار القالب المحدد تلقائياً للفواتير الجديدة."
 | 
			
		||||
    "mark_as_default_invoice_template_description": "If enabled, the selected template will be automatically selected for new invoices."
 | 
			
		||||
  },
 | 
			
		||||
  "recurring_invoices": {
 | 
			
		||||
    "title": "الفواتير المتكررة",
 | 
			
		||||
    "invoices_list": "الفواتير المتكررة",
 | 
			
		||||
    "days": "{days} أيام",
 | 
			
		||||
    "months": "{months} أشهر",
 | 
			
		||||
    "years": "{years} سنوات",
 | 
			
		||||
    "title": "Recurring Invoices",
 | 
			
		||||
    "invoices_list": "Recurring Invoices List",
 | 
			
		||||
    "days": "{days} Days",
 | 
			
		||||
    "months": "{months} Month",
 | 
			
		||||
    "years": "{years} Year",
 | 
			
		||||
    "all": "All",
 | 
			
		||||
    "paid": "Paid",
 | 
			
		||||
    "unpaid": "Unpaid",
 | 
			
		||||
@ -1485,7 +1485,7 @@
 | 
			
		||||
  "pdf_estimate_label": "تقدير",
 | 
			
		||||
  "pdf_estimate_number": "رقم تقدير",
 | 
			
		||||
  "pdf_estimate_date": "تاريخ التقدير",
 | 
			
		||||
  "pdf_estimate_expire_date": "Expiry Date",
 | 
			
		||||
  "pdf_estimate_expire_date": "تاريخ انتهاء الصلاحية",
 | 
			
		||||
  "pdf_invoice_label": "الفاتورة",
 | 
			
		||||
  "pdf_invoice_number": "رقم الفاتورة",
 | 
			
		||||
  "pdf_invoice_date": "تاريخ الفاتورة",
 | 
			
		||||
 | 
			
		||||
@ -112,7 +112,7 @@
 | 
			
		||||
      "payments": "Platby"
 | 
			
		||||
    },
 | 
			
		||||
    "chart_info": {
 | 
			
		||||
      "total_sales": "Prodeje",
 | 
			
		||||
      "total_sales": "Slevy",
 | 
			
		||||
      "total_receipts": "Doklady",
 | 
			
		||||
      "total_expense": "Výdaje",
 | 
			
		||||
      "net_income": "Čistý příjem",
 | 
			
		||||
@ -1485,7 +1485,7 @@
 | 
			
		||||
  "pdf_estimate_label": "Odhad",
 | 
			
		||||
  "pdf_estimate_number": "Číslo odhadu",
 | 
			
		||||
  "pdf_estimate_date": "Datum odhadu",
 | 
			
		||||
  "pdf_estimate_expire_date": "Datum expirace",
 | 
			
		||||
  "pdf_estimate_expire_date": "Doba platnosti",
 | 
			
		||||
  "pdf_invoice_label": "Faktura",
 | 
			
		||||
  "pdf_invoice_number": "Číslo faktury",
 | 
			
		||||
  "pdf_invoice_date": "Datum fakturace",
 | 
			
		||||
@ -1495,7 +1495,7 @@
 | 
			
		||||
  "pdf_quantity_label": "Množství",
 | 
			
		||||
  "pdf_price_label": "Cena",
 | 
			
		||||
  "pdf_discount_label": "Sleva",
 | 
			
		||||
  "pdf_amount_label": "Částka",
 | 
			
		||||
  "pdf_amount_label": "Množství",
 | 
			
		||||
  "pdf_subtotal": "Mezisoučet",
 | 
			
		||||
  "pdf_total": "Celkem",
 | 
			
		||||
  "pdf_payment_label": "Platba",
 | 
			
		||||
 | 
			
		||||
@ -688,7 +688,7 @@
 | 
			
		||||
    "other_modules": "Weitere Module",
 | 
			
		||||
    "view_all": "Alle Anzeigen",
 | 
			
		||||
    "no_reviews_found": "Für dieses Modul gibt es noch keine Bewertungen!",
 | 
			
		||||
    "module_not_purchased": "Modul noch nicht erworben",
 | 
			
		||||
    "module_not_purchased": "Module Not Purchased",
 | 
			
		||||
    "module_not_found": "Modul nicht gefunden",
 | 
			
		||||
    "version_not_supported": "This module version doesn't support the current version of Crater",
 | 
			
		||||
    "last_updated": "Zuletzt aktualisiert am",
 | 
			
		||||
@ -1113,7 +1113,7 @@
 | 
			
		||||
      "default_currency_error": "Diese Währung wird bereits in einem der aktiven Anbieter verwendet",
 | 
			
		||||
      "exchange_help_text": "Wechselkurs eingeben um von {currency} nach {baseCurrency} zu konvertieren",
 | 
			
		||||
      "currency_freak": "CurrencyFreaks",
 | 
			
		||||
      "currency_layer": "Währungsebene",
 | 
			
		||||
      "currency_layer": "Currency Layer",
 | 
			
		||||
      "open_exchange_rate": "Open Exchange Rate",
 | 
			
		||||
      "currency_converter": "Währungsumrechner",
 | 
			
		||||
      "server": "Server",
 | 
			
		||||
@ -1150,8 +1150,8 @@
 | 
			
		||||
      "payment_mode_added": "Zahlungsart hinzugefügt",
 | 
			
		||||
      "payment_mode_updated": "Zahlungsart aktualisiert",
 | 
			
		||||
      "payment_mode_confirm_delete": "Sie werden diese Zahlungsart nicht wiederherstellen können",
 | 
			
		||||
      "payments_attached": "Diese Zahlungsmethode ist bereits mit Zahlungen verknüpft. Bitte löschen Sie die angehängten Zahlungen, um mit der Löschung fortzufahren.",
 | 
			
		||||
      "expenses_attached": "Diese Zahlungsmethode ist bereits mit Ausgaben verknüpft. Bitte löschen Sie die angehängten Ausgaben, um mit der Löschung fortzufahren.",
 | 
			
		||||
      "payments_attached": "This payment method is already attached to payments. Please delete the attached payments to proceed with deletion.",
 | 
			
		||||
      "expenses_attached": "This payment method is already attached to expenses. Please delete the attached expenses to proceed with deletion.",
 | 
			
		||||
      "deleted_message": "Zahlungsart erfolgreich gelöscht"
 | 
			
		||||
    },
 | 
			
		||||
    "expense_category": {
 | 
			
		||||
@ -1179,7 +1179,7 @@
 | 
			
		||||
      "discount_per_item": "Rabatt pro Artikel ",
 | 
			
		||||
      "discount_setting_description": "Aktivieren Sie diese Option, wenn Sie einzelnen Rechnungspositionen einen Rabatt hinzufügen möchten. Standardmäßig wird der Rabatt direkt zur Rechnung hinzugefügt.",
 | 
			
		||||
      "expire_public_links": "Öffentliche Links automatisch ablaufen lassen",
 | 
			
		||||
      "expire_setting_description": "Geben Sie an, ob Sie alle von der Anwendung gesendeten Links zur Ansicht von Rechnungen, Kostenvoranschlägen und Zahlungen usw. nach einer bestimmten Zeit ablaufen lassen möchten.",
 | 
			
		||||
      "expire_setting_description": "Specify whether you would like to expire all the links sent by application to view invoices, estimates & payments, etc after a specified duration.",
 | 
			
		||||
      "save": "Speichern",
 | 
			
		||||
      "preference": "Präferenz | Präferenzen",
 | 
			
		||||
      "general_settings": "Standardeinstellungen für das System.",
 | 
			
		||||
@ -1272,14 +1272,14 @@
 | 
			
		||||
      "do_spaces_secret": "Do Spaces Secret",
 | 
			
		||||
      "do_spaces_region": "Do Spaced Region",
 | 
			
		||||
      "do_spaces_bucket": "Do Spaces Bucket",
 | 
			
		||||
      "do_spaces_endpoint": "Do Spaces Endpunkt",
 | 
			
		||||
      "do_spaces_endpoint": "Do Spaces Endpoint",
 | 
			
		||||
      "do_spaces_root": "Do Spaced Root",
 | 
			
		||||
      "dropbox_type": "Dropbox Typ",
 | 
			
		||||
      "dropbox_token": "Dropbox Token",
 | 
			
		||||
      "dropbox_key": "Dropbox Schlüssel",
 | 
			
		||||
      "dropbox_secret": "Dropbox Secret",
 | 
			
		||||
      "dropbox_app": "Dropbox App",
 | 
			
		||||
      "dropbox_root": "Dropbox Root Verzeichnis",
 | 
			
		||||
      "dropbox_root": "Dropbox Root",
 | 
			
		||||
      "default_driver": "Standard-Treiber",
 | 
			
		||||
      "is_default": "Standard",
 | 
			
		||||
      "set_default_disk": "Als Standard festlegen",
 | 
			
		||||
@ -1485,7 +1485,7 @@
 | 
			
		||||
  "pdf_estimate_label": "Angebot",
 | 
			
		||||
  "pdf_estimate_number": "Angebotsnummer",
 | 
			
		||||
  "pdf_estimate_date": "Angebotsdatum",
 | 
			
		||||
  "pdf_estimate_expire_date": "Zahlungsziel",
 | 
			
		||||
  "pdf_estimate_expire_date": "Gültig bis",
 | 
			
		||||
  "pdf_invoice_label": "Rechnung",
 | 
			
		||||
  "pdf_invoice_number": "Rechnungsnummer",
 | 
			
		||||
  "pdf_invoice_date": "Rechnungsdatum",
 | 
			
		||||
 | 
			
		||||
@ -1485,7 +1485,7 @@
 | 
			
		||||
  "pdf_estimate_label": "Εκτίμηση",
 | 
			
		||||
  "pdf_estimate_number": "Εκτίμηση Αριθμού",
 | 
			
		||||
  "pdf_estimate_date": "Εκτιμώμενη ημ. επισκευής",
 | 
			
		||||
  "pdf_estimate_expire_date": "Expiry Date",
 | 
			
		||||
  "pdf_estimate_expire_date": "Ημερομηνία λήξης",
 | 
			
		||||
  "pdf_invoice_label": "Τιμολόγιο",
 | 
			
		||||
  "pdf_invoice_number": "Αριθμός τιμολογίου",
 | 
			
		||||
  "pdf_invoice_date": "Ημ/νία Τιμολόγησης",
 | 
			
		||||
 | 
			
		||||
@ -863,6 +863,8 @@
 | 
			
		||||
    "company_info": {
 | 
			
		||||
      "company_info": "Company info",
 | 
			
		||||
      "company_name": "Company Name",
 | 
			
		||||
      "company_slug": "Company Slug",
 | 
			
		||||
      "company_slug_help_text": "A unique URL friendly name for your company (It will appear on Customer Portal URL)",
 | 
			
		||||
      "company_logo": "Company Logo",
 | 
			
		||||
      "section_description": "Information about your company that will be displayed on invoices, estimates and other documents created by Crater.",
 | 
			
		||||
      "phone": "Phone",
 | 
			
		||||
@ -1324,6 +1326,8 @@
 | 
			
		||||
    "company_info": "Company Information",
 | 
			
		||||
    "company_info_desc": "This information will be displayed on invoices. Note that you can edit this later on settings page.",
 | 
			
		||||
    "company_name": "Company Name",
 | 
			
		||||
    "company_slug": "Company Slug",
 | 
			
		||||
    "company_slug_help_text": "A unique URL friendly name for your company (It will appear on Customer Portal URL)",
 | 
			
		||||
    "company_logo": "Company Logo",
 | 
			
		||||
    "logo_preview": "Logo Preview",
 | 
			
		||||
    "preferences": "Company Preferences",
 | 
			
		||||
@ -1454,7 +1458,8 @@
 | 
			
		||||
    "at_least_one_ability": "Please select atleast one Permission.",
 | 
			
		||||
    "valid_driver_key": "Please enter a valid {driver} key.",
 | 
			
		||||
    "valid_exchange_rate": "Please enter a valid exchange rate.",
 | 
			
		||||
    "company_name_not_same": "Company name must match with given name."
 | 
			
		||||
    "company_name_not_same": "Company name must match with given name.",
 | 
			
		||||
    "invalid_slug": "Invalid Slug"
 | 
			
		||||
  },
 | 
			
		||||
  "errors": {
 | 
			
		||||
    "starter_plan": "This feature is available on Starter plan and onwards!",
 | 
			
		||||
@ -1522,5 +1527,13 @@
 | 
			
		||||
  "pdf_bill_to": "Bill to,",
 | 
			
		||||
  "pdf_ship_to": "Ship to,",
 | 
			
		||||
  "pdf_received_from": "Received from:",
 | 
			
		||||
  "pdf_tax_label": "Tax"
 | 
			
		||||
  "pdf_tax_label": "Tax",
 | 
			
		||||
  "date_picker": {
 | 
			
		||||
    "same_day": "Same Day",
 | 
			
		||||
    "within_7_days": "Within 7 Days",
 | 
			
		||||
    "within_15_days": "Within 15 Days",
 | 
			
		||||
    "within_30_days": "Within 30 Days",
 | 
			
		||||
    "within_45_days": "Within 45 Days",
 | 
			
		||||
    "within_60_days": "Within 60 Days"
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
@ -1,6 +1,6 @@
 | 
			
		||||
{
 | 
			
		||||
  "navigation": {
 | 
			
		||||
    "dashboard": "Panel de Control",
 | 
			
		||||
    "dashboard": "Tablero",
 | 
			
		||||
    "customers": "Clientes",
 | 
			
		||||
    "items": "Artículos",
 | 
			
		||||
    "invoices": "Facturas",
 | 
			
		||||
@ -9,7 +9,7 @@
 | 
			
		||||
    "estimates": "Presupuestos",
 | 
			
		||||
    "payments": "Pagos",
 | 
			
		||||
    "reports": "Informes",
 | 
			
		||||
    "settings": "Configuración",
 | 
			
		||||
    "settings": "Ajustes",
 | 
			
		||||
    "logout": "Cerrar sesión",
 | 
			
		||||
    "users": "Usuarios",
 | 
			
		||||
    "modules": "Módulos"
 | 
			
		||||
@ -47,7 +47,7 @@
 | 
			
		||||
    "delete": "Eliminar",
 | 
			
		||||
    "edit": "Editar",
 | 
			
		||||
    "view": "Ver",
 | 
			
		||||
    "add_new_item": "Agregar Nuevo Artículo",
 | 
			
		||||
    "add_new_item": "Agregar ítem nuevo",
 | 
			
		||||
    "clear_all": "Limpiar todo",
 | 
			
		||||
    "showing": "Mostrar",
 | 
			
		||||
    "of": "de",
 | 
			
		||||
@ -87,7 +87,7 @@
 | 
			
		||||
    "select_city": "Seleccionar ciudad",
 | 
			
		||||
    "street_1": "Calle 1",
 | 
			
		||||
    "street_2": "Calle 2",
 | 
			
		||||
    "action_failed": "Acción Fallida",
 | 
			
		||||
    "action_failed": "Accion Fallida",
 | 
			
		||||
    "retry": "Procesar de nuevo",
 | 
			
		||||
    "choose_note": "Elegir nota",
 | 
			
		||||
    "no_note_found": "No se encontró ninguna nota",
 | 
			
		||||
@ -98,7 +98,7 @@
 | 
			
		||||
    "do_you_wish_to_continue": "¿Deseas continuar?",
 | 
			
		||||
    "note": "Nota",
 | 
			
		||||
    "pay_invoice": "Pagar factura",
 | 
			
		||||
    "login_successfully": "¡Sesión inciada con éxito!",
 | 
			
		||||
    "login_successfully": "Logeado Satisfactoriamente!",
 | 
			
		||||
    "logged_out_successfully": "Logeado Satisfactoriamente",
 | 
			
		||||
    "mark_as_default": "Marcar como predeterminado"
 | 
			
		||||
  },
 | 
			
		||||
@ -113,7 +113,7 @@
 | 
			
		||||
    },
 | 
			
		||||
    "chart_info": {
 | 
			
		||||
      "total_sales": "Ventas",
 | 
			
		||||
      "total_receipts": "Recibos",
 | 
			
		||||
      "total_receipts": "Ingresos",
 | 
			
		||||
      "total_expense": "Gastos",
 | 
			
		||||
      "net_income": "Ingresos netos",
 | 
			
		||||
      "year": "Seleccione año"
 | 
			
		||||
@ -1485,7 +1485,7 @@
 | 
			
		||||
  "pdf_estimate_label": "Presupuestar",
 | 
			
		||||
  "pdf_estimate_number": "Número de Presupuesto",
 | 
			
		||||
  "pdf_estimate_date": "Fecha presupuesto",
 | 
			
		||||
  "pdf_estimate_expire_date": "Fecha de vencimiento",
 | 
			
		||||
  "pdf_estimate_expire_date": "Fecha de caducidad",
 | 
			
		||||
  "pdf_invoice_label": "Factura",
 | 
			
		||||
  "pdf_invoice_number": "Numero de factura",
 | 
			
		||||
  "pdf_invoice_date": "Fecha de la factura",
 | 
			
		||||
 | 
			
		||||
@ -1485,7 +1485,7 @@
 | 
			
		||||
  "pdf_estimate_label": "Estimate",
 | 
			
		||||
  "pdf_estimate_number": "Estimate Number",
 | 
			
		||||
  "pdf_estimate_date": "Estimate Date",
 | 
			
		||||
  "pdf_estimate_expire_date": "Expiry Date",
 | 
			
		||||
  "pdf_estimate_expire_date": "Expiry date",
 | 
			
		||||
  "pdf_invoice_label": "Invoice",
 | 
			
		||||
  "pdf_invoice_number": "Invoice Number",
 | 
			
		||||
  "pdf_invoice_date": "Invoice Date",
 | 
			
		||||
 | 
			
		||||
@ -1485,7 +1485,7 @@
 | 
			
		||||
  "pdf_estimate_label": "Tarjous",
 | 
			
		||||
  "pdf_estimate_number": "Tarjousnumero",
 | 
			
		||||
  "pdf_estimate_date": "Tarjouksen päiväys",
 | 
			
		||||
  "pdf_estimate_expire_date": "Expiry Date",
 | 
			
		||||
  "pdf_estimate_expire_date": "Voimassaolo päivä",
 | 
			
		||||
  "pdf_invoice_label": "Lasku",
 | 
			
		||||
  "pdf_invoice_number": "Laskunumero",
 | 
			
		||||
  "pdf_invoice_date": "Laskun päiväys",
 | 
			
		||||
 | 
			
		||||
@ -310,7 +310,7 @@
 | 
			
		||||
    "confirm_mark_as_sent": "Ce devis sera marqué comme envoyé",
 | 
			
		||||
    "confirm_mark_as_accepted": "Ce devis sera marqué comme accepté",
 | 
			
		||||
    "confirm_mark_as_rejected": "Ce devis sera marqué comme rejeté",
 | 
			
		||||
    "no_matching_estimates": "Aucun devis correspondant !",
 | 
			
		||||
    "no_matching_estimates": "Aucune estimation correspondante !",
 | 
			
		||||
    "mark_as_sent_successfully": "Devis marqué comme envoyé",
 | 
			
		||||
    "send_estimate_successfully": "Devis envoyé",
 | 
			
		||||
    "errors": {
 | 
			
		||||
@ -355,7 +355,7 @@
 | 
			
		||||
      "select_an_item": "Sélectionnez un article",
 | 
			
		||||
      "type_item_description": "Taper la description de l'article (facultatif)"
 | 
			
		||||
    },
 | 
			
		||||
    "mark_as_default_estimate_template_description": "Si activé, le modèle sélectionné sera automatiquement utilisé pour les nouvelles estimations."
 | 
			
		||||
    "mark_as_default_estimate_template_description": "If enabled, the selected template will be automatically selected for new estimates."
 | 
			
		||||
  },
 | 
			
		||||
  "invoices": {
 | 
			
		||||
    "title": "Factures",
 | 
			
		||||
@ -447,7 +447,7 @@
 | 
			
		||||
    "marked_as_sent_message": "Facture supprimée | Factures supprimées",
 | 
			
		||||
    "something_went_wrong": "quelque chose a mal tourné",
 | 
			
		||||
    "invalid_due_amount_message": "Le paiement entré est supérieur au montant total dû pour cette facture. Veuillez vérifier et réessayer.",
 | 
			
		||||
    "mark_as_default_invoice_template_description": "Si activé, le modèle sélectionné sera automatiquement utilisé pour les nouvelles factures."
 | 
			
		||||
    "mark_as_default_invoice_template_description": "If enabled, the selected template will be automatically selected for new invoices."
 | 
			
		||||
  },
 | 
			
		||||
  "recurring_invoices": {
 | 
			
		||||
    "title": "Factures récurrentes",
 | 
			
		||||
@ -526,7 +526,7 @@
 | 
			
		||||
    "cloned_successfully": "Facture récurrente clonée",
 | 
			
		||||
    "clone_invoice": "Dupliquer",
 | 
			
		||||
    "confirm_clone": "Cette facture récurrente sera clonée dans une nouvelle facture récurrente",
 | 
			
		||||
    "add_customer_email": "Veuillez ajouter une adresse e-mail pour ce client afin d'envoyer les factures automatiquement.",
 | 
			
		||||
    "add_customer_email": "Please add an email address for this customer to send invoices automatically.",
 | 
			
		||||
    "item": {
 | 
			
		||||
      "title": "Nom",
 | 
			
		||||
      "description": "Description",
 | 
			
		||||
@ -844,9 +844,9 @@
 | 
			
		||||
      "secret": "Secret",
 | 
			
		||||
      "mailgun_secret": "Secret Mailgun",
 | 
			
		||||
      "mailgun_domain": "Domaine",
 | 
			
		||||
      "mailgun_endpoint": "Endpoint de Mailgun",
 | 
			
		||||
      "ses_secret": "Clé secrète SES",
 | 
			
		||||
      "ses_key": "Clé SES",
 | 
			
		||||
      "mailgun_endpoint": "Mailgun Endpoint",
 | 
			
		||||
      "ses_secret": "SES Secret",
 | 
			
		||||
      "ses_key": "SES Key",
 | 
			
		||||
      "password": "Mot de passe",
 | 
			
		||||
      "username": "Nom d'utilisateur",
 | 
			
		||||
      "mail_config": "Envoi d'emails",
 | 
			
		||||
@ -1112,10 +1112,10 @@
 | 
			
		||||
      "error": "Vous ne pouvez pas supprimer le fournisseur actif",
 | 
			
		||||
      "default_currency_error": "Cette devise est déjà affectée à un fournisseur",
 | 
			
		||||
      "exchange_help_text": "Veuillez entrer le taux de change pour convertir {currency} en {baseCurrency}",
 | 
			
		||||
      "currency_freak": "Currency Freaks",
 | 
			
		||||
      "currency_freak": "Currency Freak",
 | 
			
		||||
      "currency_layer": "Currency Layer",
 | 
			
		||||
      "open_exchange_rate": "Ouvrir le taux de change",
 | 
			
		||||
      "currency_converter": "Convertisseur de devises",
 | 
			
		||||
      "open_exchange_rate": "Open Exchange Rate",
 | 
			
		||||
      "currency_converter": "Currency Converter",
 | 
			
		||||
      "server": "Serveur",
 | 
			
		||||
      "url": "URL",
 | 
			
		||||
      "active": "Actif",
 | 
			
		||||
@ -1150,8 +1150,8 @@
 | 
			
		||||
      "payment_mode_added": "Mode de paiement ajouté",
 | 
			
		||||
      "payment_mode_updated": "Mode de paiement mis à jour",
 | 
			
		||||
      "payment_mode_confirm_delete": "Vous ne pourrez pas récupérer ce mode de paiement",
 | 
			
		||||
      "payments_attached": "Ce moyen de paiement est déjà utilisé par des paiements. Merci de supprimer les paiements associés avant de procéder à la suppression.",
 | 
			
		||||
      "expenses_attached": "Ce moyen de paiement est déjà utilisé par des dépenses. Merci de supprimer les dépenses associés avant de procéder à la suppression.",
 | 
			
		||||
      "payments_attached": "This payment method is already attached to payments. Please delete the attached payments to proceed with deletion.",
 | 
			
		||||
      "expenses_attached": "This payment method is already attached to expenses. Please delete the attached expenses to proceed with deletion.",
 | 
			
		||||
      "deleted_message": "Mode de paiement supprimé"
 | 
			
		||||
    },
 | 
			
		||||
    "expense_category": {
 | 
			
		||||
@ -1262,8 +1262,8 @@
 | 
			
		||||
      "media_driver": "Stockage multimédia",
 | 
			
		||||
      "media_root": "Répertoire média",
 | 
			
		||||
      "aws_driver": "AWS",
 | 
			
		||||
      "aws_key": "Clé AWS",
 | 
			
		||||
      "aws_secret": "Clé secrète AWS",
 | 
			
		||||
      "aws_key": "AWS Key",
 | 
			
		||||
      "aws_secret": "AWS Secret",
 | 
			
		||||
      "aws_region": "Région AWS",
 | 
			
		||||
      "aws_bucket": "Bucket",
 | 
			
		||||
      "aws_root": "Répertoire",
 | 
			
		||||
@ -1491,7 +1491,7 @@
 | 
			
		||||
  "pdf_invoice_date": "Date",
 | 
			
		||||
  "pdf_invoice_due_date": "Date d’échéance",
 | 
			
		||||
  "pdf_notes": "Notes de bas de page",
 | 
			
		||||
  "pdf_items_label": "Désignation",
 | 
			
		||||
  "pdf_items_label": "Articles",
 | 
			
		||||
  "pdf_quantity_label": "Quantité",
 | 
			
		||||
  "pdf_price_label": "Prix",
 | 
			
		||||
  "pdf_discount_label": "Remise",
 | 
			
		||||
 | 
			
		||||
@ -510,11 +510,11 @@
 | 
			
		||||
    "update_expense": "Update Expense",
 | 
			
		||||
    "edit_invoice": "Edit Recurring Invoice",
 | 
			
		||||
    "new_invoice": "New Recurring Invoice",
 | 
			
		||||
    "send_automatically": "अटोमेटिक",
 | 
			
		||||
    "send_automatically": "Send Automatically",
 | 
			
		||||
    "send_automatically_desc": "Enable this, if you would like to send the invoice automatically to the customer when its created.",
 | 
			
		||||
    "save_invoice": "Save Recurring Invoice",
 | 
			
		||||
    "update_invoice": "Update Recurring Invoice",
 | 
			
		||||
    "add_new_tax": "नवी कर",
 | 
			
		||||
    "add_new_tax": "Add New Tax",
 | 
			
		||||
    "no_invoices": "No Recurring Invoices yet!",
 | 
			
		||||
    "mark_as_rejected": "Mark as rejected",
 | 
			
		||||
    "mark_as_accepted": "Mark as accepted",
 | 
			
		||||
@ -1485,7 +1485,7 @@
 | 
			
		||||
  "pdf_estimate_label": "Estimate",
 | 
			
		||||
  "pdf_estimate_number": "Estimate Number",
 | 
			
		||||
  "pdf_estimate_date": "Estimate Date",
 | 
			
		||||
  "pdf_estimate_expire_date": "Expiry Date",
 | 
			
		||||
  "pdf_estimate_expire_date": "Expiry date",
 | 
			
		||||
  "pdf_invoice_label": "Invoice",
 | 
			
		||||
  "pdf_invoice_number": "Invoice Number",
 | 
			
		||||
  "pdf_invoice_date": "Invoice Date",
 | 
			
		||||
 | 
			
		||||
@ -4,7 +4,7 @@
 | 
			
		||||
    "customers": "Klijenti",
 | 
			
		||||
    "items": "Stavke",
 | 
			
		||||
    "invoices": "Fakture",
 | 
			
		||||
    "recurring-invoices": "Ponavljajuće fakture\n",
 | 
			
		||||
    "recurring-invoices": "Recurring Invoices",
 | 
			
		||||
    "expenses": "Rashodi",
 | 
			
		||||
    "estimates": "Ponude",
 | 
			
		||||
    "payments": "Uplate",
 | 
			
		||||
@ -12,7 +12,7 @@
 | 
			
		||||
    "settings": "Postavke",
 | 
			
		||||
    "logout": "Odjava",
 | 
			
		||||
    "users": "Korisnici",
 | 
			
		||||
    "modules": "Moduli"
 | 
			
		||||
    "modules": "Modules"
 | 
			
		||||
  },
 | 
			
		||||
  "general": {
 | 
			
		||||
    "add_company": "Dodaj tvrtku",
 | 
			
		||||
@ -30,8 +30,8 @@
 | 
			
		||||
    "from": "Pošiljatelj",
 | 
			
		||||
    "to": "Primatelj",
 | 
			
		||||
    "ok": "Ok",
 | 
			
		||||
    "yes": "Da",
 | 
			
		||||
    "no": "Ne",
 | 
			
		||||
    "yes": "Yes",
 | 
			
		||||
    "no": "No",
 | 
			
		||||
    "sort_by": "Posloži Po",
 | 
			
		||||
    "ascending": "Rastuće",
 | 
			
		||||
    "descending": "Padajuće",
 | 
			
		||||
@ -39,7 +39,7 @@
 | 
			
		||||
    "body": "Tijelo",
 | 
			
		||||
    "message": "Poruka",
 | 
			
		||||
    "send": "Pošalji",
 | 
			
		||||
    "preview": "Pregled",
 | 
			
		||||
    "preview": "Preview",
 | 
			
		||||
    "go_back": "Natrag",
 | 
			
		||||
    "back_to_login": "Natrag na prijavu?",
 | 
			
		||||
    "home": "Početna",
 | 
			
		||||
@ -65,7 +65,7 @@
 | 
			
		||||
    "sent": "Poslano",
 | 
			
		||||
    "all": "Sve",
 | 
			
		||||
    "select_all": "Izaberi sve",
 | 
			
		||||
    "select_template": "Odaberite predložak",
 | 
			
		||||
    "select_template": "Select Template",
 | 
			
		||||
    "choose_file": "Klikni ovdje da izabereš fajl",
 | 
			
		||||
    "choose_template": "Izaberi predložak",
 | 
			
		||||
    "choose": "Izaberi",
 | 
			
		||||
@ -93,13 +93,13 @@
 | 
			
		||||
    "no_note_found": "Ne postoje spremljene napomene",
 | 
			
		||||
    "insert_note": "Unesi bilješku",
 | 
			
		||||
    "copied_pdf_url_clipboard": "Link do PDF fajla kopiran!",
 | 
			
		||||
    "copied_url_clipboard": "URL je kopiran u međuspremnik!",
 | 
			
		||||
    "docs": "Dokumenti",
 | 
			
		||||
    "do_you_wish_to_continue": "Želite li nastaviti?",
 | 
			
		||||
    "note": "Bilješka",
 | 
			
		||||
    "pay_invoice": "Plati račun",
 | 
			
		||||
    "login_successfully": "Uspješno ste prijavljeni!\n",
 | 
			
		||||
    "logged_out_successfully": "Uspješno odjavljen\n",
 | 
			
		||||
    "copied_url_clipboard": "Copied url to clipboard!",
 | 
			
		||||
    "docs": "Docs",
 | 
			
		||||
    "do_you_wish_to_continue": "Do you wish to continue?",
 | 
			
		||||
    "note": "Note",
 | 
			
		||||
    "pay_invoice": "Pay Invoice",
 | 
			
		||||
    "login_successfully": "Logged in successfully!",
 | 
			
		||||
    "logged_out_successfully": "Logged out successfully",
 | 
			
		||||
    "mark_as_default": "Postavi kao zadano"
 | 
			
		||||
  },
 | 
			
		||||
  "dashboard": {
 | 
			
		||||
@ -109,7 +109,7 @@
 | 
			
		||||
      "customers": "Klijenti",
 | 
			
		||||
      "invoices": "Računi",
 | 
			
		||||
      "estimates": "Ponude",
 | 
			
		||||
      "payments": "Plaćanja"
 | 
			
		||||
      "payments": "Payments"
 | 
			
		||||
    },
 | 
			
		||||
    "chart_info": {
 | 
			
		||||
      "total_sales": "Prodaja",
 | 
			
		||||
@ -151,18 +151,18 @@
 | 
			
		||||
    "no_results_found": "Nema rezultata"
 | 
			
		||||
  },
 | 
			
		||||
  "company_switcher": {
 | 
			
		||||
    "label": "IZABERI TVRTKU",
 | 
			
		||||
    "no_results_found": "Nema rezultata\n",
 | 
			
		||||
    "add_new_company": "Dodajte novu tvrtku\n",
 | 
			
		||||
    "new_company": "Nova tvrtka\n",
 | 
			
		||||
    "created_message": "Tvrtka uspješno stvorena\n"
 | 
			
		||||
    "label": "SWITCH COMPANY",
 | 
			
		||||
    "no_results_found": "No Results Found",
 | 
			
		||||
    "add_new_company": "Add new company",
 | 
			
		||||
    "new_company": "New company",
 | 
			
		||||
    "created_message": "Company created successfully"
 | 
			
		||||
  },
 | 
			
		||||
  "dateRange": {
 | 
			
		||||
    "today": "Danas\n",
 | 
			
		||||
    "this_week": "Danas\n",
 | 
			
		||||
    "this_month": "Danas\n",
 | 
			
		||||
    "this_quarter": "Danas\n",
 | 
			
		||||
    "this_year": "Danas\n",
 | 
			
		||||
    "today": "Today",
 | 
			
		||||
    "this_week": "This Week",
 | 
			
		||||
    "this_month": "This Month",
 | 
			
		||||
    "this_quarter": "This Quarter",
 | 
			
		||||
    "this_year": "This Year",
 | 
			
		||||
    "previous_week": "Previous Week",
 | 
			
		||||
    "previous_month": "Previous Month",
 | 
			
		||||
    "previous_quarter": "Previous Quarter",
 | 
			
		||||
@ -456,32 +456,32 @@
 | 
			
		||||
    "months": "{months} Month",
 | 
			
		||||
    "years": "{years} Year",
 | 
			
		||||
    "all": "All",
 | 
			
		||||
    "paid": "Plaćeno",
 | 
			
		||||
    "unpaid": "Ne plaćeno",
 | 
			
		||||
    "viewed": "Pregledano",
 | 
			
		||||
    "overdue": "Kašnjenja",
 | 
			
		||||
    "active": "Aktivno",
 | 
			
		||||
    "completed": "Završeno",
 | 
			
		||||
    "customer": "KUPAC",
 | 
			
		||||
    "paid_status": "STATUS PLAĆANJA",
 | 
			
		||||
    "ref_no": "BR. REFERENCE",
 | 
			
		||||
    "number": "BROJ",
 | 
			
		||||
    "paid": "Paid",
 | 
			
		||||
    "unpaid": "Unpaid",
 | 
			
		||||
    "viewed": "Viewed",
 | 
			
		||||
    "overdue": "Overdue",
 | 
			
		||||
    "active": "Active",
 | 
			
		||||
    "completed": "Completed",
 | 
			
		||||
    "customer": "CUSTOMER",
 | 
			
		||||
    "paid_status": "PAID STATUS",
 | 
			
		||||
    "ref_no": "REF NO.",
 | 
			
		||||
    "number": "NUMBER",
 | 
			
		||||
    "amount_due": "AMOUNT DUE",
 | 
			
		||||
    "partially_paid": "Djelomično plaćeno\n",
 | 
			
		||||
    "total": "Ukupno",
 | 
			
		||||
    "discount": "Popust",
 | 
			
		||||
    "sub_total": "Popdzbroj",
 | 
			
		||||
    "invoice": "Ponavljajuća faktura | Ponavjaljuća faktura",
 | 
			
		||||
    "invoice_number": "Broj ponavljajuće fakture\n",
 | 
			
		||||
    "next_invoice_date": "Datum sljedećeg računa",
 | 
			
		||||
    "ref_number": "Broj reference",
 | 
			
		||||
    "contact": "Kontakt",
 | 
			
		||||
    "add_item": "Dodaj stavku",
 | 
			
		||||
    "date": "Datum",
 | 
			
		||||
    "limit_by": "Ograniči po",
 | 
			
		||||
    "limit_date": "Vremenski rok",
 | 
			
		||||
    "limit_count": "Broj ograničenja\n",
 | 
			
		||||
    "count": "Brojač",
 | 
			
		||||
    "partially_paid": "Partially Paid",
 | 
			
		||||
    "total": "Total",
 | 
			
		||||
    "discount": "Discount",
 | 
			
		||||
    "sub_total": "Sub Total",
 | 
			
		||||
    "invoice": "Recurring Invoice | Recurring Invoices",
 | 
			
		||||
    "invoice_number": "Recurring Invoice Number",
 | 
			
		||||
    "next_invoice_date": "Next Invoice Date",
 | 
			
		||||
    "ref_number": "Ref Number",
 | 
			
		||||
    "contact": "Contact",
 | 
			
		||||
    "add_item": "Add an Item",
 | 
			
		||||
    "date": "Date",
 | 
			
		||||
    "limit_by": "Limit by",
 | 
			
		||||
    "limit_date": "Limit Date",
 | 
			
		||||
    "limit_count": "Limit Count",
 | 
			
		||||
    "count": "Count",
 | 
			
		||||
    "status": "Status",
 | 
			
		||||
    "select_a_status": "Select a status",
 | 
			
		||||
    "working": "Working",
 | 
			
		||||
@ -1485,7 +1485,7 @@
 | 
			
		||||
  "pdf_estimate_label": "Ponuda",
 | 
			
		||||
  "pdf_estimate_number": "Broj Ponude",
 | 
			
		||||
  "pdf_estimate_date": "Datum Ponude",
 | 
			
		||||
  "pdf_estimate_expire_date": "Expiry Date",
 | 
			
		||||
  "pdf_estimate_expire_date": "Datum isteka Ponude",
 | 
			
		||||
  "pdf_invoice_label": "Faktura",
 | 
			
		||||
  "pdf_invoice_number": "Broj Fakture",
 | 
			
		||||
  "pdf_invoice_date": "Datum Fakture",
 | 
			
		||||
 | 
			
		||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							@ -54,9 +54,9 @@
 | 
			
		||||
    "actions": "Azioni",
 | 
			
		||||
    "subtotal": "SUBTOTALE",
 | 
			
		||||
    "discount": "SCONTO",
 | 
			
		||||
    "fixed": "Fisso",
 | 
			
		||||
    "fixed": "Fissato",
 | 
			
		||||
    "percentage": "Percentuale",
 | 
			
		||||
    "tax": "IMPOSTA",
 | 
			
		||||
    "tax": "TASSA",
 | 
			
		||||
    "total_amount": "AMMONTARE TOTALE",
 | 
			
		||||
    "bill_to": "Fattura a",
 | 
			
		||||
    "ship_to": "Invia a",
 | 
			
		||||
 | 
			
		||||
@ -1485,7 +1485,7 @@
 | 
			
		||||
  "pdf_estimate_label": "Estimate",
 | 
			
		||||
  "pdf_estimate_number": "Estimate Number",
 | 
			
		||||
  "pdf_estimate_date": "Estimate Date",
 | 
			
		||||
  "pdf_estimate_expire_date": "Expiry Date",
 | 
			
		||||
  "pdf_estimate_expire_date": "Expiry date",
 | 
			
		||||
  "pdf_invoice_label": "Invoice",
 | 
			
		||||
  "pdf_invoice_number": "Invoice Number",
 | 
			
		||||
  "pdf_invoice_date": "Invoice Date",
 | 
			
		||||
 | 
			
		||||
@ -17,6 +17,7 @@ import sk from './sk.json'
 | 
			
		||||
import vi from './vi.json'
 | 
			
		||||
import el from './el.json'
 | 
			
		||||
import hr from './hr.json'
 | 
			
		||||
import th from './th.json'
 | 
			
		||||
 | 
			
		||||
export default {
 | 
			
		||||
  cs,
 | 
			
		||||
@ -37,5 +38,6 @@ export default {
 | 
			
		||||
  vi,
 | 
			
		||||
  pl,
 | 
			
		||||
  el,
 | 
			
		||||
  hr
 | 
			
		||||
  hr,
 | 
			
		||||
  th
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
@ -1485,7 +1485,7 @@
 | 
			
		||||
  "pdf_estimate_label": "Pasiūlymas",
 | 
			
		||||
  "pdf_estimate_number": "Pasiūlymo numeris",
 | 
			
		||||
  "pdf_estimate_date": "Pasiūlymo data",
 | 
			
		||||
  "pdf_estimate_expire_date": "Expiry Date",
 | 
			
		||||
  "pdf_estimate_expire_date": "Galiojimo laikas",
 | 
			
		||||
  "pdf_invoice_label": "Sąskaita",
 | 
			
		||||
  "pdf_invoice_number": "Invoice Number",
 | 
			
		||||
  "pdf_invoice_date": "Invoice Date",
 | 
			
		||||
 | 
			
		||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							@ -4,7 +4,7 @@
 | 
			
		||||
    "customers": "Klanten",
 | 
			
		||||
    "items": "Artikelen",
 | 
			
		||||
    "invoices": "Facturen",
 | 
			
		||||
    "recurring-invoices": "Periodieke facturen",
 | 
			
		||||
    "recurring-invoices": "Periodieke factuur",
 | 
			
		||||
    "expenses": "Uitgaven",
 | 
			
		||||
    "estimates": "Offertes",
 | 
			
		||||
    "payments": "Betalingen",
 | 
			
		||||
@ -28,16 +28,16 @@
 | 
			
		||||
    "from_date": "Vanaf datum",
 | 
			
		||||
    "to_date": "T/m datum",
 | 
			
		||||
    "from": "Vanaf",
 | 
			
		||||
    "to": "Naar",
 | 
			
		||||
    "ok": "Oké",
 | 
			
		||||
    "yes": "Ja",
 | 
			
		||||
    "no": "Nee",
 | 
			
		||||
    "to": "Naar.",
 | 
			
		||||
    "ok": "Oké.",
 | 
			
		||||
    "yes": "Ja.",
 | 
			
		||||
    "no": "Nee.",
 | 
			
		||||
    "sort_by": "Sorteer op",
 | 
			
		||||
    "ascending": "Oplopend",
 | 
			
		||||
    "descending": "Aflopend",
 | 
			
		||||
    "subject": "Onderwerp",
 | 
			
		||||
    "body": "Inhoud",
 | 
			
		||||
    "message": "Bericht",
 | 
			
		||||
    "message": "Bericht.",
 | 
			
		||||
    "send": "Verstuur",
 | 
			
		||||
    "preview": "Voorbeeld",
 | 
			
		||||
    "go_back": "Ga terug",
 | 
			
		||||
@ -54,7 +54,7 @@
 | 
			
		||||
    "actions": "Acties",
 | 
			
		||||
    "subtotal": "SUBTOTAAL",
 | 
			
		||||
    "discount": "KORTING",
 | 
			
		||||
    "fixed": "Vast bedrag",
 | 
			
		||||
    "fixed": "Gemaakt",
 | 
			
		||||
    "percentage": "Percentage",
 | 
			
		||||
    "tax": "BELASTING",
 | 
			
		||||
    "total_amount": "TOTAALBEDRAG",
 | 
			
		||||
@ -85,17 +85,17 @@
 | 
			
		||||
    "select_state": "Selecteer staat",
 | 
			
		||||
    "select_country": "Selecteer land",
 | 
			
		||||
    "select_city": "Selecteer stad",
 | 
			
		||||
    "street_1": "Straat 1",
 | 
			
		||||
    "street_2": "Straat 2",
 | 
			
		||||
    "action_failed": "Actie mislukt",
 | 
			
		||||
    "retry": "Opnieuw proberen",
 | 
			
		||||
    "street_1": "straat 1",
 | 
			
		||||
    "street_2": "Straat # 2",
 | 
			
		||||
    "action_failed": "Actie: mislukt",
 | 
			
		||||
    "retry": "Retr",
 | 
			
		||||
    "choose_note": "Kies notitie",
 | 
			
		||||
    "no_note_found": "Geen notitie gevonden",
 | 
			
		||||
    "insert_note": "Notitie invoegen",
 | 
			
		||||
    "copied_pdf_url_clipboard": "PDF link naar klembord gekopieerd!",
 | 
			
		||||
    "copied_url_clipboard": "URL naar klembord gekopieerd!",
 | 
			
		||||
    "docs": "Documentatie",
 | 
			
		||||
    "do_you_wish_to_continue": "Wil je doorgaan?",
 | 
			
		||||
    "docs": "Documenten",
 | 
			
		||||
    "do_you_wish_to_continue": "Wilt u Doorgaan?",
 | 
			
		||||
    "note": "Notitie",
 | 
			
		||||
    "pay_invoice": "Betaal factuur",
 | 
			
		||||
    "login_successfully": "Succesvol ingelogd!",
 | 
			
		||||
@ -526,7 +526,7 @@
 | 
			
		||||
    "cloned_successfully": "Terugkerende factuur succesvol gekopieerd",
 | 
			
		||||
    "clone_invoice": "Kopieer periodieke factuur",
 | 
			
		||||
    "confirm_clone": "Deze periodieke factuur wordt gekopieerd naar een nieuwe periodieke factuur",
 | 
			
		||||
    "add_customer_email": "Voeg een e-mailadres aan deze klant toe zodat facturen automatisch verzonden kunnen worden.",
 | 
			
		||||
    "add_customer_email": "Voeg een e-mailadres aan deze klant toe, zodat facturen automatisch verzonden kunnen worden.",
 | 
			
		||||
    "item": {
 | 
			
		||||
      "title": "Item titel",
 | 
			
		||||
      "description": "Beschrijving",
 | 
			
		||||
@ -1114,13 +1114,13 @@
 | 
			
		||||
      "exchange_help_text": "Voer de wisselkoers in om te converteren van {currency} naar {baseCurrency}",
 | 
			
		||||
      "currency_freak": "Valuta Freak",
 | 
			
		||||
      "currency_layer": "Valuta-laag",
 | 
			
		||||
      "open_exchange_rate": "Open wisselkoers",
 | 
			
		||||
      "open_exchange_rate": "Open Exchange Rate",
 | 
			
		||||
      "currency_converter": "Valuta omzetter",
 | 
			
		||||
      "server": "Server",
 | 
			
		||||
      "url": "URL",
 | 
			
		||||
      "active": "Actief",
 | 
			
		||||
      "currency_help_text": "Deze aanbieder wordt alleen gebruikt voor de hier boven geselecteerde valuta",
 | 
			
		||||
      "currency_in_used": "De volgende valuta zijn al actief bij een andere aanbieder. Verwijder deze valuta uit de selectie om deze aanbieder opnieuw te activeren."
 | 
			
		||||
      "currency_help_text": "This provider will only be used on above selected currencies",
 | 
			
		||||
      "currency_in_used": "The following currencies are already active on another provider. Please remove these currencies from selection to activate this provider again."
 | 
			
		||||
    },
 | 
			
		||||
    "tax_types": {
 | 
			
		||||
      "title": "Belastingtypen",
 | 
			
		||||
@ -1143,16 +1143,16 @@
 | 
			
		||||
    },
 | 
			
		||||
    "payment_modes": {
 | 
			
		||||
      "title": "Betaalmethodes",
 | 
			
		||||
      "description": "Modi van transacties voor betalingen",
 | 
			
		||||
      "add_payment_mode": "Voeg betaalwijze toe",
 | 
			
		||||
      "edit_payment_mode": "Wijzig betaalwijze",
 | 
			
		||||
      "mode_name": "Modusnaam",
 | 
			
		||||
      "description": "Modes of transaction for payments",
 | 
			
		||||
      "add_payment_mode": "Add Payment Mode",
 | 
			
		||||
      "edit_payment_mode": "Edit Payment Mode",
 | 
			
		||||
      "mode_name": "Mode Name",
 | 
			
		||||
      "payment_mode_added": "Betaalwijze toegevoegd",
 | 
			
		||||
      "payment_mode_updated": "Betaalwijze bijgewerkt",
 | 
			
		||||
      "payment_mode_confirm_delete": "U kunt deze betalingsmodus niet herstellen",
 | 
			
		||||
      "payments_attached": "Deze betalingsmethode is al gekoppeld aan betalingen. Verwijder de gekoppelde betalingen om verder te gaan met het verwijderen.",
 | 
			
		||||
      "expenses_attached": "Deze betaalmethode is al gekoppeld aan uitgaven. Verwijder de gekoppelde kosten om door te gaan met het verwijderen.",
 | 
			
		||||
      "deleted_message": "Betaalwijze succesvol verwijderd"
 | 
			
		||||
      "payment_mode_updated": "Payment Mode Updated",
 | 
			
		||||
      "payment_mode_confirm_delete": "You will not be able to recover this Payment Mode",
 | 
			
		||||
      "payments_attached": "This payment method is already attached to payments. Please delete the attached payments to proceed with deletion.",
 | 
			
		||||
      "expenses_attached": "This payment method is already attached to expenses. Please delete the attached expenses to proceed with deletion.",
 | 
			
		||||
      "deleted_message": "Payment Mode deleted successfully"
 | 
			
		||||
    },
 | 
			
		||||
    "expense_category": {
 | 
			
		||||
      "title": "Onkostencategorieën",
 | 
			
		||||
@ -1178,8 +1178,8 @@
 | 
			
		||||
      "discount_setting": "Kortingsinstelling",
 | 
			
		||||
      "discount_per_item": "Korting per item",
 | 
			
		||||
      "discount_setting_description": "Schakel dit in als u korting wilt toevoegen aan afzonderlijke factuuritems. Standaard wordt korting rechtstreeks aan de factuur toegevoegd.",
 | 
			
		||||
      "expire_public_links": "Publieke links automatisch laten vervallen",
 | 
			
		||||
      "expire_setting_description": "Geef aan of je alle links die eerder zijn verstuurd door de applicatie om facturen, offertes en betalingen te bekijken wilt laten verlopen na een bepaalde duur.",
 | 
			
		||||
      "expire_public_links": "Automatically Expire Public Links",
 | 
			
		||||
      "expire_setting_description": "Specify whether you would like to expire all the links sent by application to view invoices, estimates & payments, etc after a specified duration.",
 | 
			
		||||
      "save": "Opslaan",
 | 
			
		||||
      "preference": "Voorkeur | Voorkeuren",
 | 
			
		||||
      "general_settings": "Standaardvoorkeuren voor het systeem.",
 | 
			
		||||
@ -1188,9 +1188,9 @@
 | 
			
		||||
      "select_time_zone": "Selecteer Tijdzone",
 | 
			
		||||
      "select_date_format": "Selecteer datum/tijdindeling",
 | 
			
		||||
      "select_financial_year": "Selecteer financieel ja",
 | 
			
		||||
      "recurring_invoice_status": "Status periodieke facturen",
 | 
			
		||||
      "create_status": "Status aanmaken",
 | 
			
		||||
      "active": "Actief",
 | 
			
		||||
      "recurring_invoice_status": "Recurring Invoice Status",
 | 
			
		||||
      "create_status": "Create Status",
 | 
			
		||||
      "active": "Active",
 | 
			
		||||
      "on_hold": "In wacht",
 | 
			
		||||
      "update_status": "Updatestatus",
 | 
			
		||||
      "completed": "Voltooid",
 | 
			
		||||
@ -1217,10 +1217,10 @@
 | 
			
		||||
      "finishing_update": "Afwerking Update",
 | 
			
		||||
      "update_failed": "Update mislukt",
 | 
			
		||||
      "update_failed_text": "Sorry! Je update is mislukt op: {step} step ",
 | 
			
		||||
      "update_warning": "Alle applicatiebestanden en de standaard sjabloonbestanden worden overschreven wanneer u de applicatie met behulp van dit hulpprogramma bijwerkt. Maak een reservekopie van uw sjablonen en database voordat u deze bijwerkt."
 | 
			
		||||
      "update_warning": "All of the application files and default template files will be overwritten when you update the application using this utility. Please take a backup of your templates & database before updating."
 | 
			
		||||
    },
 | 
			
		||||
    "backup": {
 | 
			
		||||
      "title": "Back-up | Back-ups",
 | 
			
		||||
      "title": "Backup | Backups",
 | 
			
		||||
      "description": "De back-up is een zipfile met alle bestanden in de mappen die je opgeeft samen met een dump van je database",
 | 
			
		||||
      "new_backup": "Nieuwe back-up",
 | 
			
		||||
      "create_backup": "Backup maken",
 | 
			
		||||
 | 
			
		||||
@ -2,7 +2,7 @@
 | 
			
		||||
  "navigation": {
 | 
			
		||||
    "dashboard": "Pulpit",
 | 
			
		||||
    "customers": "Kontrahenci",
 | 
			
		||||
    "items": "Produkty",
 | 
			
		||||
    "items": "Pozycje",
 | 
			
		||||
    "invoices": "Faktury",
 | 
			
		||||
    "recurring-invoices": "Faktury cykliczne",
 | 
			
		||||
    "expenses": "Wydatki",
 | 
			
		||||
@ -100,7 +100,7 @@
 | 
			
		||||
    "pay_invoice": "Zapłać Fakturę",
 | 
			
		||||
    "login_successfully": "Zalogowano pomyślnie!",
 | 
			
		||||
    "logged_out_successfully": "Wylogowano pomyślnie",
 | 
			
		||||
    "mark_as_default": "Oznacz jako domyślne"
 | 
			
		||||
    "mark_as_default": "Mark as default"
 | 
			
		||||
  },
 | 
			
		||||
  "dashboard": {
 | 
			
		||||
    "select_year": "Wybierz rok",
 | 
			
		||||
@ -355,7 +355,7 @@
 | 
			
		||||
      "select_an_item": "Wpisz lub kliknij aby wybrać element",
 | 
			
		||||
      "type_item_description": "Opis pozycji (opcjonalnie)"
 | 
			
		||||
    },
 | 
			
		||||
    "mark_as_default_estimate_template_description": "Jeśli włączone, wybrany szablon zostanie automatycznie wybrany dla nowych ofert."
 | 
			
		||||
    "mark_as_default_estimate_template_description": "If enabled, the selected template will be automatically selected for new estimates."
 | 
			
		||||
  },
 | 
			
		||||
  "invoices": {
 | 
			
		||||
    "title": "Faktury",
 | 
			
		||||
@ -447,7 +447,7 @@
 | 
			
		||||
    "marked_as_sent_message": "Faktura oznaczona jako wysłana pomyślnie",
 | 
			
		||||
    "something_went_wrong": "coś poszło nie tak",
 | 
			
		||||
    "invalid_due_amount_message": "Całkowita kwota faktury nie może być mniejsza niż całkowita kwota zapłacona za tę fakturę. Proszę zaktualizować fakturę lub usunąć powiązane płatności, aby kontynuować.",
 | 
			
		||||
    "mark_as_default_invoice_template_description": "Jeśli włączone, wybrany szablon zostanie automatycznie wybrany dla nowych faktur."
 | 
			
		||||
    "mark_as_default_invoice_template_description": "If enabled, the selected template will be automatically selected for new invoices."
 | 
			
		||||
  },
 | 
			
		||||
  "recurring_invoices": {
 | 
			
		||||
    "title": "Faktury cykliczne",
 | 
			
		||||
@ -526,7 +526,7 @@
 | 
			
		||||
    "cloned_successfully": "Faktura Cykliczna sklonowana pomyślnie",
 | 
			
		||||
    "clone_invoice": "Klonuj Fakturę Cykliczną",
 | 
			
		||||
    "confirm_clone": "Ta faktura cykliczna zostanie sklonowana do nowej faktury cyklicznej",
 | 
			
		||||
    "add_customer_email": "Dodaj adres e-mail dla tego klienta, aby wysyłać faktury automatycznie.",
 | 
			
		||||
    "add_customer_email": "Please add an email address for this customer to send invoices automatically.",
 | 
			
		||||
    "item": {
 | 
			
		||||
      "title": "Tytuł pozycji",
 | 
			
		||||
      "description": "Opis",
 | 
			
		||||
@ -1485,7 +1485,7 @@
 | 
			
		||||
  "pdf_estimate_label": "Oferta",
 | 
			
		||||
  "pdf_estimate_number": "Numer oferty",
 | 
			
		||||
  "pdf_estimate_date": "Data oferty",
 | 
			
		||||
  "pdf_estimate_expire_date": "Data ważności",
 | 
			
		||||
  "pdf_estimate_expire_date": "Termin ważności",
 | 
			
		||||
  "pdf_invoice_label": "Faktura",
 | 
			
		||||
  "pdf_invoice_number": "Numer faktury",
 | 
			
		||||
  "pdf_invoice_date": "Data faktury",
 | 
			
		||||
 | 
			
		||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							@ -97,8 +97,8 @@
 | 
			
		||||
    "docs": "Documentație",
 | 
			
		||||
    "do_you_wish_to_continue": "Doriţi să continuaţi?",
 | 
			
		||||
    "note": "Note",
 | 
			
		||||
    "pay_invoice": "Plătește factura",
 | 
			
		||||
    "login_successfully": "Autentificat cu succes!",
 | 
			
		||||
    "pay_invoice": "Pay Invoice",
 | 
			
		||||
    "login_successfully": "Logged in successfully!",
 | 
			
		||||
    "logged_out_successfully": "Logged out successfully",
 | 
			
		||||
    "mark_as_default": "Mark as default"
 | 
			
		||||
  },
 | 
			
		||||
@ -1485,7 +1485,7 @@
 | 
			
		||||
  "pdf_estimate_label": "Estimate",
 | 
			
		||||
  "pdf_estimate_number": "Estimate Number",
 | 
			
		||||
  "pdf_estimate_date": "Estimate Date",
 | 
			
		||||
  "pdf_estimate_expire_date": "Expiry Date",
 | 
			
		||||
  "pdf_estimate_expire_date": "Expiry date",
 | 
			
		||||
  "pdf_invoice_label": "Invoice",
 | 
			
		||||
  "pdf_invoice_number": "Invoice Number",
 | 
			
		||||
  "pdf_invoice_date": "Invoice Date",
 | 
			
		||||
 | 
			
		||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							@ -4,7 +4,7 @@
 | 
			
		||||
    "customers": "Zákazníci",
 | 
			
		||||
    "items": "Položky",
 | 
			
		||||
    "invoices": "Faktúry",
 | 
			
		||||
    "recurring-invoices": "Pravidelné faktúry",
 | 
			
		||||
    "recurring-invoices": "Recurring Invoices",
 | 
			
		||||
    "expenses": "Výdaje",
 | 
			
		||||
    "estimates": "Cenové odhady",
 | 
			
		||||
    "payments": "Platby",
 | 
			
		||||
@ -12,7 +12,7 @@
 | 
			
		||||
    "settings": "Nastavenia",
 | 
			
		||||
    "logout": "Odhlásiť sa",
 | 
			
		||||
    "users": "Uživatelia",
 | 
			
		||||
    "modules": "Moduly"
 | 
			
		||||
    "modules": "Modules"
 | 
			
		||||
  },
 | 
			
		||||
  "general": {
 | 
			
		||||
    "add_company": "Pridať firmu",
 | 
			
		||||
@ -30,8 +30,8 @@
 | 
			
		||||
    "from": "Od",
 | 
			
		||||
    "to": "Pre",
 | 
			
		||||
    "ok": "Ok",
 | 
			
		||||
    "yes": "Áno",
 | 
			
		||||
    "no": "Nie",
 | 
			
		||||
    "yes": "Yes",
 | 
			
		||||
    "no": "No",
 | 
			
		||||
    "sort_by": "Zoradiť podľa",
 | 
			
		||||
    "ascending": "Vzostupne",
 | 
			
		||||
    "descending": "Zostupne",
 | 
			
		||||
@ -39,7 +39,7 @@
 | 
			
		||||
    "body": "Telo textu",
 | 
			
		||||
    "message": "Správa",
 | 
			
		||||
    "send": "Odoslať",
 | 
			
		||||
    "preview": "Náhľad",
 | 
			
		||||
    "preview": "Preview",
 | 
			
		||||
    "go_back": "Späť",
 | 
			
		||||
    "back_to_login": "Späť na prihlásenie?",
 | 
			
		||||
    "home": "Domov",
 | 
			
		||||
@ -65,7 +65,7 @@
 | 
			
		||||
    "sent": "Odoslané",
 | 
			
		||||
    "all": "Všetko",
 | 
			
		||||
    "select_all": "Vybrať všetky",
 | 
			
		||||
    "select_template": "Vyberte šablónu",
 | 
			
		||||
    "select_template": "Select Template",
 | 
			
		||||
    "choose_file": "Kliknite sem pre vybratie súboru",
 | 
			
		||||
    "choose_template": "Vybrať vzhľad",
 | 
			
		||||
    "choose": "Vybrať",
 | 
			
		||||
@ -92,15 +92,15 @@
 | 
			
		||||
    "choose_note": "Vyberte poznámku",
 | 
			
		||||
    "no_note_found": "Neboli nájdené žiadne poznámky",
 | 
			
		||||
    "insert_note": "Vlož poznámku",
 | 
			
		||||
    "copied_pdf_url_clipboard": "PDF bolo skopírované do schránky!",
 | 
			
		||||
    "copied_url_clipboard": "URL adresa bola skopírovaná do schránky!",
 | 
			
		||||
    "copied_pdf_url_clipboard": "Copied PDF url to clipboard!",
 | 
			
		||||
    "copied_url_clipboard": "Copied url to clipboard!",
 | 
			
		||||
    "docs": "Docs",
 | 
			
		||||
    "do_you_wish_to_continue": "Želáte si pokračovať?",
 | 
			
		||||
    "note": "Poznámka",
 | 
			
		||||
    "pay_invoice": "Zaplatiť faktúru",
 | 
			
		||||
    "login_successfully": "Prihlásenie bolo úspešné!",
 | 
			
		||||
    "logged_out_successfully": "Odhlásenie bolo úspešné",
 | 
			
		||||
    "mark_as_default": "Označiť ako predvolené"
 | 
			
		||||
    "do_you_wish_to_continue": "Do you wish to continue?",
 | 
			
		||||
    "note": "Note",
 | 
			
		||||
    "pay_invoice": "Pay Invoice",
 | 
			
		||||
    "login_successfully": "Logged in successfully!",
 | 
			
		||||
    "logged_out_successfully": "Logged out successfully",
 | 
			
		||||
    "mark_as_default": "Mark as default"
 | 
			
		||||
  },
 | 
			
		||||
  "dashboard": {
 | 
			
		||||
    "select_year": "Vyberte rok",
 | 
			
		||||
@ -109,7 +109,7 @@
 | 
			
		||||
      "customers": "Zákazníci",
 | 
			
		||||
      "invoices": "Faktúry",
 | 
			
		||||
      "estimates": "Cenové odhady",
 | 
			
		||||
      "payments": "Platby"
 | 
			
		||||
      "payments": "Payments"
 | 
			
		||||
    },
 | 
			
		||||
    "chart_info": {
 | 
			
		||||
      "total_sales": "Predaje",
 | 
			
		||||
@ -151,27 +151,27 @@
 | 
			
		||||
    "no_results_found": "Neboli nájdené žiadne výsledky"
 | 
			
		||||
  },
 | 
			
		||||
  "company_switcher": {
 | 
			
		||||
    "label": "PREPNÚŤ SPOLOČNOSŤ",
 | 
			
		||||
    "no_results_found": "Neboli nájdené žiadne výsledky",
 | 
			
		||||
    "add_new_company": "Pridať novú spoločnosť",
 | 
			
		||||
    "new_company": "Vytvorte spoločnosť",
 | 
			
		||||
    "created_message": "Spoločnosť úspešne vytvorená"
 | 
			
		||||
    "label": "SWITCH COMPANY",
 | 
			
		||||
    "no_results_found": "No Results Found",
 | 
			
		||||
    "add_new_company": "Add new company",
 | 
			
		||||
    "new_company": "New company",
 | 
			
		||||
    "created_message": "Company created successfully"
 | 
			
		||||
  },
 | 
			
		||||
  "dateRange": {
 | 
			
		||||
    "today": "Dnes",
 | 
			
		||||
    "this_week": "Tento týždeň",
 | 
			
		||||
    "this_month": "Tento mesiac",
 | 
			
		||||
    "this_quarter": "Tento štvrťrok",
 | 
			
		||||
    "this_year": "Tento rok",
 | 
			
		||||
    "previous_week": "Predchádzajúci týždeň",
 | 
			
		||||
    "previous_month": "Predchádzajúci mesiac",
 | 
			
		||||
    "previous_quarter": "Predchádzajúci štvrťrok",
 | 
			
		||||
    "previous_year": "Predchádzajúci rok",
 | 
			
		||||
    "custom": "Vlastný"
 | 
			
		||||
    "today": "Today",
 | 
			
		||||
    "this_week": "This Week",
 | 
			
		||||
    "this_month": "This Month",
 | 
			
		||||
    "this_quarter": "This Quarter",
 | 
			
		||||
    "this_year": "This Year",
 | 
			
		||||
    "previous_week": "Previous Week",
 | 
			
		||||
    "previous_month": "Previous Month",
 | 
			
		||||
    "previous_quarter": "Previous Quarter",
 | 
			
		||||
    "previous_year": "Previous Year",
 | 
			
		||||
    "custom": "Custom"
 | 
			
		||||
  },
 | 
			
		||||
  "customers": {
 | 
			
		||||
    "title": "Zákazníci",
 | 
			
		||||
    "prefix": "Predpona",
 | 
			
		||||
    "prefix": "Prefix",
 | 
			
		||||
    "add_customer": "Pridať Zákazníka",
 | 
			
		||||
    "contacts_list": "Zoznam zákazníkov",
 | 
			
		||||
    "name": "Meno",
 | 
			
		||||
@ -186,9 +186,9 @@
 | 
			
		||||
    "phone": "Telefón",
 | 
			
		||||
    "website": "Webové stránky",
 | 
			
		||||
    "overview": "Prehľad",
 | 
			
		||||
    "invoice_prefix": "Predpona Faktúry",
 | 
			
		||||
    "estimate_prefix": "Predpona cenového odhadu",
 | 
			
		||||
    "payment_prefix": "Predpona platby",
 | 
			
		||||
    "invoice_prefix": "Invoice Prefix",
 | 
			
		||||
    "estimate_prefix": "Estimate Prefix",
 | 
			
		||||
    "payment_prefix": "Payment Prefix",
 | 
			
		||||
    "enable_portal": "Aktivovať portál",
 | 
			
		||||
    "country": "Krajina",
 | 
			
		||||
    "state": "Štát",
 | 
			
		||||
@ -197,7 +197,7 @@
 | 
			
		||||
    "added_on": "Pridané Dňa",
 | 
			
		||||
    "action": "Akcia",
 | 
			
		||||
    "password": "Heslo",
 | 
			
		||||
    "confirm_password": "Potvrdiť heslo",
 | 
			
		||||
    "confirm_password": "Confirm Password",
 | 
			
		||||
    "street_number": "Číslo Ulice",
 | 
			
		||||
    "primary_currency": "Hlavná Mena",
 | 
			
		||||
    "description": "Popis",
 | 
			
		||||
@ -208,17 +208,17 @@
 | 
			
		||||
    "new_customer": "Nový Zákazník",
 | 
			
		||||
    "edit_customer": "Upraviť Zákazníka",
 | 
			
		||||
    "basic_info": "Základné Informácie",
 | 
			
		||||
    "portal_access": "Prístupy na portál",
 | 
			
		||||
    "portal_access_text": "Chcete povoliť tomuto používateľovi pripojiť sa na Zákaznícky Portál?",
 | 
			
		||||
    "portal_access_url": "Adresa zákazníckeho portálu",
 | 
			
		||||
    "portal_access_url_help": "Prosím, skopírujte a prepošlite URL adresu uvedenú vyššie vášmu klientovi pre udelenie prístupu.",
 | 
			
		||||
    "portal_access": "Portal Access",
 | 
			
		||||
    "portal_access_text": "Would you like to allow this customer to login to the Customer Portal?",
 | 
			
		||||
    "portal_access_url": "Customer Portal Login URL",
 | 
			
		||||
    "portal_access_url_help": "Please copy & forward the above given URL to your customer for providing access.",
 | 
			
		||||
    "billing_address": "Fakturačná Adresa",
 | 
			
		||||
    "shipping_address": "Doručovacia Adresa",
 | 
			
		||||
    "copy_billing_address": "Kopírovať podľa Fakturačnej adresy",
 | 
			
		||||
    "no_customers": "Zatiaľ nebol pridaný žiadny zákazník!",
 | 
			
		||||
    "no_customers_found": "Nenájdení žiadni zákazníci!",
 | 
			
		||||
    "no_contact": "Žiadny kontakt",
 | 
			
		||||
    "no_contact_name": "Žiadny kontakt",
 | 
			
		||||
    "no_contact": "No contact",
 | 
			
		||||
    "no_contact_name": "No contact name",
 | 
			
		||||
    "list_of_customers": "Táto sekcia bude obsahovať zoznam zákazníkov.",
 | 
			
		||||
    "primary_display_name": "Hlavné meno pre zobrazenie",
 | 
			
		||||
    "select_currency": "Vyberte menu",
 | 
			
		||||
@ -231,7 +231,7 @@
 | 
			
		||||
    "confirm_delete": "Nebudete môcť obnoviť tohto zákazníka ani žiadne faktúry, cenové odhady alebo platby s ním spojené. | Nebudete môcť obnoviť týchto zákazníkov ani žiadne faktúry, cenové odhady alebo platby s nimi spojené.",
 | 
			
		||||
    "created_message": "Zákazník úspešne vytvorený",
 | 
			
		||||
    "updated_message": "Zákazník úspešne aktualizovaný",
 | 
			
		||||
    "address_updated_message": "Nastavenia adresy úspešne aktualizované",
 | 
			
		||||
    "address_updated_message": "Address Information Updated succesfully",
 | 
			
		||||
    "deleted_message": "Zákazník úspešne odstránený | Zákazníci úspešne odstránení",
 | 
			
		||||
    "edit_currency_not_allowed": "Cannot change currency once transactions created."
 | 
			
		||||
  },
 | 
			
		||||
@ -244,7 +244,7 @@
 | 
			
		||||
    "added_on": "Pridané Dňa",
 | 
			
		||||
    "price": "Cena",
 | 
			
		||||
    "date_of_creation": "Dátum Vytvorenia",
 | 
			
		||||
    "not_selected": "Nie je vybratá žiadna položka",
 | 
			
		||||
    "not_selected": "No item selected",
 | 
			
		||||
    "action": "Akcia",
 | 
			
		||||
    "add_item": "Pridať Položku",
 | 
			
		||||
    "save_item": "Uložiť Položku",
 | 
			
		||||
@ -317,7 +317,7 @@
 | 
			
		||||
      "required": "Pole je povinné"
 | 
			
		||||
    },
 | 
			
		||||
    "accepted": "Prijátá",
 | 
			
		||||
    "rejected": "Odmietnuté",
 | 
			
		||||
    "rejected": "Rejected",
 | 
			
		||||
    "expired": "Expired",
 | 
			
		||||
    "sent": "Odoslaná",
 | 
			
		||||
    "draft": "Koncept",
 | 
			
		||||
@ -359,8 +359,8 @@
 | 
			
		||||
  },
 | 
			
		||||
  "invoices": {
 | 
			
		||||
    "title": "Faktúry",
 | 
			
		||||
    "download": "Stiahnuť",
 | 
			
		||||
    "pay_invoice": "Zaplatiť faktúru",
 | 
			
		||||
    "download": "Download",
 | 
			
		||||
    "pay_invoice": "Pay Invoice",
 | 
			
		||||
    "invoices_list": "Zoznam Faktúr",
 | 
			
		||||
    "invoice_information": "Invoice Information",
 | 
			
		||||
    "days": "{days} Ďeň",
 | 
			
		||||
@ -370,8 +370,8 @@
 | 
			
		||||
    "paid": "Zaplatené",
 | 
			
		||||
    "unpaid": "Nezaplatené",
 | 
			
		||||
    "viewed": "Viewed",
 | 
			
		||||
    "overdue": "Po splatnosti",
 | 
			
		||||
    "completed": "Dokončené",
 | 
			
		||||
    "overdue": "Overdue",
 | 
			
		||||
    "completed": "Completed",
 | 
			
		||||
    "customer": "ZÁKAZNÍK",
 | 
			
		||||
    "paid_status": "Stav platby",
 | 
			
		||||
    "ref_no": "REF Č.",
 | 
			
		||||
@ -408,7 +408,7 @@
 | 
			
		||||
    "invoice_date": "Dátum Vystavenia",
 | 
			
		||||
    "record_payment": "Zaznamenať Platbu",
 | 
			
		||||
    "add_new_invoice": "Nová Faktúra",
 | 
			
		||||
    "update_expense": "Aktualizovať Výdaj",
 | 
			
		||||
    "update_expense": "Update Expense",
 | 
			
		||||
    "edit_invoice": "Upraviť Faktúru",
 | 
			
		||||
    "new_invoice": "Nová Faktúra",
 | 
			
		||||
    "save_invoice": "Uložiť Faktúru",
 | 
			
		||||
@ -421,7 +421,7 @@
 | 
			
		||||
    "select_invoice": "Vybrať Faktúru",
 | 
			
		||||
    "no_matching_invoices": "Nenašli sa žiadne faktúry!",
 | 
			
		||||
    "mark_as_sent_successfully": "Faktúra označená ako úspešne odoslaná",
 | 
			
		||||
    "invoice_sent_successfully": "Faktúra bola úspešne odoslaná",
 | 
			
		||||
    "invoice_sent_successfully": "Invoice sent successfully",
 | 
			
		||||
    "cloned_successfully": "Faktúra bola úspešne okopírovaná",
 | 
			
		||||
    "clone_invoice": "Kopírovať faktúru",
 | 
			
		||||
    "confirm_clone": "Faktúra bude okopírovaná do novej",
 | 
			
		||||
@ -450,34 +450,34 @@
 | 
			
		||||
    "mark_as_default_invoice_template_description": "If enabled, the selected template will be automatically selected for new invoices."
 | 
			
		||||
  },
 | 
			
		||||
  "recurring_invoices": {
 | 
			
		||||
    "title": "Pravidelné faktúry",
 | 
			
		||||
    "invoices_list": "Zoznam pravidelných faktúr",
 | 
			
		||||
    "title": "Recurring Invoices",
 | 
			
		||||
    "invoices_list": "Recurring Invoices List",
 | 
			
		||||
    "days": "{days} Days",
 | 
			
		||||
    "months": "{months} Month",
 | 
			
		||||
    "years": "{years} Year",
 | 
			
		||||
    "all": "Všetko",
 | 
			
		||||
    "paid": "Zaplatené",
 | 
			
		||||
    "unpaid": "Nezaplatené",
 | 
			
		||||
    "all": "All",
 | 
			
		||||
    "paid": "Paid",
 | 
			
		||||
    "unpaid": "Unpaid",
 | 
			
		||||
    "viewed": "Viewed",
 | 
			
		||||
    "overdue": "Po splatnosti",
 | 
			
		||||
    "overdue": "Overdue",
 | 
			
		||||
    "active": "Active",
 | 
			
		||||
    "completed": "Dokončené",
 | 
			
		||||
    "customer": "ZÁKAZNÍK",
 | 
			
		||||
    "completed": "Completed",
 | 
			
		||||
    "customer": "CUSTOMER",
 | 
			
		||||
    "paid_status": "PAID STATUS",
 | 
			
		||||
    "ref_no": "REF Č.",
 | 
			
		||||
    "number": "ČÍSLO",
 | 
			
		||||
    "ref_no": "REF NO.",
 | 
			
		||||
    "number": "NUMBER",
 | 
			
		||||
    "amount_due": "AMOUNT DUE",
 | 
			
		||||
    "partially_paid": "Čiastočne Zaplatené",
 | 
			
		||||
    "total": "Celkom",
 | 
			
		||||
    "discount": "Zľava",
 | 
			
		||||
    "sub_total": "Medzisúčet",
 | 
			
		||||
    "invoice": "Pravidelná faktúra | Pravidelné faktúry",
 | 
			
		||||
    "invoice_number": "Číslo pravidelnej faktúry",
 | 
			
		||||
    "next_invoice_date": "Dátum nasledujúceho vystavenia",
 | 
			
		||||
    "ref_number": "Ref. Číslo",
 | 
			
		||||
    "contact": "Kontakt",
 | 
			
		||||
    "add_item": "Pridať položku",
 | 
			
		||||
    "date": "Dátum",
 | 
			
		||||
    "partially_paid": "Partially Paid",
 | 
			
		||||
    "total": "Total",
 | 
			
		||||
    "discount": "Discount",
 | 
			
		||||
    "sub_total": "Sub Total",
 | 
			
		||||
    "invoice": "Recurring Invoice | Recurring Invoices",
 | 
			
		||||
    "invoice_number": "Recurring Invoice Number",
 | 
			
		||||
    "next_invoice_date": "Next Invoice Date",
 | 
			
		||||
    "ref_number": "Ref Number",
 | 
			
		||||
    "contact": "Contact",
 | 
			
		||||
    "add_item": "Add an Item",
 | 
			
		||||
    "date": "Date",
 | 
			
		||||
    "limit_by": "Limit by",
 | 
			
		||||
    "limit_date": "Limit Date",
 | 
			
		||||
    "limit_count": "Limit Count",
 | 
			
		||||
@ -506,15 +506,15 @@
 | 
			
		||||
    "starts_at": "Start Date",
 | 
			
		||||
    "due_date": "Invoice Due Date",
 | 
			
		||||
    "record_payment": "Record Payment",
 | 
			
		||||
    "add_new_invoice": "Vytvoriť novú pravidelnú faktúru",
 | 
			
		||||
    "update_expense": "Aktualizovať Výdaj",
 | 
			
		||||
    "edit_invoice": "Upraviť pravidelnú faktúru",
 | 
			
		||||
    "new_invoice": "Nová pravidelná faktúra",
 | 
			
		||||
    "send_automatically": "Odoslať automaticky",
 | 
			
		||||
    "add_new_invoice": "Add New Recurring Invoice",
 | 
			
		||||
    "update_expense": "Update Expense",
 | 
			
		||||
    "edit_invoice": "Edit Recurring Invoice",
 | 
			
		||||
    "new_invoice": "New Recurring Invoice",
 | 
			
		||||
    "send_automatically": "Send Automatically",
 | 
			
		||||
    "send_automatically_desc": "Enable this, if you would like to send the invoice automatically to the customer when its created.",
 | 
			
		||||
    "save_invoice": "Uložiť pravidelnú faktúru",
 | 
			
		||||
    "update_invoice": "Upraviť pravidelnú faktúru",
 | 
			
		||||
    "add_new_tax": "Pridať novú daň",
 | 
			
		||||
    "save_invoice": "Save Recurring Invoice",
 | 
			
		||||
    "update_invoice": "Update Recurring Invoice",
 | 
			
		||||
    "add_new_tax": "Add New Tax",
 | 
			
		||||
    "no_invoices": "No Recurring Invoices yet!",
 | 
			
		||||
    "mark_as_rejected": "Mark as rejected",
 | 
			
		||||
    "mark_as_accepted": "Mark as accepted",
 | 
			
		||||
@ -528,27 +528,27 @@
 | 
			
		||||
    "confirm_clone": "This recurring invoice will be cloned into a new Recurring Invoice",
 | 
			
		||||
    "add_customer_email": "Please add an email address for this customer to send invoices automatically.",
 | 
			
		||||
    "item": {
 | 
			
		||||
      "title": "Názov položky",
 | 
			
		||||
      "description": "Popis",
 | 
			
		||||
      "quantity": "Množstvo",
 | 
			
		||||
      "price": "Cena",
 | 
			
		||||
      "discount": "Zľava",
 | 
			
		||||
      "total": "Súčet",
 | 
			
		||||
      "total_discount": "Celková zľava",
 | 
			
		||||
      "sub_total": "Medzisúčet",
 | 
			
		||||
      "tax": "Daň",
 | 
			
		||||
      "amount": "Množstvo",
 | 
			
		||||
      "select_an_item": "Začnite písať alebo kliknite pre vybratie položky",
 | 
			
		||||
      "type_item_description": "Popis položky (voliteľné)"
 | 
			
		||||
      "title": "Item Title",
 | 
			
		||||
      "description": "Description",
 | 
			
		||||
      "quantity": "Quantity",
 | 
			
		||||
      "price": "Price",
 | 
			
		||||
      "discount": "Discount",
 | 
			
		||||
      "total": "Total",
 | 
			
		||||
      "total_discount": "Total Discount",
 | 
			
		||||
      "sub_total": "Sub Total",
 | 
			
		||||
      "tax": "Tax",
 | 
			
		||||
      "amount": "Amount",
 | 
			
		||||
      "select_an_item": "Type or click to select an item",
 | 
			
		||||
      "type_item_description": "Type Item Description (optional)"
 | 
			
		||||
    },
 | 
			
		||||
    "frequency": {
 | 
			
		||||
      "title": "Frekvencia",
 | 
			
		||||
      "select_frequency": "Vybrať frekvenciu",
 | 
			
		||||
      "minute": "Minúta",
 | 
			
		||||
      "hour": "Hodina",
 | 
			
		||||
      "day_month": "Deň v mesiaci",
 | 
			
		||||
      "month": "Mesiac",
 | 
			
		||||
      "day_week": "Deň v týždni"
 | 
			
		||||
      "title": "Frequency",
 | 
			
		||||
      "select_frequency": "Select Frequency",
 | 
			
		||||
      "minute": "Minute",
 | 
			
		||||
      "hour": "Hour",
 | 
			
		||||
      "day_month": "Day of month",
 | 
			
		||||
      "month": "Month",
 | 
			
		||||
      "day_week": "Day of week"
 | 
			
		||||
    },
 | 
			
		||||
    "confirm_delete": "You will not be able to recover this Invoice | You will not be able to recover these Invoices",
 | 
			
		||||
    "created_message": "Recurring Invoice created successfully",
 | 
			
		||||
@ -686,12 +686,12 @@
 | 
			
		||||
    "api_token": "API token",
 | 
			
		||||
    "invalid_api_token": "Invalid API Token.",
 | 
			
		||||
    "other_modules": "Other Modules",
 | 
			
		||||
    "view_all": "Zobraziť všetky",
 | 
			
		||||
    "no_reviews_found": "Zatiaľ nie sú dostupné žiadne hodnotenia pre tento modul!",
 | 
			
		||||
    "module_not_purchased": "Modul nie je kúpený",
 | 
			
		||||
    "module_not_found": "Modul nebol nájdený",
 | 
			
		||||
    "view_all": "View All",
 | 
			
		||||
    "no_reviews_found": "There are no reviews for this module yet!",
 | 
			
		||||
    "module_not_purchased": "Module Not Purchased",
 | 
			
		||||
    "module_not_found": "Module Not Found",
 | 
			
		||||
    "version_not_supported": "This module version doesn't support the current version of Crater",
 | 
			
		||||
    "last_updated": "Naposledy aktualizované",
 | 
			
		||||
    "last_updated": "Last Updated On",
 | 
			
		||||
    "connect_installation": "Connect your installation",
 | 
			
		||||
    "api_token_description": "Login to {url} and connect this installation by entering the API Token. Your purchased modules will show up here after the connection is established.",
 | 
			
		||||
    "view_module": "View Module",
 | 
			
		||||
@ -806,8 +806,8 @@
 | 
			
		||||
      "custom_fields": "Vlastné Polia",
 | 
			
		||||
      "payment_modes": "Spôsoby Platby",
 | 
			
		||||
      "notes": "Poznámky",
 | 
			
		||||
      "exchange_rate": "Výmenný kurz",
 | 
			
		||||
      "address_information": "Údaje adresy"
 | 
			
		||||
      "exchange_rate": "Exchange Rate",
 | 
			
		||||
      "address_information": "Address Information"
 | 
			
		||||
    },
 | 
			
		||||
    "address_information": {
 | 
			
		||||
      "section_description": "  You can update Your Address information using form below."
 | 
			
		||||
@ -872,9 +872,9 @@
 | 
			
		||||
      "address": "Adresa",
 | 
			
		||||
      "zip": "PSČ",
 | 
			
		||||
      "save": "Uložiť",
 | 
			
		||||
      "delete": "Odstrániť",
 | 
			
		||||
      "delete": "Delete",
 | 
			
		||||
      "updated_message": "Informácie o firme úspešne aktualizované",
 | 
			
		||||
      "delete_company": "Odstrániť spoločnosť",
 | 
			
		||||
      "delete_company": "Delete Company",
 | 
			
		||||
      "delete_company_description": "Once you delete your company, you will lose all the data and files associated with it permanently.",
 | 
			
		||||
      "are_you_absolutely_sure": "Are you absolutely sure?",
 | 
			
		||||
      "delete_company_modal_desc": "This action cannot be undone. This will permanently delete {company} and all of its associated data.",
 | 
			
		||||
@ -1485,7 +1485,7 @@
 | 
			
		||||
  "pdf_estimate_label": "Cenový odhad",
 | 
			
		||||
  "pdf_estimate_number": "Číslo cenového odhadu",
 | 
			
		||||
  "pdf_estimate_date": "Dátum cenového odhadu",
 | 
			
		||||
  "pdf_estimate_expire_date": "Expiry Date",
 | 
			
		||||
  "pdf_estimate_expire_date": "Platnosť cenového odhadu",
 | 
			
		||||
  "pdf_invoice_label": "Faktúra",
 | 
			
		||||
  "pdf_invoice_number": "Číslo faktúry",
 | 
			
		||||
  "pdf_invoice_date": "Dátum vystavenia",
 | 
			
		||||
 | 
			
		||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							@ -12,7 +12,7 @@
 | 
			
		||||
    "settings": "Podešavanja",
 | 
			
		||||
    "logout": "Odjavi se",
 | 
			
		||||
    "users": "Korisnici",
 | 
			
		||||
    "modules": "Moduli"
 | 
			
		||||
    "modules": "Modules"
 | 
			
		||||
  },
 | 
			
		||||
  "general": {
 | 
			
		||||
    "add_company": "Dodaj kompaniju",
 | 
			
		||||
@ -30,8 +30,8 @@
 | 
			
		||||
    "from": "Pošiljalac",
 | 
			
		||||
    "to": "Primalac",
 | 
			
		||||
    "ok": "Ok",
 | 
			
		||||
    "yes": "Da",
 | 
			
		||||
    "no": "Ne",
 | 
			
		||||
    "yes": "Yes",
 | 
			
		||||
    "no": "No",
 | 
			
		||||
    "sort_by": "Rasporedi Po",
 | 
			
		||||
    "ascending": "Rastuće",
 | 
			
		||||
    "descending": "Opadajuće",
 | 
			
		||||
@ -39,7 +39,7 @@
 | 
			
		||||
    "body": "Telo",
 | 
			
		||||
    "message": "Poruka",
 | 
			
		||||
    "send": "Pošalji",
 | 
			
		||||
    "preview": "Pregled",
 | 
			
		||||
    "preview": "Preview",
 | 
			
		||||
    "go_back": "Idi nazad",
 | 
			
		||||
    "back_to_login": "Nazad na prijavu?",
 | 
			
		||||
    "home": "Početna",
 | 
			
		||||
@ -95,9 +95,9 @@
 | 
			
		||||
    "copied_pdf_url_clipboard": "Link do PDF fajla kopiran!",
 | 
			
		||||
    "copied_url_clipboard": "Copied url to clipboard!",
 | 
			
		||||
    "docs": "Docs",
 | 
			
		||||
    "do_you_wish_to_continue": "Da li želite nastaviti?",
 | 
			
		||||
    "note": "Bilješka",
 | 
			
		||||
    "pay_invoice": "Plati račun",
 | 
			
		||||
    "do_you_wish_to_continue": "Do you wish to continue?",
 | 
			
		||||
    "note": "Note",
 | 
			
		||||
    "pay_invoice": "Pay Invoice",
 | 
			
		||||
    "login_successfully": "Logged in successfully!",
 | 
			
		||||
    "logged_out_successfully": "Logged out successfully",
 | 
			
		||||
    "mark_as_default": "Mark as default"
 | 
			
		||||
@ -318,10 +318,10 @@
 | 
			
		||||
    },
 | 
			
		||||
    "accepted": "Prihvaćeno",
 | 
			
		||||
    "rejected": "Odbijeno",
 | 
			
		||||
    "expired": "Istekao",
 | 
			
		||||
    "expired": "Expired",
 | 
			
		||||
    "sent": "Poslato",
 | 
			
		||||
    "draft": "U izradi",
 | 
			
		||||
    "viewed": "Pregledano",
 | 
			
		||||
    "viewed": "Viewed",
 | 
			
		||||
    "declined": "Odbijeno",
 | 
			
		||||
    "new_estimate": "Nova Profaktura",
 | 
			
		||||
    "add_new_estimate": "Dodaj novu Profakturu",
 | 
			
		||||
@ -1485,7 +1485,7 @@
 | 
			
		||||
  "pdf_estimate_label": "Profaktura",
 | 
			
		||||
  "pdf_estimate_number": "Broj Profakture",
 | 
			
		||||
  "pdf_estimate_date": "Datum Profakture",
 | 
			
		||||
  "pdf_estimate_expire_date": "Expiry Date",
 | 
			
		||||
  "pdf_estimate_expire_date": "Datum isteka Profakture",
 | 
			
		||||
  "pdf_invoice_label": "Faktura",
 | 
			
		||||
  "pdf_invoice_number": "Broj Fakture",
 | 
			
		||||
  "pdf_invoice_date": "Datum Fakture",
 | 
			
		||||
 | 
			
		||||
@ -1485,7 +1485,7 @@
 | 
			
		||||
  "pdf_estimate_label": "Kostnadsförslag",
 | 
			
		||||
  "pdf_estimate_number": "Kostnadsförslagsnummer",
 | 
			
		||||
  "pdf_estimate_date": "Kostnadsförslagsdatum",
 | 
			
		||||
  "pdf_estimate_expire_date": "Expiry Date",
 | 
			
		||||
  "pdf_estimate_expire_date": "Utgångsdatum",
 | 
			
		||||
  "pdf_invoice_label": "Faktura",
 | 
			
		||||
  "pdf_invoice_number": "Fakturanummer",
 | 
			
		||||
  "pdf_invoice_date": "Fakturadatum",
 | 
			
		||||
 | 
			
		||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							@ -1485,7 +1485,7 @@
 | 
			
		||||
  "pdf_estimate_label": "Estimate",
 | 
			
		||||
  "pdf_estimate_number": "Estimate Number",
 | 
			
		||||
  "pdf_estimate_date": "Estimate Date",
 | 
			
		||||
  "pdf_estimate_expire_date": "Expiry Date",
 | 
			
		||||
  "pdf_estimate_expire_date": "Expiry date",
 | 
			
		||||
  "pdf_invoice_label": "Invoice",
 | 
			
		||||
  "pdf_invoice_number": "Invoice Number",
 | 
			
		||||
  "pdf_invoice_date": "Invoice Date",
 | 
			
		||||
 | 
			
		||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							@ -12,7 +12,7 @@
 | 
			
		||||
    "settings": "Cài đặt",
 | 
			
		||||
    "logout": "Đăng xuất",
 | 
			
		||||
    "users": "Người dùng",
 | 
			
		||||
    "modules": "Các Mô-Đun"
 | 
			
		||||
    "modules": "Modules"
 | 
			
		||||
  },
 | 
			
		||||
  "general": {
 | 
			
		||||
    "add_company": "Thêm công ty",
 | 
			
		||||
@ -93,13 +93,13 @@
 | 
			
		||||
    "no_note_found": "Không tìm thấy ghi chú",
 | 
			
		||||
    "insert_note": "Chèn ghi chú",
 | 
			
		||||
    "copied_pdf_url_clipboard": "Đã sao chép url PDF vào khay nhớ tạm!",
 | 
			
		||||
    "copied_url_clipboard": "Đã sao chép url vào khay nhớ tạm!",
 | 
			
		||||
    "copied_url_clipboard": "Copied url to clipboard!",
 | 
			
		||||
    "docs": "Tài liệu",
 | 
			
		||||
    "do_you_wish_to_continue": "Bạn có muốn tiếp tục không?",
 | 
			
		||||
    "note": "Ghi chú",
 | 
			
		||||
    "pay_invoice": "Thanh toán hóa đơn",
 | 
			
		||||
    "login_successfully": "Đăng nhập thành công!",
 | 
			
		||||
    "logged_out_successfully": "Đăng xuất thành công",
 | 
			
		||||
    "pay_invoice": "Pay Invoice",
 | 
			
		||||
    "login_successfully": "Logged in successfully!",
 | 
			
		||||
    "logged_out_successfully": "Logged out successfully",
 | 
			
		||||
    "mark_as_default": "Đánh dấu mặc định"
 | 
			
		||||
  },
 | 
			
		||||
  "dashboard": {
 | 
			
		||||
@ -109,7 +109,7 @@
 | 
			
		||||
      "customers": "Khách hàng",
 | 
			
		||||
      "invoices": "Hóa đơn",
 | 
			
		||||
      "estimates": "Ước tính",
 | 
			
		||||
      "payments": "Thanh toán"
 | 
			
		||||
      "payments": "Payments"
 | 
			
		||||
    },
 | 
			
		||||
    "chart_info": {
 | 
			
		||||
      "total_sales": "Bán hàng",
 | 
			
		||||
@ -208,10 +208,10 @@
 | 
			
		||||
    "new_customer": "Khách hàng mới",
 | 
			
		||||
    "edit_customer": "Chỉnh sửa khách hàng",
 | 
			
		||||
    "basic_info": "Thông tin cơ bản",
 | 
			
		||||
    "portal_access": "Truy cập cổng thông tin",
 | 
			
		||||
    "portal_access_text": "Bạn có muốn cho phép người dùng này truy cập vào cổng thông tin khách hàng không?",
 | 
			
		||||
    "portal_access_url": "Đường dẫn đăng nhập cổng thông tin khách hàng",
 | 
			
		||||
    "portal_access_url_help": "Hãy sao chép & chuyển tiếp đường dẫn bên trên cho khách hàng của bạn để cho phép truy cập.",
 | 
			
		||||
    "portal_access": "Portal Access",
 | 
			
		||||
    "portal_access_text": "Would you like to allow this customer to login to the Customer Portal?",
 | 
			
		||||
    "portal_access_url": "Customer Portal Login URL",
 | 
			
		||||
    "portal_access_url_help": "Please copy & forward the above given URL to your customer for providing access.",
 | 
			
		||||
    "billing_address": "Địa chỉ thanh toán",
 | 
			
		||||
    "shipping_address": "Địa chỉ giao hàng",
 | 
			
		||||
    "copy_billing_address": "Sao chép từ thanh toán",
 | 
			
		||||
@ -231,7 +231,7 @@
 | 
			
		||||
    "confirm_delete": "Bạn sẽ không thể khôi phục khách hàng này và tất cả các Hóa đơn, Ước tính và Thanh toán có liên quan. | Bạn sẽ không thể khôi phục những khách hàng này và tất cả các Hóa đơn, Ước tính và Thanh toán có liên quan.",
 | 
			
		||||
    "created_message": "Khách hàng được tạo thành công",
 | 
			
		||||
    "updated_message": "Đã cập nhật khách hàng thành công",
 | 
			
		||||
    "address_updated_message": "Thông tin địa chỉ được cập nhật thành công",
 | 
			
		||||
    "address_updated_message": "Address Information Updated succesfully",
 | 
			
		||||
    "deleted_message": "Đã xóa khách hàng thành công | Đã xóa khách hàng thành công",
 | 
			
		||||
    "edit_currency_not_allowed": "Không thể đổi tiền tệ khi bản dịch đã được tạo."
 | 
			
		||||
  },
 | 
			
		||||
@ -265,7 +265,7 @@
 | 
			
		||||
  },
 | 
			
		||||
  "estimates": {
 | 
			
		||||
    "title": "Ước tính",
 | 
			
		||||
    "accept_estimate": "Chấp nhận ước tính",
 | 
			
		||||
    "accept_estimate": "Accept Estimate",
 | 
			
		||||
    "reject_estimate": "Reject Estimate",
 | 
			
		||||
    "estimate": "Ước tính | Ước tính",
 | 
			
		||||
    "estimates_list": "Danh sách ước tính",
 | 
			
		||||
@ -318,7 +318,7 @@
 | 
			
		||||
    },
 | 
			
		||||
    "accepted": "Đã được chấp nhận",
 | 
			
		||||
    "rejected": "Từ chối",
 | 
			
		||||
    "expired": "Hết hạn",
 | 
			
		||||
    "expired": "Expired",
 | 
			
		||||
    "sent": "Gởi",
 | 
			
		||||
    "draft": "Bản nháp",
 | 
			
		||||
    "viewed": "Viewed",
 | 
			
		||||
@ -463,36 +463,36 @@
 | 
			
		||||
    "active": "Hoạt động",
 | 
			
		||||
    "completed": "Hoàn thành",
 | 
			
		||||
    "customer": "KHÁCH HÀNG",
 | 
			
		||||
    "paid_status": "TÌNH TRẠNG THANH TOÁN",
 | 
			
		||||
    "ref_no": "Số tham chiếu.",
 | 
			
		||||
    "number": "SỐ",
 | 
			
		||||
    "paid_status": "PAID STATUS",
 | 
			
		||||
    "ref_no": "REF NO.",
 | 
			
		||||
    "number": "NUMBER",
 | 
			
		||||
    "amount_due": "AMOUNT DUE",
 | 
			
		||||
    "partially_paid": "Partially Paid",
 | 
			
		||||
    "total": "Tổng",
 | 
			
		||||
    "discount": "Giảm giá",
 | 
			
		||||
    "total": "Total",
 | 
			
		||||
    "discount": "Discount",
 | 
			
		||||
    "sub_total": "Sub Total",
 | 
			
		||||
    "invoice": "Recurring Invoice | Recurring Invoices",
 | 
			
		||||
    "invoice_number": "Số hóa đơn định kì",
 | 
			
		||||
    "next_invoice_date": "Ngày lập hoá đơn tiếp theo",
 | 
			
		||||
    "ref_number": "Số tham chiếu",
 | 
			
		||||
    "contact": "Liên hệ",
 | 
			
		||||
    "add_item": "Thêm một mặt hàng",
 | 
			
		||||
    "date": "Ngày",
 | 
			
		||||
    "limit_by": "Giới hạn bởi",
 | 
			
		||||
    "limit_date": "Ngày giới hạn",
 | 
			
		||||
    "invoice_number": "Recurring Invoice Number",
 | 
			
		||||
    "next_invoice_date": "Next Invoice Date",
 | 
			
		||||
    "ref_number": "Ref Number",
 | 
			
		||||
    "contact": "Contact",
 | 
			
		||||
    "add_item": "Add an Item",
 | 
			
		||||
    "date": "Date",
 | 
			
		||||
    "limit_by": "Limit by",
 | 
			
		||||
    "limit_date": "Limit Date",
 | 
			
		||||
    "limit_count": "Limit Count",
 | 
			
		||||
    "count": "Count",
 | 
			
		||||
    "status": "Trạng thái",
 | 
			
		||||
    "select_a_status": "Chọn một trạng thái",
 | 
			
		||||
    "working": "Đang hoạt động",
 | 
			
		||||
    "on_hold": "Đang chờ",
 | 
			
		||||
    "complete": "Hoàn thành",
 | 
			
		||||
    "add_tax": "Thêm thuế",
 | 
			
		||||
    "amount": "Số tiền",
 | 
			
		||||
    "action": "Hành động",
 | 
			
		||||
    "notes": "Ghi chú",
 | 
			
		||||
    "view": "Xem",
 | 
			
		||||
    "basic_info": "Thông tin cơ bản",
 | 
			
		||||
    "status": "Status",
 | 
			
		||||
    "select_a_status": "Select a status",
 | 
			
		||||
    "working": "Working",
 | 
			
		||||
    "on_hold": "On Hold",
 | 
			
		||||
    "complete": "Completed",
 | 
			
		||||
    "add_tax": "Add Tax",
 | 
			
		||||
    "amount": "Amount",
 | 
			
		||||
    "action": "Action",
 | 
			
		||||
    "notes": "Notes",
 | 
			
		||||
    "view": "View",
 | 
			
		||||
    "basic_info": "Basic Info",
 | 
			
		||||
    "send_invoice": "Send Recurring Invoice",
 | 
			
		||||
    "auto_send": "Auto Send",
 | 
			
		||||
    "resend_invoice": "Resend Recurring Invoice",
 | 
			
		||||
@ -504,9 +504,9 @@
 | 
			
		||||
    "invoice_mark_as_sent": "This recurring invoice will be marked as sent",
 | 
			
		||||
    "confirm_send": "This recurring invoice will be sent via email to the customer",
 | 
			
		||||
    "starts_at": "Start Date",
 | 
			
		||||
    "due_date": "Ngày lập hóa đơn",
 | 
			
		||||
    "record_payment": "Ghi lại Thanh toán",
 | 
			
		||||
    "add_new_invoice": "Cập nhật Hóa đơn định kỳ",
 | 
			
		||||
    "due_date": "Invoice Due Date",
 | 
			
		||||
    "record_payment": "Record Payment",
 | 
			
		||||
    "add_new_invoice": "Add New Recurring Invoice",
 | 
			
		||||
    "update_expense": "Update Expense",
 | 
			
		||||
    "edit_invoice": "Edit Recurring Invoice",
 | 
			
		||||
    "new_invoice": "New Recurring Invoice",
 | 
			
		||||
@ -533,7 +533,7 @@
 | 
			
		||||
      "quantity": "Quantity",
 | 
			
		||||
      "price": "Price",
 | 
			
		||||
      "discount": "Discount",
 | 
			
		||||
      "total": "Tổng cộng",
 | 
			
		||||
      "total": "Total",
 | 
			
		||||
      "total_discount": "Total Discount",
 | 
			
		||||
      "sub_total": "Sub Total",
 | 
			
		||||
      "tax": "Tax",
 | 
			
		||||
@ -1485,7 +1485,7 @@
 | 
			
		||||
  "pdf_estimate_label": "Ước tính",
 | 
			
		||||
  "pdf_estimate_number": "Số ước tính",
 | 
			
		||||
  "pdf_estimate_date": "Ngày ước tính",
 | 
			
		||||
  "pdf_estimate_expire_date": "Expiry Date",
 | 
			
		||||
  "pdf_estimate_expire_date": "Ngày hết hạn",
 | 
			
		||||
  "pdf_invoice_label": "Hóa đơn",
 | 
			
		||||
  "pdf_invoice_number": "Số hóa đơn",
 | 
			
		||||
  "pdf_invoice_date": "Ngày lập hóa đơn",
 | 
			
		||||
 | 
			
		||||
@ -12,7 +12,7 @@
 | 
			
		||||
    "settings": "設定",
 | 
			
		||||
    "logout": "登出",
 | 
			
		||||
    "users": "使用者",
 | 
			
		||||
    "modules": "功能模組"
 | 
			
		||||
    "modules": "Modules"
 | 
			
		||||
  },
 | 
			
		||||
  "general": {
 | 
			
		||||
    "add_company": "新增公司",
 | 
			
		||||
@ -93,14 +93,14 @@
 | 
			
		||||
    "no_note_found": "沒有找到備註",
 | 
			
		||||
    "insert_note": "插入備註",
 | 
			
		||||
    "copied_pdf_url_clipboard": "複製PDF位址到剪貼簿!",
 | 
			
		||||
    "copied_url_clipboard": "將網址複製到剪貼簿!",
 | 
			
		||||
    "copied_url_clipboard": "Copied url to clipboard!",
 | 
			
		||||
    "docs": "文檔",
 | 
			
		||||
    "do_you_wish_to_continue": "你確定要繼續?",
 | 
			
		||||
    "note": "備註",
 | 
			
		||||
    "pay_invoice": "支付發票",
 | 
			
		||||
    "login_successfully": "已成功登入!",
 | 
			
		||||
    "logged_out_successfully": "已成功登出",
 | 
			
		||||
    "mark_as_default": "標記為預設值"
 | 
			
		||||
    "pay_invoice": "Pay Invoice",
 | 
			
		||||
    "login_successfully": "Logged in successfully!",
 | 
			
		||||
    "logged_out_successfully": "Logged out successfully",
 | 
			
		||||
    "mark_as_default": "Mark as default"
 | 
			
		||||
  },
 | 
			
		||||
  "dashboard": {
 | 
			
		||||
    "select_year": "選擇年份",
 | 
			
		||||
@ -109,7 +109,7 @@
 | 
			
		||||
      "customers": "客户",
 | 
			
		||||
      "invoices": "發票",
 | 
			
		||||
      "estimates": "報價",
 | 
			
		||||
      "payments": "付款"
 | 
			
		||||
      "payments": "Payments"
 | 
			
		||||
    },
 | 
			
		||||
    "chart_info": {
 | 
			
		||||
      "total_sales": "銷售",
 | 
			
		||||
@ -208,10 +208,10 @@
 | 
			
		||||
    "new_customer": "新客戶",
 | 
			
		||||
    "edit_customer": "編輯客戶",
 | 
			
		||||
    "basic_info": "基本資料",
 | 
			
		||||
    "portal_access": "門戶訪問",
 | 
			
		||||
    "portal_access_text": "您想允許此客戶登入客戶門戶嗎?",
 | 
			
		||||
    "portal_access_url": "客戶門戶登入URL",
 | 
			
		||||
    "portal_access_url_help": "請將上述給定的URL複製並轉發給您的客戶以提供訪問許可權。",
 | 
			
		||||
    "portal_access": "Portal Access",
 | 
			
		||||
    "portal_access_text": "Would you like to allow this customer to login to the Customer Portal?",
 | 
			
		||||
    "portal_access_url": "Customer Portal Login URL",
 | 
			
		||||
    "portal_access_url_help": "Please copy & forward the above given URL to your customer for providing access.",
 | 
			
		||||
    "billing_address": "帳單地址",
 | 
			
		||||
    "shipping_address": "送貨地址",
 | 
			
		||||
    "copy_billing_address": "由帳單複製",
 | 
			
		||||
@ -231,7 +231,7 @@
 | 
			
		||||
    "confirm_delete": "你將不能夠還原此客戶, 以及此客戶相關的發票, 報價及付款. | 你將不能夠還原此客戶, 以及此客戶相關的發票, 報價及付款.",
 | 
			
		||||
    "created_message": "成功新增客戶",
 | 
			
		||||
    "updated_message": "成功更新客戶",
 | 
			
		||||
    "address_updated_message": "地址資訊已成功更新",
 | 
			
		||||
    "address_updated_message": "Address Information Updated succesfully",
 | 
			
		||||
    "deleted_message": "成功刪除客戶 | 成功刪除客戶",
 | 
			
		||||
    "edit_currency_not_allowed": "交易一旦創建後就不能改變貨幣!"
 | 
			
		||||
  },
 | 
			
		||||
@ -265,8 +265,8 @@
 | 
			
		||||
  },
 | 
			
		||||
  "estimates": {
 | 
			
		||||
    "title": "報價",
 | 
			
		||||
    "accept_estimate": "接受估價",
 | 
			
		||||
    "reject_estimate": "拒絕估算",
 | 
			
		||||
    "accept_estimate": "Accept Estimate",
 | 
			
		||||
    "reject_estimate": "Reject Estimate",
 | 
			
		||||
    "estimate": "報價 | 報價",
 | 
			
		||||
    "estimates_list": "報價列表",
 | 
			
		||||
    "days": "{days} 天",
 | 
			
		||||
@ -318,10 +318,10 @@
 | 
			
		||||
    },
 | 
			
		||||
    "accepted": "已接受",
 | 
			
		||||
    "rejected": "已拒絕",
 | 
			
		||||
    "expired": "已過期",
 | 
			
		||||
    "expired": "Expired",
 | 
			
		||||
    "sent": "傳送",
 | 
			
		||||
    "draft": "草稿",
 | 
			
		||||
    "viewed": "已檢視",
 | 
			
		||||
    "viewed": "Viewed",
 | 
			
		||||
    "declined": "拒絕",
 | 
			
		||||
    "new_estimate": "新報價",
 | 
			
		||||
    "add_new_estimate": "新增報價",
 | 
			
		||||
@ -355,14 +355,14 @@
 | 
			
		||||
      "select_an_item": "輸入或點擊去選擇商品",
 | 
			
		||||
      "type_item_description": "商品詳情(可選)"
 | 
			
		||||
    },
 | 
			
		||||
    "mark_as_default_estimate_template_description": "如果啟用,所選模板將自動選擇新的估算。"
 | 
			
		||||
    "mark_as_default_estimate_template_description": "If enabled, the selected template will be automatically selected for new estimates."
 | 
			
		||||
  },
 | 
			
		||||
  "invoices": {
 | 
			
		||||
    "title": "發票",
 | 
			
		||||
    "download": "下載",
 | 
			
		||||
    "pay_invoice": "支付發票",
 | 
			
		||||
    "download": "Download",
 | 
			
		||||
    "pay_invoice": "Pay Invoice",
 | 
			
		||||
    "invoices_list": "發票列表",
 | 
			
		||||
    "invoice_information": "發票資訊",
 | 
			
		||||
    "invoice_information": "Invoice Information",
 | 
			
		||||
    "days": "{days} 天",
 | 
			
		||||
    "months": "{months} 月",
 | 
			
		||||
    "years": "{years} 年",
 | 
			
		||||
@ -447,7 +447,7 @@
 | 
			
		||||
    "marked_as_sent_message": "發票已標示為成功傳送",
 | 
			
		||||
    "something_went_wrong": "出現錯誤",
 | 
			
		||||
    "invalid_due_amount_message": "發票總額不能少於支付總額. 請更新發票或刪除相關支付再繼續.",
 | 
			
		||||
    "mark_as_default_invoice_template_description": "如果啟用,所選模板將自動選擇新發票"
 | 
			
		||||
    "mark_as_default_invoice_template_description": "If enabled, the selected template will be automatically selected for new invoices."
 | 
			
		||||
  },
 | 
			
		||||
  "recurring_invoices": {
 | 
			
		||||
    "title": "定期發票",
 | 
			
		||||
@ -464,12 +464,12 @@
 | 
			
		||||
    "completed": "已完成",
 | 
			
		||||
    "customer": "客戶",
 | 
			
		||||
    "paid_status": "付款狀態",
 | 
			
		||||
    "ref_no": "參考號碼",
 | 
			
		||||
    "number": "號",
 | 
			
		||||
    "amount_due": "到期金額",
 | 
			
		||||
    "partially_paid": "部分支付",
 | 
			
		||||
    "total": "總計",
 | 
			
		||||
    "discount": "折扣",
 | 
			
		||||
    "ref_no": "REF NO.",
 | 
			
		||||
    "number": "NUMBER",
 | 
			
		||||
    "amount_due": "AMOUNT DUE",
 | 
			
		||||
    "partially_paid": "Partially Paid",
 | 
			
		||||
    "total": "Total",
 | 
			
		||||
    "discount": "Discount",
 | 
			
		||||
    "sub_total": "Sub Total",
 | 
			
		||||
    "invoice": "Recurring Invoice | Recurring Invoices",
 | 
			
		||||
    "invoice_number": "Recurring Invoice Number",
 | 
			
		||||
@ -504,16 +504,16 @@
 | 
			
		||||
    "invoice_mark_as_sent": "This recurring invoice will be marked as sent",
 | 
			
		||||
    "confirm_send": "This recurring invoice will be sent via email to the customer",
 | 
			
		||||
    "starts_at": "Start Date",
 | 
			
		||||
    "due_date": "發票到期日期",
 | 
			
		||||
    "record_payment": "紀錄付款",
 | 
			
		||||
    "add_new_invoice": "添加定期發票",
 | 
			
		||||
    "update_expense": "更新支出",
 | 
			
		||||
    "edit_invoice": "編輯定期發票",
 | 
			
		||||
    "new_invoice": "添加定期發票",
 | 
			
		||||
    "send_automatically": "自動發送",
 | 
			
		||||
    "send_automatically_desc": "如果您希望在建立發票時自動將發票發送給客戶,請啟用此選項。",
 | 
			
		||||
    "save_invoice": "保存定期發票",
 | 
			
		||||
    "update_invoice": "更新定期發票",
 | 
			
		||||
    "due_date": "Invoice Due Date",
 | 
			
		||||
    "record_payment": "Record Payment",
 | 
			
		||||
    "add_new_invoice": "Add New Recurring Invoice",
 | 
			
		||||
    "update_expense": "Update Expense",
 | 
			
		||||
    "edit_invoice": "Edit Recurring Invoice",
 | 
			
		||||
    "new_invoice": "New Recurring Invoice",
 | 
			
		||||
    "send_automatically": "Send Automatically",
 | 
			
		||||
    "send_automatically_desc": "Enable this, if you would like to send the invoice automatically to the customer when its created.",
 | 
			
		||||
    "save_invoice": "Save Recurring Invoice",
 | 
			
		||||
    "update_invoice": "Update Recurring Invoice",
 | 
			
		||||
    "add_new_tax": "Add New Tax",
 | 
			
		||||
    "no_invoices": "No Recurring Invoices yet!",
 | 
			
		||||
    "mark_as_rejected": "Mark as rejected",
 | 
			
		||||
@ -1485,7 +1485,7 @@
 | 
			
		||||
  "pdf_estimate_label": "報價",
 | 
			
		||||
  "pdf_estimate_number": "報價單號",
 | 
			
		||||
  "pdf_estimate_date": "報價日期",
 | 
			
		||||
  "pdf_estimate_expire_date": "Expiry Date",
 | 
			
		||||
  "pdf_estimate_expire_date": "有效日期",
 | 
			
		||||
  "pdf_invoice_label": "發票",
 | 
			
		||||
  "pdf_invoice_number": "發票號碼",
 | 
			
		||||
  "pdf_invoice_date": "發票日期",
 | 
			
		||||
 | 
			
		||||
							
								
								
									
										
											BIN
										
									
								
								resources/static/fonts/THSarabunNew-Bold.ttf
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								resources/static/fonts/THSarabunNew-Bold.ttf
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								resources/static/fonts/THSarabunNew-BoldItalic.ttf
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								resources/static/fonts/THSarabunNew-BoldItalic.ttf
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								resources/static/fonts/THSarabunNew-Italic.ttf
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								resources/static/fonts/THSarabunNew-Italic.ttf
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										
											BIN
										
									
								
								resources/static/fonts/THSarabunNew.ttf
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								resources/static/fonts/THSarabunNew.ttf
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							@ -17,7 +17,7 @@
 | 
			
		||||
    <meta name="csrf-token" content="{{ csrf_token() }}">
 | 
			
		||||
 | 
			
		||||
    <!-- Module Styles -->
 | 
			
		||||
    @foreach(\Crater\Services\Module\ModuleFacade::allStyles() as $name => $path)
 | 
			
		||||
    @foreach (\Crater\Services\Module\ModuleFacade::allStyles() as $name => $path)
 | 
			
		||||
        <link rel="stylesheet" href="/modules/styles/{{ $name }}">
 | 
			
		||||
    @endforeach
 | 
			
		||||
 | 
			
		||||
@ -25,8 +25,8 @@
 | 
			
		||||
</head>
 | 
			
		||||
 | 
			
		||||
<body
 | 
			
		||||
    class="h-full overflow-hidden bg-gray-100 font-base
 | 
			
		||||
    @if(isset($current_theme)) theme-{{ $current_theme }} @else theme-{{get_app_setting('admin_portal_theme') ?? 'crater'}} @endif ">
 | 
			
		||||
    class="h-full overflow-hidden bg-gray-100 dark:bg-gray-900 dark:text-white font-base
 | 
			
		||||
    @if (isset($current_theme)) theme-{{ $current_theme }} @else theme-{{ get_app_setting('admin_portal_theme') ?? 'crater' }} @endif ">
 | 
			
		||||
 | 
			
		||||
    <!-- Module Scripts -->
 | 
			
		||||
    @foreach (\Crater\Services\Module\ModuleFacade::allScripts() as $name => $path)
 | 
			
		||||
@ -38,6 +38,14 @@
 | 
			
		||||
    @endforeach
 | 
			
		||||
 | 
			
		||||
    <script type="module">
 | 
			
		||||
        if (localStorage.theme === 'dark' || (!('theme' in localStorage) && window.matchMedia('(prefers-color-scheme: dark)').matches)) {
 | 
			
		||||
            document.documentElement.classList.add('dark')
 | 
			
		||||
            document.documentElement.style.setProperty('color-scheme', 'dark');
 | 
			
		||||
        } else {
 | 
			
		||||
            document.documentElement.classList.remove('dark')
 | 
			
		||||
            document.documentElement.style.setProperty('color-scheme', 'light')
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        @if(isset($customer_logo))
 | 
			
		||||
 | 
			
		||||
        window.customer_logo = "/storage/{{$customer_logo}}"
 | 
			
		||||
 | 
			
		||||
@ -386,6 +386,10 @@
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
    </style>
 | 
			
		||||
 | 
			
		||||
    @if (App::isLocale('th'))
 | 
			
		||||
        @include('app.pdf.locale.th')
 | 
			
		||||
    @endif
 | 
			
		||||
</head>
 | 
			
		||||
 | 
			
		||||
<body>
 | 
			
		||||
 | 
			
		||||
@ -408,6 +408,10 @@
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
    </style>
 | 
			
		||||
 | 
			
		||||
    @if (App::isLocale('th'))
 | 
			
		||||
        @include('app.pdf.locale.th')
 | 
			
		||||
    @endif
 | 
			
		||||
</head>
 | 
			
		||||
 | 
			
		||||
<body>
 | 
			
		||||
 | 
			
		||||
@ -346,6 +346,10 @@
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
    </style>
 | 
			
		||||
 | 
			
		||||
    @if (App::isLocale('th'))
 | 
			
		||||
        @include('app.pdf.locale.th')
 | 
			
		||||
    @endif
 | 
			
		||||
</head>
 | 
			
		||||
 | 
			
		||||
<body>
 | 
			
		||||
 | 
			
		||||
@ -327,6 +327,10 @@
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
    </style>
 | 
			
		||||
 | 
			
		||||
    @if (App::isLocale('th'))
 | 
			
		||||
        @include('app.pdf.locale.th')
 | 
			
		||||
    @endif
 | 
			
		||||
</head>
 | 
			
		||||
 | 
			
		||||
<body>
 | 
			
		||||
 | 
			
		||||
@ -377,6 +377,10 @@
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
    </style>
 | 
			
		||||
 | 
			
		||||
    @if (App::isLocale('th'))
 | 
			
		||||
        @include('app.pdf.locale.th')
 | 
			
		||||
    @endif
 | 
			
		||||
</head>
 | 
			
		||||
 | 
			
		||||
<body>
 | 
			
		||||
 | 
			
		||||
@ -2,7 +2,7 @@
 | 
			
		||||
<html>
 | 
			
		||||
 | 
			
		||||
<head>
 | 
			
		||||
    <title>@lang('pdf_invoice_label') - {{$invoice->invoice_number}}</title>
 | 
			
		||||
    <title>@lang('pdf_invoice_label') - {{ $invoice->invoice_number }}</title>
 | 
			
		||||
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
 | 
			
		||||
 | 
			
		||||
    <style type="text/css">
 | 
			
		||||
@ -304,7 +304,12 @@
 | 
			
		||||
        .pl-0 {
 | 
			
		||||
            padding-left: 0;
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
    </style>
 | 
			
		||||
 | 
			
		||||
    @if (App::isLocale('th'))
 | 
			
		||||
        @include('app.pdf.locale.th')
 | 
			
		||||
    @endif
 | 
			
		||||
</head>
 | 
			
		||||
 | 
			
		||||
<body>
 | 
			
		||||
@ -312,10 +317,10 @@
 | 
			
		||||
        <table width="100%">
 | 
			
		||||
            <tr>
 | 
			
		||||
                <td width="50%" class="header-section-left">
 | 
			
		||||
                    @if($logo)
 | 
			
		||||
                    @if ($logo)
 | 
			
		||||
                        <img class="header-logo" style="height: 50px;" src="{{ $logo }}" alt="Company Logo">
 | 
			
		||||
                    @else
 | 
			
		||||
                    <h1 class="header-logo"> {{$invoice->customer->company->name}} </h1>
 | 
			
		||||
                        <h1 class="header-logo"> {{ $invoice->customer->company->name }} </h1>
 | 
			
		||||
                    @endif
 | 
			
		||||
                </td>
 | 
			
		||||
                <td width="50%" class="text-right company-address-container company-address">
 | 
			
		||||
@ -331,14 +336,14 @@
 | 
			
		||||
        <div class="main-content">
 | 
			
		||||
            <div class="customer-address-container">
 | 
			
		||||
                <div class="billing-address-container billing-address">
 | 
			
		||||
                    @if($billing_address)
 | 
			
		||||
                    @if ($billing_address)
 | 
			
		||||
                        <b>@lang('pdf_bill_to')</b> <br>
 | 
			
		||||
                        {!! $billing_address !!}
 | 
			
		||||
                    @endif
 | 
			
		||||
                </div>
 | 
			
		||||
 | 
			
		||||
                <div @if($billing_address !== '</br>') class="shipping-address-container shipping-address" @else class="shipping-address-container--left shipping-address" @endif>
 | 
			
		||||
                    @if($shipping_address)
 | 
			
		||||
                <div @if ($billing_address !== '</br>') class="shipping-address-container shipping-address" @else class="shipping-address-container--left shipping-address" @endif>
 | 
			
		||||
                    @if ($shipping_address)
 | 
			
		||||
                        <b>@lang('pdf_ship_to')</b> <br>
 | 
			
		||||
                        {!! $shipping_address !!}
 | 
			
		||||
                    @endif
 | 
			
		||||
@ -350,15 +355,15 @@
 | 
			
		||||
                <table>
 | 
			
		||||
                    <tr>
 | 
			
		||||
                        <td class="attribute-label">@lang('pdf_invoice_number')</td>
 | 
			
		||||
                        <td class="attribute-value">  {{$invoice->invoice_number}}</td>
 | 
			
		||||
                        <td class="attribute-value">  {{ $invoice->invoice_number }}</td>
 | 
			
		||||
                    </tr>
 | 
			
		||||
                    <tr>
 | 
			
		||||
                        <td class="attribute-label">@lang('pdf_invoice_date')</td>
 | 
			
		||||
                        <td class="attribute-value">  {{$invoice->formattedInvoiceDate}}</td>
 | 
			
		||||
                        <td class="attribute-value">  {{ $invoice->formattedInvoiceDate }}</td>
 | 
			
		||||
                    </tr>
 | 
			
		||||
                    <tr>
 | 
			
		||||
                        <td class="attribute-label">@lang('pdf_invoice_due_date')</td>
 | 
			
		||||
                        <td class="attribute-value">  {{$invoice->formattedDueDate}}</td>
 | 
			
		||||
                        <td class="attribute-value">  {{ $invoice->formattedDueDate }}</td>
 | 
			
		||||
                    </tr>
 | 
			
		||||
                </table>
 | 
			
		||||
            </div>
 | 
			
		||||
@ -368,7 +373,7 @@
 | 
			
		||||
        @include('app.pdf.invoice.partials.table')
 | 
			
		||||
 | 
			
		||||
        <div class="notes">
 | 
			
		||||
            @if($notes)
 | 
			
		||||
            @if ($notes)
 | 
			
		||||
                <div class="notes-label">
 | 
			
		||||
                    @lang('pdf_notes')
 | 
			
		||||
                </div>
 | 
			
		||||
 | 
			
		||||
							
								
								
									
										34
									
								
								resources/views/app/pdf/locale/th.blade.php
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										34
									
								
								resources/views/app/pdf/locale/th.blade.php
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,34 @@
 | 
			
		||||
<style type="text/css">
 | 
			
		||||
    @font-face {
 | 
			
		||||
        font-family: 'THSarabunNew';
 | 
			
		||||
        font-style: normal;
 | 
			
		||||
        font-weight: normal;
 | 
			
		||||
        src: url("{{ resource_path('static/fonts/THSarabunNew.ttf') }}") format('truetype');
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    @font-face {
 | 
			
		||||
        font-family: 'THSarabunNew';
 | 
			
		||||
        font-style: normal;
 | 
			
		||||
        font-weight: bold;
 | 
			
		||||
        src: url("{{ resource_path('static/fonts/THSarabunNew-Bold.ttf') }}") format('truetype');
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    @font-face {
 | 
			
		||||
        font-family: 'THSarabunNew';
 | 
			
		||||
        font-style: italic;
 | 
			
		||||
        font-weight: normal;
 | 
			
		||||
        src: url("{{ resource_path('static/fonts/THSarabunNew-Italic.ttf') }}") format('truetype');
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    @font-face {
 | 
			
		||||
        font-family: 'THSarabunNew';
 | 
			
		||||
        font-style: italic;
 | 
			
		||||
        font-weight: bold;
 | 
			
		||||
        src: url("{{ resource_path('static/fonts/THSarabunNew-BoldItalic.ttf') }}") format('truetype');
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    body {
 | 
			
		||||
        font-family: "THSarabunNew", sans-serif !important;
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
</style>
 | 
			
		||||
@ -276,6 +276,10 @@
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
    </style>
 | 
			
		||||
 | 
			
		||||
    @if (App::isLocale('th'))
 | 
			
		||||
        @include('app.pdf.locale.th')
 | 
			
		||||
    @endif
 | 
			
		||||
</head>
 | 
			
		||||
 | 
			
		||||
<body>
 | 
			
		||||
 | 
			
		||||
@ -1,5 +1,6 @@
 | 
			
		||||
<!DOCTYPE html>
 | 
			
		||||
<html lang="en">
 | 
			
		||||
 | 
			
		||||
<head>
 | 
			
		||||
    <title>@lang('pdf_expense_report_label')</title>
 | 
			
		||||
    <style type="text/css">
 | 
			
		||||
@ -11,7 +12,7 @@
 | 
			
		||||
            border-collapse: collapse;
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        .sub-container{
 | 
			
		||||
        .sub-container {
 | 
			
		||||
            padding: 0px 20px;
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
@ -133,7 +134,12 @@
 | 
			
		||||
            color: #5851D8;
 | 
			
		||||
        }
 | 
			
		||||
    </style>
 | 
			
		||||
 | 
			
		||||
    @if (App::isLocale('th'))
 | 
			
		||||
    @include('app.pdf.locale.th')
 | 
			
		||||
    @endif
 | 
			
		||||
</head>
 | 
			
		||||
 | 
			
		||||
<body>
 | 
			
		||||
    <div class="sub-container">
 | 
			
		||||
        <table class="report-header">
 | 
			
		||||
@ -163,7 +169,7 @@
 | 
			
		||||
                    </td>
 | 
			
		||||
                    <td>
 | 
			
		||||
                        <p class="expense-amount">
 | 
			
		||||
                                {!! format_money_pdf($expenseCategory->total_amount) !!}
 | 
			
		||||
                            {!! format_money_pdf($expenseCategory->total_amount, $currency) !!}
 | 
			
		||||
                        </p>
 | 
			
		||||
                    </td>
 | 
			
		||||
                </tr>
 | 
			
		||||
@ -175,7 +181,7 @@
 | 
			
		||||
    <table class="expense-total-table">
 | 
			
		||||
        <tr>
 | 
			
		||||
            <td class="expense-total-cell">
 | 
			
		||||
                <p class="expense-total">{!! format_money_pdf($totalExpense) !!}</p>
 | 
			
		||||
                <p class="expense-total">{!! format_money_pdf($totalExpense, $currency) !!}</p>
 | 
			
		||||
            </td>
 | 
			
		||||
        </tr>
 | 
			
		||||
    </table>
 | 
			
		||||
@ -185,9 +191,10 @@
 | 
			
		||||
                <p class="report-footer-label">@lang('pdf_total_expenses_label')</p>
 | 
			
		||||
            </td>
 | 
			
		||||
            <td>
 | 
			
		||||
                <p class="report-footer-value">{!! format_money_pdf($totalExpense) !!}</p>
 | 
			
		||||
                <p class="report-footer-value">{!! format_money_pdf($totalExpense, $currency) !!}</p>
 | 
			
		||||
            </td>
 | 
			
		||||
        </tr>
 | 
			
		||||
    </table>
 | 
			
		||||
</body>
 | 
			
		||||
 | 
			
		||||
</html>
 | 
			
		||||
@ -1,5 +1,6 @@
 | 
			
		||||
<!DOCTYPE html>
 | 
			
		||||
<html lang="en">
 | 
			
		||||
 | 
			
		||||
<head>
 | 
			
		||||
    <title>@lang('pdf_profit_loss_label')</title>
 | 
			
		||||
    <style type="text/css">
 | 
			
		||||
@ -11,7 +12,7 @@
 | 
			
		||||
            border-collapse: collapse;
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        .sub-container{
 | 
			
		||||
        .sub-container {
 | 
			
		||||
            padding: 0px 20px;
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
@ -158,7 +159,12 @@
 | 
			
		||||
            color: #5851D8;
 | 
			
		||||
        }
 | 
			
		||||
    </style>
 | 
			
		||||
 | 
			
		||||
    @if (App::isLocale('th'))
 | 
			
		||||
    @include('app.pdf.locale.th')
 | 
			
		||||
    @endif
 | 
			
		||||
</head>
 | 
			
		||||
 | 
			
		||||
<body>
 | 
			
		||||
    <div class="sub-container">
 | 
			
		||||
        <table class="report-header">
 | 
			
		||||
@ -183,7 +189,7 @@
 | 
			
		||||
                    <p class="income-title">@lang("pdf_income_label")</p>
 | 
			
		||||
                </td>
 | 
			
		||||
                <td>
 | 
			
		||||
                    <p class="income-amount">{!! format_money_pdf($income) !!}</p>
 | 
			
		||||
                    <p class="income-amount">{!! format_money_pdf($income, $currency) !!}</p>
 | 
			
		||||
                </td>
 | 
			
		||||
            </tr>
 | 
			
		||||
        </table>
 | 
			
		||||
@ -199,7 +205,7 @@
 | 
			
		||||
                    </td>
 | 
			
		||||
                    <td>
 | 
			
		||||
                        <p class="expense-amount">
 | 
			
		||||
                                {!! format_money_pdf($expenseCategory->total_amount) !!}
 | 
			
		||||
                            {!! format_money_pdf($expenseCategory->total_amount, $currency) !!}
 | 
			
		||||
                        </p>
 | 
			
		||||
                    </td>
 | 
			
		||||
                </tr>
 | 
			
		||||
@ -212,7 +218,7 @@
 | 
			
		||||
    <table class="expense-total-indicator-table">
 | 
			
		||||
        <tr>
 | 
			
		||||
            <td class="expense-total-cell">
 | 
			
		||||
                <p class="expense-total">{!! format_money_pdf($totalExpense) !!}</p>
 | 
			
		||||
                <p class="expense-total">{!! format_money_pdf($totalExpense, $currency) !!}</p>
 | 
			
		||||
            </td>
 | 
			
		||||
        </tr>
 | 
			
		||||
    </table>
 | 
			
		||||
@ -222,9 +228,10 @@
 | 
			
		||||
                <p class="report-footer-label">@lang("pdf_net_profit_label")</p>
 | 
			
		||||
            </td>
 | 
			
		||||
            <td>
 | 
			
		||||
                <p class="report-footer-value">{!! format_money_pdf(($income-$totalExpense)) !!}</p>
 | 
			
		||||
                <p class="report-footer-value">{!! format_money_pdf($income - $totalExpense, $currency) !!}</p>
 | 
			
		||||
            </td>
 | 
			
		||||
        </tr>
 | 
			
		||||
    </table>
 | 
			
		||||
</body>
 | 
			
		||||
 | 
			
		||||
</html>
 | 
			
		||||
@ -1,5 +1,6 @@
 | 
			
		||||
<!DOCTYPE html>
 | 
			
		||||
<html lang="en">
 | 
			
		||||
 | 
			
		||||
<head>
 | 
			
		||||
    <title>@lang('pdf_sales_customers_label')</title>
 | 
			
		||||
    <style type="text/css">
 | 
			
		||||
@ -11,7 +12,7 @@
 | 
			
		||||
            border-collapse: collapse;
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        .sub-container{
 | 
			
		||||
        .sub-container {
 | 
			
		||||
            padding: 0px 20px;
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
@ -132,11 +133,17 @@
 | 
			
		||||
            line-height: 21px;
 | 
			
		||||
            color: #5851D8;
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        .text-center {
 | 
			
		||||
            text-align: center;
 | 
			
		||||
        }
 | 
			
		||||
    </style>
 | 
			
		||||
 | 
			
		||||
    @if (App::isLocale('th'))
 | 
			
		||||
    @include('app.pdf.locale.th')
 | 
			
		||||
    @endif
 | 
			
		||||
</head>
 | 
			
		||||
 | 
			
		||||
<body>
 | 
			
		||||
    <div class="sub-container">
 | 
			
		||||
        <table class="report-header">
 | 
			
		||||
@ -168,7 +175,7 @@
 | 
			
		||||
                    </td>
 | 
			
		||||
                    <td>
 | 
			
		||||
                        <p class="sales-amount">
 | 
			
		||||
                                    {!! format_money_pdf($invoice->base_total) !!}
 | 
			
		||||
                            {!! format_money_pdf($invoice->base_total, $currency) !!}
 | 
			
		||||
                        </p>
 | 
			
		||||
                    </td>
 | 
			
		||||
                </tr>
 | 
			
		||||
@ -179,7 +186,7 @@
 | 
			
		||||
            <tr>
 | 
			
		||||
                <td class="sales-total-cell">
 | 
			
		||||
                    <p class="sales-total-amount">
 | 
			
		||||
                            {!! format_money_pdf($customer->totalAmount) !!}
 | 
			
		||||
                        {!! format_money_pdf($customer->totalAmount, $currency) !!}
 | 
			
		||||
                    </p>
 | 
			
		||||
                </td>
 | 
			
		||||
            </tr>
 | 
			
		||||
@ -195,10 +202,11 @@
 | 
			
		||||
            </td>
 | 
			
		||||
            <td>
 | 
			
		||||
                <p class="report-footer-value">
 | 
			
		||||
                    {!! format_money_pdf($totalAmount) !!}
 | 
			
		||||
                    {!! format_money_pdf($totalAmount, $currency) !!}
 | 
			
		||||
                </p>
 | 
			
		||||
            </td>
 | 
			
		||||
        </tr>
 | 
			
		||||
    </table>
 | 
			
		||||
</body>
 | 
			
		||||
 | 
			
		||||
</html>
 | 
			
		||||
@ -1,5 +1,6 @@
 | 
			
		||||
<!DOCTYPE html>
 | 
			
		||||
<html lang="en">
 | 
			
		||||
 | 
			
		||||
<head>
 | 
			
		||||
    <title>@lang('pdf_sales_items_label')</title>
 | 
			
		||||
    <style type="text/css">
 | 
			
		||||
@ -11,7 +12,7 @@
 | 
			
		||||
            border-collapse: collapse;
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        .sub-container{
 | 
			
		||||
        .sub-container {
 | 
			
		||||
            padding: 0px 20px;
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
@ -132,11 +133,17 @@
 | 
			
		||||
            line-height: 21px;
 | 
			
		||||
            color: #5851D8;
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        .text-center {
 | 
			
		||||
            text-align: center;
 | 
			
		||||
        }
 | 
			
		||||
    </style>
 | 
			
		||||
 | 
			
		||||
    @if (App::isLocale('th'))
 | 
			
		||||
    @include('app.pdf.locale.th')
 | 
			
		||||
    @endif
 | 
			
		||||
</head>
 | 
			
		||||
 | 
			
		||||
<body>
 | 
			
		||||
    <div class="sub-container">
 | 
			
		||||
        <table class="report-header">
 | 
			
		||||
@ -167,7 +174,7 @@
 | 
			
		||||
                    </td>
 | 
			
		||||
                    <td>
 | 
			
		||||
                        <p class="item-sales-amount">
 | 
			
		||||
                                {!! format_money_pdf($item->total_amount) !!}
 | 
			
		||||
                            {!! format_money_pdf($item->total_amount, $currency) !!}
 | 
			
		||||
                        </p>
 | 
			
		||||
                    </td>
 | 
			
		||||
                </tr>
 | 
			
		||||
@ -179,7 +186,7 @@
 | 
			
		||||
            <tr>
 | 
			
		||||
                <td class="sales-total-cell">
 | 
			
		||||
                    <p class="sales-total-amount">
 | 
			
		||||
                            {!! format_money_pdf($totalAmount) !!}
 | 
			
		||||
                        {!! format_money_pdf($totalAmount, $currency) !!}
 | 
			
		||||
                    </p>
 | 
			
		||||
                </td>
 | 
			
		||||
            </tr>
 | 
			
		||||
@ -194,10 +201,11 @@
 | 
			
		||||
            </td>
 | 
			
		||||
            <td>
 | 
			
		||||
                <p class="report-footer-value">
 | 
			
		||||
                    {!! format_money_pdf($totalAmount) !!}
 | 
			
		||||
                    {!! format_money_pdf($totalAmount, $currency) !!}
 | 
			
		||||
                </p>
 | 
			
		||||
            </td>
 | 
			
		||||
        </tr>
 | 
			
		||||
    </table>
 | 
			
		||||
</body>
 | 
			
		||||
 | 
			
		||||
</html>
 | 
			
		||||
@ -1,5 +1,6 @@
 | 
			
		||||
<!DOCTYPE html>
 | 
			
		||||
<html lang="en">
 | 
			
		||||
 | 
			
		||||
<head>
 | 
			
		||||
    <title>@lang('pdf_tax_summery_label')</title>
 | 
			
		||||
    <style type="text/css">
 | 
			
		||||
@ -11,7 +12,7 @@
 | 
			
		||||
            border-collapse: collapse;
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
        .sub-container{
 | 
			
		||||
        .sub-container {
 | 
			
		||||
            padding: 0px 20px;
 | 
			
		||||
        }
 | 
			
		||||
 | 
			
		||||
@ -134,7 +135,12 @@
 | 
			
		||||
            color: #5851D8;
 | 
			
		||||
        }
 | 
			
		||||
    </style>
 | 
			
		||||
 | 
			
		||||
    @if (App::isLocale('th'))
 | 
			
		||||
    @include('app.pdf.locale.th')
 | 
			
		||||
    @endif
 | 
			
		||||
</head>
 | 
			
		||||
 | 
			
		||||
<body>
 | 
			
		||||
    <div class="sub-container">
 | 
			
		||||
        <table class="report-header">
 | 
			
		||||
@ -168,7 +174,7 @@
 | 
			
		||||
                    </td>
 | 
			
		||||
                    <td>
 | 
			
		||||
                        <p class="tax-amount">
 | 
			
		||||
                                {!! format_money_pdf($tax->total_tax_amount) !!}
 | 
			
		||||
                            {!! format_money_pdf($tax->total_tax_amount, $currency) !!}
 | 
			
		||||
                        </p>
 | 
			
		||||
                    </td>
 | 
			
		||||
                </tr>
 | 
			
		||||
@ -182,7 +188,7 @@
 | 
			
		||||
        <tr>
 | 
			
		||||
            <td class="tax-total-cell">
 | 
			
		||||
                <p class="tax-total">
 | 
			
		||||
                    {!! format_money_pdf($totalTaxAmount) !!}
 | 
			
		||||
                    {!! format_money_pdf($totalTaxAmount, $currency) !!}
 | 
			
		||||
                </p>
 | 
			
		||||
            </td>
 | 
			
		||||
        </tr>
 | 
			
		||||
@ -194,10 +200,11 @@
 | 
			
		||||
            </td>
 | 
			
		||||
            <td>
 | 
			
		||||
                <p class="report-footer-value">
 | 
			
		||||
                    {!! format_money_pdf($totalTaxAmount) !!}
 | 
			
		||||
                    {!! format_money_pdf($totalTaxAmount, $currency) !!}
 | 
			
		||||
                </p>
 | 
			
		||||
            </td>
 | 
			
		||||
        </tr>
 | 
			
		||||
    </table>
 | 
			
		||||
</body>
 | 
			
		||||
 | 
			
		||||
</html>
 | 
			
		||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user