mirror of
				https://github.com/crater-invoice/crater.git
				synced 2025-11-03 22:13:18 -05:00 
			
		
		
		
	Compare commits
	
		
			1 Commits
		
	
	
		
			tax-calcul
			...
			dependabot
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 59f433dd00 | 
							
								
								
									
										161
									
								
								.github/workflows/uffizzi-build.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										161
									
								
								.github/workflows/uffizzi-build.yml
									
									
									
									
										vendored
									
									
								
							@ -1,161 +0,0 @@
 | 
				
			|||||||
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: 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
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  build-nginx:
 | 
					 | 
				
			||||||
    needs: 
 | 
					 | 
				
			||||||
      - build-application
 | 
					 | 
				
			||||||
    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
 | 
					 | 
				
			||||||
          build-args: |
 | 
					 | 
				
			||||||
            BASE_IMAGE=${{ needs.build-application.outputs.tags }}
 | 
					 | 
				
			||||||
          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
									
									
								
							
							
						
						
									
										84
									
								
								.github/workflows/uffizzi-preview.yml
									
									
									
									
										vendored
									
									
								
							@ -1,84 +0,0 @@
 | 
				
			|||||||
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
									
									
								
							@ -17,4 +17,3 @@ Homestead.yaml
 | 
				
			|||||||
/public/docs
 | 
					/public/docs
 | 
				
			||||||
/.scribe
 | 
					/.scribe
 | 
				
			||||||
!storage/fonts/.gitkeep
 | 
					!storage/fonts/.gitkeep
 | 
				
			||||||
.DS_Store
 | 
					 | 
				
			||||||
 | 
				
			|||||||
@ -1,4 +1,4 @@
 | 
				
			|||||||
FROM php:8.1-fpm
 | 
					FROM php:7.4-fpm
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# Arguments defined in docker-compose.yml
 | 
					# Arguments defined in docker-compose.yml
 | 
				
			||||||
ARG user
 | 
					ARG user
 | 
				
			||||||
 | 
				
			|||||||
@ -55,7 +55,7 @@ class CreateTemplateCommand extends Command
 | 
				
			|||||||
        copy(public_path("/build/img/PDF/{$type}1.png"), public_path("/build/img/PDF/{$templateName}.png"));
 | 
					        copy(public_path("/build/img/PDF/{$type}1.png"), public_path("/build/img/PDF/{$templateName}.png"));
 | 
				
			||||||
        copy(resource_path("/static/img/PDF/{$type}1.png"), resource_path("/static/img/PDF/{$templateName}.png"));
 | 
					        copy(resource_path("/static/img/PDF/{$type}1.png"), resource_path("/static/img/PDF/{$templateName}.png"));
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        $path = resource_path("views/app/pdf/{$type}/{$templateName}.blade.php");
 | 
					        $path = resource_path("app/pdf/{$type}/{$templateName}.blade.php");
 | 
				
			||||||
        $type = ucfirst($type);
 | 
					        $type = ucfirst($type);
 | 
				
			||||||
        $this->info("{$type} Template created successfully at ".$path);
 | 
					        $this->info("{$type} Template created successfully at ".$path);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
				
			|||||||
@ -2,15 +2,14 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
namespace Crater\Http\Controllers\V1\Admin\Report;
 | 
					namespace Crater\Http\Controllers\V1\Admin\Report;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
use PDF;
 | 
					 | 
				
			||||||
use Carbon\Carbon;
 | 
					use Carbon\Carbon;
 | 
				
			||||||
 | 
					use Crater\Http\Controllers\Controller;
 | 
				
			||||||
use Crater\Models\Company;
 | 
					use Crater\Models\Company;
 | 
				
			||||||
use Crater\Models\Currency;
 | 
					use Crater\Models\CompanySetting;
 | 
				
			||||||
use Crater\Models\Customer;
 | 
					use Crater\Models\Customer;
 | 
				
			||||||
use Illuminate\Http\Request;
 | 
					use Illuminate\Http\Request;
 | 
				
			||||||
use Crater\Models\CompanySetting;
 | 
					 | 
				
			||||||
use Illuminate\Support\Facades\App;
 | 
					use Illuminate\Support\Facades\App;
 | 
				
			||||||
use Crater\Http\Controllers\Controller;
 | 
					use PDF;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
class CustomerSalesReportController extends Controller
 | 
					class CustomerSalesReportController extends Controller
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
@ -57,7 +56,6 @@ class CustomerSalesReportController extends Controller
 | 
				
			|||||||
        $dateFormat = CompanySetting::getSetting('carbon_date_format', $company->id);
 | 
					        $dateFormat = CompanySetting::getSetting('carbon_date_format', $company->id);
 | 
				
			||||||
        $from_date = Carbon::createFromFormat('Y-m-d', $request->from_date)->format($dateFormat);
 | 
					        $from_date = Carbon::createFromFormat('Y-m-d', $request->from_date)->format($dateFormat);
 | 
				
			||||||
        $to_date = Carbon::createFromFormat('Y-m-d', $request->to_date)->format($dateFormat);
 | 
					        $to_date = Carbon::createFromFormat('Y-m-d', $request->to_date)->format($dateFormat);
 | 
				
			||||||
        $currency = Currency::findOrFail(CompanySetting::getSetting('currency', $company->id));
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
        $colors = [
 | 
					        $colors = [
 | 
				
			||||||
            'primary_text_color',
 | 
					            'primary_text_color',
 | 
				
			||||||
@ -82,7 +80,6 @@ class CustomerSalesReportController extends Controller
 | 
				
			|||||||
            'company' => $company,
 | 
					            'company' => $company,
 | 
				
			||||||
            'from_date' => $from_date,
 | 
					            'from_date' => $from_date,
 | 
				
			||||||
            'to_date' => $to_date,
 | 
					            'to_date' => $to_date,
 | 
				
			||||||
            'currency' => $currency,
 | 
					 | 
				
			||||||
        ]);
 | 
					        ]);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        $pdf = PDF::loadView('app.pdf.reports.sales-customers');
 | 
					        $pdf = PDF::loadView('app.pdf.reports.sales-customers');
 | 
				
			||||||
 | 
				
			|||||||
@ -2,15 +2,14 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
namespace Crater\Http\Controllers\V1\Admin\Report;
 | 
					namespace Crater\Http\Controllers\V1\Admin\Report;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
use PDF;
 | 
					 | 
				
			||||||
use Carbon\Carbon;
 | 
					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;
 | 
					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;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
class ExpensesReportController extends Controller
 | 
					class ExpensesReportController extends Controller
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
@ -44,7 +43,6 @@ class ExpensesReportController extends Controller
 | 
				
			|||||||
        $dateFormat = CompanySetting::getSetting('carbon_date_format', $company->id);
 | 
					        $dateFormat = CompanySetting::getSetting('carbon_date_format', $company->id);
 | 
				
			||||||
        $from_date = Carbon::createFromFormat('Y-m-d', $request->from_date)->format($dateFormat);
 | 
					        $from_date = Carbon::createFromFormat('Y-m-d', $request->from_date)->format($dateFormat);
 | 
				
			||||||
        $to_date = Carbon::createFromFormat('Y-m-d', $request->to_date)->format($dateFormat);
 | 
					        $to_date = Carbon::createFromFormat('Y-m-d', $request->to_date)->format($dateFormat);
 | 
				
			||||||
        $currency = Currency::findOrFail(CompanySetting::getSetting('currency', $company->id));
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
        $colors = [
 | 
					        $colors = [
 | 
				
			||||||
            'primary_text_color',
 | 
					            'primary_text_color',
 | 
				
			||||||
@ -68,7 +66,6 @@ class ExpensesReportController extends Controller
 | 
				
			|||||||
            'company' => $company,
 | 
					            'company' => $company,
 | 
				
			||||||
            'from_date' => $from_date,
 | 
					            'from_date' => $from_date,
 | 
				
			||||||
            'to_date' => $to_date,
 | 
					            'to_date' => $to_date,
 | 
				
			||||||
            'currency' => $currency,
 | 
					 | 
				
			||||||
        ]);
 | 
					        ]);
 | 
				
			||||||
        $pdf = PDF::loadView('app.pdf.reports.expenses');
 | 
					        $pdf = PDF::loadView('app.pdf.reports.expenses');
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
				
			|||||||
@ -2,15 +2,14 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
namespace Crater\Http\Controllers\V1\Admin\Report;
 | 
					namespace Crater\Http\Controllers\V1\Admin\Report;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
use PDF;
 | 
					 | 
				
			||||||
use Carbon\Carbon;
 | 
					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;
 | 
					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;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
class ItemSalesReportController extends Controller
 | 
					class ItemSalesReportController extends Controller
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
@ -44,7 +43,6 @@ class ItemSalesReportController extends Controller
 | 
				
			|||||||
        $dateFormat = CompanySetting::getSetting('carbon_date_format', $company->id);
 | 
					        $dateFormat = CompanySetting::getSetting('carbon_date_format', $company->id);
 | 
				
			||||||
        $from_date = Carbon::createFromFormat('Y-m-d', $request->from_date)->format($dateFormat);
 | 
					        $from_date = Carbon::createFromFormat('Y-m-d', $request->from_date)->format($dateFormat);
 | 
				
			||||||
        $to_date = Carbon::createFromFormat('Y-m-d', $request->to_date)->format($dateFormat);
 | 
					        $to_date = Carbon::createFromFormat('Y-m-d', $request->to_date)->format($dateFormat);
 | 
				
			||||||
        $currency = Currency::findOrFail(CompanySetting::getSetting('currency', $company->id));
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
        $colors = [
 | 
					        $colors = [
 | 
				
			||||||
            'primary_text_color',
 | 
					            'primary_text_color',
 | 
				
			||||||
@ -68,7 +66,6 @@ class ItemSalesReportController extends Controller
 | 
				
			|||||||
            'company' => $company,
 | 
					            'company' => $company,
 | 
				
			||||||
            'from_date' => $from_date,
 | 
					            'from_date' => $from_date,
 | 
				
			||||||
            'to_date' => $to_date,
 | 
					            'to_date' => $to_date,
 | 
				
			||||||
            'currency' => $currency,
 | 
					 | 
				
			||||||
        ]);
 | 
					        ]);
 | 
				
			||||||
        $pdf = PDF::loadView('app.pdf.reports.sales-items');
 | 
					        $pdf = PDF::loadView('app.pdf.reports.sales-items');
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
				
			|||||||
@ -2,16 +2,15 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
namespace Crater\Http\Controllers\V1\Admin\Report;
 | 
					namespace Crater\Http\Controllers\V1\Admin\Report;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
use PDF;
 | 
					 | 
				
			||||||
use Carbon\Carbon;
 | 
					use Carbon\Carbon;
 | 
				
			||||||
 | 
					use Crater\Http\Controllers\Controller;
 | 
				
			||||||
use Crater\Models\Company;
 | 
					use Crater\Models\Company;
 | 
				
			||||||
 | 
					use Crater\Models\CompanySetting;
 | 
				
			||||||
use Crater\Models\Expense;
 | 
					use Crater\Models\Expense;
 | 
				
			||||||
use Crater\Models\Payment;
 | 
					use Crater\Models\Payment;
 | 
				
			||||||
use Crater\Models\Currency;
 | 
					 | 
				
			||||||
use Illuminate\Http\Request;
 | 
					use Illuminate\Http\Request;
 | 
				
			||||||
use Crater\Models\CompanySetting;
 | 
					 | 
				
			||||||
use Illuminate\Support\Facades\App;
 | 
					use Illuminate\Support\Facades\App;
 | 
				
			||||||
use Crater\Http\Controllers\Controller;
 | 
					use PDF;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
class ProfitLossReportController extends Controller
 | 
					class ProfitLossReportController extends Controller
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
@ -50,8 +49,6 @@ class ProfitLossReportController extends Controller
 | 
				
			|||||||
        $dateFormat = CompanySetting::getSetting('carbon_date_format', $company->id);
 | 
					        $dateFormat = CompanySetting::getSetting('carbon_date_format', $company->id);
 | 
				
			||||||
        $from_date = Carbon::createFromFormat('Y-m-d', $request->from_date)->format($dateFormat);
 | 
					        $from_date = Carbon::createFromFormat('Y-m-d', $request->from_date)->format($dateFormat);
 | 
				
			||||||
        $to_date = Carbon::createFromFormat('Y-m-d', $request->to_date)->format($dateFormat);
 | 
					        $to_date = Carbon::createFromFormat('Y-m-d', $request->to_date)->format($dateFormat);
 | 
				
			||||||
        $currency = Currency::findOrFail(CompanySetting::getSetting('currency', $company->id));
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
        $colors = [
 | 
					        $colors = [
 | 
				
			||||||
            'primary_text_color',
 | 
					            'primary_text_color',
 | 
				
			||||||
@ -77,7 +74,6 @@ class ProfitLossReportController extends Controller
 | 
				
			|||||||
            'company' => $company,
 | 
					            'company' => $company,
 | 
				
			||||||
            'from_date' => $from_date,
 | 
					            'from_date' => $from_date,
 | 
				
			||||||
            'to_date' => $to_date,
 | 
					            'to_date' => $to_date,
 | 
				
			||||||
            'currency' => $currency,
 | 
					 | 
				
			||||||
        ]);
 | 
					        ]);
 | 
				
			||||||
        $pdf = PDF::loadView('app.pdf.reports.profit-loss');
 | 
					        $pdf = PDF::loadView('app.pdf.reports.profit-loss');
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
				
			|||||||
@ -2,15 +2,14 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
namespace Crater\Http\Controllers\V1\Admin\Report;
 | 
					namespace Crater\Http\Controllers\V1\Admin\Report;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
use PDF;
 | 
					 | 
				
			||||||
use Carbon\Carbon;
 | 
					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;
 | 
					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;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
class TaxSummaryReportController extends Controller
 | 
					class TaxSummaryReportController extends Controller
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
@ -45,8 +44,6 @@ class TaxSummaryReportController extends Controller
 | 
				
			|||||||
        $dateFormat = CompanySetting::getSetting('carbon_date_format', $company->id);
 | 
					        $dateFormat = CompanySetting::getSetting('carbon_date_format', $company->id);
 | 
				
			||||||
        $from_date = Carbon::createFromFormat('Y-m-d', $request->from_date)->format($dateFormat);
 | 
					        $from_date = Carbon::createFromFormat('Y-m-d', $request->from_date)->format($dateFormat);
 | 
				
			||||||
        $to_date = Carbon::createFromFormat('Y-m-d', $request->to_date)->format($dateFormat);
 | 
					        $to_date = Carbon::createFromFormat('Y-m-d', $request->to_date)->format($dateFormat);
 | 
				
			||||||
        $currency = Currency::findOrFail(CompanySetting::getSetting('currency', $company->id));
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
        $colors = [
 | 
					        $colors = [
 | 
				
			||||||
            'primary_text_color',
 | 
					            'primary_text_color',
 | 
				
			||||||
@ -71,7 +68,6 @@ class TaxSummaryReportController extends Controller
 | 
				
			|||||||
            'company' => $company,
 | 
					            'company' => $company,
 | 
				
			||||||
            'from_date' => $from_date,
 | 
					            'from_date' => $from_date,
 | 
				
			||||||
            'to_date' => $to_date,
 | 
					            'to_date' => $to_date,
 | 
				
			||||||
            'currency' => $currency,
 | 
					 | 
				
			||||||
        ]);
 | 
					        ]);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        $pdf = PDF::loadView('app.pdf.reports.tax-summary');
 | 
					        $pdf = PDF::loadView('app.pdf.reports.tax-summary');
 | 
				
			||||||
 | 
				
			|||||||
@ -45,21 +45,15 @@ class EstimatesRequest extends FormRequest
 | 
				
			|||||||
                'nullable'
 | 
					                'nullable'
 | 
				
			||||||
            ],
 | 
					            ],
 | 
				
			||||||
            'discount' => [
 | 
					            'discount' => [
 | 
				
			||||||
                'numeric',
 | 
					 | 
				
			||||||
                'required',
 | 
					                'required',
 | 
				
			||||||
            ],
 | 
					            ],
 | 
				
			||||||
            'discount_val' => [
 | 
					            'discount_val' => [
 | 
				
			||||||
                'integer',
 | 
					 | 
				
			||||||
                'required',
 | 
					                'required',
 | 
				
			||||||
            ],
 | 
					            ],
 | 
				
			||||||
            'sub_total' => [
 | 
					            'sub_total' => [
 | 
				
			||||||
                'integer',
 | 
					 | 
				
			||||||
                'required',
 | 
					                'required',
 | 
				
			||||||
            ],
 | 
					            ],
 | 
				
			||||||
            'total' => [
 | 
					            'total' => [
 | 
				
			||||||
                'integer',
 | 
					 | 
				
			||||||
                'numeric',
 | 
					 | 
				
			||||||
                'max:99999999',
 | 
					 | 
				
			||||||
                'required',
 | 
					                'required',
 | 
				
			||||||
            ],
 | 
					            ],
 | 
				
			||||||
            'tax' => [
 | 
					            'tax' => [
 | 
				
			||||||
@ -83,11 +77,9 @@ class EstimatesRequest extends FormRequest
 | 
				
			|||||||
                'required',
 | 
					                'required',
 | 
				
			||||||
            ],
 | 
					            ],
 | 
				
			||||||
            'items.*.quantity' => [
 | 
					            'items.*.quantity' => [
 | 
				
			||||||
                'integer',
 | 
					 | 
				
			||||||
                'required',
 | 
					                'required',
 | 
				
			||||||
            ],
 | 
					            ],
 | 
				
			||||||
            'items.*.price' => [
 | 
					            'items.*.price' => [
 | 
				
			||||||
                'integer',
 | 
					 | 
				
			||||||
                'required',
 | 
					                'required',
 | 
				
			||||||
            ],
 | 
					            ],
 | 
				
			||||||
        ];
 | 
					        ];
 | 
				
			||||||
 | 
				
			|||||||
@ -45,21 +45,15 @@ class InvoicesRequest extends FormRequest
 | 
				
			|||||||
                'nullable'
 | 
					                'nullable'
 | 
				
			||||||
            ],
 | 
					            ],
 | 
				
			||||||
            'discount' => [
 | 
					            'discount' => [
 | 
				
			||||||
                'numeric',
 | 
					 | 
				
			||||||
                'required',
 | 
					                'required',
 | 
				
			||||||
            ],
 | 
					            ],
 | 
				
			||||||
            'discount_val' => [
 | 
					            'discount_val' => [
 | 
				
			||||||
                'integer',
 | 
					 | 
				
			||||||
                'required',
 | 
					                'required',
 | 
				
			||||||
            ],
 | 
					            ],
 | 
				
			||||||
            'sub_total' => [
 | 
					            'sub_total' => [
 | 
				
			||||||
                'integer',
 | 
					 | 
				
			||||||
                'required',
 | 
					                'required',
 | 
				
			||||||
            ],
 | 
					            ],
 | 
				
			||||||
            'total' => [
 | 
					            'total' => [
 | 
				
			||||||
                'integer',
 | 
					 | 
				
			||||||
                'numeric',
 | 
					 | 
				
			||||||
                'max:99999999',
 | 
					 | 
				
			||||||
                'required',
 | 
					                'required',
 | 
				
			||||||
            ],
 | 
					            ],
 | 
				
			||||||
            'tax' => [
 | 
					            'tax' => [
 | 
				
			||||||
@ -83,11 +77,9 @@ class InvoicesRequest extends FormRequest
 | 
				
			|||||||
                'required',
 | 
					                'required',
 | 
				
			||||||
            ],
 | 
					            ],
 | 
				
			||||||
            'items.*.quantity' => [
 | 
					            'items.*.quantity' => [
 | 
				
			||||||
                'integer',
 | 
					 | 
				
			||||||
                'required',
 | 
					                'required',
 | 
				
			||||||
            ],
 | 
					            ],
 | 
				
			||||||
            'items.*.price' => [
 | 
					            'items.*.price' => [
 | 
				
			||||||
                'integer',
 | 
					 | 
				
			||||||
                'required',
 | 
					                'required',
 | 
				
			||||||
            ],
 | 
					            ],
 | 
				
			||||||
        ];
 | 
					        ];
 | 
				
			||||||
 | 
				
			|||||||
@ -43,21 +43,15 @@ class RecurringInvoiceRequest extends FormRequest
 | 
				
			|||||||
                'nullable'
 | 
					                'nullable'
 | 
				
			||||||
            ],
 | 
					            ],
 | 
				
			||||||
            'discount' => [
 | 
					            'discount' => [
 | 
				
			||||||
                'numeric',
 | 
					 | 
				
			||||||
                'required',
 | 
					                'required',
 | 
				
			||||||
            ],
 | 
					            ],
 | 
				
			||||||
            'discount_val' => [
 | 
					            'discount_val' => [
 | 
				
			||||||
                'integer',
 | 
					 | 
				
			||||||
                'required',
 | 
					                'required',
 | 
				
			||||||
            ],
 | 
					            ],
 | 
				
			||||||
            'sub_total' => [
 | 
					            'sub_total' => [
 | 
				
			||||||
                'integer',
 | 
					 | 
				
			||||||
                'required',
 | 
					                'required',
 | 
				
			||||||
            ],
 | 
					            ],
 | 
				
			||||||
            'total' => [
 | 
					            'total' => [
 | 
				
			||||||
                'integer',
 | 
					 | 
				
			||||||
                'numeric',
 | 
					 | 
				
			||||||
                'max:99999999',
 | 
					 | 
				
			||||||
                'required',
 | 
					                'required',
 | 
				
			||||||
            ],
 | 
					            ],
 | 
				
			||||||
            'tax' => [
 | 
					            'tax' => [
 | 
				
			||||||
 | 
				
			|||||||
@ -38,7 +38,7 @@
 | 
				
			|||||||
    "barryvdh/laravel-ide-helper": "^2.6",
 | 
					    "barryvdh/laravel-ide-helper": "^2.6",
 | 
				
			||||||
    "beyondcode/laravel-dump-server": "^1.0",
 | 
					    "beyondcode/laravel-dump-server": "^1.0",
 | 
				
			||||||
    "facade/ignition": "^2.3.6",
 | 
					    "facade/ignition": "^2.3.6",
 | 
				
			||||||
    "friendsofphp/php-cs-fixer": "^3.8",
 | 
					    "friendsofphp/php-cs-fixer": "^3.0",
 | 
				
			||||||
    "fakerphp/faker": "^1.9.1",
 | 
					    "fakerphp/faker": "^1.9.1",
 | 
				
			||||||
    "mockery/mockery": "^1.3.1",
 | 
					    "mockery/mockery": "^1.3.1",
 | 
				
			||||||
    "nunomaduro/collision": "^5.0",
 | 
					    "nunomaduro/collision": "^5.0",
 | 
				
			||||||
@ -81,10 +81,7 @@
 | 
				
			|||||||
  "config": {
 | 
					  "config": {
 | 
				
			||||||
    "optimize-autoloader": true,
 | 
					    "optimize-autoloader": true,
 | 
				
			||||||
    "preferred-install": "dist",
 | 
					    "preferred-install": "dist",
 | 
				
			||||||
    "sort-packages": true,
 | 
					    "sort-packages": true
 | 
				
			||||||
    "allow-plugins": {
 | 
					 | 
				
			||||||
      "pestphp/pest-plugin": true
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
  "extra": {
 | 
					  "extra": {
 | 
				
			||||||
    "laravel": {
 | 
					    "laravel": {
 | 
				
			||||||
 | 
				
			|||||||
							
								
								
									
										2345
									
								
								composer.lock
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										2345
									
								
								composer.lock
									
									
									
										generated
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							@ -27,7 +27,6 @@ return [
 | 
				
			|||||||
            'tokenizer',
 | 
					            'tokenizer',
 | 
				
			||||||
            'JSON',
 | 
					            'JSON',
 | 
				
			||||||
            'cURL',
 | 
					            'cURL',
 | 
				
			||||||
            'zip',
 | 
					 | 
				
			||||||
        ],
 | 
					        ],
 | 
				
			||||||
        'apache' => [
 | 
					        'apache' => [
 | 
				
			||||||
            'mod_rewrite',
 | 
					            'mod_rewrite',
 | 
				
			||||||
 | 
				
			|||||||
							
								
								
									
										483
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										483
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							@ -65,6 +65,13 @@
 | 
				
			|||||||
        "to-fast-properties": "^2.0.0"
 | 
					        "to-fast-properties": "^2.0.0"
 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
 | 
					    "@esbuild/linux-loong64": {
 | 
				
			||||||
 | 
					      "version": "0.14.54",
 | 
				
			||||||
 | 
					      "resolved": "https://registry.npmjs.org/@esbuild/linux-loong64/-/linux-loong64-0.14.54.tgz",
 | 
				
			||||||
 | 
					      "integrity": "sha512-bZBrLAIX1kpWelV0XemxBZllyRmM6vgFQQG2GdNb+r3Fkp0FOh1NJSvekXDs7jq70k4euu1cryLMfU+mTXlEpw==",
 | 
				
			||||||
 | 
					      "dev": true,
 | 
				
			||||||
 | 
					      "optional": true
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
    "@eslint/eslintrc": {
 | 
					    "@eslint/eslintrc": {
 | 
				
			||||||
      "version": "0.4.3",
 | 
					      "version": "0.4.3",
 | 
				
			||||||
      "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-0.4.3.tgz",
 | 
					      "resolved": "https://registry.npmjs.org/@eslint/eslintrc/-/eslintrc-0.4.3.tgz",
 | 
				
			||||||
@ -214,6 +221,23 @@
 | 
				
			|||||||
      "resolved": "https://registry.npmjs.org/@popperjs/core/-/core-2.9.3.tgz",
 | 
					      "resolved": "https://registry.npmjs.org/@popperjs/core/-/core-2.9.3.tgz",
 | 
				
			||||||
      "integrity": "sha512-xDu17cEfh7Kid/d95kB6tZsLOmSWKCZKtprnhVepjsSaCij+lM3mItSJDuuHDMbCWTh8Ejmebwb+KONcCJ0eXQ=="
 | 
					      "integrity": "sha512-xDu17cEfh7Kid/d95kB6tZsLOmSWKCZKtprnhVepjsSaCij+lM3mItSJDuuHDMbCWTh8Ejmebwb+KONcCJ0eXQ=="
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
 | 
					    "@rvxlab/tailwind-plugin-ios-full-height": {
 | 
				
			||||||
 | 
					      "version": "1.1.0",
 | 
				
			||||||
 | 
					      "resolved": "https://registry.npmjs.org/@rvxlab/tailwind-plugin-ios-full-height/-/tailwind-plugin-ios-full-height-1.1.0.tgz",
 | 
				
			||||||
 | 
					      "integrity": "sha512-jPIxXn0raN/YTk8nXesqM+JbS2WWd5XaUk/MbaAgVDDPyYtsPfeN3B26xIhSa2oE2+JB66tegPUMSOmixzroXg==",
 | 
				
			||||||
 | 
					      "dev": true
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    "@stripe/stripe-js": {
 | 
				
			||||||
 | 
					      "version": "1.35.0",
 | 
				
			||||||
 | 
					      "resolved": "https://registry.npmjs.org/@stripe/stripe-js/-/stripe-js-1.35.0.tgz",
 | 
				
			||||||
 | 
					      "integrity": "sha512-UIuzpbJqgXCTvJhY/aZYvBtaKdMfQgnIv6kkLlfRJ9smZcC4zoPvq3j7k9wobYI+idHAWP4BRiPnqA8lvzJCtg=="
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    "@tailwindcss/aspect-ratio": {
 | 
				
			||||||
 | 
					      "version": "0.4.0",
 | 
				
			||||||
 | 
					      "resolved": "https://registry.npmjs.org/@tailwindcss/aspect-ratio/-/aspect-ratio-0.4.0.tgz",
 | 
				
			||||||
 | 
					      "integrity": "sha512-WJu0I4PpqNPuutpaA9zDUq2JXR+lorZ7PbLcKNLmb6GL9/HLfC7w3CRsMhJF4BbYd/lkY6CfXOvkYpuGnZfkpQ==",
 | 
				
			||||||
 | 
					      "dev": true
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
    "@tailwindcss/forms": {
 | 
					    "@tailwindcss/forms": {
 | 
				
			||||||
      "version": "0.4.0",
 | 
					      "version": "0.4.0",
 | 
				
			||||||
      "resolved": "https://registry.npmjs.org/@tailwindcss/forms/-/forms-0.4.0.tgz",
 | 
					      "resolved": "https://registry.npmjs.org/@tailwindcss/forms/-/forms-0.4.0.tgz",
 | 
				
			||||||
@ -223,6 +247,22 @@
 | 
				
			|||||||
        "mini-svg-data-uri": "^1.2.3"
 | 
					        "mini-svg-data-uri": "^1.2.3"
 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
 | 
					    "@tailwindcss/line-clamp": {
 | 
				
			||||||
 | 
					      "version": "0.3.1",
 | 
				
			||||||
 | 
					      "resolved": "https://registry.npmjs.org/@tailwindcss/line-clamp/-/line-clamp-0.3.1.tgz",
 | 
				
			||||||
 | 
					      "integrity": "sha512-pNr0T8LAc3TUx/gxCfQZRe9NB2dPEo/cedPHzUGIPxqDMhgjwNm6jYxww4W5l0zAsAddxr+XfZcqttGiFDgrGg=="
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    "@tailwindcss/typography": {
 | 
				
			||||||
 | 
					      "version": "0.5.4",
 | 
				
			||||||
 | 
					      "resolved": "https://registry.npmjs.org/@tailwindcss/typography/-/typography-0.5.4.tgz",
 | 
				
			||||||
 | 
					      "integrity": "sha512-QEdg40EmGvE7kKoDei8zr5sf4D1pIayHj4R31bH3lX8x2BtTiR+jNejYPOkhbmy3DXgkMF9jC8xqNiGFAuL9Sg==",
 | 
				
			||||||
 | 
					      "dev": true,
 | 
				
			||||||
 | 
					      "requires": {
 | 
				
			||||||
 | 
					        "lodash.castarray": "^4.4.0",
 | 
				
			||||||
 | 
					        "lodash.isplainobject": "^4.0.6",
 | 
				
			||||||
 | 
					        "lodash.merge": "^4.6.2"
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
    "@tiptap/core": {
 | 
					    "@tiptap/core": {
 | 
				
			||||||
      "version": "2.0.0-beta.99",
 | 
					      "version": "2.0.0-beta.99",
 | 
				
			||||||
      "resolved": "https://registry.npmjs.org/@tiptap/core/-/core-2.0.0-beta.99.tgz",
 | 
					      "resolved": "https://registry.npmjs.org/@tiptap/core/-/core-2.0.0-beta.99.tgz",
 | 
				
			||||||
@ -386,6 +426,11 @@
 | 
				
			|||||||
      "resolved": "https://registry.npmjs.org/@tiptap/extension-text/-/extension-text-2.0.0-beta.13.tgz",
 | 
					      "resolved": "https://registry.npmjs.org/@tiptap/extension-text/-/extension-text-2.0.0-beta.13.tgz",
 | 
				
			||||||
      "integrity": "sha512-0EtAwuRldCAoFaL/iXgkRepEeOd55rPg5N4FQUN1xTwZT7PDofukP0DG/2jff/Uj17x4uTaJAa9qlFWuNnDvjw=="
 | 
					      "integrity": "sha512-0EtAwuRldCAoFaL/iXgkRepEeOd55rPg5N4FQUN1xTwZT7PDofukP0DG/2jff/Uj17x4uTaJAa9qlFWuNnDvjw=="
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
 | 
					    "@tiptap/extension-text-align": {
 | 
				
			||||||
 | 
					      "version": "2.0.0-beta.31",
 | 
				
			||||||
 | 
					      "resolved": "https://registry.npmjs.org/@tiptap/extension-text-align/-/extension-text-align-2.0.0-beta.31.tgz",
 | 
				
			||||||
 | 
					      "integrity": "sha512-gSJqi57piiMPc2r6WEkXv7ZgQIogigsRUhmlnZC/7s3zzOvjXrexWnV0Ctt/9A7BKcM7OHMykpZyoewvk6QRTw=="
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
    "@tiptap/starter-kit": {
 | 
					    "@tiptap/starter-kit": {
 | 
				
			||||||
      "version": "2.0.0-beta.97",
 | 
					      "version": "2.0.0-beta.97",
 | 
				
			||||||
      "resolved": "https://registry.npmjs.org/@tiptap/starter-kit/-/starter-kit-2.0.0-beta.97.tgz",
 | 
					      "resolved": "https://registry.npmjs.org/@tiptap/starter-kit/-/starter-kit-2.0.0-beta.97.tgz",
 | 
				
			||||||
@ -537,6 +582,12 @@
 | 
				
			|||||||
        "@types/prosemirror-transform": "*"
 | 
					        "@types/prosemirror-transform": "*"
 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
 | 
					    "@vitejs/plugin-vue": {
 | 
				
			||||||
 | 
					      "version": "1.10.2",
 | 
				
			||||||
 | 
					      "resolved": "https://registry.npmjs.org/@vitejs/plugin-vue/-/plugin-vue-1.10.2.tgz",
 | 
				
			||||||
 | 
					      "integrity": "sha512-/QJ0Z9qfhAFtKRY+r57ziY4BSbGUTGsPRMpB/Ron3QPwBZM4OZAZHdTa4a8PafCwU5DTatXG8TMDoP8z+oDqJw==",
 | 
				
			||||||
 | 
					      "dev": true
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
    "@vue/compiler-core": {
 | 
					    "@vue/compiler-core": {
 | 
				
			||||||
      "version": "3.2.4",
 | 
					      "version": "3.2.4",
 | 
				
			||||||
      "resolved": "https://registry.npmjs.org/@vue/compiler-core/-/compiler-core-3.2.4.tgz",
 | 
					      "resolved": "https://registry.npmjs.org/@vue/compiler-core/-/compiler-core-3.2.4.tgz",
 | 
				
			||||||
@ -558,6 +609,70 @@
 | 
				
			|||||||
        "@vue/shared": "3.2.4"
 | 
					        "@vue/shared": "3.2.4"
 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
 | 
					    "@vue/compiler-sfc": {
 | 
				
			||||||
 | 
					      "version": "3.2.38",
 | 
				
			||||||
 | 
					      "resolved": "https://registry.npmjs.org/@vue/compiler-sfc/-/compiler-sfc-3.2.38.tgz",
 | 
				
			||||||
 | 
					      "integrity": "sha512-KZjrW32KloMYtTcHAFuw3CqsyWc5X6seb8KbkANSWt3Cz9p2qA8c1GJpSkksFP9ABb6an0FLCFl46ZFXx3kKpg==",
 | 
				
			||||||
 | 
					      "dev": true,
 | 
				
			||||||
 | 
					      "requires": {
 | 
				
			||||||
 | 
					        "@babel/parser": "^7.16.4",
 | 
				
			||||||
 | 
					        "@vue/compiler-core": "3.2.38",
 | 
				
			||||||
 | 
					        "@vue/compiler-dom": "3.2.38",
 | 
				
			||||||
 | 
					        "@vue/compiler-ssr": "3.2.38",
 | 
				
			||||||
 | 
					        "@vue/reactivity-transform": "3.2.38",
 | 
				
			||||||
 | 
					        "@vue/shared": "3.2.38",
 | 
				
			||||||
 | 
					        "estree-walker": "^2.0.2",
 | 
				
			||||||
 | 
					        "magic-string": "^0.25.7",
 | 
				
			||||||
 | 
					        "postcss": "^8.1.10",
 | 
				
			||||||
 | 
					        "source-map": "^0.6.1"
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					      "dependencies": {
 | 
				
			||||||
 | 
					        "@babel/parser": {
 | 
				
			||||||
 | 
					          "version": "7.18.13",
 | 
				
			||||||
 | 
					          "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.18.13.tgz",
 | 
				
			||||||
 | 
					          "integrity": "sha512-dgXcIfMuQ0kgzLB2b9tRZs7TTFFaGM2AbtA4fJgUUYukzGH4jwsS7hzQHEGs67jdehpm22vkgKwvbU+aEflgwg==",
 | 
				
			||||||
 | 
					          "dev": true
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					        "@vue/compiler-core": {
 | 
				
			||||||
 | 
					          "version": "3.2.38",
 | 
				
			||||||
 | 
					          "resolved": "https://registry.npmjs.org/@vue/compiler-core/-/compiler-core-3.2.38.tgz",
 | 
				
			||||||
 | 
					          "integrity": "sha512-/FsvnSu7Z+lkd/8KXMa4yYNUiqQrI22135gfsQYVGuh5tqEgOB0XqrUdb/KnCLa5+TmQLPwvyUnKMyCpu+SX3Q==",
 | 
				
			||||||
 | 
					          "dev": true,
 | 
				
			||||||
 | 
					          "requires": {
 | 
				
			||||||
 | 
					            "@babel/parser": "^7.16.4",
 | 
				
			||||||
 | 
					            "@vue/shared": "3.2.38",
 | 
				
			||||||
 | 
					            "estree-walker": "^2.0.2",
 | 
				
			||||||
 | 
					            "source-map": "^0.6.1"
 | 
				
			||||||
 | 
					          }
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					        "@vue/compiler-dom": {
 | 
				
			||||||
 | 
					          "version": "3.2.38",
 | 
				
			||||||
 | 
					          "resolved": "https://registry.npmjs.org/@vue/compiler-dom/-/compiler-dom-3.2.38.tgz",
 | 
				
			||||||
 | 
					          "integrity": "sha512-zqX4FgUbw56kzHlgYuEEJR8mefFiiyR3u96498+zWPsLeh1WKvgIReoNE+U7gG8bCUdvsrJ0JRmev0Ky6n2O0g==",
 | 
				
			||||||
 | 
					          "dev": true,
 | 
				
			||||||
 | 
					          "requires": {
 | 
				
			||||||
 | 
					            "@vue/compiler-core": "3.2.38",
 | 
				
			||||||
 | 
					            "@vue/shared": "3.2.38"
 | 
				
			||||||
 | 
					          }
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					        "@vue/compiler-ssr": {
 | 
				
			||||||
 | 
					          "version": "3.2.38",
 | 
				
			||||||
 | 
					          "resolved": "https://registry.npmjs.org/@vue/compiler-ssr/-/compiler-ssr-3.2.38.tgz",
 | 
				
			||||||
 | 
					          "integrity": "sha512-bm9jOeyv1H3UskNm4S6IfueKjUNFmi2kRweFIGnqaGkkRePjwEcfCVqyS3roe7HvF4ugsEkhf4+kIvDhip6XzQ==",
 | 
				
			||||||
 | 
					          "dev": true,
 | 
				
			||||||
 | 
					          "requires": {
 | 
				
			||||||
 | 
					            "@vue/compiler-dom": "3.2.38",
 | 
				
			||||||
 | 
					            "@vue/shared": "3.2.38"
 | 
				
			||||||
 | 
					          }
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					        "@vue/shared": {
 | 
				
			||||||
 | 
					          "version": "3.2.38",
 | 
				
			||||||
 | 
					          "resolved": "https://registry.npmjs.org/@vue/shared/-/shared-3.2.38.tgz",
 | 
				
			||||||
 | 
					          "integrity": "sha512-dTyhTIRmGXBjxJE+skC8tTWCGLCVc4wQgRRLt8+O9p5ewBAjoBwtCAkLPrtToSr1xltoe3st21Pv953aOZ7alg==",
 | 
				
			||||||
 | 
					          "dev": true
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
    "@vue/compiler-ssr": {
 | 
					    "@vue/compiler-ssr": {
 | 
				
			||||||
      "version": "3.2.19",
 | 
					      "version": "3.2.19",
 | 
				
			||||||
      "resolved": "https://registry.npmjs.org/@vue/compiler-ssr/-/compiler-ssr-3.2.19.tgz",
 | 
					      "resolved": "https://registry.npmjs.org/@vue/compiler-ssr/-/compiler-ssr-3.2.19.tgz",
 | 
				
			||||||
@ -607,6 +722,45 @@
 | 
				
			|||||||
        "@vue/shared": "3.2.4"
 | 
					        "@vue/shared": "3.2.4"
 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
 | 
					    "@vue/reactivity-transform": {
 | 
				
			||||||
 | 
					      "version": "3.2.38",
 | 
				
			||||||
 | 
					      "resolved": "https://registry.npmjs.org/@vue/reactivity-transform/-/reactivity-transform-3.2.38.tgz",
 | 
				
			||||||
 | 
					      "integrity": "sha512-3SD3Jmi1yXrDwiNJqQ6fs1x61WsDLqVk4NyKVz78mkaIRh6d3IqtRnptgRfXn+Fzf+m6B1KxBYWq1APj6h4qeA==",
 | 
				
			||||||
 | 
					      "dev": true,
 | 
				
			||||||
 | 
					      "requires": {
 | 
				
			||||||
 | 
					        "@babel/parser": "^7.16.4",
 | 
				
			||||||
 | 
					        "@vue/compiler-core": "3.2.38",
 | 
				
			||||||
 | 
					        "@vue/shared": "3.2.38",
 | 
				
			||||||
 | 
					        "estree-walker": "^2.0.2",
 | 
				
			||||||
 | 
					        "magic-string": "^0.25.7"
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					      "dependencies": {
 | 
				
			||||||
 | 
					        "@babel/parser": {
 | 
				
			||||||
 | 
					          "version": "7.18.13",
 | 
				
			||||||
 | 
					          "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.18.13.tgz",
 | 
				
			||||||
 | 
					          "integrity": "sha512-dgXcIfMuQ0kgzLB2b9tRZs7TTFFaGM2AbtA4fJgUUYukzGH4jwsS7hzQHEGs67jdehpm22vkgKwvbU+aEflgwg==",
 | 
				
			||||||
 | 
					          "dev": true
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					        "@vue/compiler-core": {
 | 
				
			||||||
 | 
					          "version": "3.2.38",
 | 
				
			||||||
 | 
					          "resolved": "https://registry.npmjs.org/@vue/compiler-core/-/compiler-core-3.2.38.tgz",
 | 
				
			||||||
 | 
					          "integrity": "sha512-/FsvnSu7Z+lkd/8KXMa4yYNUiqQrI22135gfsQYVGuh5tqEgOB0XqrUdb/KnCLa5+TmQLPwvyUnKMyCpu+SX3Q==",
 | 
				
			||||||
 | 
					          "dev": true,
 | 
				
			||||||
 | 
					          "requires": {
 | 
				
			||||||
 | 
					            "@babel/parser": "^7.16.4",
 | 
				
			||||||
 | 
					            "@vue/shared": "3.2.38",
 | 
				
			||||||
 | 
					            "estree-walker": "^2.0.2",
 | 
				
			||||||
 | 
					            "source-map": "^0.6.1"
 | 
				
			||||||
 | 
					          }
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					        "@vue/shared": {
 | 
				
			||||||
 | 
					          "version": "3.2.38",
 | 
				
			||||||
 | 
					          "resolved": "https://registry.npmjs.org/@vue/shared/-/shared-3.2.38.tgz",
 | 
				
			||||||
 | 
					          "integrity": "sha512-dTyhTIRmGXBjxJE+skC8tTWCGLCVc4wQgRRLt8+O9p5ewBAjoBwtCAkLPrtToSr1xltoe3st21Pv953aOZ7alg==",
 | 
				
			||||||
 | 
					          "dev": true
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
    "@vue/ref-transform": {
 | 
					    "@vue/ref-transform": {
 | 
				
			||||||
      "version": "3.2.19",
 | 
					      "version": "3.2.19",
 | 
				
			||||||
      "resolved": "https://registry.npmjs.org/@vue/ref-transform/-/ref-transform-3.2.19.tgz",
 | 
					      "resolved": "https://registry.npmjs.org/@vue/ref-transform/-/ref-transform-3.2.19.tgz",
 | 
				
			||||||
@ -677,6 +831,44 @@
 | 
				
			|||||||
      "resolved": "https://registry.npmjs.org/@vue/shared/-/shared-3.2.4.tgz",
 | 
					      "resolved": "https://registry.npmjs.org/@vue/shared/-/shared-3.2.4.tgz",
 | 
				
			||||||
      "integrity": "sha512-j2j1MRmjalVKr3YBTxl/BClSIc8UQ8NnPpLYclxerK65JIowI4O7n8O8lElveEtEoHxy1d7BelPUDI0Q4bumqg=="
 | 
					      "integrity": "sha512-j2j1MRmjalVKr3YBTxl/BClSIc8UQ8NnPpLYclxerK65JIowI4O7n8O8lElveEtEoHxy1d7BelPUDI0Q4bumqg=="
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
 | 
					    "@vuelidate/components": {
 | 
				
			||||||
 | 
					      "version": "1.2.1",
 | 
				
			||||||
 | 
					      "resolved": "https://registry.npmjs.org/@vuelidate/components/-/components-1.2.1.tgz",
 | 
				
			||||||
 | 
					      "integrity": "sha512-xaFGcKVQbST0l7yQufuLAbRUwC/5SR4Z8+s7fwF3B1BtQQwlttftAZg1lTm9I30EYsBdslk38XC4z3sDC8Nm4w==",
 | 
				
			||||||
 | 
					      "requires": {
 | 
				
			||||||
 | 
					        "@vuelidate/core": "^2.0.0-alpha.44"
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    "@vuelidate/core": {
 | 
				
			||||||
 | 
					      "version": "2.0.0-alpha.44",
 | 
				
			||||||
 | 
					      "resolved": "https://registry.npmjs.org/@vuelidate/core/-/core-2.0.0-alpha.44.tgz",
 | 
				
			||||||
 | 
					      "integrity": "sha512-3DlCe3E0RRXbB+OfPacUetKhLmXzmnjeHkzjnbkc03p06mKm6h9pXR5pd6Mv4s4tus4sieuKDb2YWNmKK6rQeA==",
 | 
				
			||||||
 | 
					      "requires": {
 | 
				
			||||||
 | 
					        "vue-demi": "^0.13.4"
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					      "dependencies": {
 | 
				
			||||||
 | 
					        "vue-demi": {
 | 
				
			||||||
 | 
					          "version": "0.13.11",
 | 
				
			||||||
 | 
					          "resolved": "https://registry.npmjs.org/vue-demi/-/vue-demi-0.13.11.tgz",
 | 
				
			||||||
 | 
					          "integrity": "sha512-IR8HoEEGM65YY3ZJYAjMlKygDQn25D5ajNFNoKh9RSDMQtlzCxtfQjdQgv9jjK+m3377SsJXY8ysq8kLCZL25A=="
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    "@vuelidate/validators": {
 | 
				
			||||||
 | 
					      "version": "2.0.0-alpha.31",
 | 
				
			||||||
 | 
					      "resolved": "https://registry.npmjs.org/@vuelidate/validators/-/validators-2.0.0-alpha.31.tgz",
 | 
				
			||||||
 | 
					      "integrity": "sha512-+MFA9nZ7Y9zCpq383/voPDk/hiAmu6KqiJJhLOYB/FmrUPVoyKnuKnI9Bwiq8ok9GZlVkI8BnIrKPKGj9QpwiQ==",
 | 
				
			||||||
 | 
					      "requires": {
 | 
				
			||||||
 | 
					        "vue-demi": "^0.13.4"
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					      "dependencies": {
 | 
				
			||||||
 | 
					        "vue-demi": {
 | 
				
			||||||
 | 
					          "version": "0.13.11",
 | 
				
			||||||
 | 
					          "resolved": "https://registry.npmjs.org/vue-demi/-/vue-demi-0.13.11.tgz",
 | 
				
			||||||
 | 
					          "integrity": "sha512-IR8HoEEGM65YY3ZJYAjMlKygDQn25D5ajNFNoKh9RSDMQtlzCxtfQjdQgv9jjK+m3377SsJXY8ysq8kLCZL25A=="
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
    "@vueuse/core": {
 | 
					    "@vueuse/core": {
 | 
				
			||||||
      "version": "6.0.0",
 | 
					      "version": "6.0.0",
 | 
				
			||||||
      "resolved": "https://registry.npmjs.org/@vueuse/core/-/core-6.0.0.tgz",
 | 
					      "resolved": "https://registry.npmjs.org/@vueuse/core/-/core-6.0.0.tgz",
 | 
				
			||||||
@ -1240,6 +1432,175 @@
 | 
				
			|||||||
        }
 | 
					        }
 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
 | 
					    "esbuild": {
 | 
				
			||||||
 | 
					      "version": "0.14.54",
 | 
				
			||||||
 | 
					      "resolved": "https://registry.npmjs.org/esbuild/-/esbuild-0.14.54.tgz",
 | 
				
			||||||
 | 
					      "integrity": "sha512-Cy9llcy8DvET5uznocPyqL3BFRrFXSVqbgpMJ9Wz8oVjZlh/zUSNbPRbov0VX7VxN2JH1Oa0uNxZ7eLRb62pJA==",
 | 
				
			||||||
 | 
					      "dev": true,
 | 
				
			||||||
 | 
					      "requires": {
 | 
				
			||||||
 | 
					        "@esbuild/linux-loong64": "0.14.54",
 | 
				
			||||||
 | 
					        "esbuild-android-64": "0.14.54",
 | 
				
			||||||
 | 
					        "esbuild-android-arm64": "0.14.54",
 | 
				
			||||||
 | 
					        "esbuild-darwin-64": "0.14.54",
 | 
				
			||||||
 | 
					        "esbuild-darwin-arm64": "0.14.54",
 | 
				
			||||||
 | 
					        "esbuild-freebsd-64": "0.14.54",
 | 
				
			||||||
 | 
					        "esbuild-freebsd-arm64": "0.14.54",
 | 
				
			||||||
 | 
					        "esbuild-linux-32": "0.14.54",
 | 
				
			||||||
 | 
					        "esbuild-linux-64": "0.14.54",
 | 
				
			||||||
 | 
					        "esbuild-linux-arm": "0.14.54",
 | 
				
			||||||
 | 
					        "esbuild-linux-arm64": "0.14.54",
 | 
				
			||||||
 | 
					        "esbuild-linux-mips64le": "0.14.54",
 | 
				
			||||||
 | 
					        "esbuild-linux-ppc64le": "0.14.54",
 | 
				
			||||||
 | 
					        "esbuild-linux-riscv64": "0.14.54",
 | 
				
			||||||
 | 
					        "esbuild-linux-s390x": "0.14.54",
 | 
				
			||||||
 | 
					        "esbuild-netbsd-64": "0.14.54",
 | 
				
			||||||
 | 
					        "esbuild-openbsd-64": "0.14.54",
 | 
				
			||||||
 | 
					        "esbuild-sunos-64": "0.14.54",
 | 
				
			||||||
 | 
					        "esbuild-windows-32": "0.14.54",
 | 
				
			||||||
 | 
					        "esbuild-windows-64": "0.14.54",
 | 
				
			||||||
 | 
					        "esbuild-windows-arm64": "0.14.54"
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    "esbuild-android-64": {
 | 
				
			||||||
 | 
					      "version": "0.14.54",
 | 
				
			||||||
 | 
					      "resolved": "https://registry.npmjs.org/esbuild-android-64/-/esbuild-android-64-0.14.54.tgz",
 | 
				
			||||||
 | 
					      "integrity": "sha512-Tz2++Aqqz0rJ7kYBfz+iqyE3QMycD4vk7LBRyWaAVFgFtQ/O8EJOnVmTOiDWYZ/uYzB4kvP+bqejYdVKzE5lAQ==",
 | 
				
			||||||
 | 
					      "dev": true,
 | 
				
			||||||
 | 
					      "optional": true
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    "esbuild-android-arm64": {
 | 
				
			||||||
 | 
					      "version": "0.14.54",
 | 
				
			||||||
 | 
					      "resolved": "https://registry.npmjs.org/esbuild-android-arm64/-/esbuild-android-arm64-0.14.54.tgz",
 | 
				
			||||||
 | 
					      "integrity": "sha512-F9E+/QDi9sSkLaClO8SOV6etqPd+5DgJje1F9lOWoNncDdOBL2YF59IhsWATSt0TLZbYCf3pNlTHvVV5VfHdvg==",
 | 
				
			||||||
 | 
					      "dev": true,
 | 
				
			||||||
 | 
					      "optional": true
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    "esbuild-darwin-64": {
 | 
				
			||||||
 | 
					      "version": "0.14.54",
 | 
				
			||||||
 | 
					      "resolved": "https://registry.npmjs.org/esbuild-darwin-64/-/esbuild-darwin-64-0.14.54.tgz",
 | 
				
			||||||
 | 
					      "integrity": "sha512-jtdKWV3nBviOd5v4hOpkVmpxsBy90CGzebpbO9beiqUYVMBtSc0AL9zGftFuBon7PNDcdvNCEuQqw2x0wP9yug==",
 | 
				
			||||||
 | 
					      "dev": true,
 | 
				
			||||||
 | 
					      "optional": true
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    "esbuild-darwin-arm64": {
 | 
				
			||||||
 | 
					      "version": "0.14.54",
 | 
				
			||||||
 | 
					      "resolved": "https://registry.npmjs.org/esbuild-darwin-arm64/-/esbuild-darwin-arm64-0.14.54.tgz",
 | 
				
			||||||
 | 
					      "integrity": "sha512-OPafJHD2oUPyvJMrsCvDGkRrVCar5aVyHfWGQzY1dWnzErjrDuSETxwA2HSsyg2jORLY8yBfzc1MIpUkXlctmw==",
 | 
				
			||||||
 | 
					      "dev": true,
 | 
				
			||||||
 | 
					      "optional": true
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    "esbuild-freebsd-64": {
 | 
				
			||||||
 | 
					      "version": "0.14.54",
 | 
				
			||||||
 | 
					      "resolved": "https://registry.npmjs.org/esbuild-freebsd-64/-/esbuild-freebsd-64-0.14.54.tgz",
 | 
				
			||||||
 | 
					      "integrity": "sha512-OKwd4gmwHqOTp4mOGZKe/XUlbDJ4Q9TjX0hMPIDBUWWu/kwhBAudJdBoxnjNf9ocIB6GN6CPowYpR/hRCbSYAg==",
 | 
				
			||||||
 | 
					      "dev": true,
 | 
				
			||||||
 | 
					      "optional": true
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    "esbuild-freebsd-arm64": {
 | 
				
			||||||
 | 
					      "version": "0.14.54",
 | 
				
			||||||
 | 
					      "resolved": "https://registry.npmjs.org/esbuild-freebsd-arm64/-/esbuild-freebsd-arm64-0.14.54.tgz",
 | 
				
			||||||
 | 
					      "integrity": "sha512-sFwueGr7OvIFiQT6WeG0jRLjkjdqWWSrfbVwZp8iMP+8UHEHRBvlaxL6IuKNDwAozNUmbb8nIMXa7oAOARGs1Q==",
 | 
				
			||||||
 | 
					      "dev": true,
 | 
				
			||||||
 | 
					      "optional": true
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    "esbuild-linux-32": {
 | 
				
			||||||
 | 
					      "version": "0.14.54",
 | 
				
			||||||
 | 
					      "resolved": "https://registry.npmjs.org/esbuild-linux-32/-/esbuild-linux-32-0.14.54.tgz",
 | 
				
			||||||
 | 
					      "integrity": "sha512-1ZuY+JDI//WmklKlBgJnglpUL1owm2OX+8E1syCD6UAxcMM/XoWd76OHSjl/0MR0LisSAXDqgjT3uJqT67O3qw==",
 | 
				
			||||||
 | 
					      "dev": true,
 | 
				
			||||||
 | 
					      "optional": true
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    "esbuild-linux-64": {
 | 
				
			||||||
 | 
					      "version": "0.14.54",
 | 
				
			||||||
 | 
					      "resolved": "https://registry.npmjs.org/esbuild-linux-64/-/esbuild-linux-64-0.14.54.tgz",
 | 
				
			||||||
 | 
					      "integrity": "sha512-EgjAgH5HwTbtNsTqQOXWApBaPVdDn7XcK+/PtJwZLT1UmpLoznPd8c5CxqsH2dQK3j05YsB3L17T8vE7cp4cCg==",
 | 
				
			||||||
 | 
					      "dev": true,
 | 
				
			||||||
 | 
					      "optional": true
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    "esbuild-linux-arm": {
 | 
				
			||||||
 | 
					      "version": "0.14.54",
 | 
				
			||||||
 | 
					      "resolved": "https://registry.npmjs.org/esbuild-linux-arm/-/esbuild-linux-arm-0.14.54.tgz",
 | 
				
			||||||
 | 
					      "integrity": "sha512-qqz/SjemQhVMTnvcLGoLOdFpCYbz4v4fUo+TfsWG+1aOu70/80RV6bgNpR2JCrppV2moUQkww+6bWxXRL9YMGw==",
 | 
				
			||||||
 | 
					      "dev": true,
 | 
				
			||||||
 | 
					      "optional": true
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    "esbuild-linux-arm64": {
 | 
				
			||||||
 | 
					      "version": "0.14.54",
 | 
				
			||||||
 | 
					      "resolved": "https://registry.npmjs.org/esbuild-linux-arm64/-/esbuild-linux-arm64-0.14.54.tgz",
 | 
				
			||||||
 | 
					      "integrity": "sha512-WL71L+0Rwv+Gv/HTmxTEmpv0UgmxYa5ftZILVi2QmZBgX3q7+tDeOQNqGtdXSdsL8TQi1vIaVFHUPDe0O0kdig==",
 | 
				
			||||||
 | 
					      "dev": true,
 | 
				
			||||||
 | 
					      "optional": true
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    "esbuild-linux-mips64le": {
 | 
				
			||||||
 | 
					      "version": "0.14.54",
 | 
				
			||||||
 | 
					      "resolved": "https://registry.npmjs.org/esbuild-linux-mips64le/-/esbuild-linux-mips64le-0.14.54.tgz",
 | 
				
			||||||
 | 
					      "integrity": "sha512-qTHGQB8D1etd0u1+sB6p0ikLKRVuCWhYQhAHRPkO+OF3I/iSlTKNNS0Lh2Oc0g0UFGguaFZZiPJdJey3AGpAlw==",
 | 
				
			||||||
 | 
					      "dev": true,
 | 
				
			||||||
 | 
					      "optional": true
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    "esbuild-linux-ppc64le": {
 | 
				
			||||||
 | 
					      "version": "0.14.54",
 | 
				
			||||||
 | 
					      "resolved": "https://registry.npmjs.org/esbuild-linux-ppc64le/-/esbuild-linux-ppc64le-0.14.54.tgz",
 | 
				
			||||||
 | 
					      "integrity": "sha512-j3OMlzHiqwZBDPRCDFKcx595XVfOfOnv68Ax3U4UKZ3MTYQB5Yz3X1mn5GnodEVYzhtZgxEBidLWeIs8FDSfrQ==",
 | 
				
			||||||
 | 
					      "dev": true,
 | 
				
			||||||
 | 
					      "optional": true
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    "esbuild-linux-riscv64": {
 | 
				
			||||||
 | 
					      "version": "0.14.54",
 | 
				
			||||||
 | 
					      "resolved": "https://registry.npmjs.org/esbuild-linux-riscv64/-/esbuild-linux-riscv64-0.14.54.tgz",
 | 
				
			||||||
 | 
					      "integrity": "sha512-y7Vt7Wl9dkOGZjxQZnDAqqn+XOqFD7IMWiewY5SPlNlzMX39ocPQlOaoxvT4FllA5viyV26/QzHtvTjVNOxHZg==",
 | 
				
			||||||
 | 
					      "dev": true,
 | 
				
			||||||
 | 
					      "optional": true
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    "esbuild-linux-s390x": {
 | 
				
			||||||
 | 
					      "version": "0.14.54",
 | 
				
			||||||
 | 
					      "resolved": "https://registry.npmjs.org/esbuild-linux-s390x/-/esbuild-linux-s390x-0.14.54.tgz",
 | 
				
			||||||
 | 
					      "integrity": "sha512-zaHpW9dziAsi7lRcyV4r8dhfG1qBidQWUXweUjnw+lliChJqQr+6XD71K41oEIC3Mx1KStovEmlzm+MkGZHnHA==",
 | 
				
			||||||
 | 
					      "dev": true,
 | 
				
			||||||
 | 
					      "optional": true
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    "esbuild-netbsd-64": {
 | 
				
			||||||
 | 
					      "version": "0.14.54",
 | 
				
			||||||
 | 
					      "resolved": "https://registry.npmjs.org/esbuild-netbsd-64/-/esbuild-netbsd-64-0.14.54.tgz",
 | 
				
			||||||
 | 
					      "integrity": "sha512-PR01lmIMnfJTgeU9VJTDY9ZerDWVFIUzAtJuDHwwceppW7cQWjBBqP48NdeRtoP04/AtO9a7w3viI+PIDr6d+w==",
 | 
				
			||||||
 | 
					      "dev": true,
 | 
				
			||||||
 | 
					      "optional": true
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    "esbuild-openbsd-64": {
 | 
				
			||||||
 | 
					      "version": "0.14.54",
 | 
				
			||||||
 | 
					      "resolved": "https://registry.npmjs.org/esbuild-openbsd-64/-/esbuild-openbsd-64-0.14.54.tgz",
 | 
				
			||||||
 | 
					      "integrity": "sha512-Qyk7ikT2o7Wu76UsvvDS5q0amJvmRzDyVlL0qf5VLsLchjCa1+IAvd8kTBgUxD7VBUUVgItLkk609ZHUc1oCaw==",
 | 
				
			||||||
 | 
					      "dev": true,
 | 
				
			||||||
 | 
					      "optional": true
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    "esbuild-sunos-64": {
 | 
				
			||||||
 | 
					      "version": "0.14.54",
 | 
				
			||||||
 | 
					      "resolved": "https://registry.npmjs.org/esbuild-sunos-64/-/esbuild-sunos-64-0.14.54.tgz",
 | 
				
			||||||
 | 
					      "integrity": "sha512-28GZ24KmMSeKi5ueWzMcco6EBHStL3B6ubM7M51RmPwXQGLe0teBGJocmWhgwccA1GeFXqxzILIxXpHbl9Q/Kw==",
 | 
				
			||||||
 | 
					      "dev": true,
 | 
				
			||||||
 | 
					      "optional": true
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    "esbuild-windows-32": {
 | 
				
			||||||
 | 
					      "version": "0.14.54",
 | 
				
			||||||
 | 
					      "resolved": "https://registry.npmjs.org/esbuild-windows-32/-/esbuild-windows-32-0.14.54.tgz",
 | 
				
			||||||
 | 
					      "integrity": "sha512-T+rdZW19ql9MjS7pixmZYVObd9G7kcaZo+sETqNH4RCkuuYSuv9AGHUVnPoP9hhuE1WM1ZimHz1CIBHBboLU7w==",
 | 
				
			||||||
 | 
					      "dev": true,
 | 
				
			||||||
 | 
					      "optional": true
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    "esbuild-windows-64": {
 | 
				
			||||||
 | 
					      "version": "0.14.54",
 | 
				
			||||||
 | 
					      "resolved": "https://registry.npmjs.org/esbuild-windows-64/-/esbuild-windows-64-0.14.54.tgz",
 | 
				
			||||||
 | 
					      "integrity": "sha512-AoHTRBUuYwXtZhjXZbA1pGfTo8cJo3vZIcWGLiUcTNgHpJJMC1rVA44ZereBHMJtotyN71S8Qw0npiCIkW96cQ==",
 | 
				
			||||||
 | 
					      "dev": true,
 | 
				
			||||||
 | 
					      "optional": true
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    "esbuild-windows-arm64": {
 | 
				
			||||||
 | 
					      "version": "0.14.54",
 | 
				
			||||||
 | 
					      "resolved": "https://registry.npmjs.org/esbuild-windows-arm64/-/esbuild-windows-arm64-0.14.54.tgz",
 | 
				
			||||||
 | 
					      "integrity": "sha512-M0kuUvXhot1zOISQGXwWn6YtS+Y/1RT9WrVIOywZnJHo3jCDyewAc79aKNQWFCQm+xNHVTq9h8dZKvygoXQQRg==",
 | 
				
			||||||
 | 
					      "dev": true,
 | 
				
			||||||
 | 
					      "optional": true
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
    "escalade": {
 | 
					    "escalade": {
 | 
				
			||||||
      "version": "3.1.1",
 | 
					      "version": "3.1.1",
 | 
				
			||||||
      "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.1.1.tgz",
 | 
					      "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.1.1.tgz",
 | 
				
			||||||
@ -1947,12 +2308,24 @@
 | 
				
			|||||||
      "resolved": "https://registry.npmjs.org/lodash-es/-/lodash-es-4.17.21.tgz",
 | 
					      "resolved": "https://registry.npmjs.org/lodash-es/-/lodash-es-4.17.21.tgz",
 | 
				
			||||||
      "integrity": "sha512-mKnC+QJ9pWVzv+C4/U3rRsHapFfHvQFoFB92e52xeyGMcX6/OlIl78je1u8vePzYZSkkogMPJ2yjxxsb89cxyw=="
 | 
					      "integrity": "sha512-mKnC+QJ9pWVzv+C4/U3rRsHapFfHvQFoFB92e52xeyGMcX6/OlIl78je1u8vePzYZSkkogMPJ2yjxxsb89cxyw=="
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
 | 
					    "lodash.castarray": {
 | 
				
			||||||
 | 
					      "version": "4.4.0",
 | 
				
			||||||
 | 
					      "resolved": "https://registry.npmjs.org/lodash.castarray/-/lodash.castarray-4.4.0.tgz",
 | 
				
			||||||
 | 
					      "integrity": "sha512-aVx8ztPv7/2ULbArGJ2Y42bG1mEQ5mGjpdvrbJcJFU3TbYybe+QlLS4pst9zV52ymy2in1KpFPiZnAOATxD4+Q==",
 | 
				
			||||||
 | 
					      "dev": true
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
    "lodash.clonedeep": {
 | 
					    "lodash.clonedeep": {
 | 
				
			||||||
      "version": "4.5.0",
 | 
					      "version": "4.5.0",
 | 
				
			||||||
      "resolved": "https://registry.npmjs.org/lodash.clonedeep/-/lodash.clonedeep-4.5.0.tgz",
 | 
					      "resolved": "https://registry.npmjs.org/lodash.clonedeep/-/lodash.clonedeep-4.5.0.tgz",
 | 
				
			||||||
      "integrity": "sha1-4j8/nE+Pvd6HJSnBBxhXoIblzO8=",
 | 
					      "integrity": "sha1-4j8/nE+Pvd6HJSnBBxhXoIblzO8=",
 | 
				
			||||||
      "dev": true
 | 
					      "dev": true
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
 | 
					    "lodash.isplainobject": {
 | 
				
			||||||
 | 
					      "version": "4.0.6",
 | 
				
			||||||
 | 
					      "resolved": "https://registry.npmjs.org/lodash.isplainobject/-/lodash.isplainobject-4.0.6.tgz",
 | 
				
			||||||
 | 
					      "integrity": "sha512-oSXzaWypCMHkPC3NvBEaPHf0KsA5mvPrOPgQWDsbg8n7orZ290M0BmC/jgRZ4vcJ6DTAhjrsSYgdsW/F+MFOBA==",
 | 
				
			||||||
 | 
					      "dev": true
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
    "lodash.merge": {
 | 
					    "lodash.merge": {
 | 
				
			||||||
      "version": "4.6.2",
 | 
					      "version": "4.6.2",
 | 
				
			||||||
      "resolved": "https://registry.npmjs.org/lodash.merge/-/lodash.merge-4.6.2.tgz",
 | 
					      "resolved": "https://registry.npmjs.org/lodash.merge/-/lodash.merge-4.6.2.tgz",
 | 
				
			||||||
@ -2205,6 +2578,22 @@
 | 
				
			|||||||
      "integrity": "sha512-lY1Q/PiJGC2zOv/z391WOTD+Z02bCgsFfvxoXXf6h7kv9o+WmsmzYqrAwY63sNgOxE4xEdq0WyUnXfKeBrSvYw==",
 | 
					      "integrity": "sha512-lY1Q/PiJGC2zOv/z391WOTD+Z02bCgsFfvxoXXf6h7kv9o+WmsmzYqrAwY63sNgOxE4xEdq0WyUnXfKeBrSvYw==",
 | 
				
			||||||
      "dev": true
 | 
					      "dev": true
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
 | 
					    "pinia": {
 | 
				
			||||||
 | 
					      "version": "2.0.21",
 | 
				
			||||||
 | 
					      "resolved": "https://registry.npmjs.org/pinia/-/pinia-2.0.21.tgz",
 | 
				
			||||||
 | 
					      "integrity": "sha512-6ol04PtL29O0Z6JHI47O3JUSoyOJ7Og0rstXrHVMZSP4zAldsQBXJCNF0i/H7m8vp/Hjd/CSmuPl7C5QAwpeWQ==",
 | 
				
			||||||
 | 
					      "requires": {
 | 
				
			||||||
 | 
					        "@vue/devtools-api": "^6.2.1",
 | 
				
			||||||
 | 
					        "vue-demi": "*"
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					      "dependencies": {
 | 
				
			||||||
 | 
					        "@vue/devtools-api": {
 | 
				
			||||||
 | 
					          "version": "6.2.1",
 | 
				
			||||||
 | 
					          "resolved": "https://registry.npmjs.org/@vue/devtools-api/-/devtools-api-6.2.1.tgz",
 | 
				
			||||||
 | 
					          "integrity": "sha512-OEgAMeQXvCoJ+1x8WyQuVZzFo0wcyCmUR3baRVLmKBo1LmYZWMlRiXlux5jd0fqVJu6PfDbOrZItVqUEzLobeQ=="
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
    "postcss": {
 | 
					    "postcss": {
 | 
				
			||||||
      "version": "8.4.5",
 | 
					      "version": "8.4.5",
 | 
				
			||||||
      "resolved": "https://registry.npmjs.org/postcss/-/postcss-8.4.5.tgz",
 | 
					      "resolved": "https://registry.npmjs.org/postcss/-/postcss-8.4.5.tgz",
 | 
				
			||||||
@ -2508,6 +2897,15 @@
 | 
				
			|||||||
        "glob": "^7.1.3"
 | 
					        "glob": "^7.1.3"
 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
 | 
					    "rollup": {
 | 
				
			||||||
 | 
					      "version": "2.78.1",
 | 
				
			||||||
 | 
					      "resolved": "https://registry.npmjs.org/rollup/-/rollup-2.78.1.tgz",
 | 
				
			||||||
 | 
					      "integrity": "sha512-VeeCgtGi4P+o9hIg+xz4qQpRl6R401LWEXBmxYKOV4zlF82lyhgh2hTZnheFUbANE8l2A41F458iwj2vEYaXJg==",
 | 
				
			||||||
 | 
					      "dev": true,
 | 
				
			||||||
 | 
					      "requires": {
 | 
				
			||||||
 | 
					        "fsevents": "~2.3.2"
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
    "rope-sequence": {
 | 
					    "rope-sequence": {
 | 
				
			||||||
      "version": "1.3.2",
 | 
					      "version": "1.3.2",
 | 
				
			||||||
      "resolved": "https://registry.npmjs.org/rope-sequence/-/rope-sequence-1.3.2.tgz",
 | 
					      "resolved": "https://registry.npmjs.org/rope-sequence/-/rope-sequence-1.3.2.tgz",
 | 
				
			||||||
@ -2668,6 +3066,12 @@
 | 
				
			|||||||
        "has-flag": "^3.0.0"
 | 
					        "has-flag": "^3.0.0"
 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
 | 
					    "supports-preserve-symlinks-flag": {
 | 
				
			||||||
 | 
					      "version": "1.0.0",
 | 
				
			||||||
 | 
					      "resolved": "https://registry.npmjs.org/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz",
 | 
				
			||||||
 | 
					      "integrity": "sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==",
 | 
				
			||||||
 | 
					      "dev": true
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
    "table": {
 | 
					    "table": {
 | 
				
			||||||
      "version": "6.7.2",
 | 
					      "version": "6.7.2",
 | 
				
			||||||
      "resolved": "https://registry.npmjs.org/table/-/table-6.7.2.tgz",
 | 
					      "resolved": "https://registry.npmjs.org/table/-/table-6.7.2.tgz",
 | 
				
			||||||
@ -2934,12 +3338,86 @@
 | 
				
			|||||||
      "resolved": "https://registry.npmjs.org/v-money3/-/v-money3-3.16.1.tgz",
 | 
					      "resolved": "https://registry.npmjs.org/v-money3/-/v-money3-3.16.1.tgz",
 | 
				
			||||||
      "integrity": "sha512-U0GjmdybvEwfxCpZiTUbKugSglJbX6wxlyMeg0YJdLTAKlnjMRDph3hpNJlTlg5Gs8MQRpDVdaLysBjV749HLg=="
 | 
					      "integrity": "sha512-U0GjmdybvEwfxCpZiTUbKugSglJbX6wxlyMeg0YJdLTAKlnjMRDph3hpNJlTlg5Gs8MQRpDVdaLysBjV749HLg=="
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
 | 
					    "v-tooltip": {
 | 
				
			||||||
 | 
					      "version": "4.0.0-beta.17",
 | 
				
			||||||
 | 
					      "resolved": "https://registry.npmjs.org/v-tooltip/-/v-tooltip-4.0.0-beta.17.tgz",
 | 
				
			||||||
 | 
					      "integrity": "sha512-d7v/6KEXQOtcj3NT3Z1LpbDv8SBh8JgbsD+3s/zGIGCxiXC2SoVW6wGV4X0MlCo97PiosibcSe+VKbFiy4AKnQ==",
 | 
				
			||||||
 | 
					      "requires": {
 | 
				
			||||||
 | 
					        "@popperjs/core": "^2.11.0",
 | 
				
			||||||
 | 
					        "vue-resize": "^2.0.0-alpha.1"
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					      "dependencies": {
 | 
				
			||||||
 | 
					        "@popperjs/core": {
 | 
				
			||||||
 | 
					          "version": "2.11.6",
 | 
				
			||||||
 | 
					          "resolved": "https://registry.npmjs.org/@popperjs/core/-/core-2.11.6.tgz",
 | 
				
			||||||
 | 
					          "integrity": "sha512-50/17A98tWUfQ176raKiOGXuYpLyyVMkxxG6oylzL3BPOlA6ADGdK7EYunSa4I064xerltq9TGXs8HmOk5E+vw=="
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
    "v8-compile-cache": {
 | 
					    "v8-compile-cache": {
 | 
				
			||||||
      "version": "2.3.0",
 | 
					      "version": "2.3.0",
 | 
				
			||||||
      "resolved": "https://registry.npmjs.org/v8-compile-cache/-/v8-compile-cache-2.3.0.tgz",
 | 
					      "resolved": "https://registry.npmjs.org/v8-compile-cache/-/v8-compile-cache-2.3.0.tgz",
 | 
				
			||||||
      "integrity": "sha512-l8lCEmLcLYZh4nbunNZvQCJc5pv7+RCwa8q/LdUx8u7lsWvPDKmpodJAJNwkAhJC//dFY48KuIEmjtd4RViDrA==",
 | 
					      "integrity": "sha512-l8lCEmLcLYZh4nbunNZvQCJc5pv7+RCwa8q/LdUx8u7lsWvPDKmpodJAJNwkAhJC//dFY48KuIEmjtd4RViDrA==",
 | 
				
			||||||
      "dev": true
 | 
					      "dev": true
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
 | 
					    "vite": {
 | 
				
			||||||
 | 
					      "version": "2.9.13",
 | 
				
			||||||
 | 
					      "resolved": "https://registry.npmjs.org/vite/-/vite-2.9.13.tgz",
 | 
				
			||||||
 | 
					      "integrity": "sha512-AsOBAaT0AD7Mhe8DuK+/kE4aWYFMx/i0ZNi98hJclxb4e0OhQcZYUrvLjIaQ8e59Ui7txcvKMiJC1yftqpQoDw==",
 | 
				
			||||||
 | 
					      "dev": true,
 | 
				
			||||||
 | 
					      "requires": {
 | 
				
			||||||
 | 
					        "esbuild": "^0.14.27",
 | 
				
			||||||
 | 
					        "fsevents": "~2.3.2",
 | 
				
			||||||
 | 
					        "postcss": "^8.4.13",
 | 
				
			||||||
 | 
					        "resolve": "^1.22.0",
 | 
				
			||||||
 | 
					        "rollup": "^2.59.0"
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
 | 
					      "dependencies": {
 | 
				
			||||||
 | 
					        "is-core-module": {
 | 
				
			||||||
 | 
					          "version": "2.10.0",
 | 
				
			||||||
 | 
					          "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.10.0.tgz",
 | 
				
			||||||
 | 
					          "integrity": "sha512-Erxj2n/LDAZ7H8WNJXd9tw38GYM3dv8rk8Zcs+jJuxYTW7sozH+SS8NtrSjVL1/vpLvWi1hxy96IzjJ3EHTJJg==",
 | 
				
			||||||
 | 
					          "dev": true,
 | 
				
			||||||
 | 
					          "requires": {
 | 
				
			||||||
 | 
					            "has": "^1.0.3"
 | 
				
			||||||
 | 
					          }
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					        "nanoid": {
 | 
				
			||||||
 | 
					          "version": "3.3.4",
 | 
				
			||||||
 | 
					          "resolved": "https://registry.npmjs.org/nanoid/-/nanoid-3.3.4.tgz",
 | 
				
			||||||
 | 
					          "integrity": "sha512-MqBkQh/OHTS2egovRtLk45wEyNXwF+cokD+1YPf9u5VfJiRdAiRwB2froX5Co9Rh20xs4siNPm8naNotSD6RBw==",
 | 
				
			||||||
 | 
					          "dev": true
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					        "postcss": {
 | 
				
			||||||
 | 
					          "version": "8.4.16",
 | 
				
			||||||
 | 
					          "resolved": "https://registry.npmjs.org/postcss/-/postcss-8.4.16.tgz",
 | 
				
			||||||
 | 
					          "integrity": "sha512-ipHE1XBvKzm5xI7hiHCZJCSugxvsdq2mPnsq5+UF+VHCjiBvtDrlxJfMBToWaP9D5XlgNmcFGqoHmUn0EYEaRQ==",
 | 
				
			||||||
 | 
					          "dev": true,
 | 
				
			||||||
 | 
					          "requires": {
 | 
				
			||||||
 | 
					            "nanoid": "^3.3.4",
 | 
				
			||||||
 | 
					            "picocolors": "^1.0.0",
 | 
				
			||||||
 | 
					            "source-map-js": "^1.0.2"
 | 
				
			||||||
 | 
					          }
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					        "resolve": {
 | 
				
			||||||
 | 
					          "version": "1.22.1",
 | 
				
			||||||
 | 
					          "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.22.1.tgz",
 | 
				
			||||||
 | 
					          "integrity": "sha512-nBpuuYuY5jFsli/JIs1oldw6fOQCBioohqWZg/2hiaOybXOft4lonv85uDOKXdf8rhyK159cxU5cDcK/NKk8zw==",
 | 
				
			||||||
 | 
					          "dev": true,
 | 
				
			||||||
 | 
					          "requires": {
 | 
				
			||||||
 | 
					            "is-core-module": "^2.9.0",
 | 
				
			||||||
 | 
					            "path-parse": "^1.0.7",
 | 
				
			||||||
 | 
					            "supports-preserve-symlinks-flag": "^1.0.0"
 | 
				
			||||||
 | 
					          }
 | 
				
			||||||
 | 
					        },
 | 
				
			||||||
 | 
					        "source-map-js": {
 | 
				
			||||||
 | 
					          "version": "1.0.2",
 | 
				
			||||||
 | 
					          "resolved": "https://registry.npmjs.org/source-map-js/-/source-map-js-1.0.2.tgz",
 | 
				
			||||||
 | 
					          "integrity": "sha512-R0XvVJ9WusLiqTCEiGCmICCMplcCkIwwR11mOSD9CR5u+IXYdiseeEuXCVAjS54zqwkLcPNnmU4OeJ6tUrWhDw==",
 | 
				
			||||||
 | 
					          "dev": true
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
    "vue": {
 | 
					    "vue": {
 | 
				
			||||||
      "version": "3.2.4",
 | 
					      "version": "3.2.4",
 | 
				
			||||||
      "resolved": "https://registry.npmjs.org/vue/-/vue-3.2.4.tgz",
 | 
					      "resolved": "https://registry.npmjs.org/vue/-/vue-3.2.4.tgz",
 | 
				
			||||||
@ -3002,6 +3480,11 @@
 | 
				
			|||||||
        "@vue/devtools-api": "^6.0.0-beta.7"
 | 
					        "@vue/devtools-api": "^6.0.0-beta.7"
 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
 | 
					    "vue-resize": {
 | 
				
			||||||
 | 
					      "version": "2.0.0-alpha.1",
 | 
				
			||||||
 | 
					      "resolved": "https://registry.npmjs.org/vue-resize/-/vue-resize-2.0.0-alpha.1.tgz",
 | 
				
			||||||
 | 
					      "integrity": "sha512-7+iqOueLU7uc9NrMfrzbG8hwMqchfVfSzpVlCMeJQe4pyibqyoifDNbKTZvwxZKDvGkB+PdFeKvnGZMoEb8esg=="
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
    "vue-router": {
 | 
					    "vue-router": {
 | 
				
			||||||
      "version": "4.0.11",
 | 
					      "version": "4.0.11",
 | 
				
			||||||
      "resolved": "https://registry.npmjs.org/vue-router/-/vue-router-4.0.11.tgz",
 | 
					      "resolved": "https://registry.npmjs.org/vue-router/-/vue-router-4.0.11.tgz",
 | 
				
			||||||
 | 
				
			|||||||
@ -24,7 +24,7 @@
 | 
				
			|||||||
    "sass": "^1.32.12",
 | 
					    "sass": "^1.32.12",
 | 
				
			||||||
    "tailwind-scrollbar": "^1.3.1",
 | 
					    "tailwind-scrollbar": "^1.3.1",
 | 
				
			||||||
    "tailwindcss": "^3.0.6",
 | 
					    "tailwindcss": "^3.0.6",
 | 
				
			||||||
    "vite": "^2.6.1"
 | 
					    "vite": "^2.9.13"
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
  "dependencies": {
 | 
					  "dependencies": {
 | 
				
			||||||
    "@headlessui/vue": "^1.4.0",
 | 
					    "@headlessui/vue": "^1.4.0",
 | 
				
			||||||
 | 
				
			|||||||
@ -17,7 +17,18 @@
 | 
				
			|||||||
            <td class="px-5 py-4 text-left align-top">
 | 
					            <td class="px-5 py-4 text-left align-top">
 | 
				
			||||||
              <div class="flex justify-start">
 | 
					              <div class="flex justify-start">
 | 
				
			||||||
                <div
 | 
					                <div
 | 
				
			||||||
                  class="flex items-center justify-center w-5 h-5 mt-2 mr-2 text-gray-300 cursor-move  handle"
 | 
					                  class="
 | 
				
			||||||
 | 
					                    flex
 | 
				
			||||||
 | 
					                    items-center
 | 
				
			||||||
 | 
					                    justify-center
 | 
				
			||||||
 | 
					                    w-5
 | 
				
			||||||
 | 
					                    h-5
 | 
				
			||||||
 | 
					                    mt-2
 | 
				
			||||||
 | 
					                    text-gray-300
 | 
				
			||||||
 | 
					                    cursor-move
 | 
				
			||||||
 | 
					                    handle
 | 
				
			||||||
 | 
					                    mr-2
 | 
				
			||||||
 | 
					                  "
 | 
				
			||||||
                >
 | 
					                >
 | 
				
			||||||
                  <DragIcon />
 | 
					                  <DragIcon />
 | 
				
			||||||
                </div>
 | 
					                </div>
 | 
				
			||||||
@ -97,7 +108,7 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
                          <BaseIcon
 | 
					                          <BaseIcon
 | 
				
			||||||
                            name="ChevronDownIcon"
 | 
					                            name="ChevronDownIcon"
 | 
				
			||||||
                            class="w-4 h-4 ml-1 text-gray-500"
 | 
					                            class="w-4 h-4 text-gray-500 ml-1"
 | 
				
			||||||
                          />
 | 
					                          />
 | 
				
			||||||
                        </span>
 | 
					                        </span>
 | 
				
			||||||
                      </BaseButton>
 | 
					                      </BaseButton>
 | 
				
			||||||
@ -144,7 +155,7 @@
 | 
				
			|||||||
              <BaseContentPlaceholders v-if="loading">
 | 
					              <BaseContentPlaceholders v-if="loading">
 | 
				
			||||||
                <BaseContentPlaceholdersText
 | 
					                <BaseContentPlaceholdersText
 | 
				
			||||||
                  :lines="1"
 | 
					                  :lines="1"
 | 
				
			||||||
                  class="w-24 h-8 border rounded-md"
 | 
					                  class="w-24 h-8 rounded-md border"
 | 
				
			||||||
                />
 | 
					                />
 | 
				
			||||||
              </BaseContentPlaceholders>
 | 
					              </BaseContentPlaceholders>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@ -164,7 +175,6 @@
 | 
				
			|||||||
                :ability="abilities.CREATE_INVOICE"
 | 
					                :ability="abilities.CREATE_INVOICE"
 | 
				
			||||||
                :store="store"
 | 
					                :store="store"
 | 
				
			||||||
                :store-prop="storeProp"
 | 
					                :store-prop="storeProp"
 | 
				
			||||||
                :discount="discount"
 | 
					 | 
				
			||||||
                @update="updateTax"
 | 
					                @update="updateTax"
 | 
				
			||||||
              />
 | 
					              />
 | 
				
			||||||
            </td>
 | 
					            </td>
 | 
				
			||||||
@ -271,19 +281,23 @@ const price = computed({
 | 
				
			|||||||
    } else {
 | 
					    } else {
 | 
				
			||||||
      updateItemAttribute('price', newValue)
 | 
					      updateItemAttribute('price', newValue)
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
    setDiscount()
 | 
					 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
})
 | 
					})
 | 
				
			||||||
 | 
					
 | 
				
			||||||
const subtotal = computed(() => Math.round(props.itemData.price * props.itemData.quantity))
 | 
					const subtotal = computed(() => props.itemData.price * props.itemData.quantity)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
const discount = computed({
 | 
					const discount = computed({
 | 
				
			||||||
  get: () => {
 | 
					  get: () => {
 | 
				
			||||||
    return props.itemData.discount
 | 
					    return props.itemData.discount
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
  set: (newValue) => {
 | 
					  set: (newValue) => {
 | 
				
			||||||
 | 
					    if (props.itemData.discount_type === 'percentage') {
 | 
				
			||||||
 | 
					      updateItemAttribute('discount_val', (subtotal.value * newValue) / 100)
 | 
				
			||||||
 | 
					    } else {
 | 
				
			||||||
 | 
					      updateItemAttribute('discount_val', Math.round(newValue * 100))
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    updateItemAttribute('discount', newValue)
 | 
					    updateItemAttribute('discount', newValue)
 | 
				
			||||||
    setDiscount()
 | 
					 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
})
 | 
					})
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@ -309,7 +323,7 @@ const showRemoveButton = computed(() => {
 | 
				
			|||||||
const totalSimpleTax = computed(() => {
 | 
					const totalSimpleTax = computed(() => {
 | 
				
			||||||
  return Math.round(
 | 
					  return Math.round(
 | 
				
			||||||
    sumBy(props.itemData.taxes, function (tax) {
 | 
					    sumBy(props.itemData.taxes, function (tax) {
 | 
				
			||||||
      if (tax.amount) {
 | 
					      if (!tax.compound_tax) {
 | 
				
			||||||
        return tax.amount
 | 
					        return tax.amount
 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
      return 0
 | 
					      return 0
 | 
				
			||||||
@ -317,7 +331,18 @@ const totalSimpleTax = computed(() => {
 | 
				
			|||||||
  )
 | 
					  )
 | 
				
			||||||
})
 | 
					})
 | 
				
			||||||
 | 
					
 | 
				
			||||||
const totalTax = computed(() => totalSimpleTax.value)
 | 
					const totalCompoundTax = computed(() => {
 | 
				
			||||||
 | 
					  return Math.round(
 | 
				
			||||||
 | 
					    sumBy(props.itemData.taxes, function (tax) {
 | 
				
			||||||
 | 
					      if (tax.compound_tax) {
 | 
				
			||||||
 | 
					        return tax.amount
 | 
				
			||||||
 | 
					      }
 | 
				
			||||||
 | 
					      return 0
 | 
				
			||||||
 | 
					    })
 | 
				
			||||||
 | 
					  )
 | 
				
			||||||
 | 
					})
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					const totalTax = computed(() => totalSimpleTax.value + totalCompoundTax.value)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
const rules = {
 | 
					const rules = {
 | 
				
			||||||
  name: {
 | 
					  name: {
 | 
				
			||||||
@ -401,16 +426,6 @@ function updateTax(data) {
 | 
				
			|||||||
  syncItemToStore()
 | 
					  syncItemToStore()
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
function setDiscount() {
 | 
					 | 
				
			||||||
  const newValue = props.store[props.storeProp].items[props.index].discount
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  if (props.itemData.discount_type === 'percentage'){
 | 
					 | 
				
			||||||
    updateItemAttribute('discount_val', Math.round((subtotal.value * newValue) / 100))
 | 
					 | 
				
			||||||
  }else{
 | 
					 | 
				
			||||||
    updateItemAttribute('discount_val', Math.round(newValue * 100))
 | 
					 | 
				
			||||||
  }
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
function searchVal(val) {
 | 
					function searchVal(val) {
 | 
				
			||||||
  updateItemAttribute('name', val)
 | 
					  updateItemAttribute('name', val)
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
@ -480,12 +495,10 @@ function syncItemToStore() {
 | 
				
			|||||||
    total: total.value,
 | 
					    total: total.value,
 | 
				
			||||||
    sub_total: subtotal.value,
 | 
					    sub_total: subtotal.value,
 | 
				
			||||||
    totalSimpleTax: totalSimpleTax.value,
 | 
					    totalSimpleTax: totalSimpleTax.value,
 | 
				
			||||||
 | 
					    totalCompoundTax: totalCompoundTax.value,
 | 
				
			||||||
    totalTax: totalTax.value,
 | 
					    totalTax: totalTax.value,
 | 
				
			||||||
    tax: totalTax.value,
 | 
					    tax: totalTax.value,
 | 
				
			||||||
    taxes: [...itemTaxes],
 | 
					    taxes: [...itemTaxes],
 | 
				
			||||||
    tax_type_ids: itemTaxes.flatMap(_t =>
 | 
					 | 
				
			||||||
      _t.tax_type_id ? _t.tax_type_id : [],
 | 
					 | 
				
			||||||
    ),
 | 
					 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  props.store.updateItem(data)
 | 
					  props.store.updateItem(data)
 | 
				
			||||||
 | 
				
			|||||||
@ -30,13 +30,24 @@
 | 
				
			|||||||
        <template v-if="userStore.hasAbilities(ability)" #action>
 | 
					        <template v-if="userStore.hasAbilities(ability)" #action>
 | 
				
			||||||
          <button
 | 
					          <button
 | 
				
			||||||
            type="button"
 | 
					            type="button"
 | 
				
			||||||
            class="flex items-center justify-center w-full px-2 py-2 bg-gray-200 border-none outline-none cursor-pointer "
 | 
					            class="
 | 
				
			||||||
 | 
					              flex
 | 
				
			||||||
 | 
					              items-center
 | 
				
			||||||
 | 
					              justify-center
 | 
				
			||||||
 | 
					              w-full
 | 
				
			||||||
 | 
					              px-2
 | 
				
			||||||
 | 
					              cursor-pointer
 | 
				
			||||||
 | 
					              py-2
 | 
				
			||||||
 | 
					              bg-gray-200
 | 
				
			||||||
 | 
					              border-none
 | 
				
			||||||
 | 
					              outline-none
 | 
				
			||||||
 | 
					            "
 | 
				
			||||||
            @click="openTaxModal"
 | 
					            @click="openTaxModal"
 | 
				
			||||||
          >
 | 
					          >
 | 
				
			||||||
            <BaseIcon name="CheckCircleIcon" class="h-5 text-primary-400" />
 | 
					            <BaseIcon name="CheckCircleIcon" class="h-5 text-primary-400" />
 | 
				
			||||||
 | 
					
 | 
				
			||||||
            <label
 | 
					            <label
 | 
				
			||||||
              class="ml-2 text-sm leading-none cursor-pointer text-primary-400"
 | 
					              class="ml-2 text-sm leading-none text-primary-400 cursor-pointer"
 | 
				
			||||||
              >{{ $t('invoices.add_new_tax') }}</label
 | 
					              >{{ $t('invoices.add_new_tax') }}</label
 | 
				
			||||||
            >
 | 
					            >
 | 
				
			||||||
          </button>
 | 
					          </button>
 | 
				
			||||||
@ -104,10 +115,6 @@ const props = defineProps({
 | 
				
			|||||||
    type: Number,
 | 
					    type: Number,
 | 
				
			||||||
    default: 0,
 | 
					    default: 0,
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
  discountedTotal: {
 | 
					 | 
				
			||||||
    type: Number,
 | 
					 | 
				
			||||||
    default: 0,
 | 
					 | 
				
			||||||
  },
 | 
					 | 
				
			||||||
  currency: {
 | 
					  currency: {
 | 
				
			||||||
    type: [Object, String],
 | 
					    type: [Object, String],
 | 
				
			||||||
    required: true,
 | 
					    required: true,
 | 
				
			||||||
@ -146,19 +153,19 @@ const filteredTypes = computed(() => {
 | 
				
			|||||||
})
 | 
					})
 | 
				
			||||||
 | 
					
 | 
				
			||||||
const taxAmount = computed(() => {
 | 
					const taxAmount = computed(() => {
 | 
				
			||||||
  if (props.discountedTotal && localTax.percent) {
 | 
					  if (localTax.compound_tax && props.total) {
 | 
				
			||||||
    const taxPerItemEnabled = props.store[props.storeProp].tax_per_item === 'YES'
 | 
					    return ((props.total + props.totalTax) * localTax.percent) / 100
 | 
				
			||||||
    const discountPerItemEnabled = props.store[props.storeProp].discount_per_item === 'YES'
 | 
					 | 
				
			||||||
    if (taxPerItemEnabled && !discountPerItemEnabled){
 | 
					 | 
				
			||||||
      return getTaxAmount()
 | 
					 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
    return (props.discountedTotal * localTax.percent) / 100
 | 
					
 | 
				
			||||||
 | 
					  if (props.total && localTax.percent) {
 | 
				
			||||||
 | 
					    return (props.total * localTax.percent) / 100
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  return 0
 | 
					  return 0
 | 
				
			||||||
})
 | 
					})
 | 
				
			||||||
 | 
					
 | 
				
			||||||
watch(
 | 
					watch(
 | 
				
			||||||
  () => props.discountedTotal,
 | 
					  () => props.total,
 | 
				
			||||||
  () => {
 | 
					  () => {
 | 
				
			||||||
    updateRowTax()
 | 
					    updateRowTax()
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
@ -171,13 +178,6 @@ watch(
 | 
				
			|||||||
  }
 | 
					  }
 | 
				
			||||||
)
 | 
					)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
watch(
 | 
					 | 
				
			||||||
  () => taxAmount.value,
 | 
					 | 
				
			||||||
  () => {
 | 
					 | 
				
			||||||
    updateRowTax()
 | 
					 | 
				
			||||||
  },
 | 
					 | 
				
			||||||
)
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
// Set SelectedTax
 | 
					// Set SelectedTax
 | 
				
			||||||
if (props.taxData.tax_type_id > 0) {
 | 
					if (props.taxData.tax_type_id > 0) {
 | 
				
			||||||
  selectedTax.value = taxTypeStore.taxTypes.find(
 | 
					  selectedTax.value = taxTypeStore.taxTypes.find(
 | 
				
			||||||
@ -190,6 +190,7 @@ updateRowTax()
 | 
				
			|||||||
function onSelectTax(val) {
 | 
					function onSelectTax(val) {
 | 
				
			||||||
  localTax.percent = val.percent
 | 
					  localTax.percent = val.percent
 | 
				
			||||||
  localTax.tax_type_id = val.id
 | 
					  localTax.tax_type_id = val.id
 | 
				
			||||||
 | 
					  localTax.compound_tax = val.compound_tax
 | 
				
			||||||
  localTax.name = val.name
 | 
					  localTax.name = val.name
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  updateRowTax()
 | 
					  updateRowTax()
 | 
				
			||||||
@ -226,27 +227,6 @@ function openTaxModal() {
 | 
				
			|||||||
function removeTax(index) {
 | 
					function removeTax(index) {
 | 
				
			||||||
  props.store.$patch((state) => {
 | 
					  props.store.$patch((state) => {
 | 
				
			||||||
    state[props.storeProp].items[props.itemIndex].taxes.splice(index, 1)
 | 
					    state[props.storeProp].items[props.itemIndex].taxes.splice(index, 1)
 | 
				
			||||||
    state[props.storeProp].items[props.itemIndex].tax = 0
 | 
					 | 
				
			||||||
    state[props.storeProp].items[props.itemIndex].totalTax = 0
 | 
					 | 
				
			||||||
  })
 | 
					  })
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					 | 
				
			||||||
function getTaxAmount() {
 | 
					 | 
				
			||||||
  let total = 0
 | 
					 | 
				
			||||||
  let discount = 0
 | 
					 | 
				
			||||||
  const itemTotal = props.discountedTotal
 | 
					 | 
				
			||||||
  const modelDiscount = props.store[props.storeProp].discount ? props.store[props.storeProp].discount : 0
 | 
					 | 
				
			||||||
  const type = props.store[props.storeProp].discount_type
 | 
					 | 
				
			||||||
  if (modelDiscount > 0) {
 | 
					 | 
				
			||||||
    props.store[props.storeProp].items.forEach((_i) => {
 | 
					 | 
				
			||||||
      total += _i.total
 | 
					 | 
				
			||||||
    })
 | 
					 | 
				
			||||||
    const proportion = (itemTotal / total).toFixed(2)
 | 
					 | 
				
			||||||
    discount = type === 'fixed' ? modelDiscount * 100 : (total * modelDiscount) / 100
 | 
					 | 
				
			||||||
    const itemDiscount = Math.round(discount * proportion)
 | 
					 | 
				
			||||||
    const discounted = itemTotal - itemDiscount
 | 
					 | 
				
			||||||
    return Math.round((discounted * localTax.percent) / 100)
 | 
					 | 
				
			||||||
  }
 | 
					 | 
				
			||||||
  return Math.round((props.discountedTotal * localTax.percent) / 100)
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
</script>
 | 
					</script>
 | 
				
			||||||
 | 
				
			|||||||
@ -29,7 +29,14 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
      <label
 | 
					      <label
 | 
				
			||||||
        v-else
 | 
					        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
 | 
					        <BaseFormatMoney
 | 
				
			||||||
          :amount="store.getSubTotal"
 | 
					          :amount="store.getSubTotal"
 | 
				
			||||||
@ -59,7 +66,14 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
      <label
 | 
					      <label
 | 
				
			||||||
        v-else-if="store[storeProp].tax_per_item === 'YES'"
 | 
					        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" />
 | 
					        <BaseFormatMoney :amount="tax.amount" :currency="defaultCurrency" />
 | 
				
			||||||
      </label>
 | 
					      </label>
 | 
				
			||||||
@ -84,7 +98,7 @@
 | 
				
			|||||||
      <BaseContentPlaceholders v-if="isLoading">
 | 
					      <BaseContentPlaceholders v-if="isLoading">
 | 
				
			||||||
        <BaseContentPlaceholdersText
 | 
					        <BaseContentPlaceholdersText
 | 
				
			||||||
          :lines="1"
 | 
					          :lines="1"
 | 
				
			||||||
          class="w-24 h-8 border rounded-md"
 | 
					          class="w-24 h-8 rounded-md border"
 | 
				
			||||||
        />
 | 
					        />
 | 
				
			||||||
      </BaseContentPlaceholders>
 | 
					      </BaseContentPlaceholders>
 | 
				
			||||||
      <div v-else class="flex" style="width: 140px" role="group">
 | 
					      <div v-else class="flex" style="width: 140px" role="group">
 | 
				
			||||||
@ -100,7 +114,7 @@
 | 
				
			|||||||
        <BaseDropdown position="bottom-end">
 | 
					        <BaseDropdown position="bottom-end">
 | 
				
			||||||
          <template #activator>
 | 
					          <template #activator>
 | 
				
			||||||
            <BaseButton
 | 
					            <BaseButton
 | 
				
			||||||
              class="p-2 rounded-none rounded-tr-md rounded-br-md"
 | 
					              class="rounded-tr-md rounded-br-md p-2 rounded-none"
 | 
				
			||||||
              type="button"
 | 
					              type="button"
 | 
				
			||||||
              variant="white"
 | 
					              variant="white"
 | 
				
			||||||
            >
 | 
					            >
 | 
				
			||||||
@ -113,7 +127,7 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
                <BaseIcon
 | 
					                <BaseIcon
 | 
				
			||||||
                  name="ChevronDownIcon"
 | 
					                  name="ChevronDownIcon"
 | 
				
			||||||
                  class="w-4 h-4 ml-1 text-gray-500"
 | 
					                  class="w-4 h-4 text-gray-500 ml-1"
 | 
				
			||||||
                />
 | 
					                />
 | 
				
			||||||
              </span>
 | 
					              </span>
 | 
				
			||||||
            </BaseButton>
 | 
					            </BaseButton>
 | 
				
			||||||
@ -166,7 +180,15 @@
 | 
				
			|||||||
    </div>
 | 
					    </div>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    <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">
 | 
					      <BaseContentPlaceholders v-if="isLoading">
 | 
				
			||||||
        <BaseContentPlaceholdersText :lines="1" class="w-16 h-5" />
 | 
					        <BaseContentPlaceholdersText :lines="1" class="w-16 h-5" />
 | 
				
			||||||
@ -182,7 +204,14 @@
 | 
				
			|||||||
      </BaseContentPlaceholders>
 | 
					      </BaseContentPlaceholders>
 | 
				
			||||||
      <label
 | 
					      <label
 | 
				
			||||||
        v-else
 | 
					        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" />
 | 
					        <BaseFormatMoney :amount="store.getTotal" :currency="defaultCurrency" />
 | 
				
			||||||
      </label>
 | 
					      </label>
 | 
				
			||||||
@ -191,7 +220,7 @@
 | 
				
			|||||||
</template>
 | 
					</template>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
<script setup>
 | 
					<script setup>
 | 
				
			||||||
import { computed, inject, ref, watch } from 'vue'
 | 
					import { computed, inject, ref } from 'vue'
 | 
				
			||||||
import Guid from 'guid'
 | 
					import Guid from 'guid'
 | 
				
			||||||
import Tax from './CreateTotalTaxes.vue'
 | 
					import Tax from './CreateTotalTaxes.vue'
 | 
				
			||||||
import TaxStub from '@/scripts/admin/stub/abilities'
 | 
					import TaxStub from '@/scripts/admin/stub/abilities'
 | 
				
			||||||
@ -227,20 +256,19 @@ const utils = inject('$utils')
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
const companyStore = useCompanyStore()
 | 
					const companyStore = useCompanyStore()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
watch(
 | 
					 | 
				
			||||||
  () => props.store[props.storeProp].items,
 | 
					 | 
				
			||||||
  (val) => {
 | 
					 | 
				
			||||||
    setDiscount()
 | 
					 | 
				
			||||||
  }, { deep: true },
 | 
					 | 
				
			||||||
)
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
const totalDiscount = computed({
 | 
					const totalDiscount = computed({
 | 
				
			||||||
  get: () => {
 | 
					  get: () => {
 | 
				
			||||||
    return props.store[props.storeProp].discount
 | 
					    return props.store[props.storeProp].discount
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
  set: (newValue) => {
 | 
					  set: (newValue) => {
 | 
				
			||||||
 | 
					    if (props.store[props.storeProp].discount_type === 'percentage') {
 | 
				
			||||||
 | 
					      props.store[props.storeProp].discount_val = Math.round(
 | 
				
			||||||
 | 
					        (props.store.getSubTotal * newValue) / 100
 | 
				
			||||||
 | 
					      )
 | 
				
			||||||
 | 
					    } else {
 | 
				
			||||||
 | 
					      props.store[props.storeProp].discount_val = Math.round(newValue * 100)
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
    props.store[props.storeProp].discount = newValue
 | 
					    props.store[props.storeProp].discount = newValue
 | 
				
			||||||
    setDiscount()
 | 
					 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
})
 | 
					})
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@ -266,7 +294,7 @@ const itemWiseTaxes = computed(() => {
 | 
				
			|||||||
        } else if (tax.tax_type_id) {
 | 
					        } else if (tax.tax_type_id) {
 | 
				
			||||||
          taxes.push({
 | 
					          taxes.push({
 | 
				
			||||||
            tax_type_id: tax.tax_type_id,
 | 
					            tax_type_id: tax.tax_type_id,
 | 
				
			||||||
            amount: Math.round(tax.amount),
 | 
					            amount: tax.amount,
 | 
				
			||||||
            percent: tax.percent,
 | 
					            percent: tax.percent,
 | 
				
			||||||
            name: tax.name,
 | 
					            name: tax.name,
 | 
				
			||||||
          })
 | 
					          })
 | 
				
			||||||
@ -285,19 +313,6 @@ const defaultCurrency = computed(() => {
 | 
				
			|||||||
  }
 | 
					  }
 | 
				
			||||||
})
 | 
					})
 | 
				
			||||||
 | 
					
 | 
				
			||||||
function setDiscount() {
 | 
					 | 
				
			||||||
  const newValue = props.store[props.storeProp].discount
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  if (props.store[props.storeProp].discount_type === 'percentage') {
 | 
					 | 
				
			||||||
    props.store[props.storeProp].discount_val
 | 
					 | 
				
			||||||
      = Math.round((props.store.getSubTotal * newValue) / 100)
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    return
 | 
					 | 
				
			||||||
  }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  props.store[props.storeProp].discount_val = Math.round(newValue * 100)
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
function selectFixed() {
 | 
					function selectFixed() {
 | 
				
			||||||
  if (props.store[props.storeProp].discount_type === 'fixed') {
 | 
					  if (props.store[props.storeProp].discount_type === 'fixed') {
 | 
				
			||||||
    return
 | 
					    return
 | 
				
			||||||
@ -312,18 +327,20 @@ function selectPercentage() {
 | 
				
			|||||||
  if (props.store[props.storeProp].discount_type === 'percentage') {
 | 
					  if (props.store[props.storeProp].discount_type === 'percentage') {
 | 
				
			||||||
    return
 | 
					    return
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
 | 
					  props.store[props.storeProp].discount_val =
 | 
				
			||||||
  const val = Math.round(props.store[props.storeProp].discount * 100) / 100
 | 
					    (props.store.getSubTotal * props.store[props.storeProp].discount) / 100
 | 
				
			||||||
 | 
					 | 
				
			||||||
  props.store[props.storeProp].discount_val
 | 
					 | 
				
			||||||
    = Math.round((props.store.getSubTotal * val) / 100)
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  props.store[props.storeProp].discount_type = 'percentage'
 | 
					  props.store[props.storeProp].discount_type = 'percentage'
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
function onSelectTax(selectedTax) {
 | 
					function onSelectTax(selectedTax) {
 | 
				
			||||||
  let amount = 0
 | 
					  let amount = 0
 | 
				
			||||||
  if (props.store.getSubtotalWithDiscount && selectedTax.percent) {
 | 
					  if (selectedTax.compound_tax && props.store.getSubtotalWithDiscount) {
 | 
				
			||||||
 | 
					    amount = Math.round(
 | 
				
			||||||
 | 
					      ((props.store.getSubtotalWithDiscount + props.store.getTotalSimpleTax) *
 | 
				
			||||||
 | 
					        selectedTax.percent) /
 | 
				
			||||||
 | 
					        100
 | 
				
			||||||
 | 
					    )
 | 
				
			||||||
 | 
					  } else if (props.store.getSubtotalWithDiscount && selectedTax.percent) {
 | 
				
			||||||
    amount = Math.round(
 | 
					    amount = Math.round(
 | 
				
			||||||
      (props.store.getSubtotalWithDiscount * selectedTax.percent) / 100
 | 
					      (props.store.getSubtotalWithDiscount * selectedTax.percent) / 100
 | 
				
			||||||
    )
 | 
					    )
 | 
				
			||||||
@ -334,6 +351,7 @@ function onSelectTax(selectedTax) {
 | 
				
			|||||||
    id: Guid.raw(),
 | 
					    id: Guid.raw(),
 | 
				
			||||||
    name: selectedTax.name,
 | 
					    name: selectedTax.name,
 | 
				
			||||||
    percent: selectedTax.percent,
 | 
					    percent: selectedTax.percent,
 | 
				
			||||||
 | 
					    compound_tax: selectedTax.compound_tax,
 | 
				
			||||||
    tax_type_id: selectedTax.id,
 | 
					    tax_type_id: selectedTax.id,
 | 
				
			||||||
    amount,
 | 
					    amount,
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
 | 
				
			|||||||
@ -77,6 +77,17 @@
 | 
				
			|||||||
              @input="v$.currentTaxType.description.$touch()"
 | 
					              @input="v$.currentTaxType.description.$touch()"
 | 
				
			||||||
            />
 | 
					            />
 | 
				
			||||||
          </BaseInputGroup>
 | 
					          </BaseInputGroup>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					          <BaseInputGroup
 | 
				
			||||||
 | 
					            :label="$t('tax_types.compound_tax')"
 | 
				
			||||||
 | 
					            variant="horizontal"
 | 
				
			||||||
 | 
					            class="flex flex-row-reverse"
 | 
				
			||||||
 | 
					          >
 | 
				
			||||||
 | 
					            <BaseSwitch
 | 
				
			||||||
 | 
					              v-model="taxTypeStore.currentTaxType.compound_tax"
 | 
				
			||||||
 | 
					              class="flex items-center"
 | 
				
			||||||
 | 
					            />
 | 
				
			||||||
 | 
					          </BaseInputGroup>
 | 
				
			||||||
        </BaseInputGrid>
 | 
					        </BaseInputGrid>
 | 
				
			||||||
      </div>
 | 
					      </div>
 | 
				
			||||||
      <div
 | 
					      <div
 | 
				
			||||||
@ -198,7 +209,14 @@ async function submitTaxTypeData() {
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
function SelectTax(taxData) {
 | 
					function SelectTax(taxData) {
 | 
				
			||||||
  let amount = 0
 | 
					  let amount = 0
 | 
				
			||||||
 if (estimateStore.getSubtotalWithDiscount && taxData.percent) {
 | 
					  if (taxData.compound_tax && estimateStore.getSubtotalWithDiscount) {
 | 
				
			||||||
 | 
					    amount = Math.round(
 | 
				
			||||||
 | 
					      ((estimateStore.getSubtotalWithDiscount +
 | 
				
			||||||
 | 
					        estimateStore.getTotalSimpleTax) *
 | 
				
			||||||
 | 
					        taxData.percent) /
 | 
				
			||||||
 | 
					        100
 | 
				
			||||||
 | 
					    )
 | 
				
			||||||
 | 
					  } else if (estimateStore.getSubtotalWithDiscount && taxData.percent) {
 | 
				
			||||||
    amount = Math.round(
 | 
					    amount = Math.round(
 | 
				
			||||||
      (estimateStore.getSubtotalWithDiscount * taxData.percent) / 100
 | 
					      (estimateStore.getSubtotalWithDiscount * taxData.percent) / 100
 | 
				
			||||||
    )
 | 
					    )
 | 
				
			||||||
@ -208,6 +226,7 @@ function SelectTax(taxData) {
 | 
				
			|||||||
    id: Guid.raw(),
 | 
					    id: Guid.raw(),
 | 
				
			||||||
    name: taxData.name,
 | 
					    name: taxData.name,
 | 
				
			||||||
    percent: taxData.percent,
 | 
					    percent: taxData.percent,
 | 
				
			||||||
 | 
					    compound_tax: taxData.compound_tax,
 | 
				
			||||||
    tax_type_id: taxData.id,
 | 
					    tax_type_id: taxData.id,
 | 
				
			||||||
    amount,
 | 
					    amount,
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
@ -223,6 +242,7 @@ function selectItemTax(taxData) {
 | 
				
			|||||||
      id: Guid.raw(),
 | 
					      id: Guid.raw(),
 | 
				
			||||||
      name: taxData.name,
 | 
					      name: taxData.name,
 | 
				
			||||||
      percent: taxData.percent,
 | 
					      percent: taxData.percent,
 | 
				
			||||||
 | 
					      compound_tax: taxData.compound_tax,
 | 
				
			||||||
      tax_type_id: taxData.id,
 | 
					      tax_type_id: taxData.id,
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
    modalStore.refreshData(data)
 | 
					    modalStore.refreshData(data)
 | 
				
			||||||
 | 
				
			|||||||
@ -143,7 +143,7 @@
 | 
				
			|||||||
          <template #activator>
 | 
					          <template #activator>
 | 
				
			||||||
            <img
 | 
					            <img
 | 
				
			||||||
              :src="previewAvatar"
 | 
					              :src="previewAvatar"
 | 
				
			||||||
              class="block w-8 h-8 rounded md:h-9 md:w-9 object-cover"
 | 
					              class="block w-8 h-8 rounded md:h-9 md:w-9"
 | 
				
			||||||
            />
 | 
					            />
 | 
				
			||||||
          </template>
 | 
					          </template>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
				
			|||||||
@ -143,8 +143,7 @@ export const useEstimateStore = (useWindow = false) => {
 | 
				
			|||||||
          axios
 | 
					          axios
 | 
				
			||||||
            .get(`/api/v1/estimates/${id}`)
 | 
					            .get(`/api/v1/estimates/${id}`)
 | 
				
			||||||
            .then((response) => {
 | 
					            .then((response) => {
 | 
				
			||||||
              this.setEstimateData(response.data.data)
 | 
					              Object.assign(this.newEstimate, response.data.data)
 | 
				
			||||||
              this.setCustomerAddresses(this.newEstimate.customer)
 | 
					 | 
				
			||||||
              resolve(response)
 | 
					              resolve(response)
 | 
				
			||||||
            })
 | 
					            })
 | 
				
			||||||
            .catch((err) => {
 | 
					            .catch((err) => {
 | 
				
			||||||
@ -155,41 +154,6 @@ export const useEstimateStore = (useWindow = false) => {
 | 
				
			|||||||
        })
 | 
					        })
 | 
				
			||||||
      },
 | 
					      },
 | 
				
			||||||
 | 
					
 | 
				
			||||||
      setEstimateData(estimate) {
 | 
					 | 
				
			||||||
        Object.assign(this.newEstimate, estimate)
 | 
					 | 
				
			||||||
        if (this.newEstimate.tax_per_item === 'YES') {
 | 
					 | 
				
			||||||
          this.newEstimate.items.forEach((_i) => {
 | 
					 | 
				
			||||||
            if (_i.taxes && !_i.taxes.length){
 | 
					 | 
				
			||||||
              _i.taxes.push({ ...taxStub, id: Guid.raw() })
 | 
					 | 
				
			||||||
            }
 | 
					 | 
				
			||||||
          })
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
        if (this.newEstimate.discount_per_item === 'YES') {
 | 
					 | 
				
			||||||
          this.newEstimate.items.forEach((_i, index) => {
 | 
					 | 
				
			||||||
            if (_i.discount_type === 'fixed'){
 | 
					 | 
				
			||||||
              this.newEstimate.items[index].discount = _i.discount / 100
 | 
					 | 
				
			||||||
            }
 | 
					 | 
				
			||||||
          })
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
        else {
 | 
					 | 
				
			||||||
          if (this.newEstimate.discount_type === 'fixed'){
 | 
					 | 
				
			||||||
            this.newEstimate.discount = this.newEstimate.discount / 100
 | 
					 | 
				
			||||||
          }
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
      },
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
      setCustomerAddresses(customer) {
 | 
					 | 
				
			||||||
        const customer_business = customer.customer_business
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        if (customer_business?.billing_address){
 | 
					 | 
				
			||||||
          this.newEstimate.customer.billing_address = customer_business.billing_address
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        if (customer_business?.shipping_address){
 | 
					 | 
				
			||||||
          this.newEstimate.customer.shipping_address = customer_business.shipping_address
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
      },
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
      addSalesTaxUs() {
 | 
					      addSalesTaxUs() {
 | 
				
			||||||
        const taxTypeStore = useTaxTypeStore()
 | 
					        const taxTypeStore = useTaxTypeStore()
 | 
				
			||||||
        let salesTax = { ...taxStub }
 | 
					        let salesTax = { ...taxStub }
 | 
				
			||||||
 | 
				
			|||||||
@ -133,8 +133,8 @@ export const useInvoiceStore = (useWindow = false) => {
 | 
				
			|||||||
          axios
 | 
					          axios
 | 
				
			||||||
            .get(`/api/v1/invoices/${id}`)
 | 
					            .get(`/api/v1/invoices/${id}`)
 | 
				
			||||||
            .then((response) => {
 | 
					            .then((response) => {
 | 
				
			||||||
              this.setInvoiceData(response.data.data)
 | 
					              Object.assign(this.newInvoice, response.data.data)
 | 
				
			||||||
              this.setCustomerAddresses(this.newInvoice.customer)
 | 
					              this.newInvoice.customer = response.data.data.customer
 | 
				
			||||||
              resolve(response)
 | 
					              resolve(response)
 | 
				
			||||||
            })
 | 
					            })
 | 
				
			||||||
            .catch((err) => {
 | 
					            .catch((err) => {
 | 
				
			||||||
@ -144,38 +144,6 @@ export const useInvoiceStore = (useWindow = false) => {
 | 
				
			|||||||
        })
 | 
					        })
 | 
				
			||||||
      },
 | 
					      },
 | 
				
			||||||
 | 
					
 | 
				
			||||||
      setInvoiceData(invoice) {
 | 
					 | 
				
			||||||
        Object.assign(this.newInvoice, invoice)
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        if (this.newInvoice.tax_per_item === 'YES') {
 | 
					 | 
				
			||||||
          this.newInvoice.items.forEach((_i) => {
 | 
					 | 
				
			||||||
            if (_i.taxes && !_i.taxes.length)
 | 
					 | 
				
			||||||
              _i.taxes.push({ ...taxStub, id: Guid.raw() })
 | 
					 | 
				
			||||||
          })
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        if (this.newInvoice.discount_per_item === 'YES') {
 | 
					 | 
				
			||||||
          this.newInvoice.items.forEach((_i, index) => {
 | 
					 | 
				
			||||||
            if (_i.discount_type === 'fixed')
 | 
					 | 
				
			||||||
              this.newInvoice.items[index].discount = _i.discount / 100
 | 
					 | 
				
			||||||
          })
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
        else {
 | 
					 | 
				
			||||||
          if (this.newInvoice.discount_type === 'fixed')
 | 
					 | 
				
			||||||
            this.newInvoice.discount = this.newInvoice.discount / 100
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
      },
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
      setCustomerAddresses(customer) {
 | 
					 | 
				
			||||||
        const customer_business = customer.customer_business
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        if (customer_business?.billing_address)
 | 
					 | 
				
			||||||
          this.newInvoice.customer.billing_address = customer_business.billing_address
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        if (customer_business?.shipping_address)
 | 
					 | 
				
			||||||
          this.newInvoice.customer.shipping_address = customer_business.shipping_address
 | 
					 | 
				
			||||||
      },
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
      addSalesTaxUs() {
 | 
					      addSalesTaxUs() {
 | 
				
			||||||
        const taxTypeStore = useTaxTypeStore()
 | 
					        const taxTypeStore = useTaxTypeStore()
 | 
				
			||||||
        let salesTax = { ...taxStub }
 | 
					        let salesTax = { ...taxStub }
 | 
				
			||||||
 | 
				
			|||||||
@ -138,7 +138,6 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
<script setup>
 | 
					<script setup>
 | 
				
			||||||
import { computed, ref, watch, onMounted } from 'vue'
 | 
					import { computed, ref, watch, onMounted } from 'vue'
 | 
				
			||||||
import { cloneDeep } from 'lodash'
 | 
					 | 
				
			||||||
import { useRoute, useRouter } from 'vue-router'
 | 
					import { useRoute, useRouter } from 'vue-router'
 | 
				
			||||||
import { useI18n } from 'vue-i18n'
 | 
					import { useI18n } from 'vue-i18n'
 | 
				
			||||||
import {
 | 
					import {
 | 
				
			||||||
@ -258,30 +257,11 @@ async function submitForm() {
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
  isSaving.value = true
 | 
					  isSaving.value = true
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  let data = cloneDeep({
 | 
					  let data = {
 | 
				
			||||||
    ...estimateStore.newEstimate,
 | 
					    ...estimateStore.newEstimate,
 | 
				
			||||||
    sub_total: estimateStore.getSubTotal,
 | 
					    sub_total: estimateStore.getSubTotal,
 | 
				
			||||||
    total: estimateStore.getTotal,
 | 
					    total: estimateStore.getTotal,
 | 
				
			||||||
    tax: estimateStore.getTotalTax,
 | 
					    tax: estimateStore.getTotalTax,
 | 
				
			||||||
  })
 | 
					 | 
				
			||||||
  if (data.discount_per_item === 'YES') {
 | 
					 | 
				
			||||||
    data.items.forEach((item, index) => {
 | 
					 | 
				
			||||||
      if (item.discount_type === 'fixed'){
 | 
					 | 
				
			||||||
        data.items[index].discount = Math.round(item.discount * 100)
 | 
					 | 
				
			||||||
      }
 | 
					 | 
				
			||||||
    })
 | 
					 | 
				
			||||||
  }
 | 
					 | 
				
			||||||
  else {
 | 
					 | 
				
			||||||
    if (data.discount_type === 'fixed'){
 | 
					 | 
				
			||||||
      data.discount = Math.round(data.discount * 100)
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
  }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  if (
 | 
					 | 
				
			||||||
    !estimateStore.newEstimate.tax_per_item === 'YES'
 | 
					 | 
				
			||||||
    && data.taxes.length
 | 
					 | 
				
			||||||
  ){
 | 
					 | 
				
			||||||
    data.tax_type_ids = data.taxes.map(_t => _t.tax_type_id)
 | 
					 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  const action = isEdit.value
 | 
					  const action = isEdit.value
 | 
				
			||||||
 | 
				
			|||||||
@ -147,7 +147,6 @@ import {
 | 
				
			|||||||
  decimal,
 | 
					  decimal,
 | 
				
			||||||
} from '@vuelidate/validators'
 | 
					} from '@vuelidate/validators'
 | 
				
			||||||
import useVuelidate from '@vuelidate/core'
 | 
					import useVuelidate from '@vuelidate/core'
 | 
				
			||||||
import { cloneDeep } from 'lodash'
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
import { useInvoiceStore } from '@/scripts/admin/stores/invoice'
 | 
					import { useInvoiceStore } from '@/scripts/admin/stores/invoice'
 | 
				
			||||||
import { useModuleStore } from '@/scripts/admin/stores/module'
 | 
					import { useModuleStore } from '@/scripts/admin/stores/module'
 | 
				
			||||||
@ -259,29 +258,11 @@ async function submitForm() {
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
  isSaving.value = true
 | 
					  isSaving.value = true
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  let data = cloneDeep({
 | 
					  let data = {
 | 
				
			||||||
    ...invoiceStore.newInvoice,
 | 
					    ...invoiceStore.newInvoice,
 | 
				
			||||||
    sub_total: invoiceStore.getSubTotal,
 | 
					    sub_total: invoiceStore.getSubTotal,
 | 
				
			||||||
    total: invoiceStore.getTotal,
 | 
					    total: invoiceStore.getTotal,
 | 
				
			||||||
    tax: invoiceStore.getTotalTax,
 | 
					    tax: invoiceStore.getTotalTax,
 | 
				
			||||||
  })
 | 
					 | 
				
			||||||
  if (data.discount_per_item === 'YES') {
 | 
					 | 
				
			||||||
    data.items.forEach((item, index) => {
 | 
					 | 
				
			||||||
      if (item.discount_type === 'fixed'){
 | 
					 | 
				
			||||||
        data.items[index].discount = item.discount * 100
 | 
					 | 
				
			||||||
      }
 | 
					 | 
				
			||||||
    })
 | 
					 | 
				
			||||||
  }
 | 
					 | 
				
			||||||
  else {
 | 
					 | 
				
			||||||
    if (data.discount_type === 'fixed'){
 | 
					 | 
				
			||||||
      data.discount = data.discount * 100
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
  }
 | 
					 | 
				
			||||||
    if (
 | 
					 | 
				
			||||||
    !invoiceStore.newInvoice.tax_per_item === 'YES'
 | 
					 | 
				
			||||||
    && data.taxes.length
 | 
					 | 
				
			||||||
  ){
 | 
					 | 
				
			||||||
    data.tax_type_ids = data.taxes.map(_t => _t.tax_type_id)
 | 
					 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  try {
 | 
					  try {
 | 
				
			||||||
 | 
				
			|||||||
@ -20,6 +20,21 @@
 | 
				
			|||||||
      :data="fetchData"
 | 
					      :data="fetchData"
 | 
				
			||||||
      :columns="taxTypeColumns"
 | 
					      :columns="taxTypeColumns"
 | 
				
			||||||
    >
 | 
					    >
 | 
				
			||||||
 | 
					      <template #cell-compound_tax="{ row }">
 | 
				
			||||||
 | 
					        <BaseBadge
 | 
				
			||||||
 | 
					          :bg-color="
 | 
				
			||||||
 | 
					            utils.getBadgeStatusColor(row.data.compound_tax ? 'YES' : 'NO')
 | 
				
			||||||
 | 
					              .bgColor
 | 
				
			||||||
 | 
					          "
 | 
				
			||||||
 | 
					          :color="
 | 
				
			||||||
 | 
					            utils.getBadgeStatusColor(row.data.compound_tax ? 'YES' : 'NO')
 | 
				
			||||||
 | 
					              .color
 | 
				
			||||||
 | 
					          "
 | 
				
			||||||
 | 
					        >
 | 
				
			||||||
 | 
					          {{ row.data.compound_tax ? 'Yes' : 'No'.replace('_', ' ') }}
 | 
				
			||||||
 | 
					        </BaseBadge>
 | 
				
			||||||
 | 
					      </template>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
      <template #cell-percent="{ row }"> {{ row.data.percent }} % </template>
 | 
					      <template #cell-percent="{ row }"> {{ row.data.percent }} % </template>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
      <template v-if="hasAtleastOneAbility()" #cell-actions="{ row }">
 | 
					      <template v-if="hasAtleastOneAbility()" #cell-actions="{ row }">
 | 
				
			||||||
@ -76,6 +91,11 @@ const taxTypeColumns = computed(() => {
 | 
				
			|||||||
      thClass: 'extra',
 | 
					      thClass: 'extra',
 | 
				
			||||||
      tdClass: 'font-medium text-gray-900',
 | 
					      tdClass: 'font-medium text-gray-900',
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					      key: 'compound_tax',
 | 
				
			||||||
 | 
					      label: t('settings.tax_types.compound_tax'),
 | 
				
			||||||
 | 
					      tdClass: 'font-medium text-gray-900',
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
    {
 | 
					    {
 | 
				
			||||||
      key: 'percent',
 | 
					      key: 'percent',
 | 
				
			||||||
      label: t('settings.tax_types.percent'),
 | 
					      label: t('settings.tax_types.percent'),
 | 
				
			||||||
 | 
				
			|||||||
@ -309,8 +309,6 @@ function changeSorting(column) {
 | 
				
			|||||||
  }
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  if (!usesLocalData.value) {
 | 
					  if (!usesLocalData.value) {
 | 
				
			||||||
    if (pagination.value)
 | 
					 | 
				
			||||||
      pagination.value.currentPage = 1
 | 
					 | 
				
			||||||
    mapDataToRows()
 | 
					    mapDataToRows()
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
@ -328,10 +326,7 @@ async function pageChange(page) {
 | 
				
			|||||||
  await mapDataToRows()
 | 
					  await mapDataToRows()
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
async function refresh(isPreservePage = false) {
 | 
					async function refresh() {
 | 
				
			||||||
  if (pagination.value && !isPreservePage)
 | 
					 | 
				
			||||||
    pagination.value.currentPage = 1
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  await mapDataToRows()
 | 
					  await mapDataToRows()
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
				
			|||||||
@ -133,6 +133,7 @@
 | 
				
			|||||||
            line-height: 21px;
 | 
					            line-height: 21px;
 | 
				
			||||||
            color: #5851D8;
 | 
					            color: #5851D8;
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    </style>
 | 
					    </style>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    @if (App::isLocale('th'))
 | 
					    @if (App::isLocale('th'))
 | 
				
			||||||
@ -169,7 +170,7 @@
 | 
				
			|||||||
                        </td>
 | 
					                        </td>
 | 
				
			||||||
                        <td>
 | 
					                        <td>
 | 
				
			||||||
                            <p class="expense-amount">
 | 
					                            <p class="expense-amount">
 | 
				
			||||||
                            {!! format_money_pdf($expenseCategory->total_amount, $currency) !!}
 | 
					                                {!! format_money_pdf($expenseCategory->total_amount) !!}
 | 
				
			||||||
                            </p>
 | 
					                            </p>
 | 
				
			||||||
                        </td>
 | 
					                        </td>
 | 
				
			||||||
                    </tr>
 | 
					                    </tr>
 | 
				
			||||||
@ -181,7 +182,7 @@
 | 
				
			|||||||
    <table class="expense-total-table">
 | 
					    <table class="expense-total-table">
 | 
				
			||||||
        <tr>
 | 
					        <tr>
 | 
				
			||||||
            <td class="expense-total-cell">
 | 
					            <td class="expense-total-cell">
 | 
				
			||||||
                <p class="expense-total">{!! format_money_pdf($totalExpense, $currency) !!}</p>
 | 
					                <p class="expense-total">{!! format_money_pdf($totalExpense) !!}</p>
 | 
				
			||||||
            </td>
 | 
					            </td>
 | 
				
			||||||
        </tr>
 | 
					        </tr>
 | 
				
			||||||
    </table>
 | 
					    </table>
 | 
				
			||||||
@ -191,7 +192,7 @@
 | 
				
			|||||||
                <p class="report-footer-label">@lang('pdf_total_expenses_label')</p>
 | 
					                <p class="report-footer-label">@lang('pdf_total_expenses_label')</p>
 | 
				
			||||||
            </td>
 | 
					            </td>
 | 
				
			||||||
            <td>
 | 
					            <td>
 | 
				
			||||||
                <p class="report-footer-value">{!! format_money_pdf($totalExpense, $currency) !!}</p>
 | 
					                <p class="report-footer-value">{!! format_money_pdf($totalExpense) !!}</p>
 | 
				
			||||||
            </td>
 | 
					            </td>
 | 
				
			||||||
        </tr>
 | 
					        </tr>
 | 
				
			||||||
    </table>
 | 
					    </table>
 | 
				
			||||||
 | 
				
			|||||||
@ -158,6 +158,7 @@
 | 
				
			|||||||
            line-height: 21px;
 | 
					            line-height: 21px;
 | 
				
			||||||
            color: #5851D8;
 | 
					            color: #5851D8;
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    </style>
 | 
					    </style>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    @if (App::isLocale('th'))
 | 
					    @if (App::isLocale('th'))
 | 
				
			||||||
@ -189,7 +190,7 @@
 | 
				
			|||||||
                    <p class="income-title">@lang("pdf_income_label")</p>
 | 
					                    <p class="income-title">@lang("pdf_income_label")</p>
 | 
				
			||||||
                </td>
 | 
					                </td>
 | 
				
			||||||
                <td>
 | 
					                <td>
 | 
				
			||||||
                    <p class="income-amount">{!! format_money_pdf($income, $currency) !!}</p>
 | 
					                    <p class="income-amount">{!! format_money_pdf($income) !!}</p>
 | 
				
			||||||
                </td>
 | 
					                </td>
 | 
				
			||||||
            </tr>
 | 
					            </tr>
 | 
				
			||||||
        </table>
 | 
					        </table>
 | 
				
			||||||
@ -205,7 +206,7 @@
 | 
				
			|||||||
                        </td>
 | 
					                        </td>
 | 
				
			||||||
                        <td>
 | 
					                        <td>
 | 
				
			||||||
                            <p class="expense-amount">
 | 
					                            <p class="expense-amount">
 | 
				
			||||||
                            {!! format_money_pdf($expenseCategory->total_amount, $currency) !!}
 | 
					                                {!! format_money_pdf($expenseCategory->total_amount) !!}
 | 
				
			||||||
                            </p>
 | 
					                            </p>
 | 
				
			||||||
                        </td>
 | 
					                        </td>
 | 
				
			||||||
                    </tr>
 | 
					                    </tr>
 | 
				
			||||||
@ -218,7 +219,7 @@
 | 
				
			|||||||
    <table class="expense-total-indicator-table">
 | 
					    <table class="expense-total-indicator-table">
 | 
				
			||||||
        <tr>
 | 
					        <tr>
 | 
				
			||||||
            <td class="expense-total-cell">
 | 
					            <td class="expense-total-cell">
 | 
				
			||||||
                <p class="expense-total">{!! format_money_pdf($totalExpense, $currency) !!}</p>
 | 
					                <p class="expense-total">{!! format_money_pdf($totalExpense) !!}</p>
 | 
				
			||||||
            </td>
 | 
					            </td>
 | 
				
			||||||
        </tr>
 | 
					        </tr>
 | 
				
			||||||
    </table>
 | 
					    </table>
 | 
				
			||||||
@ -228,7 +229,7 @@
 | 
				
			|||||||
                <p class="report-footer-label">@lang("pdf_net_profit_label")</p>
 | 
					                <p class="report-footer-label">@lang("pdf_net_profit_label")</p>
 | 
				
			||||||
            </td>
 | 
					            </td>
 | 
				
			||||||
            <td>
 | 
					            <td>
 | 
				
			||||||
                <p class="report-footer-value">{!! format_money_pdf($income - $totalExpense, $currency) !!}</p>
 | 
					                <p class="report-footer-value">{!! format_money_pdf($income - $totalExpense) !!}</p>
 | 
				
			||||||
            </td>
 | 
					            </td>
 | 
				
			||||||
        </tr>
 | 
					        </tr>
 | 
				
			||||||
    </table>
 | 
					    </table>
 | 
				
			||||||
 | 
				
			|||||||
@ -137,6 +137,7 @@
 | 
				
			|||||||
        .text-center {
 | 
					        .text-center {
 | 
				
			||||||
            text-align: center;
 | 
					            text-align: center;
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    </style>
 | 
					    </style>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    @if (App::isLocale('th'))
 | 
					    @if (App::isLocale('th'))
 | 
				
			||||||
@ -175,7 +176,7 @@
 | 
				
			|||||||
                            </td>
 | 
					                            </td>
 | 
				
			||||||
                            <td>
 | 
					                            <td>
 | 
				
			||||||
                                <p class="sales-amount">
 | 
					                                <p class="sales-amount">
 | 
				
			||||||
                            {!! format_money_pdf($invoice->base_total, $currency) !!}
 | 
					                                    {!! format_money_pdf($invoice->base_total) !!}
 | 
				
			||||||
                                </p>
 | 
					                                </p>
 | 
				
			||||||
                            </td>
 | 
					                            </td>
 | 
				
			||||||
                        </tr>
 | 
					                        </tr>
 | 
				
			||||||
@ -186,7 +187,7 @@
 | 
				
			|||||||
                <tr>
 | 
					                <tr>
 | 
				
			||||||
                    <td class="sales-total-cell">
 | 
					                    <td class="sales-total-cell">
 | 
				
			||||||
                        <p class="sales-total-amount">
 | 
					                        <p class="sales-total-amount">
 | 
				
			||||||
                        {!! format_money_pdf($customer->totalAmount, $currency) !!}
 | 
					                            {!! format_money_pdf($customer->totalAmount) !!}
 | 
				
			||||||
                        </p>
 | 
					                        </p>
 | 
				
			||||||
                    </td>
 | 
					                    </td>
 | 
				
			||||||
                </tr>
 | 
					                </tr>
 | 
				
			||||||
@ -202,7 +203,7 @@
 | 
				
			|||||||
            </td>
 | 
					            </td>
 | 
				
			||||||
            <td>
 | 
					            <td>
 | 
				
			||||||
                <p class="report-footer-value">
 | 
					                <p class="report-footer-value">
 | 
				
			||||||
                    {!! format_money_pdf($totalAmount, $currency) !!}
 | 
					                    {!! format_money_pdf($totalAmount) !!}
 | 
				
			||||||
                </p>
 | 
					                </p>
 | 
				
			||||||
            </td>
 | 
					            </td>
 | 
				
			||||||
        </tr>
 | 
					        </tr>
 | 
				
			||||||
 | 
				
			|||||||
@ -137,6 +137,7 @@
 | 
				
			|||||||
        .text-center {
 | 
					        .text-center {
 | 
				
			||||||
            text-align: center;
 | 
					            text-align: center;
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    </style>
 | 
					    </style>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    @if (App::isLocale('th'))
 | 
					    @if (App::isLocale('th'))
 | 
				
			||||||
@ -174,7 +175,7 @@
 | 
				
			|||||||
                        </td>
 | 
					                        </td>
 | 
				
			||||||
                        <td>
 | 
					                        <td>
 | 
				
			||||||
                            <p class="item-sales-amount">
 | 
					                            <p class="item-sales-amount">
 | 
				
			||||||
                            {!! format_money_pdf($item->total_amount, $currency) !!}
 | 
					                                {!! format_money_pdf($item->total_amount) !!}
 | 
				
			||||||
                            </p>
 | 
					                            </p>
 | 
				
			||||||
                        </td>
 | 
					                        </td>
 | 
				
			||||||
                    </tr>
 | 
					                    </tr>
 | 
				
			||||||
@ -186,7 +187,7 @@
 | 
				
			|||||||
            <tr>
 | 
					            <tr>
 | 
				
			||||||
                <td class="sales-total-cell">
 | 
					                <td class="sales-total-cell">
 | 
				
			||||||
                    <p class="sales-total-amount">
 | 
					                    <p class="sales-total-amount">
 | 
				
			||||||
                        {!! format_money_pdf($totalAmount, $currency) !!}
 | 
					                        {!! format_money_pdf($totalAmount) !!}
 | 
				
			||||||
                    </p>
 | 
					                    </p>
 | 
				
			||||||
                </td>
 | 
					                </td>
 | 
				
			||||||
            </tr>
 | 
					            </tr>
 | 
				
			||||||
@ -201,7 +202,7 @@
 | 
				
			|||||||
            </td>
 | 
					            </td>
 | 
				
			||||||
            <td>
 | 
					            <td>
 | 
				
			||||||
                <p class="report-footer-value">
 | 
					                <p class="report-footer-value">
 | 
				
			||||||
                    {!! format_money_pdf($totalAmount, $currency) !!}
 | 
					                    {!! format_money_pdf($totalAmount) !!}
 | 
				
			||||||
                </p>
 | 
					                </p>
 | 
				
			||||||
            </td>
 | 
					            </td>
 | 
				
			||||||
        </tr>
 | 
					        </tr>
 | 
				
			||||||
 | 
				
			|||||||
@ -134,6 +134,7 @@
 | 
				
			|||||||
            line-height: 21px;
 | 
					            line-height: 21px;
 | 
				
			||||||
            color: #5851D8;
 | 
					            color: #5851D8;
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    </style>
 | 
					    </style>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    @if (App::isLocale('th'))
 | 
					    @if (App::isLocale('th'))
 | 
				
			||||||
@ -174,7 +175,7 @@
 | 
				
			|||||||
                        </td>
 | 
					                        </td>
 | 
				
			||||||
                        <td>
 | 
					                        <td>
 | 
				
			||||||
                            <p class="tax-amount">
 | 
					                            <p class="tax-amount">
 | 
				
			||||||
                            {!! format_money_pdf($tax->total_tax_amount, $currency) !!}
 | 
					                                {!! format_money_pdf($tax->total_tax_amount) !!}
 | 
				
			||||||
                            </p>
 | 
					                            </p>
 | 
				
			||||||
                        </td>
 | 
					                        </td>
 | 
				
			||||||
                    </tr>
 | 
					                    </tr>
 | 
				
			||||||
@ -188,7 +189,7 @@
 | 
				
			|||||||
        <tr>
 | 
					        <tr>
 | 
				
			||||||
            <td class="tax-total-cell">
 | 
					            <td class="tax-total-cell">
 | 
				
			||||||
                <p class="tax-total">
 | 
					                <p class="tax-total">
 | 
				
			||||||
                    {!! format_money_pdf($totalTaxAmount, $currency) !!}
 | 
					                    {!! format_money_pdf($totalTaxAmount) !!}
 | 
				
			||||||
                </p>
 | 
					                </p>
 | 
				
			||||||
            </td>
 | 
					            </td>
 | 
				
			||||||
        </tr>
 | 
					        </tr>
 | 
				
			||||||
@ -200,7 +201,7 @@
 | 
				
			|||||||
            </td>
 | 
					            </td>
 | 
				
			||||||
            <td>
 | 
					            <td>
 | 
				
			||||||
                <p class="report-footer-value">
 | 
					                <p class="report-footer-value">
 | 
				
			||||||
                    {!! format_money_pdf($totalTaxAmount, $currency) !!}
 | 
					                    {!! format_money_pdf($totalTaxAmount) !!}
 | 
				
			||||||
                </p>
 | 
					                </p>
 | 
				
			||||||
            </td>
 | 
					            </td>
 | 
				
			||||||
        </tr>
 | 
					        </tr>
 | 
				
			||||||
 | 
				
			|||||||
@ -1,40 +0,0 @@
 | 
				
			|||||||
APP_ENV=production
 | 
					 | 
				
			||||||
APP_KEY=base64:kgk/4DW1vEVy7aEvet5FPp5un6PIGe/so8H0mvoUtW0=
 | 
					 | 
				
			||||||
APP_DEBUG=true
 | 
					 | 
				
			||||||
APP_LOG_LEVEL=debug
 | 
					 | 
				
			||||||
APP_URL=http://crater.test
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
DB_CONNECTION=mysql
 | 
					 | 
				
			||||||
DB_HOST=127.0.0.1
 | 
					 | 
				
			||||||
DB_PORT=3306
 | 
					 | 
				
			||||||
DB_DATABASE=crater
 | 
					 | 
				
			||||||
DB_USERNAME=crater
 | 
					 | 
				
			||||||
DB_PASSWORD=crater
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
BROADCAST_DRIVER=log
 | 
					 | 
				
			||||||
CACHE_DRIVER=file
 | 
					 | 
				
			||||||
QUEUE_DRIVER=sync
 | 
					 | 
				
			||||||
SESSION_DRIVER=cookie
 | 
					 | 
				
			||||||
SESSION_LIFETIME=1440
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
REDIS_HOST=127.0.0.1
 | 
					 | 
				
			||||||
REDIS_PASSWORD=null
 | 
					 | 
				
			||||||
REDIS_PORT=6379
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
MAIL_DRIVER=smtp
 | 
					 | 
				
			||||||
MAIL_HOST=
 | 
					 | 
				
			||||||
MAIL_PORT=
 | 
					 | 
				
			||||||
MAIL_USERNAME=
 | 
					 | 
				
			||||||
MAIL_PASSWORD=
 | 
					 | 
				
			||||||
MAIL_ENCRYPTION=
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
PUSHER_APP_ID=
 | 
					 | 
				
			||||||
PUSHER_KEY=
 | 
					 | 
				
			||||||
PUSHER_SECRET=
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
SANCTUM_STATEFUL_DOMAINS=crater.test
 | 
					 | 
				
			||||||
SESSION_DOMAIN=crater.test
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
TRUSTED_PROXIES="*"
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
CRON_JOB_AUTH_TOKEN=""
 | 
					 | 
				
			||||||
@ -1,64 +0,0 @@
 | 
				
			|||||||
FROM php:8.1-fpm
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# Install system dependencies
 | 
					 | 
				
			||||||
RUN apt-get update && apt-get install -y \
 | 
					 | 
				
			||||||
    git \
 | 
					 | 
				
			||||||
    curl \
 | 
					 | 
				
			||||||
    libpng-dev \
 | 
					 | 
				
			||||||
    libonig-dev \
 | 
					 | 
				
			||||||
    libxml2-dev \
 | 
					 | 
				
			||||||
    zip \
 | 
					 | 
				
			||||||
    unzip \
 | 
					 | 
				
			||||||
    libzip-dev \
 | 
					 | 
				
			||||||
    libmagickwand-dev \
 | 
					 | 
				
			||||||
    mariadb-client \
 | 
					 | 
				
			||||||
    npm
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# Clear cache
 | 
					 | 
				
			||||||
RUN apt-get clean && rm -rf /var/lib/apt/lists/*
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
RUN pecl install imagick \
 | 
					 | 
				
			||||||
    && docker-php-ext-enable imagick
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# Install PHP extensions
 | 
					 | 
				
			||||||
RUN docker-php-ext-install pdo_mysql mbstring zip exif pcntl bcmath gd
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# Get latest Composer
 | 
					 | 
				
			||||||
COPY --from=composer:latest /usr/bin/composer /usr/bin/composer
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# Create system user to run Composer and Artisan Commands
 | 
					 | 
				
			||||||
RUN useradd -G www-data,root -u 1000 -d /home/crater-user crater-user
 | 
					 | 
				
			||||||
RUN mkdir -p /home/crater-user/.composer && \
 | 
					 | 
				
			||||||
    chown -R crater-user:crater-user /home/crater-user
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# Mounted volumes
 | 
					 | 
				
			||||||
COPY ./ /var/www
 | 
					 | 
				
			||||||
COPY ./docker-compose/php/uploads.ini /usr/local/etc/php/conf.d/uploads.ini
 | 
					 | 
				
			||||||
COPY ./uffizzi/.env.example /var/www/.env
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# Set working directory
 | 
					 | 
				
			||||||
WORKDIR /var/www
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
RUN chown -R crater-user:crater-user ./
 | 
					 | 
				
			||||||
RUN chmod -R 775 composer.json composer.lock \ 
 | 
					 | 
				
			||||||
        composer.lock storage/framework/ \
 | 
					 | 
				
			||||||
        storage/logs/ bootstrap/cache/ /home/crater-user/.composer
 | 
					 | 
				
			||||||
RUN chown -R $(whoami):$(whoami) /var/log/
 | 
					 | 
				
			||||||
RUN chmod -R 775 /var/log
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# Cleanup manually generated build files
 | 
					 | 
				
			||||||
RUN rm -rf /var/www/public/build
 | 
					 | 
				
			||||||
RUN npm config set user 0
 | 
					 | 
				
			||||||
RUN npm config set unsafe-perm true
 | 
					 | 
				
			||||||
# Frontend bulding
 | 
					 | 
				
			||||||
RUN sed -i 's/DB_CONNECTION=mysql/DB_CONNECTION=sqlite/g' /var/www/.env
 | 
					 | 
				
			||||||
RUN sed -i 's/DB_DATABASE=crater/DB_DATABASE=\/tmp\/crater.sqlite/g' /var/www/.env
 | 
					 | 
				
			||||||
RUN touch /tmp/crater.sqlite
 | 
					 | 
				
			||||||
RUN composer install --no-interaction --prefer-dist
 | 
					 | 
				
			||||||
RUN npm i -f
 | 
					 | 
				
			||||||
RUN npm install --save-dev sass
 | 
					 | 
				
			||||||
RUN export NODE_OPTIONS="--max-old-space-size=4096" && /usr/bin/npx vite build --target=es2020
 | 
					 | 
				
			||||||
RUN sed -i 's/DB_CONNECTION=sqlite/DB_CONNECTION=mysql/g' /var/www/.env
 | 
					 | 
				
			||||||
RUN sed -i 's/DB_DATABASE=\/tmp\/crater.sqlite/DB_DATABASE=crater/g' /var/www/.env
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
USER crater-user
 | 
					 | 
				
			||||||
@ -1,68 +0,0 @@
 | 
				
			|||||||
FROM php:8.1-fpm as build
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# Install system dependencies
 | 
					 | 
				
			||||||
RUN apt-get update && apt-get install -y \
 | 
					 | 
				
			||||||
    git \
 | 
					 | 
				
			||||||
    curl \
 | 
					 | 
				
			||||||
    libpng-dev \
 | 
					 | 
				
			||||||
    libonig-dev \
 | 
					 | 
				
			||||||
    libxml2-dev \
 | 
					 | 
				
			||||||
    zip \
 | 
					 | 
				
			||||||
    unzip \
 | 
					 | 
				
			||||||
    libzip-dev \
 | 
					 | 
				
			||||||
    libmagickwand-dev \
 | 
					 | 
				
			||||||
    mariadb-client
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# Clear cache
 | 
					 | 
				
			||||||
RUN apt-get clean && rm -rf /var/lib/apt/lists/*
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
RUN pecl install imagick \
 | 
					 | 
				
			||||||
    && docker-php-ext-enable imagick
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# Install PHP extensions
 | 
					 | 
				
			||||||
RUN docker-php-ext-install pdo_mysql mbstring zip exif pcntl bcmath gd
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# Get latest Composer
 | 
					 | 
				
			||||||
COPY --from=composer:latest /usr/bin/composer /usr/bin/composer
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# Create system user to run Composer and Artisan Commands
 | 
					 | 
				
			||||||
RUN useradd -G www-data,root -u 1000 -d /home/crater-user crater-user
 | 
					 | 
				
			||||||
RUN mkdir -p /home/crater-user/.composer && \
 | 
					 | 
				
			||||||
    chown -R crater-user:crater-user /home/crater-user
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# Mounted volumes
 | 
					 | 
				
			||||||
COPY ./ /var/www
 | 
					 | 
				
			||||||
COPY ./docker-compose/php/uploads.ini /usr/local/etc/php/conf.d/uploads.ini
 | 
					 | 
				
			||||||
COPY ./uffizzi/.env.example /var/www/.env
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# Set working directory
 | 
					 | 
				
			||||||
WORKDIR /var/www
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
RUN chown -R crater-user:crater-user ./
 | 
					 | 
				
			||||||
RUN chmod -R 775 composer.json composer.lock \ 
 | 
					 | 
				
			||||||
        composer.lock storage/framework/ \
 | 
					 | 
				
			||||||
        storage/logs/ bootstrap/cache/ /home/crater-user/.composer
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
RUN composer config --no-plugins allow-plugins.pestphp/pest-plugin true && \
 | 
					 | 
				
			||||||
    composer install --no-interaction --prefer-dist --optimize-autoloader && \
 | 
					 | 
				
			||||||
    php artisan storage:link || true && \
 | 
					 | 
				
			||||||
    php artisan key:generate
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
FROM php:8.0-fpm-alpine
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
RUN apk add --no-cache \
 | 
					 | 
				
			||||||
    php8-bcmath
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
RUN docker-php-ext-install pdo pdo_mysql bcmath
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
COPY docker-compose/crontab /etc/crontabs/root
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
# Mounted volumes
 | 
					 | 
				
			||||||
COPY --from=build /var/www /var/www
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
RUN chown -R $(whoami):$(whoami) /var/www/
 | 
					 | 
				
			||||||
RUN chmod -R 775 /var/www/
 | 
					 | 
				
			||||||
RUN chown -R $(whoami):$(whoami) /var/log/
 | 
					 | 
				
			||||||
RUN chmod -R 775 /var/log/
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
CMD ["crond", "-f"]
 | 
					 | 
				
			||||||
@ -1,58 +0,0 @@
 | 
				
			|||||||
version: '3'
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
x-uffizzi:
 | 
					 | 
				
			||||||
  ingress:
 | 
					 | 
				
			||||||
    service: nginx
 | 
					 | 
				
			||||||
    port: 80
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
services:
 | 
					 | 
				
			||||||
  app:
 | 
					 | 
				
			||||||
    image: "${APP_IMAGE}"
 | 
					 | 
				
			||||||
    restart: unless-stopped
 | 
					 | 
				
			||||||
    working_dir: /var/www/
 | 
					 | 
				
			||||||
    command: ["-c","
 | 
					 | 
				
			||||||
            composer config --no-plugins allow-plugins.pestphp/pest-plugin true && 
 | 
					 | 
				
			||||||
            composer install --no-interaction --prefer-dist --optimize-autoloader && 
 | 
					 | 
				
			||||||
            php artisan storage:link || true && 
 | 
					 | 
				
			||||||
            php artisan key:generate --force && 
 | 
					 | 
				
			||||||
            php-fpm",
 | 
					 | 
				
			||||||
            ]
 | 
					 | 
				
			||||||
    entrypoint: /bin/sh
 | 
					 | 
				
			||||||
    depends_on:
 | 
					 | 
				
			||||||
      - db
 | 
					 | 
				
			||||||
    deploy:
 | 
					 | 
				
			||||||
      resources:
 | 
					 | 
				
			||||||
        limits:
 | 
					 | 
				
			||||||
          memory: 1000m
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  db:
 | 
					 | 
				
			||||||
    image: mariadb
 | 
					 | 
				
			||||||
    restart: always
 | 
					 | 
				
			||||||
    environment:
 | 
					 | 
				
			||||||
      MYSQL_USER: crater
 | 
					 | 
				
			||||||
      MYSQL_PASSWORD: crater
 | 
					 | 
				
			||||||
      MYSQL_DATABASE: crater
 | 
					 | 
				
			||||||
      MYSQL_ROOT_PASSWORD: crater
 | 
					 | 
				
			||||||
    ports:
 | 
					 | 
				
			||||||
      - '33006:3306'
 | 
					 | 
				
			||||||
    deploy:
 | 
					 | 
				
			||||||
      resources:
 | 
					 | 
				
			||||||
        limits:
 | 
					 | 
				
			||||||
          memory: 500m
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  nginx:
 | 
					 | 
				
			||||||
    image: "${NGINX_IMAGE}"
 | 
					 | 
				
			||||||
    restart: unless-stopped
 | 
					 | 
				
			||||||
    ports:
 | 
					 | 
				
			||||||
      - 80:80
 | 
					 | 
				
			||||||
    depends_on:
 | 
					 | 
				
			||||||
      - app
 | 
					 | 
				
			||||||
    resources:
 | 
					 | 
				
			||||||
      limits:
 | 
					 | 
				
			||||||
        memory: 500m
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  cron:
 | 
					 | 
				
			||||||
    image: "${CROND_IMAGE}"
 | 
					 | 
				
			||||||
    restart: always
 | 
					 | 
				
			||||||
    
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
@ -1,9 +0,0 @@
 | 
				
			|||||||
ARG BASE_IMAGE
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
FROM $BASE_IMAGE as build
 | 
					 | 
				
			||||||
FROM nginx:1.17-alpine
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
RUN rm /etc/nginx/conf.d/default.conf
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
COPY --from=build /var/www /var/www
 | 
					 | 
				
			||||||
COPY ./uffizzi/nginx/nginx /etc/nginx/conf.d/
 | 
					 | 
				
			||||||
@ -1,22 +0,0 @@
 | 
				
			|||||||
server {
 | 
					 | 
				
			||||||
    client_max_body_size 64M;
 | 
					 | 
				
			||||||
    listen 80;
 | 
					 | 
				
			||||||
    index index.php index.html;
 | 
					 | 
				
			||||||
    error_log  /var/log/nginx/error.log;
 | 
					 | 
				
			||||||
    access_log /var/log/nginx/access.log;
 | 
					 | 
				
			||||||
    root /var/www/public;
 | 
					 | 
				
			||||||
    location ~ \.php$ {
 | 
					 | 
				
			||||||
        try_files $uri =404;
 | 
					 | 
				
			||||||
        fastcgi_split_path_info ^(.+\.php)(/.+)$;
 | 
					 | 
				
			||||||
        fastcgi_pass localhost:9000;
 | 
					 | 
				
			||||||
        fastcgi_index index.php;
 | 
					 | 
				
			||||||
        include fastcgi_params;
 | 
					 | 
				
			||||||
        fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
 | 
					 | 
				
			||||||
        fastcgi_param PATH_INFO $fastcgi_path_info;
 | 
					 | 
				
			||||||
        fastcgi_read_timeout 300;
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
    location / {
 | 
					 | 
				
			||||||
        try_files $uri $uri/ /index.php?$query_string;
 | 
					 | 
				
			||||||
        gzip_static on;
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
							
								
								
									
										320
									
								
								yarn.lock
									
									
									
									
									
								
							
							
						
						
									
										320
									
								
								yarn.lock
									
									
									
									
									
								
							@ -53,6 +53,11 @@
 | 
				
			|||||||
    "@babel/helper-validator-identifier" "^7.14.9"
 | 
					    "@babel/helper-validator-identifier" "^7.14.9"
 | 
				
			||||||
    to-fast-properties "^2.0.0"
 | 
					    to-fast-properties "^2.0.0"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					"@esbuild/linux-loong64@0.14.54":
 | 
				
			||||||
 | 
					  version "0.14.54"
 | 
				
			||||||
 | 
					  resolved "https://registry.yarnpkg.com/@esbuild/linux-loong64/-/linux-loong64-0.14.54.tgz#de2a4be678bd4d0d1ffbb86e6de779cde5999028"
 | 
				
			||||||
 | 
					  integrity sha512-bZBrLAIX1kpWelV0XemxBZllyRmM6vgFQQG2GdNb+r3Fkp0FOh1NJSvekXDs7jq70k4euu1cryLMfU+mTXlEpw==
 | 
				
			||||||
 | 
					
 | 
				
			||||||
"@eslint/eslintrc@^0.4.3":
 | 
					"@eslint/eslintrc@^0.4.3":
 | 
				
			||||||
  version "0.4.3"
 | 
					  version "0.4.3"
 | 
				
			||||||
  resolved "https://registry.yarnpkg.com/@eslint/eslintrc/-/eslintrc-0.4.3.tgz#9e42981ef035beb3dd49add17acb96e8ff6f394c"
 | 
					  resolved "https://registry.yarnpkg.com/@eslint/eslintrc/-/eslintrc-0.4.3.tgz#9e42981ef035beb3dd49add17acb96e8ff6f394c"
 | 
				
			||||||
@ -367,6 +372,11 @@
 | 
				
			|||||||
  resolved "https://registry.yarnpkg.com/@tiptap/extension-strike/-/extension-strike-2.0.0-beta.17.tgz#2280ea4e8c50189c2729814d2ae484e58c712a36"
 | 
					  resolved "https://registry.yarnpkg.com/@tiptap/extension-strike/-/extension-strike-2.0.0-beta.17.tgz#2280ea4e8c50189c2729814d2ae484e58c712a36"
 | 
				
			||||||
  integrity sha512-+WRd0RuCK4+jFKNVN+4rHTa5VMqqGDO2uc+TknkqhFqWp/z96OAGlpHJOwPrnW1fLbpjEBBQIr1vVYSw6KgcZg==
 | 
					  integrity sha512-+WRd0RuCK4+jFKNVN+4rHTa5VMqqGDO2uc+TknkqhFqWp/z96OAGlpHJOwPrnW1fLbpjEBBQIr1vVYSw6KgcZg==
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					"@tiptap/extension-text-align@^2.0.0-beta.29":
 | 
				
			||||||
 | 
					  version "2.0.0-beta.31"
 | 
				
			||||||
 | 
					  resolved "https://registry.yarnpkg.com/@tiptap/extension-text-align/-/extension-text-align-2.0.0-beta.31.tgz#31229ef1a16555a9b3a1dc94bf7d3a8c64639f51"
 | 
				
			||||||
 | 
					  integrity sha512-gSJqi57piiMPc2r6WEkXv7ZgQIogigsRUhmlnZC/7s3zzOvjXrexWnV0Ctt/9A7BKcM7OHMykpZyoewvk6QRTw==
 | 
				
			||||||
 | 
					
 | 
				
			||||||
"@tiptap/extension-text@^2.0.0-beta.13":
 | 
					"@tiptap/extension-text@^2.0.0-beta.13":
 | 
				
			||||||
  version "2.0.0-beta.13"
 | 
					  version "2.0.0-beta.13"
 | 
				
			||||||
  resolved "https://registry.yarnpkg.com/@tiptap/extension-text/-/extension-text-2.0.0-beta.13.tgz#da0af8d9a3f149d20076e15d88c6af21fb6d940f"
 | 
					  resolved "https://registry.yarnpkg.com/@tiptap/extension-text/-/extension-text-2.0.0-beta.13.tgz#da0af8d9a3f149d20076e15d88c6af21fb6d940f"
 | 
				
			||||||
@ -1048,11 +1058,6 @@ color@^4.0.1:
 | 
				
			|||||||
    color-convert "^2.0.1"
 | 
					    color-convert "^2.0.1"
 | 
				
			||||||
    color-string "^1.6.0"
 | 
					    color-string "^1.6.0"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
colorette@^1.2.2:
 | 
					 | 
				
			||||||
  version "1.3.0"
 | 
					 | 
				
			||||||
  resolved "https://registry.yarnpkg.com/colorette/-/colorette-1.3.0.tgz#ff45d2f0edb244069d3b772adeb04fed38d0a0af"
 | 
					 | 
				
			||||||
  integrity sha512-ecORCqbSFP7Wm8Y6lyqMJjexBQqXSF7SSeaTyGGphogUjBlFP9m9o08wy86HL2uB7fMTxtOUzLMk7ogKcxMg1w==
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
commander@^6.0.0:
 | 
					commander@^6.0.0:
 | 
				
			||||||
  version "6.2.1"
 | 
					  version "6.2.1"
 | 
				
			||||||
  resolved "https://registry.yarnpkg.com/commander/-/commander-6.2.1.tgz#0792eb682dfbc325999bb2b84fddddba110ac73c"
 | 
					  resolved "https://registry.yarnpkg.com/commander/-/commander-6.2.1.tgz#0792eb682dfbc325999bb2b84fddddba110ac73c"
 | 
				
			||||||
@ -1222,113 +1227,132 @@ error-ex@^1.3.1:
 | 
				
			|||||||
  dependencies:
 | 
					  dependencies:
 | 
				
			||||||
    is-arrayish "^0.2.1"
 | 
					    is-arrayish "^0.2.1"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
esbuild-android-arm64@0.13.15:
 | 
					esbuild-android-64@0.14.54:
 | 
				
			||||||
  version "0.13.15"
 | 
					  version "0.14.54"
 | 
				
			||||||
  resolved "https://registry.yarnpkg.com/esbuild-android-arm64/-/esbuild-android-arm64-0.13.15.tgz#3fc3ff0bab76fe35dd237476b5d2b32bb20a3d44"
 | 
					  resolved "https://registry.yarnpkg.com/esbuild-android-64/-/esbuild-android-64-0.14.54.tgz#505f41832884313bbaffb27704b8bcaa2d8616be"
 | 
				
			||||||
  integrity sha512-m602nft/XXeO8YQPUDVoHfjyRVPdPgjyyXOxZ44MK/agewFFkPa8tUo6lAzSWh5Ui5PB4KR9UIFTSBKh/RrCmg==
 | 
					  integrity sha512-Tz2++Aqqz0rJ7kYBfz+iqyE3QMycD4vk7LBRyWaAVFgFtQ/O8EJOnVmTOiDWYZ/uYzB4kvP+bqejYdVKzE5lAQ==
 | 
				
			||||||
 | 
					
 | 
				
			||||||
esbuild-darwin-64@0.13.15:
 | 
					esbuild-android-arm64@0.14.54:
 | 
				
			||||||
  version "0.13.15"
 | 
					  version "0.14.54"
 | 
				
			||||||
  resolved "https://registry.yarnpkg.com/esbuild-darwin-64/-/esbuild-darwin-64-0.13.15.tgz#8e9169c16baf444eacec60d09b24d11b255a8e72"
 | 
					  resolved "https://registry.yarnpkg.com/esbuild-android-arm64/-/esbuild-android-arm64-0.14.54.tgz#8ce69d7caba49646e009968fe5754a21a9871771"
 | 
				
			||||||
  integrity sha512-ihOQRGs2yyp7t5bArCwnvn2Atr6X4axqPpEdCFPVp7iUj4cVSdisgvEKdNR7yH3JDjW6aQDw40iQFoTqejqxvQ==
 | 
					  integrity sha512-F9E+/QDi9sSkLaClO8SOV6etqPd+5DgJje1F9lOWoNncDdOBL2YF59IhsWATSt0TLZbYCf3pNlTHvVV5VfHdvg==
 | 
				
			||||||
 | 
					
 | 
				
			||||||
esbuild-darwin-arm64@0.13.15:
 | 
					esbuild-darwin-64@0.14.54:
 | 
				
			||||||
  version "0.13.15"
 | 
					  version "0.14.54"
 | 
				
			||||||
  resolved "https://registry.yarnpkg.com/esbuild-darwin-arm64/-/esbuild-darwin-arm64-0.13.15.tgz#1b07f893b632114f805e188ddfca41b2b778229a"
 | 
					  resolved "https://registry.yarnpkg.com/esbuild-darwin-64/-/esbuild-darwin-64-0.14.54.tgz#24ba67b9a8cb890a3c08d9018f887cc221cdda25"
 | 
				
			||||||
  integrity sha512-i1FZssTVxUqNlJ6cBTj5YQj4imWy3m49RZRnHhLpefFIh0To05ow9DTrXROTE1urGTQCloFUXTX8QfGJy1P8dQ==
 | 
					  integrity sha512-jtdKWV3nBviOd5v4hOpkVmpxsBy90CGzebpbO9beiqUYVMBtSc0AL9zGftFuBon7PNDcdvNCEuQqw2x0wP9yug==
 | 
				
			||||||
 | 
					
 | 
				
			||||||
esbuild-freebsd-64@0.13.15:
 | 
					esbuild-darwin-arm64@0.14.54:
 | 
				
			||||||
  version "0.13.15"
 | 
					  version "0.14.54"
 | 
				
			||||||
  resolved "https://registry.yarnpkg.com/esbuild-freebsd-64/-/esbuild-freebsd-64-0.13.15.tgz#0b8b7eca1690c8ec94c75680c38c07269c1f4a85"
 | 
					  resolved "https://registry.yarnpkg.com/esbuild-darwin-arm64/-/esbuild-darwin-arm64-0.14.54.tgz#3f7cdb78888ee05e488d250a2bdaab1fa671bf73"
 | 
				
			||||||
  integrity sha512-G3dLBXUI6lC6Z09/x+WtXBXbOYQZ0E8TDBqvn7aMaOCzryJs8LyVXKY4CPnHFXZAbSwkCbqiPuSQ1+HhrNk7EA==
 | 
					  integrity sha512-OPafJHD2oUPyvJMrsCvDGkRrVCar5aVyHfWGQzY1dWnzErjrDuSETxwA2HSsyg2jORLY8yBfzc1MIpUkXlctmw==
 | 
				
			||||||
 | 
					
 | 
				
			||||||
esbuild-freebsd-arm64@0.13.15:
 | 
					esbuild-freebsd-64@0.14.54:
 | 
				
			||||||
  version "0.13.15"
 | 
					  version "0.14.54"
 | 
				
			||||||
  resolved "https://registry.yarnpkg.com/esbuild-freebsd-arm64/-/esbuild-freebsd-arm64-0.13.15.tgz#2e1a6c696bfdcd20a99578b76350b41db1934e52"
 | 
					  resolved "https://registry.yarnpkg.com/esbuild-freebsd-64/-/esbuild-freebsd-64-0.14.54.tgz#09250f997a56ed4650f3e1979c905ffc40bbe94d"
 | 
				
			||||||
  integrity sha512-KJx0fzEDf1uhNOZQStV4ujg30WlnwqUASaGSFPhznLM/bbheu9HhqZ6mJJZM32lkyfGJikw0jg7v3S0oAvtvQQ==
 | 
					  integrity sha512-OKwd4gmwHqOTp4mOGZKe/XUlbDJ4Q9TjX0hMPIDBUWWu/kwhBAudJdBoxnjNf9ocIB6GN6CPowYpR/hRCbSYAg==
 | 
				
			||||||
 | 
					
 | 
				
			||||||
esbuild-linux-32@0.13.15:
 | 
					esbuild-freebsd-arm64@0.14.54:
 | 
				
			||||||
  version "0.13.15"
 | 
					  version "0.14.54"
 | 
				
			||||||
  resolved "https://registry.yarnpkg.com/esbuild-linux-32/-/esbuild-linux-32-0.13.15.tgz#6fd39f36fc66dd45b6b5f515728c7bbebc342a69"
 | 
					  resolved "https://registry.yarnpkg.com/esbuild-freebsd-arm64/-/esbuild-freebsd-arm64-0.14.54.tgz#bafb46ed04fc5f97cbdb016d86947a79579f8e48"
 | 
				
			||||||
  integrity sha512-ZvTBPk0YWCLMCXiFmD5EUtB30zIPvC5Itxz0mdTu/xZBbbHJftQgLWY49wEPSn2T/TxahYCRDWun5smRa0Tu+g==
 | 
					  integrity sha512-sFwueGr7OvIFiQT6WeG0jRLjkjdqWWSrfbVwZp8iMP+8UHEHRBvlaxL6IuKNDwAozNUmbb8nIMXa7oAOARGs1Q==
 | 
				
			||||||
 | 
					
 | 
				
			||||||
esbuild-linux-64@0.13.15:
 | 
					esbuild-linux-32@0.14.54:
 | 
				
			||||||
  version "0.13.15"
 | 
					  version "0.14.54"
 | 
				
			||||||
  resolved "https://registry.yarnpkg.com/esbuild-linux-64/-/esbuild-linux-64-0.13.15.tgz#9cb8e4bcd7574e67946e4ee5f1f1e12386bb6dd3"
 | 
					  resolved "https://registry.yarnpkg.com/esbuild-linux-32/-/esbuild-linux-32-0.14.54.tgz#e2a8c4a8efdc355405325033fcebeb941f781fe5"
 | 
				
			||||||
  integrity sha512-eCKzkNSLywNeQTRBxJRQ0jxRCl2YWdMB3+PkWFo2BBQYC5mISLIVIjThNtn6HUNqua1pnvgP5xX0nHbZbPj5oA==
 | 
					  integrity sha512-1ZuY+JDI//WmklKlBgJnglpUL1owm2OX+8E1syCD6UAxcMM/XoWd76OHSjl/0MR0LisSAXDqgjT3uJqT67O3qw==
 | 
				
			||||||
 | 
					
 | 
				
			||||||
esbuild-linux-arm64@0.13.15:
 | 
					esbuild-linux-64@0.14.54:
 | 
				
			||||||
  version "0.13.15"
 | 
					  version "0.14.54"
 | 
				
			||||||
  resolved "https://registry.yarnpkg.com/esbuild-linux-arm64/-/esbuild-linux-arm64-0.13.15.tgz#3891aa3704ec579a1b92d2a586122e5b6a2bfba1"
 | 
					  resolved "https://registry.yarnpkg.com/esbuild-linux-64/-/esbuild-linux-64-0.14.54.tgz#de5fdba1c95666cf72369f52b40b03be71226652"
 | 
				
			||||||
  integrity sha512-bYpuUlN6qYU9slzr/ltyLTR9YTBS7qUDymO8SV7kjeNext61OdmqFAzuVZom+OLW1HPHseBfJ/JfdSlx8oTUoA==
 | 
					  integrity sha512-EgjAgH5HwTbtNsTqQOXWApBaPVdDn7XcK+/PtJwZLT1UmpLoznPd8c5CxqsH2dQK3j05YsB3L17T8vE7cp4cCg==
 | 
				
			||||||
 | 
					
 | 
				
			||||||
esbuild-linux-arm@0.13.15:
 | 
					esbuild-linux-arm64@0.14.54:
 | 
				
			||||||
  version "0.13.15"
 | 
					  version "0.14.54"
 | 
				
			||||||
  resolved "https://registry.yarnpkg.com/esbuild-linux-arm/-/esbuild-linux-arm-0.13.15.tgz#8a00e99e6a0c6c9a6b7f334841364d8a2b4aecfe"
 | 
					  resolved "https://registry.yarnpkg.com/esbuild-linux-arm64/-/esbuild-linux-arm64-0.14.54.tgz#dae4cd42ae9787468b6a5c158da4c84e83b0ce8b"
 | 
				
			||||||
  integrity sha512-wUHttDi/ol0tD8ZgUMDH8Ef7IbDX+/UsWJOXaAyTdkT7Yy9ZBqPg8bgB/Dn3CZ9SBpNieozrPRHm0BGww7W/jA==
 | 
					  integrity sha512-WL71L+0Rwv+Gv/HTmxTEmpv0UgmxYa5ftZILVi2QmZBgX3q7+tDeOQNqGtdXSdsL8TQi1vIaVFHUPDe0O0kdig==
 | 
				
			||||||
 | 
					
 | 
				
			||||||
esbuild-linux-mips64le@0.13.15:
 | 
					esbuild-linux-arm@0.14.54:
 | 
				
			||||||
  version "0.13.15"
 | 
					  version "0.14.54"
 | 
				
			||||||
  resolved "https://registry.yarnpkg.com/esbuild-linux-mips64le/-/esbuild-linux-mips64le-0.13.15.tgz#36b07cc47c3d21e48db3bb1f4d9ef8f46aead4f7"
 | 
					  resolved "https://registry.yarnpkg.com/esbuild-linux-arm/-/esbuild-linux-arm-0.14.54.tgz#a2c1dff6d0f21dbe8fc6998a122675533ddfcd59"
 | 
				
			||||||
  integrity sha512-KlVjIG828uFPyJkO/8gKwy9RbXhCEUeFsCGOJBepUlpa7G8/SeZgncUEz/tOOUJTcWMTmFMtdd3GElGyAtbSWg==
 | 
					  integrity sha512-qqz/SjemQhVMTnvcLGoLOdFpCYbz4v4fUo+TfsWG+1aOu70/80RV6bgNpR2JCrppV2moUQkww+6bWxXRL9YMGw==
 | 
				
			||||||
 | 
					
 | 
				
			||||||
esbuild-linux-ppc64le@0.13.15:
 | 
					esbuild-linux-mips64le@0.14.54:
 | 
				
			||||||
  version "0.13.15"
 | 
					  version "0.14.54"
 | 
				
			||||||
  resolved "https://registry.yarnpkg.com/esbuild-linux-ppc64le/-/esbuild-linux-ppc64le-0.13.15.tgz#f7e6bba40b9a11eb9dcae5b01550ea04670edad2"
 | 
					  resolved "https://registry.yarnpkg.com/esbuild-linux-mips64le/-/esbuild-linux-mips64le-0.14.54.tgz#d9918e9e4cb972f8d6dae8e8655bf9ee131eda34"
 | 
				
			||||||
  integrity sha512-h6gYF+OsaqEuBjeesTBtUPw0bmiDu7eAeuc2OEH9S6mV9/jPhPdhOWzdeshb0BskRZxPhxPOjqZ+/OqLcxQwEQ==
 | 
					  integrity sha512-qTHGQB8D1etd0u1+sB6p0ikLKRVuCWhYQhAHRPkO+OF3I/iSlTKNNS0Lh2Oc0g0UFGguaFZZiPJdJey3AGpAlw==
 | 
				
			||||||
 | 
					
 | 
				
			||||||
esbuild-netbsd-64@0.13.15:
 | 
					esbuild-linux-ppc64le@0.14.54:
 | 
				
			||||||
  version "0.13.15"
 | 
					  version "0.14.54"
 | 
				
			||||||
  resolved "https://registry.yarnpkg.com/esbuild-netbsd-64/-/esbuild-netbsd-64-0.13.15.tgz#a2fedc549c2b629d580a732d840712b08d440038"
 | 
					  resolved "https://registry.yarnpkg.com/esbuild-linux-ppc64le/-/esbuild-linux-ppc64le-0.14.54.tgz#3f9a0f6d41073fb1a640680845c7de52995f137e"
 | 
				
			||||||
  integrity sha512-3+yE9emwoevLMyvu+iR3rsa+Xwhie7ZEHMGDQ6dkqP/ndFzRHkobHUKTe+NCApSqG5ce2z4rFu+NX/UHnxlh3w==
 | 
					  integrity sha512-j3OMlzHiqwZBDPRCDFKcx595XVfOfOnv68Ax3U4UKZ3MTYQB5Yz3X1mn5GnodEVYzhtZgxEBidLWeIs8FDSfrQ==
 | 
				
			||||||
 | 
					
 | 
				
			||||||
esbuild-openbsd-64@0.13.15:
 | 
					esbuild-linux-riscv64@0.14.54:
 | 
				
			||||||
  version "0.13.15"
 | 
					  version "0.14.54"
 | 
				
			||||||
  resolved "https://registry.yarnpkg.com/esbuild-openbsd-64/-/esbuild-openbsd-64-0.13.15.tgz#b22c0e5806d3a1fbf0325872037f885306b05cd7"
 | 
					  resolved "https://registry.yarnpkg.com/esbuild-linux-riscv64/-/esbuild-linux-riscv64-0.14.54.tgz#618853c028178a61837bc799d2013d4695e451c8"
 | 
				
			||||||
  integrity sha512-wTfvtwYJYAFL1fSs8yHIdf5GEE4NkbtbXtjLWjM3Cw8mmQKqsg8kTiqJ9NJQe5NX/5Qlo7Xd9r1yKMMkHllp5g==
 | 
					  integrity sha512-y7Vt7Wl9dkOGZjxQZnDAqqn+XOqFD7IMWiewY5SPlNlzMX39ocPQlOaoxvT4FllA5viyV26/QzHtvTjVNOxHZg==
 | 
				
			||||||
 | 
					
 | 
				
			||||||
esbuild-sunos-64@0.13.15:
 | 
					esbuild-linux-s390x@0.14.54:
 | 
				
			||||||
  version "0.13.15"
 | 
					  version "0.14.54"
 | 
				
			||||||
  resolved "https://registry.yarnpkg.com/esbuild-sunos-64/-/esbuild-sunos-64-0.13.15.tgz#d0b6454a88375ee8d3964daeff55c85c91c7cef4"
 | 
					  resolved "https://registry.yarnpkg.com/esbuild-linux-s390x/-/esbuild-linux-s390x-0.14.54.tgz#d1885c4c5a76bbb5a0fe182e2c8c60eb9e29f2a6"
 | 
				
			||||||
  integrity sha512-lbivT9Bx3t1iWWrSnGyBP9ODriEvWDRiweAs69vI+miJoeKwHWOComSRukttbuzjZ8r1q0mQJ8Z7yUsDJ3hKdw==
 | 
					  integrity sha512-zaHpW9dziAsi7lRcyV4r8dhfG1qBidQWUXweUjnw+lliChJqQr+6XD71K41oEIC3Mx1KStovEmlzm+MkGZHnHA==
 | 
				
			||||||
 | 
					
 | 
				
			||||||
esbuild-windows-32@0.13.15:
 | 
					esbuild-netbsd-64@0.14.54:
 | 
				
			||||||
  version "0.13.15"
 | 
					  version "0.14.54"
 | 
				
			||||||
  resolved "https://registry.yarnpkg.com/esbuild-windows-32/-/esbuild-windows-32-0.13.15.tgz#c96d0b9bbb52f3303322582ef8e4847c5ad375a7"
 | 
					  resolved "https://registry.yarnpkg.com/esbuild-netbsd-64/-/esbuild-netbsd-64-0.14.54.tgz#69ae917a2ff241b7df1dbf22baf04bd330349e81"
 | 
				
			||||||
  integrity sha512-fDMEf2g3SsJ599MBr50cY5ve5lP1wyVwTe6aLJsM01KtxyKkB4UT+fc5MXQFn3RLrAIAZOG+tHC+yXObpSn7Nw==
 | 
					  integrity sha512-PR01lmIMnfJTgeU9VJTDY9ZerDWVFIUzAtJuDHwwceppW7cQWjBBqP48NdeRtoP04/AtO9a7w3viI+PIDr6d+w==
 | 
				
			||||||
 | 
					
 | 
				
			||||||
esbuild-windows-64@0.13.15:
 | 
					esbuild-openbsd-64@0.14.54:
 | 
				
			||||||
  version "0.13.15"
 | 
					  version "0.14.54"
 | 
				
			||||||
  resolved "https://registry.yarnpkg.com/esbuild-windows-64/-/esbuild-windows-64-0.13.15.tgz#1f79cb9b1e1bb02fb25cd414cb90d4ea2892c294"
 | 
					  resolved "https://registry.yarnpkg.com/esbuild-openbsd-64/-/esbuild-openbsd-64-0.14.54.tgz#db4c8495287a350a6790de22edea247a57c5d47b"
 | 
				
			||||||
  integrity sha512-9aMsPRGDWCd3bGjUIKG/ZOJPKsiztlxl/Q3C1XDswO6eNX/Jtwu4M+jb6YDH9hRSUflQWX0XKAfWzgy5Wk54JQ==
 | 
					  integrity sha512-Qyk7ikT2o7Wu76UsvvDS5q0amJvmRzDyVlL0qf5VLsLchjCa1+IAvd8kTBgUxD7VBUUVgItLkk609ZHUc1oCaw==
 | 
				
			||||||
 | 
					
 | 
				
			||||||
esbuild-windows-arm64@0.13.15:
 | 
					esbuild-sunos-64@0.14.54:
 | 
				
			||||||
  version "0.13.15"
 | 
					  version "0.14.54"
 | 
				
			||||||
  resolved "https://registry.yarnpkg.com/esbuild-windows-arm64/-/esbuild-windows-arm64-0.13.15.tgz#482173070810df22a752c686509c370c3be3b3c3"
 | 
					  resolved "https://registry.yarnpkg.com/esbuild-sunos-64/-/esbuild-sunos-64-0.14.54.tgz#54287ee3da73d3844b721c21bc80c1dc7e1bf7da"
 | 
				
			||||||
  integrity sha512-zzvyCVVpbwQQATaf3IG8mu1IwGEiDxKkYUdA4FpoCHi1KtPa13jeScYDjlW0Qh+ebWzpKfR2ZwvqAQkSWNcKjA==
 | 
					  integrity sha512-28GZ24KmMSeKi5ueWzMcco6EBHStL3B6ubM7M51RmPwXQGLe0teBGJocmWhgwccA1GeFXqxzILIxXpHbl9Q/Kw==
 | 
				
			||||||
 | 
					
 | 
				
			||||||
esbuild@^0.13.2:
 | 
					esbuild-windows-32@0.14.54:
 | 
				
			||||||
  version "0.13.15"
 | 
					  version "0.14.54"
 | 
				
			||||||
  resolved "https://registry.yarnpkg.com/esbuild/-/esbuild-0.13.15.tgz#db56a88166ee373f87dbb2d8798ff449e0450cdf"
 | 
					  resolved "https://registry.yarnpkg.com/esbuild-windows-32/-/esbuild-windows-32-0.14.54.tgz#f8aaf9a5667630b40f0fb3aa37bf01bbd340ce31"
 | 
				
			||||||
  integrity sha512-raCxt02HBKv8RJxE8vkTSCXGIyKHdEdGfUmiYb8wnabnaEmHzyW7DCHb5tEN0xU8ryqg5xw54mcwnYkC4x3AIw==
 | 
					  integrity sha512-T+rdZW19ql9MjS7pixmZYVObd9G7kcaZo+sETqNH4RCkuuYSuv9AGHUVnPoP9hhuE1WM1ZimHz1CIBHBboLU7w==
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					esbuild-windows-64@0.14.54:
 | 
				
			||||||
 | 
					  version "0.14.54"
 | 
				
			||||||
 | 
					  resolved "https://registry.yarnpkg.com/esbuild-windows-64/-/esbuild-windows-64-0.14.54.tgz#bf54b51bd3e9b0f1886ffdb224a4176031ea0af4"
 | 
				
			||||||
 | 
					  integrity sha512-AoHTRBUuYwXtZhjXZbA1pGfTo8cJo3vZIcWGLiUcTNgHpJJMC1rVA44ZereBHMJtotyN71S8Qw0npiCIkW96cQ==
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					esbuild-windows-arm64@0.14.54:
 | 
				
			||||||
 | 
					  version "0.14.54"
 | 
				
			||||||
 | 
					  resolved "https://registry.yarnpkg.com/esbuild-windows-arm64/-/esbuild-windows-arm64-0.14.54.tgz#937d15675a15e4b0e4fafdbaa3a01a776a2be982"
 | 
				
			||||||
 | 
					  integrity sha512-M0kuUvXhot1zOISQGXwWn6YtS+Y/1RT9WrVIOywZnJHo3jCDyewAc79aKNQWFCQm+xNHVTq9h8dZKvygoXQQRg==
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					esbuild@^0.14.27:
 | 
				
			||||||
 | 
					  version "0.14.54"
 | 
				
			||||||
 | 
					  resolved "https://registry.yarnpkg.com/esbuild/-/esbuild-0.14.54.tgz#8b44dcf2b0f1a66fc22459943dccf477535e9aa2"
 | 
				
			||||||
 | 
					  integrity sha512-Cy9llcy8DvET5uznocPyqL3BFRrFXSVqbgpMJ9Wz8oVjZlh/zUSNbPRbov0VX7VxN2JH1Oa0uNxZ7eLRb62pJA==
 | 
				
			||||||
  optionalDependencies:
 | 
					  optionalDependencies:
 | 
				
			||||||
    esbuild-android-arm64 "0.13.15"
 | 
					    "@esbuild/linux-loong64" "0.14.54"
 | 
				
			||||||
    esbuild-darwin-64 "0.13.15"
 | 
					    esbuild-android-64 "0.14.54"
 | 
				
			||||||
    esbuild-darwin-arm64 "0.13.15"
 | 
					    esbuild-android-arm64 "0.14.54"
 | 
				
			||||||
    esbuild-freebsd-64 "0.13.15"
 | 
					    esbuild-darwin-64 "0.14.54"
 | 
				
			||||||
    esbuild-freebsd-arm64 "0.13.15"
 | 
					    esbuild-darwin-arm64 "0.14.54"
 | 
				
			||||||
    esbuild-linux-32 "0.13.15"
 | 
					    esbuild-freebsd-64 "0.14.54"
 | 
				
			||||||
    esbuild-linux-64 "0.13.15"
 | 
					    esbuild-freebsd-arm64 "0.14.54"
 | 
				
			||||||
    esbuild-linux-arm "0.13.15"
 | 
					    esbuild-linux-32 "0.14.54"
 | 
				
			||||||
    esbuild-linux-arm64 "0.13.15"
 | 
					    esbuild-linux-64 "0.14.54"
 | 
				
			||||||
    esbuild-linux-mips64le "0.13.15"
 | 
					    esbuild-linux-arm "0.14.54"
 | 
				
			||||||
    esbuild-linux-ppc64le "0.13.15"
 | 
					    esbuild-linux-arm64 "0.14.54"
 | 
				
			||||||
    esbuild-netbsd-64 "0.13.15"
 | 
					    esbuild-linux-mips64le "0.14.54"
 | 
				
			||||||
    esbuild-openbsd-64 "0.13.15"
 | 
					    esbuild-linux-ppc64le "0.14.54"
 | 
				
			||||||
    esbuild-sunos-64 "0.13.15"
 | 
					    esbuild-linux-riscv64 "0.14.54"
 | 
				
			||||||
    esbuild-windows-32 "0.13.15"
 | 
					    esbuild-linux-s390x "0.14.54"
 | 
				
			||||||
    esbuild-windows-64 "0.13.15"
 | 
					    esbuild-netbsd-64 "0.14.54"
 | 
				
			||||||
    esbuild-windows-arm64 "0.13.15"
 | 
					    esbuild-openbsd-64 "0.14.54"
 | 
				
			||||||
 | 
					    esbuild-sunos-64 "0.14.54"
 | 
				
			||||||
 | 
					    esbuild-windows-32 "0.14.54"
 | 
				
			||||||
 | 
					    esbuild-windows-64 "0.14.54"
 | 
				
			||||||
 | 
					    esbuild-windows-arm64 "0.14.54"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
escalade@^3.1.1:
 | 
					escalade@^3.1.1:
 | 
				
			||||||
  version "3.1.1"
 | 
					  version "3.1.1"
 | 
				
			||||||
@ -1787,10 +1811,10 @@ is-color-stop@^1.1.0:
 | 
				
			|||||||
    rgb-regex "^1.0.1"
 | 
					    rgb-regex "^1.0.1"
 | 
				
			||||||
    rgba-regex "^1.0.0"
 | 
					    rgba-regex "^1.0.0"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
is-core-module@^2.2.0:
 | 
					is-core-module@^2.9.0:
 | 
				
			||||||
  version "2.6.0"
 | 
					  version "2.10.0"
 | 
				
			||||||
  resolved "https://registry.yarnpkg.com/is-core-module/-/is-core-module-2.6.0.tgz#d7553b2526fe59b92ba3e40c8df757ec8a709e19"
 | 
					  resolved "https://registry.yarnpkg.com/is-core-module/-/is-core-module-2.10.0.tgz#9012ede0a91c69587e647514e1d5277019e728ed"
 | 
				
			||||||
  integrity sha512-wShG8vs60jKfPWpF2KZRaAtvt3a20OAn7+IJ6hLPECpSABLcKtFKTTI4ZtH5QcBruBHlq+WsdHWyz0BCZW7svQ==
 | 
					  integrity sha512-Erxj2n/LDAZ7H8WNJXd9tw38GYM3dv8rk8Zcs+jJuxYTW7sozH+SS8NtrSjVL1/vpLvWi1hxy96IzjJ3EHTJJg==
 | 
				
			||||||
  dependencies:
 | 
					  dependencies:
 | 
				
			||||||
    has "^1.0.3"
 | 
					    has "^1.0.3"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@ -2032,15 +2056,10 @@ ms@2.1.2:
 | 
				
			|||||||
  resolved "https://registry.yarnpkg.com/ms/-/ms-2.1.2.tgz#d09d1f357b443f493382a8eb3ccd183872ae6009"
 | 
					  resolved "https://registry.yarnpkg.com/ms/-/ms-2.1.2.tgz#d09d1f357b443f493382a8eb3ccd183872ae6009"
 | 
				
			||||||
  integrity sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==
 | 
					  integrity sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==
 | 
				
			||||||
 | 
					
 | 
				
			||||||
nanoid@^3.1.23:
 | 
					nanoid@^3.3.4:
 | 
				
			||||||
  version "3.1.25"
 | 
					  version "3.3.4"
 | 
				
			||||||
  resolved "https://registry.yarnpkg.com/nanoid/-/nanoid-3.1.25.tgz#09ca32747c0e543f0e1814b7d3793477f9c8e152"
 | 
					  resolved "https://registry.yarnpkg.com/nanoid/-/nanoid-3.3.4.tgz#730b67e3cd09e2deacf03c027c81c9d9dbc5e8ab"
 | 
				
			||||||
  integrity sha512-rdwtIXaXCLFAQbnfqDRnI6jaRHp9fTcYBjtFKE8eezcZ7LuLjhUaQGNeMXf1HmRoCH32CLz6XwX0TtxEOS/A3Q==
 | 
					  integrity sha512-MqBkQh/OHTS2egovRtLk45wEyNXwF+cokD+1YPf9u5VfJiRdAiRwB2froX5Co9Rh20xs4siNPm8naNotSD6RBw==
 | 
				
			||||||
 | 
					 | 
				
			||||||
nanoid@^3.1.30:
 | 
					 | 
				
			||||||
  version "3.1.30"
 | 
					 | 
				
			||||||
  resolved "https://registry.yarnpkg.com/nanoid/-/nanoid-3.1.30.tgz#63f93cc548d2a113dc5dfbc63bfa09e2b9b64362"
 | 
					 | 
				
			||||||
  integrity sha512-zJpuPDwOv8D2zq2WRoMe1HsfZthVewpel9CAvTfc/2mBD1uUT/agc5f7GHGWXlYkFvi1mVxe4IjvP2HNrop7nQ==
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
natural-compare@^1.4.0:
 | 
					natural-compare@^1.4.0:
 | 
				
			||||||
  version "1.4.0"
 | 
					  version "1.4.0"
 | 
				
			||||||
@ -2149,7 +2168,7 @@ path-key@^3.0.0, path-key@^3.1.0:
 | 
				
			|||||||
  resolved "https://registry.yarnpkg.com/path-key/-/path-key-3.1.1.tgz#581f6ade658cbba65a0d3380de7753295054f375"
 | 
					  resolved "https://registry.yarnpkg.com/path-key/-/path-key-3.1.1.tgz#581f6ade658cbba65a0d3380de7753295054f375"
 | 
				
			||||||
  integrity sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==
 | 
					  integrity sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==
 | 
				
			||||||
 | 
					
 | 
				
			||||||
path-parse@^1.0.6:
 | 
					path-parse@^1.0.7:
 | 
				
			||||||
  version "1.0.7"
 | 
					  version "1.0.7"
 | 
				
			||||||
  resolved "https://registry.yarnpkg.com/path-parse/-/path-parse-1.0.7.tgz#fbc114b60ca42b30d9daf5858e4bd68bbedb6735"
 | 
					  resolved "https://registry.yarnpkg.com/path-parse/-/path-parse-1.0.7.tgz#fbc114b60ca42b30d9daf5858e4bd68bbedb6735"
 | 
				
			||||||
  integrity sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==
 | 
					  integrity sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==
 | 
				
			||||||
@ -2237,32 +2256,14 @@ postcss-value-parser@^4.2.0:
 | 
				
			|||||||
  resolved "https://registry.yarnpkg.com/postcss-value-parser/-/postcss-value-parser-4.2.0.tgz#723c09920836ba6d3e5af019f92bc0971c02e514"
 | 
					  resolved "https://registry.yarnpkg.com/postcss-value-parser/-/postcss-value-parser-4.2.0.tgz#723c09920836ba6d3e5af019f92bc0971c02e514"
 | 
				
			||||||
  integrity sha512-1NNCs6uurfkVbeXG4S8JFT9t19m45ICnif8zWLd5oPSZ50QnwMfK+H3jv408d4jw/7Bttv5axS5IiHoLaVNHeQ==
 | 
					  integrity sha512-1NNCs6uurfkVbeXG4S8JFT9t19m45ICnif8zWLd5oPSZ50QnwMfK+H3jv408d4jw/7Bttv5axS5IiHoLaVNHeQ==
 | 
				
			||||||
 | 
					
 | 
				
			||||||
postcss@^8.1.10, postcss@^8.1.6, postcss@^8.2.1:
 | 
					postcss@^8.1.10, postcss@^8.1.6, postcss@^8.2.1, postcss@^8.4.13, postcss@^8.4.5:
 | 
				
			||||||
  version "8.3.6"
 | 
					  version "8.4.16"
 | 
				
			||||||
  resolved "https://registry.yarnpkg.com/postcss/-/postcss-8.3.6.tgz#2730dd76a97969f37f53b9a6096197be311cc4ea"
 | 
					  resolved "https://registry.yarnpkg.com/postcss/-/postcss-8.4.16.tgz#33a1d675fac39941f5f445db0de4db2b6e01d43c"
 | 
				
			||||||
  integrity sha512-wG1cc/JhRgdqB6WHEuyLTedf3KIRuD0hG6ldkFEZNCjRxiC+3i6kkWUUbiJQayP28iwG35cEmAbe98585BYV0A==
 | 
					  integrity sha512-ipHE1XBvKzm5xI7hiHCZJCSugxvsdq2mPnsq5+UF+VHCjiBvtDrlxJfMBToWaP9D5XlgNmcFGqoHmUn0EYEaRQ==
 | 
				
			||||||
  dependencies:
 | 
					  dependencies:
 | 
				
			||||||
    colorette "^1.2.2"
 | 
					    nanoid "^3.3.4"
 | 
				
			||||||
    nanoid "^3.1.23"
 | 
					 | 
				
			||||||
    source-map-js "^0.6.2"
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
postcss@^8.3.8:
 | 
					 | 
				
			||||||
  version "8.3.11"
 | 
					 | 
				
			||||||
  resolved "https://registry.yarnpkg.com/postcss/-/postcss-8.3.11.tgz#c3beca7ea811cd5e1c4a3ec6d2e7599ef1f8f858"
 | 
					 | 
				
			||||||
  integrity sha512-hCmlUAIlUiav8Xdqw3Io4LcpA1DOt7h3LSTAC4G6JGHFFaWzI6qvFt9oilvl8BmkbBRX1IhM90ZAmpk68zccQA==
 | 
					 | 
				
			||||||
  dependencies:
 | 
					 | 
				
			||||||
    nanoid "^3.1.30"
 | 
					 | 
				
			||||||
    picocolors "^1.0.0"
 | 
					    picocolors "^1.0.0"
 | 
				
			||||||
    source-map-js "^0.6.2"
 | 
					    source-map-js "^1.0.2"
 | 
				
			||||||
 | 
					 | 
				
			||||||
postcss@^8.4.5:
 | 
					 | 
				
			||||||
  version "8.4.5"
 | 
					 | 
				
			||||||
  resolved "https://registry.yarnpkg.com/postcss/-/postcss-8.4.5.tgz#bae665764dfd4c6fcc24dc0fdf7e7aa00cc77f95"
 | 
					 | 
				
			||||||
  integrity sha512-jBDboWM8qpaqwkMwItqTQTiFikhs/67OYVvblFFTM7MrZjt6yMKd6r2kgXizEbTTljacm4NldIlZnhbjr84QYg==
 | 
					 | 
				
			||||||
  dependencies:
 | 
					 | 
				
			||||||
    nanoid "^3.1.30"
 | 
					 | 
				
			||||||
    picocolors "^1.0.0"
 | 
					 | 
				
			||||||
    source-map-js "^1.0.1"
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
prelude-ls@^1.2.1:
 | 
					prelude-ls@^1.2.1:
 | 
				
			||||||
  version "1.2.1"
 | 
					  version "1.2.1"
 | 
				
			||||||
@ -2443,13 +2444,14 @@ resolve-from@^5.0.0:
 | 
				
			|||||||
  resolved "https://registry.yarnpkg.com/resolve-from/-/resolve-from-5.0.0.tgz#c35225843df8f776df21c57557bc087e9dfdfc69"
 | 
					  resolved "https://registry.yarnpkg.com/resolve-from/-/resolve-from-5.0.0.tgz#c35225843df8f776df21c57557bc087e9dfdfc69"
 | 
				
			||||||
  integrity sha512-qYg9KP24dD5qka9J47d0aVky0N+b4fTU89LN9iDnjB5waksiC49rvMB0PrUJQGoTmH50XPiqOvAjDfaijGxYZw==
 | 
					  integrity sha512-qYg9KP24dD5qka9J47d0aVky0N+b4fTU89LN9iDnjB5waksiC49rvMB0PrUJQGoTmH50XPiqOvAjDfaijGxYZw==
 | 
				
			||||||
 | 
					
 | 
				
			||||||
resolve@^1.20.0:
 | 
					resolve@^1.20.0, resolve@^1.22.0:
 | 
				
			||||||
  version "1.20.0"
 | 
					  version "1.22.1"
 | 
				
			||||||
  resolved "https://registry.yarnpkg.com/resolve/-/resolve-1.20.0.tgz#629a013fb3f70755d6f0b7935cc1c2c5378b1975"
 | 
					  resolved "https://registry.yarnpkg.com/resolve/-/resolve-1.22.1.tgz#27cb2ebb53f91abb49470a928bba7558066ac177"
 | 
				
			||||||
  integrity sha512-wENBPt4ySzg4ybFQW2TT1zMQucPK95HSh/nq2CFTZVOGut2+pQvSsgtda4d26YrYcr067wjbmzOG8byDPBX63A==
 | 
					  integrity sha512-nBpuuYuY5jFsli/JIs1oldw6fOQCBioohqWZg/2hiaOybXOft4lonv85uDOKXdf8rhyK159cxU5cDcK/NKk8zw==
 | 
				
			||||||
  dependencies:
 | 
					  dependencies:
 | 
				
			||||||
    is-core-module "^2.2.0"
 | 
					    is-core-module "^2.9.0"
 | 
				
			||||||
    path-parse "^1.0.6"
 | 
					    path-parse "^1.0.7"
 | 
				
			||||||
 | 
					    supports-preserve-symlinks-flag "^1.0.0"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
reusify@^1.0.4:
 | 
					reusify@^1.0.4:
 | 
				
			||||||
  version "1.0.4"
 | 
					  version "1.0.4"
 | 
				
			||||||
@ -2473,10 +2475,10 @@ rimraf@^3.0.0, rimraf@^3.0.2:
 | 
				
			|||||||
  dependencies:
 | 
					  dependencies:
 | 
				
			||||||
    glob "^7.1.3"
 | 
					    glob "^7.1.3"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
rollup@^2.57.0:
 | 
					rollup@^2.59.0:
 | 
				
			||||||
  version "2.60.1"
 | 
					  version "2.78.1"
 | 
				
			||||||
  resolved "https://registry.yarnpkg.com/rollup/-/rollup-2.60.1.tgz#4b34cd247f09b421f10a3c9286eda2ecf9972079"
 | 
					  resolved "https://registry.yarnpkg.com/rollup/-/rollup-2.78.1.tgz#52fe3934d9c83cb4f7c4cb5fb75d88591be8648f"
 | 
				
			||||||
  integrity sha512-akwfnpjY0rXEDSn1UTVfKXJhPsEBu+imi1gqBA1ZkHGydUnkV/fWCC90P7rDaLEW8KTwBcS1G3N4893Ndz+jwg==
 | 
					  integrity sha512-VeeCgtGi4P+o9hIg+xz4qQpRl6R401LWEXBmxYKOV4zlF82lyhgh2hTZnheFUbANE8l2A41F458iwj2vEYaXJg==
 | 
				
			||||||
  optionalDependencies:
 | 
					  optionalDependencies:
 | 
				
			||||||
    fsevents "~2.3.2"
 | 
					    fsevents "~2.3.2"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@ -2571,15 +2573,10 @@ sortablejs@1.14.0:
 | 
				
			|||||||
  resolved "https://registry.yarnpkg.com/sortablejs/-/sortablejs-1.14.0.tgz#6d2e17ccbdb25f464734df621d4f35d4ab35b3d8"
 | 
					  resolved "https://registry.yarnpkg.com/sortablejs/-/sortablejs-1.14.0.tgz#6d2e17ccbdb25f464734df621d4f35d4ab35b3d8"
 | 
				
			||||||
  integrity sha512-pBXvQCs5/33fdN1/39pPL0NZF20LeRbLQ5jtnheIPN9JQAaufGjKdWduZn4U7wCtVuzKhmRkI0DFYHYRbB2H1w==
 | 
					  integrity sha512-pBXvQCs5/33fdN1/39pPL0NZF20LeRbLQ5jtnheIPN9JQAaufGjKdWduZn4U7wCtVuzKhmRkI0DFYHYRbB2H1w==
 | 
				
			||||||
 | 
					
 | 
				
			||||||
source-map-js@^0.6.2:
 | 
					source-map-js@^1.0.2:
 | 
				
			||||||
  version "0.6.2"
 | 
					  version "1.0.2"
 | 
				
			||||||
  resolved "https://registry.yarnpkg.com/source-map-js/-/source-map-js-0.6.2.tgz#0bb5de631b41cfbda6cfba8bd05a80efdfd2385e"
 | 
					  resolved "https://registry.yarnpkg.com/source-map-js/-/source-map-js-1.0.2.tgz#adbc361d9c62df380125e7f161f71c826f1e490c"
 | 
				
			||||||
  integrity sha512-/3GptzWzu0+0MBQFrDKzw/DvvMTUORvgY6k6jd/VS6iCR4RDTKWH6v6WPwQoUO8667uQEf9Oe38DxAYWY5F/Ug==
 | 
					  integrity sha512-R0XvVJ9WusLiqTCEiGCmICCMplcCkIwwR11mOSD9CR5u+IXYdiseeEuXCVAjS54zqwkLcPNnmU4OeJ6tUrWhDw==
 | 
				
			||||||
 | 
					 | 
				
			||||||
source-map-js@^1.0.1:
 | 
					 | 
				
			||||||
  version "1.0.1"
 | 
					 | 
				
			||||||
  resolved "https://registry.yarnpkg.com/source-map-js/-/source-map-js-1.0.1.tgz#a1741c131e3c77d048252adfa24e23b908670caf"
 | 
					 | 
				
			||||||
  integrity sha512-4+TN2b3tqOCd/kaGRJ/sTYA0tR0mdXx26ipdolxcwtJVqEnqNYvlCAt1q3ypy4QMlYus+Zh34RNtYLoq2oQ4IA==
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
source-map@0.6.1, source-map@^0.6.1:
 | 
					source-map@0.6.1, source-map@^0.6.1:
 | 
				
			||||||
  version "0.6.1"
 | 
					  version "0.6.1"
 | 
				
			||||||
@ -2636,6 +2633,11 @@ supports-color@^7.1.0:
 | 
				
			|||||||
  dependencies:
 | 
					  dependencies:
 | 
				
			||||||
    has-flag "^4.0.0"
 | 
					    has-flag "^4.0.0"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					supports-preserve-symlinks-flag@^1.0.0:
 | 
				
			||||||
 | 
					  version "1.0.0"
 | 
				
			||||||
 | 
					  resolved "https://registry.yarnpkg.com/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz#6eda4bd344a3c94aea376d4cc31bc77311039e09"
 | 
				
			||||||
 | 
					  integrity sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==
 | 
				
			||||||
 | 
					
 | 
				
			||||||
table@^6.0.9:
 | 
					table@^6.0.9:
 | 
				
			||||||
  version "6.7.1"
 | 
					  version "6.7.1"
 | 
				
			||||||
  resolved "https://registry.yarnpkg.com/table/-/table-6.7.1.tgz#ee05592b7143831a8c94f3cee6aae4c1ccef33e2"
 | 
					  resolved "https://registry.yarnpkg.com/table/-/table-6.7.1.tgz#ee05592b7143831a8c94f3cee6aae4c1ccef33e2"
 | 
				
			||||||
@ -2808,15 +2810,15 @@ v8-compile-cache@^2.0.3:
 | 
				
			|||||||
  resolved "https://registry.yarnpkg.com/v8-compile-cache/-/v8-compile-cache-2.3.0.tgz#2de19618c66dc247dcfb6f99338035d8245a2cee"
 | 
					  resolved "https://registry.yarnpkg.com/v8-compile-cache/-/v8-compile-cache-2.3.0.tgz#2de19618c66dc247dcfb6f99338035d8245a2cee"
 | 
				
			||||||
  integrity sha512-l8lCEmLcLYZh4nbunNZvQCJc5pv7+RCwa8q/LdUx8u7lsWvPDKmpodJAJNwkAhJC//dFY48KuIEmjtd4RViDrA==
 | 
					  integrity sha512-l8lCEmLcLYZh4nbunNZvQCJc5pv7+RCwa8q/LdUx8u7lsWvPDKmpodJAJNwkAhJC//dFY48KuIEmjtd4RViDrA==
 | 
				
			||||||
 | 
					
 | 
				
			||||||
vite@^2.6.1:
 | 
					vite@^2.9.13:
 | 
				
			||||||
  version "2.6.14"
 | 
					  version "2.9.13"
 | 
				
			||||||
  resolved "https://registry.yarnpkg.com/vite/-/vite-2.6.14.tgz#35c09a15e4df823410819a2a239ab11efb186271"
 | 
					  resolved "https://registry.yarnpkg.com/vite/-/vite-2.9.13.tgz#859cb5d4c316c0d8c6ec9866045c0f7858ca6abc"
 | 
				
			||||||
  integrity sha512-2HA9xGyi+EhY2MXo0+A2dRsqsAG3eFNEVIo12olkWhOmc8LfiM+eMdrXf+Ruje9gdXgvSqjLI9freec1RUM5EA==
 | 
					  integrity sha512-AsOBAaT0AD7Mhe8DuK+/kE4aWYFMx/i0ZNi98hJclxb4e0OhQcZYUrvLjIaQ8e59Ui7txcvKMiJC1yftqpQoDw==
 | 
				
			||||||
  dependencies:
 | 
					  dependencies:
 | 
				
			||||||
    esbuild "^0.13.2"
 | 
					    esbuild "^0.14.27"
 | 
				
			||||||
    postcss "^8.3.8"
 | 
					    postcss "^8.4.13"
 | 
				
			||||||
    resolve "^1.20.0"
 | 
					    resolve "^1.22.0"
 | 
				
			||||||
    rollup "^2.57.0"
 | 
					    rollup "^2.59.0"
 | 
				
			||||||
  optionalDependencies:
 | 
					  optionalDependencies:
 | 
				
			||||||
    fsevents "~2.3.2"
 | 
					    fsevents "~2.3.2"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user