mirror of
				https://github.com/crater-invoice/crater.git
				synced 2025-11-03 22:13:18 -05:00 
			
		
		
		
	Compare commits
	
		
			66 Commits
		
	
	
		
			dependabot
			...
			dark-date-
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 55da562a42 | |||
| 3b3da13218 | |||
| 5440b0f354 | |||
| 9249105ad6 | |||
| 238cdb3c25 | |||
| 55bf70c868 | |||
| 0c5adff9b4 | |||
| 3d5732ee26 | |||
| 5aa7decdbe | |||
| 5c67780870 | |||
| ba7f619c67 | |||
| 82efad71c0 | |||
| 826ef72faa | |||
| 2adaa7a84a | |||
| 13557ea075 | |||
| ce88c772d1 | |||
| a32d36363d | |||
| f874b3507d | |||
| c36d25931f | |||
| 1e6c3b287f | |||
| 0462ff60a0 | |||
| 29a135adaf | |||
| 1aceb2c672 | |||
| fb9fab641d | |||
| 8f2edc220b | |||
| d14ab013ad | |||
| f6639f5863 | |||
| c5acf1343e | |||
| 0321ca5515 | |||
| bd345949e5 | |||
| b4b00ebdd6 | |||
| 43316dae28 | |||
| 80e2548b38 | |||
| e8d92cd641 | |||
| 2c8bb38531 | |||
| 04c7ae39a2 | |||
| af2482a69c | |||
| cac35826c2 | |||
| 18b5705372 | |||
| c61fbad5ce | |||
| 15f3f566e3 | |||
| 2e93082282 | |||
| ca55221c4f | |||
| 98196194e2 | |||
| df04fd9e53 | |||
| 189c51cdf4 | |||
| bd5f0fe5cf | |||
| 787619b907 | |||
| fd70ab9a99 | |||
| 33315638df | |||
| bba14bf51a | |||
| ea41989034 | |||
| 3f3f83a00a | |||
| adc5962071 | |||
| c4c00002d7 | |||
| a7c1e12db6 | |||
| 32949d1eec | |||
| 7718f77f3d | |||
| a9e54981bf | |||
| ef35293f8a | |||
| 5c63770b6b | |||
| d130e20c92 | |||
| 586fb1ae10 | |||
| 20c2502e31 | |||
| 0e31f85c18 | |||
| e7301eb7a3 | 
							
								
								
									
										9
									
								
								.github/workflows/uffizzi-build.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										9
									
								
								.github/workflows/uffizzi-build.yml
									
									
									
									
										vendored
									
									
								
							@ -14,6 +14,8 @@ jobs:
 | 
				
			|||||||
    steps:
 | 
					    steps:
 | 
				
			||||||
      - name: Checkout git repo
 | 
					      - name: Checkout git repo
 | 
				
			||||||
        uses: actions/checkout@v3
 | 
					        uses: actions/checkout@v3
 | 
				
			||||||
 | 
					      - name: Set up Docker Buildx
 | 
				
			||||||
 | 
					        uses: docker/setup-buildx-action@v2        
 | 
				
			||||||
      - name: Generate UUID image name
 | 
					      - name: Generate UUID image name
 | 
				
			||||||
        id: uuid
 | 
					        id: uuid
 | 
				
			||||||
        run: echo "UUID_TAG_APP=$(uuidgen)" >> $GITHUB_ENV
 | 
					        run: echo "UUID_TAG_APP=$(uuidgen)" >> $GITHUB_ENV
 | 
				
			||||||
@ -31,10 +33,11 @@ jobs:
 | 
				
			|||||||
          tags: ${{ steps.meta.outputs.tags }}
 | 
					          tags: ${{ steps.meta.outputs.tags }}
 | 
				
			||||||
          labels: ${{ steps.meta.outputs.labels }}
 | 
					          labels: ${{ steps.meta.outputs.labels }}
 | 
				
			||||||
          file: ./uffizzi/Dockerfile
 | 
					          file: ./uffizzi/Dockerfile
 | 
				
			||||||
 | 
					          cache-from: type=gha
 | 
				
			||||||
 | 
					          cache-to: type=gha,mode=max
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  build-nginx:
 | 
					  build-nginx:
 | 
				
			||||||
    needs: 
 | 
					 | 
				
			||||||
      - build-application
 | 
					 | 
				
			||||||
    name: Build and Push `nginx`
 | 
					    name: Build and Push `nginx`
 | 
				
			||||||
    runs-on: ubuntu-latest
 | 
					    runs-on: ubuntu-latest
 | 
				
			||||||
    if: ${{ github.event_name != 'pull_request' || github.event.action != 'closed' }}
 | 
					    if: ${{ github.event_name != 'pull_request' || github.event.action != 'closed' }}
 | 
				
			||||||
@ -62,8 +65,6 @@ jobs:
 | 
				
			|||||||
          tags: ${{ steps.meta.outputs.tags }}
 | 
					          tags: ${{ steps.meta.outputs.tags }}
 | 
				
			||||||
          labels: ${{ steps.meta.outputs.labels }}
 | 
					          labels: ${{ steps.meta.outputs.labels }}
 | 
				
			||||||
          file: ./uffizzi/nginx/Dockerfile
 | 
					          file: ./uffizzi/nginx/Dockerfile
 | 
				
			||||||
          build-args: |
 | 
					 | 
				
			||||||
            BASE_IMAGE=${{ needs.build-application.outputs.tags }}
 | 
					 | 
				
			||||||
          cache-from: type=gha
 | 
					          cache-from: type=gha
 | 
				
			||||||
          cache-to: type=gha,mode=max
 | 
					          cache-to: type=gha,mode=max
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
				
			|||||||
							
								
								
									
										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
 | 
					 | 
				
			||||||
 | 
				
			|||||||
@ -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);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
				
			|||||||
@ -103,6 +103,7 @@ class CustomerStatsController extends Controller
 | 
				
			|||||||
        )
 | 
					        )
 | 
				
			||||||
            ->whereCompany()
 | 
					            ->whereCompany()
 | 
				
			||||||
            ->whereCustomer($customer->id)
 | 
					            ->whereCustomer($customer->id)
 | 
				
			||||||
 | 
					            ->where('status', '<>', Invoice::STATUS_DRAFT)
 | 
				
			||||||
            ->sum('total');
 | 
					            ->sum('total');
 | 
				
			||||||
        $totalReceipts = Payment::whereBetween(
 | 
					        $totalReceipts = Payment::whereBetween(
 | 
				
			||||||
            'payment_date',
 | 
					            'payment_date',
 | 
				
			||||||
 | 
				
			|||||||
@ -104,6 +104,7 @@ class DashboardController extends Controller
 | 
				
			|||||||
            'invoice_date',
 | 
					            'invoice_date',
 | 
				
			||||||
            [$startDate->format('Y-m-d'), $start->format('Y-m-d')]
 | 
					            [$startDate->format('Y-m-d'), $start->format('Y-m-d')]
 | 
				
			||||||
        )
 | 
					        )
 | 
				
			||||||
 | 
					            ->where('status', '<>', Invoice::STATUS_DRAFT)
 | 
				
			||||||
            ->whereCompany()
 | 
					            ->whereCompany()
 | 
				
			||||||
            ->sum('base_total');
 | 
					            ->sum('base_total');
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@ -141,6 +142,7 @@ class DashboardController extends Controller
 | 
				
			|||||||
        $recent_due_invoices = Invoice::with('customer')
 | 
					        $recent_due_invoices = Invoice::with('customer')
 | 
				
			||||||
            ->whereCompany()
 | 
					            ->whereCompany()
 | 
				
			||||||
            ->where('base_due_amount', '>', 0)
 | 
					            ->where('base_due_amount', '>', 0)
 | 
				
			||||||
 | 
					            ->where('status', '<>', Invoice::STATUS_DRAFT)
 | 
				
			||||||
            ->take(5)
 | 
					            ->take(5)
 | 
				
			||||||
            ->latest()
 | 
					            ->latest()
 | 
				
			||||||
            ->get();
 | 
					            ->get();
 | 
				
			||||||
 | 
				
			|||||||
@ -24,6 +24,7 @@ class InvoicesController extends Controller
 | 
				
			|||||||
        $limit = $request->has('limit') ? $request->limit : 10;
 | 
					        $limit = $request->has('limit') ? $request->limit : 10;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        $invoices = Invoice::whereCompany()
 | 
					        $invoices = Invoice::whereCompany()
 | 
				
			||||||
 | 
					            ->whereTabFilters($request->tab_status)
 | 
				
			||||||
            ->join('customers', 'customers.id', '=', 'invoices.customer_id')
 | 
					            ->join('customers', 'customers.id', '=', 'invoices.customer_id')
 | 
				
			||||||
            ->applyFilters($request->all())
 | 
					            ->applyFilters($request->all())
 | 
				
			||||||
            ->select('invoices.*', 'customers.name')
 | 
					            ->select('invoices.*', 'customers.name')
 | 
				
			||||||
 | 
				
			|||||||
@ -3,7 +3,6 @@
 | 
				
			|||||||
namespace Crater\Http\Requests;
 | 
					namespace Crater\Http\Requests;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
use Illuminate\Foundation\Http\FormRequest;
 | 
					use Illuminate\Foundation\Http\FormRequest;
 | 
				
			||||||
use Illuminate\Support\Str;
 | 
					 | 
				
			||||||
use Illuminate\Validation\Rule;
 | 
					use Illuminate\Validation\Rule;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
class CompaniesRequest extends FormRequest
 | 
					class CompaniesRequest extends FormRequest
 | 
				
			||||||
@ -34,6 +33,10 @@ class CompaniesRequest extends FormRequest
 | 
				
			|||||||
            'currency' => [
 | 
					            'currency' => [
 | 
				
			||||||
                'required'
 | 
					                'required'
 | 
				
			||||||
            ],
 | 
					            ],
 | 
				
			||||||
 | 
					            'slug' => [
 | 
				
			||||||
 | 
					                'required',
 | 
				
			||||||
 | 
					                Rule::unique('companies')
 | 
				
			||||||
 | 
					            ],
 | 
				
			||||||
            'address.name' => [
 | 
					            'address.name' => [
 | 
				
			||||||
                'nullable',
 | 
					                'nullable',
 | 
				
			||||||
            ],
 | 
					            ],
 | 
				
			||||||
@ -68,11 +71,11 @@ class CompaniesRequest extends FormRequest
 | 
				
			|||||||
    {
 | 
					    {
 | 
				
			||||||
        return collect($this->validated())
 | 
					        return collect($this->validated())
 | 
				
			||||||
            ->only([
 | 
					            ->only([
 | 
				
			||||||
                'name'
 | 
					                'name',
 | 
				
			||||||
 | 
					                'slug'
 | 
				
			||||||
            ])
 | 
					            ])
 | 
				
			||||||
            ->merge([
 | 
					            ->merge([
 | 
				
			||||||
                'owner_id' => $this->user()->id,
 | 
					                'owner_id' => $this->user()->id
 | 
				
			||||||
                'slug' => Str::slug($this->name)
 | 
					 | 
				
			||||||
            ])
 | 
					            ])
 | 
				
			||||||
            ->toArray();
 | 
					            ->toArray();
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
				
			|||||||
@ -30,7 +30,8 @@ class CompanyRequest extends FormRequest
 | 
				
			|||||||
                Rule::unique('companies')->ignore($this->header('company'), 'id'),
 | 
					                Rule::unique('companies')->ignore($this->header('company'), 'id'),
 | 
				
			||||||
            ],
 | 
					            ],
 | 
				
			||||||
            'slug' => [
 | 
					            'slug' => [
 | 
				
			||||||
                'nullable'
 | 
					                'required',
 | 
				
			||||||
 | 
					                Rule::unique('companies')->ignore($this->header('company'), 'id'),
 | 
				
			||||||
            ],
 | 
					            ],
 | 
				
			||||||
            'address.country_id' => [
 | 
					            'address.country_id' => [
 | 
				
			||||||
                'required',
 | 
					                'required',
 | 
				
			||||||
 | 
				
			|||||||
@ -23,7 +23,7 @@ class EstimateResource extends JsonResource
 | 
				
			|||||||
            'reference_number' => $this->reference_number,
 | 
					            'reference_number' => $this->reference_number,
 | 
				
			||||||
            'tax_per_item' => $this->tax_per_item,
 | 
					            'tax_per_item' => $this->tax_per_item,
 | 
				
			||||||
            'discount_per_item' => $this->discount_per_item,
 | 
					            'discount_per_item' => $this->discount_per_item,
 | 
				
			||||||
            'notes' => $this->getNotes(),
 | 
					            'notes' => $this->notes,
 | 
				
			||||||
            'discount' => $this->discount,
 | 
					            'discount' => $this->discount,
 | 
				
			||||||
            'discount_type' => $this->discount_type,
 | 
					            'discount_type' => $this->discount_type,
 | 
				
			||||||
            'discount_val' => $this->discount_val,
 | 
					            'discount_val' => $this->discount_val,
 | 
				
			||||||
 | 
				
			|||||||
@ -18,7 +18,7 @@ class PaymentResource extends JsonResource
 | 
				
			|||||||
            'id' => $this->id,
 | 
					            'id' => $this->id,
 | 
				
			||||||
            'payment_number' => $this->payment_number,
 | 
					            'payment_number' => $this->payment_number,
 | 
				
			||||||
            'payment_date' => $this->payment_date,
 | 
					            'payment_date' => $this->payment_date,
 | 
				
			||||||
            'notes' => $this->getNotes(),
 | 
					            'notes' => $this->notes,
 | 
				
			||||||
            'amount' => $this->amount,
 | 
					            'amount' => $this->amount,
 | 
				
			||||||
            'unique_hash' => $this->unique_hash,
 | 
					            'unique_hash' => $this->unique_hash,
 | 
				
			||||||
            'invoice_id' => $this->invoice_id,
 | 
					            'invoice_id' => $this->invoice_id,
 | 
				
			||||||
 | 
				
			|||||||
@ -217,7 +217,7 @@ class Company extends Model implements HasMedia
 | 
				
			|||||||
            'estimate_billing_address_format' => $billingAddressFormat,
 | 
					            'estimate_billing_address_format' => $billingAddressFormat,
 | 
				
			||||||
            'payment_company_address_format' => $companyAddressFormat,
 | 
					            'payment_company_address_format' => $companyAddressFormat,
 | 
				
			||||||
            'payment_from_customer_address_format' => $paymentFromCustomerAddress,
 | 
					            'payment_from_customer_address_format' => $paymentFromCustomerAddress,
 | 
				
			||||||
            'currency' => request()->currency ?? 13,
 | 
					            'currency' => request()->currency ?? 1,
 | 
				
			||||||
            'time_zone' => 'Asia/Kolkata',
 | 
					            'time_zone' => 'Asia/Kolkata',
 | 
				
			||||||
            'language' => 'en',
 | 
					            'language' => 'en',
 | 
				
			||||||
            'fiscal_year' => '1-12',
 | 
					            'fiscal_year' => '1-12',
 | 
				
			||||||
 | 
				
			|||||||
@ -483,7 +483,8 @@ class Estimate extends Model implements HasMedia
 | 
				
			|||||||
            '{ESTIMATE_DATE}' => $this->formattedEstimateDate,
 | 
					            '{ESTIMATE_DATE}' => $this->formattedEstimateDate,
 | 
				
			||||||
            '{ESTIMATE_EXPIRY_DATE}' => $this->formattedExpiryDate,
 | 
					            '{ESTIMATE_EXPIRY_DATE}' => $this->formattedExpiryDate,
 | 
				
			||||||
            '{ESTIMATE_NUMBER}' => $this->estimate_number,
 | 
					            '{ESTIMATE_NUMBER}' => $this->estimate_number,
 | 
				
			||||||
            '{ESTIMATE_REF_NUMBER}' => $this->reference_number,
 | 
					            '{PDF_LINK}' => $this->estimatePdfUrl,
 | 
				
			||||||
 | 
					            '{TOTAL_AMOUNT}' => format_money_pdf($this->total, $this->customer->currency)
 | 
				
			||||||
        ];
 | 
					        ];
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
				
			|||||||
@ -240,7 +240,7 @@ class Expense extends Model implements HasMedia
 | 
				
			|||||||
        }
 | 
					        }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        if ($request->hasFile('attachment_receipt')) {
 | 
					        if ($request->hasFile('attachment_receipt')) {
 | 
				
			||||||
            $expense->addMediaFromRequest('attachment_receipt')->toMediaCollection('receipts');
 | 
					            $expense->addMediaFromRequest('attachment_receipt')->toMediaCollection('receipts', 'local');
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        if ($request->customFields) {
 | 
					        if ($request->customFields) {
 | 
				
			||||||
@ -262,12 +262,12 @@ class Expense extends Model implements HasMedia
 | 
				
			|||||||
            ExchangeRateLog::addExchangeRateLog($this);
 | 
					            ExchangeRateLog::addExchangeRateLog($this);
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        if (isset($request->is_attachment_receipt_removed) && (bool) $request->is_attachment_receipt_removed) {
 | 
					        if (isset($request->is_attachment_receipt_removed) && $request->is_attachment_receipt_removed == "true") {
 | 
				
			||||||
            $this->clearMediaCollection('receipts');
 | 
					            $this->clearMediaCollection('receipts');
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
        if ($request->hasFile('attachment_receipt')) {
 | 
					        if ($request->hasFile('attachment_receipt')) {
 | 
				
			||||||
            $this->clearMediaCollection('receipts');
 | 
					            $this->clearMediaCollection('receipts');
 | 
				
			||||||
            $this->addMediaFromRequest('attachment_receipt')->toMediaCollection('receipts');
 | 
					            $this->addMediaFromRequest('attachment_receipt')->toMediaCollection('receipts', 'local');
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        if ($request->customFields) {
 | 
					        if ($request->customFields) {
 | 
				
			||||||
 | 
				
			|||||||
@ -187,16 +187,6 @@ class Invoice extends Model implements HasMedia
 | 
				
			|||||||
        return Carbon::parse($this->invoice_date)->format($dateFormat);
 | 
					        return Carbon::parse($this->invoice_date)->format($dateFormat);
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    public function scopeWhereStatus($query, $status)
 | 
					 | 
				
			||||||
    {
 | 
					 | 
				
			||||||
        return $query->where('invoices.status', $status);
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    public function scopeWherePaidStatus($query, $status)
 | 
					 | 
				
			||||||
    {
 | 
					 | 
				
			||||||
        return $query->where('invoices.paid_status', $status);
 | 
					 | 
				
			||||||
    }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    public function scopeWhereDueStatus($query, $status)
 | 
					    public function scopeWhereDueStatus($query, $status)
 | 
				
			||||||
    {
 | 
					    {
 | 
				
			||||||
        return $query->whereIn('invoices.paid_status', [
 | 
					        return $query->whereIn('invoices.paid_status', [
 | 
				
			||||||
@ -234,6 +224,40 @@ class Invoice extends Model implements HasMedia
 | 
				
			|||||||
        $query->orderBy($orderByField, $orderBy);
 | 
					        $query->orderBy($orderByField, $orderBy);
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public function scopeWhereStatus($query, $status)
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        return $query->where('invoices.status', $status);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public function scopeWherePaidStatus($query, $status)
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        return $query->where('invoices.paid_status', $status);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    public function scopeWhereTabFilters($query, $status)
 | 
				
			||||||
 | 
					    {
 | 
				
			||||||
 | 
					        if ($status == "DRAFT") {
 | 
				
			||||||
 | 
					            return $query->where('invoices.status', $status);
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        if ($status == "SENT") {
 | 
				
			||||||
 | 
					            return $query->whereIn('invoices.status', [
 | 
				
			||||||
 | 
					                self::STATUS_SENT,
 | 
				
			||||||
 | 
					                self::STATUS_VIEWED,
 | 
				
			||||||
 | 
					                self::STATUS_COMPLETED
 | 
				
			||||||
 | 
					            ]);
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        if ($status == 'DUE') {
 | 
				
			||||||
 | 
					            return $query->whereIn('invoices.paid_status', [
 | 
				
			||||||
 | 
					                self::STATUS_UNPAID,
 | 
				
			||||||
 | 
					                self::STATUS_PARTIALLY_PAID,
 | 
				
			||||||
 | 
					            ]);
 | 
				
			||||||
 | 
					        }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        return ;
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    public function scopeApplyFilters($query, array $filters)
 | 
					    public function scopeApplyFilters($query, array $filters)
 | 
				
			||||||
    {
 | 
					    {
 | 
				
			||||||
        $filters = collect($filters);
 | 
					        $filters = collect($filters);
 | 
				
			||||||
@ -249,17 +273,11 @@ class Invoice extends Model implements HasMedia
 | 
				
			|||||||
                $filters->get('status') == self::STATUS_PAID
 | 
					                $filters->get('status') == self::STATUS_PAID
 | 
				
			||||||
            ) {
 | 
					            ) {
 | 
				
			||||||
                $query->wherePaidStatus($filters->get('status'));
 | 
					                $query->wherePaidStatus($filters->get('status'));
 | 
				
			||||||
            } elseif ($filters->get('status') == 'DUE') {
 | 
					 | 
				
			||||||
                $query->whereDueStatus($filters->get('status'));
 | 
					 | 
				
			||||||
            } else {
 | 
					            } else {
 | 
				
			||||||
                $query->whereStatus($filters->get('status'));
 | 
					                $query->whereStatus($filters->get('status'));
 | 
				
			||||||
            }
 | 
					            }
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        if ($filters->get('paid_status')) {
 | 
					 | 
				
			||||||
            $query->wherePaidStatus($filters->get('status'));
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        if ($filters->get('invoice_id')) {
 | 
					        if ($filters->get('invoice_id')) {
 | 
				
			||||||
            $query->whereInvoice($filters->get('invoice_id'));
 | 
					            $query->whereInvoice($filters->get('invoice_id'));
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
@ -651,7 +669,9 @@ class Invoice extends Model implements HasMedia
 | 
				
			|||||||
            '{INVOICE_DATE}' => $this->formattedInvoiceDate,
 | 
					            '{INVOICE_DATE}' => $this->formattedInvoiceDate,
 | 
				
			||||||
            '{INVOICE_DUE_DATE}' => $this->formattedDueDate,
 | 
					            '{INVOICE_DUE_DATE}' => $this->formattedDueDate,
 | 
				
			||||||
            '{INVOICE_NUMBER}' => $this->invoice_number,
 | 
					            '{INVOICE_NUMBER}' => $this->invoice_number,
 | 
				
			||||||
            '{INVOICE_REF_NUMBER}' => $this->reference_number,
 | 
					            '{PDF_LINK}' => $this->invoicePdfUrl,
 | 
				
			||||||
 | 
					            '{DUE_AMOUNT}' => format_money_pdf($this->due_amount, $this->customer->currency),
 | 
				
			||||||
 | 
					            '{TOTAL_AMOUNT}' => format_money_pdf($this->total, $this->customer->currency)
 | 
				
			||||||
        ];
 | 
					        ];
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
				
			|||||||
@ -435,7 +435,8 @@ class Payment extends Model implements HasMedia
 | 
				
			|||||||
            '{PAYMENT_DATE}' => $this->formattedPaymentDate,
 | 
					            '{PAYMENT_DATE}' => $this->formattedPaymentDate,
 | 
				
			||||||
            '{PAYMENT_MODE}' => $this->paymentMethod ? $this->paymentMethod->name : null,
 | 
					            '{PAYMENT_MODE}' => $this->paymentMethod ? $this->paymentMethod->name : null,
 | 
				
			||||||
            '{PAYMENT_NUMBER}' => $this->payment_number,
 | 
					            '{PAYMENT_NUMBER}' => $this->payment_number,
 | 
				
			||||||
            '{PAYMENT_AMOUNT}' => $this->reference_number,
 | 
					            '{PDF_LINK}' => $this->paymentPdfUrl,
 | 
				
			||||||
 | 
					            '{PAYMENT_AMOUNT}' => format_money_pdf($this->amount, $this->customer->currency)
 | 
				
			||||||
        ];
 | 
					        ];
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
				
			|||||||
@ -27,7 +27,6 @@ return [
 | 
				
			|||||||
            'tokenizer',
 | 
					            'tokenizer',
 | 
				
			||||||
            'JSON',
 | 
					            'JSON',
 | 
				
			||||||
            'cURL',
 | 
					            'cURL',
 | 
				
			||||||
            'zip',
 | 
					 | 
				
			||||||
        ],
 | 
					        ],
 | 
				
			||||||
        'apache' => [
 | 
					        'apache' => [
 | 
				
			||||||
            'mod_rewrite',
 | 
					            'mod_rewrite',
 | 
				
			||||||
 | 
				
			|||||||
							
								
								
									
										502
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										502
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							@ -65,13 +65,6 @@
 | 
				
			|||||||
        "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",
 | 
				
			||||||
@ -221,23 +214,6 @@
 | 
				
			|||||||
      "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.48.0",
 | 
					 | 
				
			||||||
      "resolved": "https://registry.npmjs.org/@stripe/stripe-js/-/stripe-js-1.48.0.tgz",
 | 
					 | 
				
			||||||
      "integrity": "sha512-Kw2BRXk6z/wnTU9m2IJOhxJNrx9xzmpFSbk6D/Z0x6LJntMafiHeHFag2PvSF30O2quMb1UUdWsnZqGVDruZww=="
 | 
					 | 
				
			||||||
    },
 | 
					 | 
				
			||||||
    "@tailwindcss/aspect-ratio": {
 | 
					 | 
				
			||||||
      "version": "0.4.2",
 | 
					 | 
				
			||||||
      "resolved": "https://registry.npmjs.org/@tailwindcss/aspect-ratio/-/aspect-ratio-0.4.2.tgz",
 | 
					 | 
				
			||||||
      "integrity": "sha512-8QPrypskfBa7QIMuKHg2TA7BqES6vhBrDLOv8Unb6FcFyd3TjKbc6lcmb9UPQHxfl24sXoJ41ux/H7qQQvfaSQ==",
 | 
					 | 
				
			||||||
      "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",
 | 
				
			||||||
@ -247,35 +223,6 @@
 | 
				
			|||||||
        "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.9",
 | 
					 | 
				
			||||||
      "resolved": "https://registry.npmjs.org/@tailwindcss/typography/-/typography-0.5.9.tgz",
 | 
					 | 
				
			||||||
      "integrity": "sha512-t8Sg3DyynFysV9f4JDOVISGsjazNb48AeIYQwcL+Bsq5uf4RYL75C1giZ43KISjeDGBaTN3Kxh7Xj/vRSMJUUg==",
 | 
					 | 
				
			||||||
      "dev": true,
 | 
					 | 
				
			||||||
      "requires": {
 | 
					 | 
				
			||||||
        "lodash.castarray": "^4.4.0",
 | 
					 | 
				
			||||||
        "lodash.isplainobject": "^4.0.6",
 | 
					 | 
				
			||||||
        "lodash.merge": "^4.6.2",
 | 
					 | 
				
			||||||
        "postcss-selector-parser": "6.0.10"
 | 
					 | 
				
			||||||
      },
 | 
					 | 
				
			||||||
      "dependencies": {
 | 
					 | 
				
			||||||
        "postcss-selector-parser": {
 | 
					 | 
				
			||||||
          "version": "6.0.10",
 | 
					 | 
				
			||||||
          "resolved": "https://registry.npmjs.org/postcss-selector-parser/-/postcss-selector-parser-6.0.10.tgz",
 | 
					 | 
				
			||||||
          "integrity": "sha512-IQ7TZdoaqbT+LCpShg46jnZVlhWD2w6iQYAcYXfHARZ7X1t/UGhhceQDs5X0cGqKvYlHNOuv7Oa1xmb0oQuA3w==",
 | 
					 | 
				
			||||||
          "dev": true,
 | 
					 | 
				
			||||||
          "requires": {
 | 
					 | 
				
			||||||
            "cssesc": "^3.0.0",
 | 
					 | 
				
			||||||
            "util-deprecate": "^1.0.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",
 | 
				
			||||||
@ -439,11 +386,6 @@
 | 
				
			|||||||
      "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.220",
 | 
					 | 
				
			||||||
      "resolved": "https://registry.npmjs.org/@tiptap/extension-text-align/-/extension-text-align-2.0.0-beta.220.tgz",
 | 
					 | 
				
			||||||
      "integrity": "sha512-xUYhozdJA0UVLxlrxYLHLhwDYD5oDDiy0omAzFKAyRRtHAkNSPot7Vp7UJW2M0R6XHIQDMFEopxKQNJMBTRk3w=="
 | 
					 | 
				
			||||||
    },
 | 
					 | 
				
			||||||
    "@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",
 | 
				
			||||||
@ -595,12 +537,6 @@
 | 
				
			|||||||
        "@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",
 | 
				
			||||||
@ -622,70 +558,6 @@
 | 
				
			|||||||
        "@vue/shared": "3.2.4"
 | 
					        "@vue/shared": "3.2.4"
 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    "@vue/compiler-sfc": {
 | 
					 | 
				
			||||||
      "version": "3.2.47",
 | 
					 | 
				
			||||||
      "resolved": "https://registry.npmjs.org/@vue/compiler-sfc/-/compiler-sfc-3.2.47.tgz",
 | 
					 | 
				
			||||||
      "integrity": "sha512-rog05W+2IFfxjMcFw10tM9+f7i/+FFpZJJ5XHX72NP9eC2uRD+42M3pYcQqDXVYoj74kHMSEdQ/WmCjt8JFksQ==",
 | 
					 | 
				
			||||||
      "dev": true,
 | 
					 | 
				
			||||||
      "requires": {
 | 
					 | 
				
			||||||
        "@babel/parser": "^7.16.4",
 | 
					 | 
				
			||||||
        "@vue/compiler-core": "3.2.47",
 | 
					 | 
				
			||||||
        "@vue/compiler-dom": "3.2.47",
 | 
					 | 
				
			||||||
        "@vue/compiler-ssr": "3.2.47",
 | 
					 | 
				
			||||||
        "@vue/reactivity-transform": "3.2.47",
 | 
					 | 
				
			||||||
        "@vue/shared": "3.2.47",
 | 
					 | 
				
			||||||
        "estree-walker": "^2.0.2",
 | 
					 | 
				
			||||||
        "magic-string": "^0.25.7",
 | 
					 | 
				
			||||||
        "postcss": "^8.1.10",
 | 
					 | 
				
			||||||
        "source-map": "^0.6.1"
 | 
					 | 
				
			||||||
      },
 | 
					 | 
				
			||||||
      "dependencies": {
 | 
					 | 
				
			||||||
        "@babel/parser": {
 | 
					 | 
				
			||||||
          "version": "7.21.2",
 | 
					 | 
				
			||||||
          "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.21.2.tgz",
 | 
					 | 
				
			||||||
          "integrity": "sha512-URpaIJQwEkEC2T9Kn+Ai6Xe/02iNaVCuT/PtoRz3GPVJVDpPd7mLo+VddTbhCRU9TXqW5mSrQfXZyi8kDKOVpQ==",
 | 
					 | 
				
			||||||
          "dev": true
 | 
					 | 
				
			||||||
        },
 | 
					 | 
				
			||||||
        "@vue/compiler-core": {
 | 
					 | 
				
			||||||
          "version": "3.2.47",
 | 
					 | 
				
			||||||
          "resolved": "https://registry.npmjs.org/@vue/compiler-core/-/compiler-core-3.2.47.tgz",
 | 
					 | 
				
			||||||
          "integrity": "sha512-p4D7FDnQb7+YJmO2iPEv0SQNeNzcbHdGByJDsT4lynf63AFkOTFN07HsiRSvjGo0QrxR/o3d0hUyNCUnBU2Tig==",
 | 
					 | 
				
			||||||
          "dev": true,
 | 
					 | 
				
			||||||
          "requires": {
 | 
					 | 
				
			||||||
            "@babel/parser": "^7.16.4",
 | 
					 | 
				
			||||||
            "@vue/shared": "3.2.47",
 | 
					 | 
				
			||||||
            "estree-walker": "^2.0.2",
 | 
					 | 
				
			||||||
            "source-map": "^0.6.1"
 | 
					 | 
				
			||||||
          }
 | 
					 | 
				
			||||||
        },
 | 
					 | 
				
			||||||
        "@vue/compiler-dom": {
 | 
					 | 
				
			||||||
          "version": "3.2.47",
 | 
					 | 
				
			||||||
          "resolved": "https://registry.npmjs.org/@vue/compiler-dom/-/compiler-dom-3.2.47.tgz",
 | 
					 | 
				
			||||||
          "integrity": "sha512-dBBnEHEPoftUiS03a4ggEig74J2YBZ2UIeyfpcRM2tavgMWo4bsEfgCGsu+uJIL/vax9S+JztH8NmQerUo7shQ==",
 | 
					 | 
				
			||||||
          "dev": true,
 | 
					 | 
				
			||||||
          "requires": {
 | 
					 | 
				
			||||||
            "@vue/compiler-core": "3.2.47",
 | 
					 | 
				
			||||||
            "@vue/shared": "3.2.47"
 | 
					 | 
				
			||||||
          }
 | 
					 | 
				
			||||||
        },
 | 
					 | 
				
			||||||
        "@vue/compiler-ssr": {
 | 
					 | 
				
			||||||
          "version": "3.2.47",
 | 
					 | 
				
			||||||
          "resolved": "https://registry.npmjs.org/@vue/compiler-ssr/-/compiler-ssr-3.2.47.tgz",
 | 
					 | 
				
			||||||
          "integrity": "sha512-wVXC+gszhulcMD8wpxMsqSOpvDZ6xKXSVWkf50Guf/S+28hTAXPDYRTbLQ3EDkOP5Xz/+SY37YiwDquKbJOgZw==",
 | 
					 | 
				
			||||||
          "dev": true,
 | 
					 | 
				
			||||||
          "requires": {
 | 
					 | 
				
			||||||
            "@vue/compiler-dom": "3.2.47",
 | 
					 | 
				
			||||||
            "@vue/shared": "3.2.47"
 | 
					 | 
				
			||||||
          }
 | 
					 | 
				
			||||||
        },
 | 
					 | 
				
			||||||
        "@vue/shared": {
 | 
					 | 
				
			||||||
          "version": "3.2.47",
 | 
					 | 
				
			||||||
          "resolved": "https://registry.npmjs.org/@vue/shared/-/shared-3.2.47.tgz",
 | 
					 | 
				
			||||||
          "integrity": "sha512-BHGyyGN3Q97EZx0taMQ+OLNuZcW3d37ZEVmEAyeoA9ERdGvm9Irc/0Fua8SNyOtV1w6BS4q25wbMzJujO9HIfQ==",
 | 
					 | 
				
			||||||
          "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",
 | 
				
			||||||
@ -735,45 +607,6 @@
 | 
				
			|||||||
        "@vue/shared": "3.2.4"
 | 
					        "@vue/shared": "3.2.4"
 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    "@vue/reactivity-transform": {
 | 
					 | 
				
			||||||
      "version": "3.2.47",
 | 
					 | 
				
			||||||
      "resolved": "https://registry.npmjs.org/@vue/reactivity-transform/-/reactivity-transform-3.2.47.tgz",
 | 
					 | 
				
			||||||
      "integrity": "sha512-m8lGXw8rdnPVVIdIFhf0LeQ/ixyHkH5plYuS83yop5n7ggVJU+z5v0zecwEnX7fa7HNLBhh2qngJJkxpwEEmYA==",
 | 
					 | 
				
			||||||
      "dev": true,
 | 
					 | 
				
			||||||
      "requires": {
 | 
					 | 
				
			||||||
        "@babel/parser": "^7.16.4",
 | 
					 | 
				
			||||||
        "@vue/compiler-core": "3.2.47",
 | 
					 | 
				
			||||||
        "@vue/shared": "3.2.47",
 | 
					 | 
				
			||||||
        "estree-walker": "^2.0.2",
 | 
					 | 
				
			||||||
        "magic-string": "^0.25.7"
 | 
					 | 
				
			||||||
      },
 | 
					 | 
				
			||||||
      "dependencies": {
 | 
					 | 
				
			||||||
        "@babel/parser": {
 | 
					 | 
				
			||||||
          "version": "7.21.2",
 | 
					 | 
				
			||||||
          "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.21.2.tgz",
 | 
					 | 
				
			||||||
          "integrity": "sha512-URpaIJQwEkEC2T9Kn+Ai6Xe/02iNaVCuT/PtoRz3GPVJVDpPd7mLo+VddTbhCRU9TXqW5mSrQfXZyi8kDKOVpQ==",
 | 
					 | 
				
			||||||
          "dev": true
 | 
					 | 
				
			||||||
        },
 | 
					 | 
				
			||||||
        "@vue/compiler-core": {
 | 
					 | 
				
			||||||
          "version": "3.2.47",
 | 
					 | 
				
			||||||
          "resolved": "https://registry.npmjs.org/@vue/compiler-core/-/compiler-core-3.2.47.tgz",
 | 
					 | 
				
			||||||
          "integrity": "sha512-p4D7FDnQb7+YJmO2iPEv0SQNeNzcbHdGByJDsT4lynf63AFkOTFN07HsiRSvjGo0QrxR/o3d0hUyNCUnBU2Tig==",
 | 
					 | 
				
			||||||
          "dev": true,
 | 
					 | 
				
			||||||
          "requires": {
 | 
					 | 
				
			||||||
            "@babel/parser": "^7.16.4",
 | 
					 | 
				
			||||||
            "@vue/shared": "3.2.47",
 | 
					 | 
				
			||||||
            "estree-walker": "^2.0.2",
 | 
					 | 
				
			||||||
            "source-map": "^0.6.1"
 | 
					 | 
				
			||||||
          }
 | 
					 | 
				
			||||||
        },
 | 
					 | 
				
			||||||
        "@vue/shared": {
 | 
					 | 
				
			||||||
          "version": "3.2.47",
 | 
					 | 
				
			||||||
          "resolved": "https://registry.npmjs.org/@vue/shared/-/shared-3.2.47.tgz",
 | 
					 | 
				
			||||||
          "integrity": "sha512-BHGyyGN3Q97EZx0taMQ+OLNuZcW3d37ZEVmEAyeoA9ERdGvm9Irc/0Fua8SNyOtV1w6BS4q25wbMzJujO9HIfQ==",
 | 
					 | 
				
			||||||
          "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",
 | 
				
			||||||
@ -844,44 +677,6 @@
 | 
				
			|||||||
      "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.3",
 | 
					 | 
				
			||||||
      "resolved": "https://registry.npmjs.org/@vuelidate/components/-/components-1.2.3.tgz",
 | 
					 | 
				
			||||||
      "integrity": "sha512-QE+oSzJVYZUfYcIAsM+QCrB3xRJoesFzUTNtfuYbhWfdMmTHxA9YtKuKWlTsR1nK8+SmHMJROIG8PnL77ZLSuQ==",
 | 
					 | 
				
			||||||
      "requires": {
 | 
					 | 
				
			||||||
        "@vuelidate/core": "^2.0.0"
 | 
					 | 
				
			||||||
      }
 | 
					 | 
				
			||||||
    },
 | 
					 | 
				
			||||||
    "@vuelidate/core": {
 | 
					 | 
				
			||||||
      "version": "2.0.0",
 | 
					 | 
				
			||||||
      "resolved": "https://registry.npmjs.org/@vuelidate/core/-/core-2.0.0.tgz",
 | 
					 | 
				
			||||||
      "integrity": "sha512-xIFgdQlScO0aaSZ0wTGPJh8YcTMNAj5veI8yPgiAyxOT+GV7vNQFiU1vpYWCL4cklkkhYvRRSC2OEX7YOZNmPQ==",
 | 
					 | 
				
			||||||
      "requires": {
 | 
					 | 
				
			||||||
        "vue-demi": "^0.13.11"
 | 
					 | 
				
			||||||
      },
 | 
					 | 
				
			||||||
      "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",
 | 
					 | 
				
			||||||
      "resolved": "https://registry.npmjs.org/@vuelidate/validators/-/validators-2.0.0.tgz",
 | 
					 | 
				
			||||||
      "integrity": "sha512-fQQcmDWfz7pyH5/JPi0Ng2GEgNK1pUHn/Z/j5rG/Q+HwhgIXvJblTPcZwKOj1ABL7V4UVuGKECvZCDHNGOwdrg==",
 | 
					 | 
				
			||||||
      "requires": {
 | 
					 | 
				
			||||||
        "vue-demi": "^0.13.11"
 | 
					 | 
				
			||||||
      },
 | 
					 | 
				
			||||||
      "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",
 | 
				
			||||||
@ -1445,175 +1240,6 @@
 | 
				
			|||||||
        }
 | 
					        }
 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    "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",
 | 
				
			||||||
@ -2321,24 +1947,12 @@
 | 
				
			|||||||
      "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",
 | 
				
			||||||
@ -2413,9 +2027,9 @@
 | 
				
			|||||||
      }
 | 
					      }
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    "minimist": {
 | 
					    "minimist": {
 | 
				
			||||||
      "version": "1.2.8",
 | 
					      "version": "1.2.5",
 | 
				
			||||||
      "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.8.tgz",
 | 
					      "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.5.tgz",
 | 
				
			||||||
      "integrity": "sha512-2yyAR8qBkN3YuheJanUpWC5U3bb5osDywNB8RzDVlDwDHbocAJveqqj1u8+SVD7jkWT4yvsHCpWqqWqAxb0zCA==",
 | 
					      "integrity": "sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw==",
 | 
				
			||||||
      "dev": true
 | 
					      "dev": true
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    "modern-normalize": {
 | 
					    "modern-normalize": {
 | 
				
			||||||
@ -2591,22 +2205,6 @@
 | 
				
			|||||||
      "integrity": "sha512-lY1Q/PiJGC2zOv/z391WOTD+Z02bCgsFfvxoXXf6h7kv9o+WmsmzYqrAwY63sNgOxE4xEdq0WyUnXfKeBrSvYw==",
 | 
					      "integrity": "sha512-lY1Q/PiJGC2zOv/z391WOTD+Z02bCgsFfvxoXXf6h7kv9o+WmsmzYqrAwY63sNgOxE4xEdq0WyUnXfKeBrSvYw==",
 | 
				
			||||||
      "dev": true
 | 
					      "dev": true
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    "pinia": {
 | 
					 | 
				
			||||||
      "version": "2.0.32",
 | 
					 | 
				
			||||||
      "resolved": "https://registry.npmjs.org/pinia/-/pinia-2.0.32.tgz",
 | 
					 | 
				
			||||||
      "integrity": "sha512-8Tw4OrpCSJ028UUyp0gYPP/wyjigLoEceuO/x1G+FlHVf73337e5vLm4uDmrRIoBG1hvaed/eSHnrCFjOc4nkA==",
 | 
					 | 
				
			||||||
      "requires": {
 | 
					 | 
				
			||||||
        "@vue/devtools-api": "^6.5.0",
 | 
					 | 
				
			||||||
        "vue-demi": "*"
 | 
					 | 
				
			||||||
      },
 | 
					 | 
				
			||||||
      "dependencies": {
 | 
					 | 
				
			||||||
        "@vue/devtools-api": {
 | 
					 | 
				
			||||||
          "version": "6.5.0",
 | 
					 | 
				
			||||||
          "resolved": "https://registry.npmjs.org/@vue/devtools-api/-/devtools-api-6.5.0.tgz",
 | 
					 | 
				
			||||||
          "integrity": "sha512-o9KfBeaBmCKl10usN4crU53fYtC1r7jJwdGKjPT24t348rHxgfpZ0xL3Xm/gLUYnc0oTp8LAmrxOeLyu6tbk2Q=="
 | 
					 | 
				
			||||||
        }
 | 
					 | 
				
			||||||
      }
 | 
					 | 
				
			||||||
    },
 | 
					 | 
				
			||||||
    "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",
 | 
				
			||||||
@ -2910,15 +2508,6 @@
 | 
				
			|||||||
        "glob": "^7.1.3"
 | 
					        "glob": "^7.1.3"
 | 
				
			||||||
      }
 | 
					      }
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    "rollup": {
 | 
					 | 
				
			||||||
      "version": "2.77.3",
 | 
					 | 
				
			||||||
      "resolved": "https://registry.npmjs.org/rollup/-/rollup-2.77.3.tgz",
 | 
					 | 
				
			||||||
      "integrity": "sha512-/qxNTG7FbmefJWoeeYJFbHehJ2HNWnjkAFRKzWN/45eNBBF/r8lo992CwcJXEzyVxs5FmfId+vTSTQDb+bxA+g==",
 | 
					 | 
				
			||||||
      "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",
 | 
				
			||||||
@ -3079,12 +2668,6 @@
 | 
				
			|||||||
        "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",
 | 
				
			||||||
@ -3351,86 +2934,12 @@
 | 
				
			|||||||
      "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.15",
 | 
					 | 
				
			||||||
      "resolved": "https://registry.npmjs.org/vite/-/vite-2.9.15.tgz",
 | 
					 | 
				
			||||||
      "integrity": "sha512-fzMt2jK4vQ3yK56te3Kqpkaeq9DkcZfBbzHwYpobasvgYmP2SoAr6Aic05CsB4CzCZbsDv4sujX3pkEGhLabVQ==",
 | 
					 | 
				
			||||||
      "dev": true,
 | 
					 | 
				
			||||||
      "requires": {
 | 
					 | 
				
			||||||
        "esbuild": "^0.14.27",
 | 
					 | 
				
			||||||
        "fsevents": "~2.3.2",
 | 
					 | 
				
			||||||
        "postcss": "^8.4.13",
 | 
					 | 
				
			||||||
        "resolve": "^1.22.0",
 | 
					 | 
				
			||||||
        "rollup": ">=2.59.0 <2.78.0"
 | 
					 | 
				
			||||||
      },
 | 
					 | 
				
			||||||
      "dependencies": {
 | 
					 | 
				
			||||||
        "is-core-module": {
 | 
					 | 
				
			||||||
          "version": "2.11.0",
 | 
					 | 
				
			||||||
          "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.11.0.tgz",
 | 
					 | 
				
			||||||
          "integrity": "sha512-RRjxlvLDkD1YJwDbroBHMb+cukurkDWNyHx7D3oNB5x9rb5ogcksMC5wHCadcXoo67gVr/+3GFySh3134zi6rw==",
 | 
					 | 
				
			||||||
          "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.21",
 | 
					 | 
				
			||||||
          "resolved": "https://registry.npmjs.org/postcss/-/postcss-8.4.21.tgz",
 | 
					 | 
				
			||||||
          "integrity": "sha512-tP7u/Sn/dVxK2NnruI4H9BG+x+Wxz6oeZ1cJ8P6G/PZY0IKk4k/63TDsQf2kQq3+qoJeLm2kIBUNlZe3zgb4Zg==",
 | 
					 | 
				
			||||||
          "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",
 | 
				
			||||||
@ -3493,11 +3002,6 @@
 | 
				
			|||||||
        "@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",
 | 
				
			||||||
 | 
				
			|||||||
@ -27,7 +27,7 @@
 | 
				
			|||||||
    "vite": "^2.6.1"
 | 
					    "vite": "^2.6.1"
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
  "dependencies": {
 | 
					  "dependencies": {
 | 
				
			||||||
    "@headlessui/vue": "^1.4.0",
 | 
					    "@headlessui/vue": "^1.5.0",
 | 
				
			||||||
    "@heroicons/vue": "^1.0.1",
 | 
					    "@heroicons/vue": "^1.0.1",
 | 
				
			||||||
    "@popperjs/core": "^2.9.2",
 | 
					    "@popperjs/core": "^2.9.2",
 | 
				
			||||||
    "@stripe/stripe-js": "^1.21.2",
 | 
					    "@stripe/stripe-js": "^1.21.2",
 | 
				
			||||||
@ -48,7 +48,8 @@
 | 
				
			|||||||
    "mini-svg-data-uri": "^1.3.3",
 | 
					    "mini-svg-data-uri": "^1.3.3",
 | 
				
			||||||
    "moment": "^2.29.1",
 | 
					    "moment": "^2.29.1",
 | 
				
			||||||
    "pinia": "^2.0.4",
 | 
					    "pinia": "^2.0.4",
 | 
				
			||||||
    "v-money3": "^3.13.5",
 | 
					    "v-calendar": "3.0.0-alpha.8",
 | 
				
			||||||
 | 
					    "v-money3": "3.16.1",
 | 
				
			||||||
    "v-tooltip": "^4.0.0-alpha.1",
 | 
					    "v-tooltip": "^4.0.0-alpha.1",
 | 
				
			||||||
    "vue": "^3.2.0-beta.5",
 | 
					    "vue": "^3.2.0-beta.5",
 | 
				
			||||||
    "vue-flatpickr-component": "^9.0.3",
 | 
					    "vue-flatpickr-component": "^9.0.3",
 | 
				
			||||||
 | 
				
			|||||||
@ -7,6 +7,7 @@
 | 
				
			|||||||
      py-2
 | 
					      py-2
 | 
				
			||||||
      rounded-lg
 | 
					      rounded-lg
 | 
				
			||||||
      bg-opacity-40 bg-gray-300
 | 
					      bg-opacity-40 bg-gray-300
 | 
				
			||||||
 | 
					      dark:bg-gray-700 dark:border-gray-600
 | 
				
			||||||
      whitespace-nowrap
 | 
					      whitespace-nowrap
 | 
				
			||||||
      flex-col
 | 
					      flex-col
 | 
				
			||||||
      mt-1
 | 
					      mt-1
 | 
				
			||||||
@ -19,6 +20,7 @@
 | 
				
			|||||||
        text-sm
 | 
					        text-sm
 | 
				
			||||||
        font-medium
 | 
					        font-medium
 | 
				
			||||||
        text-black
 | 
					        text-black
 | 
				
			||||||
 | 
					        dark:text-white
 | 
				
			||||||
        truncate
 | 
					        truncate
 | 
				
			||||||
        select-all select-color
 | 
					        select-all select-color
 | 
				
			||||||
      "
 | 
					      "
 | 
				
			||||||
 | 
				
			|||||||
@ -91,6 +91,7 @@
 | 
				
			|||||||
                        leading-tight
 | 
					                        leading-tight
 | 
				
			||||||
                        text-gray-700
 | 
					                        text-gray-700
 | 
				
			||||||
                        cursor-pointer
 | 
					                        cursor-pointer
 | 
				
			||||||
 | 
					                        dark:text-gray-400
 | 
				
			||||||
                      "
 | 
					                      "
 | 
				
			||||||
                    >
 | 
					                    >
 | 
				
			||||||
                      {{ note.name }}
 | 
					                      {{ note.name }}
 | 
				
			||||||
 | 
				
			|||||||
@ -6,8 +6,17 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
<script setup>
 | 
					<script setup>
 | 
				
			||||||
import Chart from 'chart.js'
 | 
					import Chart from 'chart.js'
 | 
				
			||||||
import { ref, reactive, computed, onMounted, watchEffect, inject } from 'vue'
 | 
					import {
 | 
				
			||||||
 | 
					  ref,
 | 
				
			||||||
 | 
					  reactive,
 | 
				
			||||||
 | 
					  computed,
 | 
				
			||||||
 | 
					  onMounted,
 | 
				
			||||||
 | 
					  watchEffect,
 | 
				
			||||||
 | 
					  inject,
 | 
				
			||||||
 | 
					  watch,
 | 
				
			||||||
 | 
					} from 'vue'
 | 
				
			||||||
import { useCompanyStore } from '@/scripts/admin/stores/company'
 | 
					import { useCompanyStore } from '@/scripts/admin/stores/company'
 | 
				
			||||||
 | 
					import { useGlobalStore } from '@/scripts/admin/stores/global'
 | 
				
			||||||
 | 
					
 | 
				
			||||||
const utils = inject('utils')
 | 
					const utils = inject('utils')
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@ -44,9 +53,11 @@ const props = defineProps({
 | 
				
			|||||||
  },
 | 
					  },
 | 
				
			||||||
})
 | 
					})
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					const isDarkModeOn = document.documentElement.classList.contains('dark')
 | 
				
			||||||
let myLineChart = null
 | 
					let myLineChart = null
 | 
				
			||||||
const graph = ref(null)
 | 
					const graph = ref(null)
 | 
				
			||||||
const companyStore = useCompanyStore()
 | 
					const companyStore = useCompanyStore()
 | 
				
			||||||
 | 
					const globalStore = useGlobalStore()
 | 
				
			||||||
const defaultCurrency = computed(() => {
 | 
					const defaultCurrency = computed(() => {
 | 
				
			||||||
  return companyStore.selectedCompanyCurrency
 | 
					  return companyStore.selectedCompanyCurrency
 | 
				
			||||||
})
 | 
					})
 | 
				
			||||||
@ -60,6 +71,14 @@ watchEffect(() => {
 | 
				
			|||||||
  }
 | 
					  }
 | 
				
			||||||
})
 | 
					})
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					watch(
 | 
				
			||||||
 | 
					  () => globalStore.isDarkModeOn,
 | 
				
			||||||
 | 
					  () => {
 | 
				
			||||||
 | 
					    myLineChart.reset()
 | 
				
			||||||
 | 
					    updateColors()
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
onMounted(() => {
 | 
					onMounted(() => {
 | 
				
			||||||
  let context = graph.value.getContext('2d')
 | 
					  let context = graph.value.getContext('2d')
 | 
				
			||||||
  let options = reactive({
 | 
					  let options = reactive({
 | 
				
			||||||
@ -81,6 +100,8 @@ onMounted(() => {
 | 
				
			|||||||
    },
 | 
					    },
 | 
				
			||||||
  })
 | 
					  })
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  const salesColor = globalStore.isDarkModeOn ? '#ffffff' : '#040405'
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  let data = reactive({
 | 
					  let data = reactive({
 | 
				
			||||||
    labels: props.labels,
 | 
					    labels: props.labels,
 | 
				
			||||||
    datasets: [
 | 
					    datasets: [
 | 
				
			||||||
@ -89,16 +110,16 @@ onMounted(() => {
 | 
				
			|||||||
        fill: false,
 | 
					        fill: false,
 | 
				
			||||||
        lineTension: 0.3,
 | 
					        lineTension: 0.3,
 | 
				
			||||||
        backgroundColor: 'rgba(230, 254, 249)',
 | 
					        backgroundColor: 'rgba(230, 254, 249)',
 | 
				
			||||||
        borderColor: '#040405',
 | 
					        borderColor: salesColor,
 | 
				
			||||||
        borderCapStyle: 'butt',
 | 
					        borderCapStyle: 'butt',
 | 
				
			||||||
        borderDash: [],
 | 
					        borderDash: [],
 | 
				
			||||||
        borderDashOffset: 0.0,
 | 
					        borderDashOffset: 0.0,
 | 
				
			||||||
        borderJoinStyle: 'miter',
 | 
					        borderJoinStyle: 'miter',
 | 
				
			||||||
        pointBorderColor: '#040405',
 | 
					        pointBorderColor: salesColor,
 | 
				
			||||||
        pointBackgroundColor: '#fff',
 | 
					        pointBackgroundColor: '#fff',
 | 
				
			||||||
        pointBorderWidth: 1,
 | 
					        pointBorderWidth: 1,
 | 
				
			||||||
        pointHoverRadius: 5,
 | 
					        pointHoverRadius: 5,
 | 
				
			||||||
        pointHoverBackgroundColor: '#040405',
 | 
					        pointHoverBackgroundColor: salesColor,
 | 
				
			||||||
        pointHoverBorderColor: 'rgba(220,220,220,1)',
 | 
					        pointHoverBorderColor: 'rgba(220,220,220,1)',
 | 
				
			||||||
        pointHoverBorderWidth: 2,
 | 
					        pointHoverBorderWidth: 2,
 | 
				
			||||||
        pointRadius: 4,
 | 
					        pointRadius: 4,
 | 
				
			||||||
@ -194,4 +215,12 @@ function update() {
 | 
				
			|||||||
    lazy: true,
 | 
					    lazy: true,
 | 
				
			||||||
  })
 | 
					  })
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					function updateColors() {
 | 
				
			||||||
 | 
					  const newColor = globalStore.isDarkModeOn ? '#ffffff' : '#040405'
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  myLineChart.data.datasets[0].borderColor = newColor
 | 
				
			||||||
 | 
					  myLineChart.data.datasets[0].pointBorderColor = newColor
 | 
				
			||||||
 | 
					  myLineChart.data.datasets[0].pointHoverBackgroundColor = newColor
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
</script>
 | 
					</script>
 | 
				
			||||||
 | 
				
			|||||||
@ -50,21 +50,11 @@
 | 
				
			|||||||
          </BaseInputGroup>
 | 
					          </BaseInputGroup>
 | 
				
			||||||
        </template>
 | 
					        </template>
 | 
				
			||||||
      </ValidateEach>
 | 
					      </ValidateEach>
 | 
				
			||||||
      <div
 | 
					      <BaseModalFooter>
 | 
				
			||||||
        slot="footer"
 | 
					 | 
				
			||||||
        class="
 | 
					 | 
				
			||||||
          z-0
 | 
					 | 
				
			||||||
          flex
 | 
					 | 
				
			||||||
          justify-end
 | 
					 | 
				
			||||||
          mt-4
 | 
					 | 
				
			||||||
          pt-4
 | 
					 | 
				
			||||||
          border-t border-gray-200 border-solid border-modal-bg
 | 
					 | 
				
			||||||
        "
 | 
					 | 
				
			||||||
      >
 | 
					 | 
				
			||||||
        <BaseButton :loading="isSaving" variant="primary" type="submit">
 | 
					        <BaseButton :loading="isSaving" variant="primary" type="submit">
 | 
				
			||||||
          {{ $t('general.save') }}
 | 
					          {{ $t('general.save') }}
 | 
				
			||||||
        </BaseButton>
 | 
					        </BaseButton>
 | 
				
			||||||
      </div>
 | 
					      </BaseModalFooter>
 | 
				
			||||||
    </form>
 | 
					    </form>
 | 
				
			||||||
  </BaseCard>
 | 
					  </BaseCard>
 | 
				
			||||||
</template>
 | 
					</template>
 | 
				
			||||||
 | 
				
			|||||||
@ -64,7 +64,7 @@ function mergeExistingValues() {
 | 
				
			|||||||
  if (props.isEdit) {
 | 
					  if (props.isEdit) {
 | 
				
			||||||
    props.store[props.storeProp].fields.forEach((field) => {
 | 
					    props.store[props.storeProp].fields.forEach((field) => {
 | 
				
			||||||
      const existingIndex = props.store[props.storeProp].customFields.findIndex(
 | 
					      const existingIndex = props.store[props.storeProp].customFields.findIndex(
 | 
				
			||||||
        (f) => f.id === field.custom_field_id
 | 
					        (f) => f.id == field.custom_field_id
 | 
				
			||||||
      )
 | 
					      )
 | 
				
			||||||
 | 
					
 | 
				
			||||||
      if (existingIndex > -1) {
 | 
					      if (existingIndex > -1) {
 | 
				
			||||||
 | 
				
			|||||||
@ -9,7 +9,7 @@ import { computed } from 'vue'
 | 
				
			|||||||
const props = defineProps({
 | 
					const props = defineProps({
 | 
				
			||||||
  modelValue: {
 | 
					  modelValue: {
 | 
				
			||||||
    type: String,
 | 
					    type: String,
 | 
				
			||||||
    default: moment().format('YYYY-MM-DD hh:MM'),
 | 
					    default: moment().format('YYYY-MM-DD HH:mm'),
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
})
 | 
					})
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
				
			|||||||
@ -7,11 +7,12 @@
 | 
				
			|||||||
    <!-- edit customField  -->
 | 
					    <!-- edit customField  -->
 | 
				
			||||||
    <BaseDropdownItem
 | 
					    <BaseDropdownItem
 | 
				
			||||||
      v-if="userStore.hasAbilities(abilities.EDIT_CUSTOM_FIELDS)"
 | 
					      v-if="userStore.hasAbilities(abilities.EDIT_CUSTOM_FIELDS)"
 | 
				
			||||||
 | 
					      v-slot="slotProps"
 | 
				
			||||||
      @click="editCustomField(row.id)"
 | 
					      @click="editCustomField(row.id)"
 | 
				
			||||||
    >
 | 
					    >
 | 
				
			||||||
      <BaseIcon
 | 
					      <BaseIcon
 | 
				
			||||||
        name="PencilIcon"
 | 
					        name="PencilIcon"
 | 
				
			||||||
        class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					        :class="slotProps.class"
 | 
				
			||||||
      />
 | 
					      />
 | 
				
			||||||
      {{ $t('general.edit') }}
 | 
					      {{ $t('general.edit') }}
 | 
				
			||||||
    </BaseDropdownItem>
 | 
					    </BaseDropdownItem>
 | 
				
			||||||
@ -19,11 +20,12 @@
 | 
				
			|||||||
    <!-- delete customField  -->
 | 
					    <!-- delete customField  -->
 | 
				
			||||||
    <BaseDropdownItem
 | 
					    <BaseDropdownItem
 | 
				
			||||||
      v-if="userStore.hasAbilities(abilities.DELETE_CUSTOM_FIELDS)"
 | 
					      v-if="userStore.hasAbilities(abilities.DELETE_CUSTOM_FIELDS)"
 | 
				
			||||||
 | 
					      v-slot="slotProps"
 | 
				
			||||||
      @click="removeCustomField(row.id)"
 | 
					      @click="removeCustomField(row.id)"
 | 
				
			||||||
    >
 | 
					    >
 | 
				
			||||||
      <BaseIcon
 | 
					      <BaseIcon
 | 
				
			||||||
        name="TrashIcon"
 | 
					        name="TrashIcon"
 | 
				
			||||||
        class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					        :class="slotProps.class"
 | 
				
			||||||
      />
 | 
					      />
 | 
				
			||||||
      {{ $t('general.delete') }}
 | 
					      {{ $t('general.delete') }}
 | 
				
			||||||
    </BaseDropdownItem>
 | 
					    </BaseDropdownItem>
 | 
				
			||||||
 | 
				
			|||||||
@ -12,10 +12,10 @@
 | 
				
			|||||||
      v-if="userStore.hasAbilities(abilities.EDIT_CUSTOMER)"
 | 
					      v-if="userStore.hasAbilities(abilities.EDIT_CUSTOMER)"
 | 
				
			||||||
      :to="`/admin/customers/${row.id}/edit`"
 | 
					      :to="`/admin/customers/${row.id}/edit`"
 | 
				
			||||||
    >
 | 
					    >
 | 
				
			||||||
      <BaseDropdownItem>
 | 
					      <BaseDropdownItem v-slot="slotProps">
 | 
				
			||||||
        <BaseIcon
 | 
					        <BaseIcon
 | 
				
			||||||
          name="PencilIcon"
 | 
					          name="PencilIcon"
 | 
				
			||||||
          class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					          :class="slotProps.class"
 | 
				
			||||||
        />
 | 
					        />
 | 
				
			||||||
        {{ $t('general.edit') }}
 | 
					        {{ $t('general.edit') }}
 | 
				
			||||||
      </BaseDropdownItem>
 | 
					      </BaseDropdownItem>
 | 
				
			||||||
@ -29,10 +29,10 @@
 | 
				
			|||||||
      "
 | 
					      "
 | 
				
			||||||
      :to="`customers/${row.id}/view`"
 | 
					      :to="`customers/${row.id}/view`"
 | 
				
			||||||
    >
 | 
					    >
 | 
				
			||||||
      <BaseDropdownItem>
 | 
					      <BaseDropdownItem v-slot="slotProps">
 | 
				
			||||||
        <BaseIcon
 | 
					        <BaseIcon
 | 
				
			||||||
          name="EyeIcon"
 | 
					          name="EyeIcon"
 | 
				
			||||||
          class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					          :class="slotProps.class"
 | 
				
			||||||
        />
 | 
					        />
 | 
				
			||||||
        {{ $t('general.view') }}
 | 
					        {{ $t('general.view') }}
 | 
				
			||||||
      </BaseDropdownItem>
 | 
					      </BaseDropdownItem>
 | 
				
			||||||
@ -41,11 +41,12 @@
 | 
				
			|||||||
    <!-- Delete Customer  -->
 | 
					    <!-- Delete Customer  -->
 | 
				
			||||||
    <BaseDropdownItem
 | 
					    <BaseDropdownItem
 | 
				
			||||||
      v-if="userStore.hasAbilities(abilities.DELETE_CUSTOMER)"
 | 
					      v-if="userStore.hasAbilities(abilities.DELETE_CUSTOMER)"
 | 
				
			||||||
 | 
					      v-slot="slotProps"
 | 
				
			||||||
      @click="removeCustomer(row.id)"
 | 
					      @click="removeCustomer(row.id)"
 | 
				
			||||||
    >
 | 
					    >
 | 
				
			||||||
      <BaseIcon
 | 
					      <BaseIcon
 | 
				
			||||||
        name="TrashIcon"
 | 
					        name="TrashIcon"
 | 
				
			||||||
        class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					        :class="slotProps.class"
 | 
				
			||||||
      />
 | 
					      />
 | 
				
			||||||
      {{ $t('general.delete') }}
 | 
					      {{ $t('general.delete') }}
 | 
				
			||||||
    </BaseDropdownItem>
 | 
					    </BaseDropdownItem>
 | 
				
			||||||
 | 
				
			|||||||
@ -10,11 +10,12 @@
 | 
				
			|||||||
    <!-- Copy PDF url  -->
 | 
					    <!-- Copy PDF url  -->
 | 
				
			||||||
    <BaseDropdownItem
 | 
					    <BaseDropdownItem
 | 
				
			||||||
      v-if="route.name === 'estimates.view'"
 | 
					      v-if="route.name === 'estimates.view'"
 | 
				
			||||||
 | 
					      v-slot="slotProps"
 | 
				
			||||||
      @click="copyPdfUrl"
 | 
					      @click="copyPdfUrl"
 | 
				
			||||||
    >
 | 
					    >
 | 
				
			||||||
      <BaseIcon
 | 
					      <BaseIcon
 | 
				
			||||||
        name="LinkIcon"
 | 
					        name="LinkIcon"
 | 
				
			||||||
        class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					        :class="slotProps.class"
 | 
				
			||||||
      />
 | 
					      />
 | 
				
			||||||
      {{ $t('general.copy_pdf_url') }}
 | 
					      {{ $t('general.copy_pdf_url') }}
 | 
				
			||||||
    </BaseDropdownItem>
 | 
					    </BaseDropdownItem>
 | 
				
			||||||
@ -24,10 +25,10 @@
 | 
				
			|||||||
      v-if="userStore.hasAbilities(abilities.EDIT_ESTIMATE)"
 | 
					      v-if="userStore.hasAbilities(abilities.EDIT_ESTIMATE)"
 | 
				
			||||||
      :to="`/admin/estimates/${row.id}/edit`"
 | 
					      :to="`/admin/estimates/${row.id}/edit`"
 | 
				
			||||||
    >
 | 
					    >
 | 
				
			||||||
      <BaseDropdownItem>
 | 
					      <BaseDropdownItem v-slot="slotProps">
 | 
				
			||||||
        <BaseIcon
 | 
					        <BaseIcon
 | 
				
			||||||
          name="PencilIcon"
 | 
					          name="PencilIcon"
 | 
				
			||||||
          class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					          :class="slotProps.class"
 | 
				
			||||||
        />
 | 
					        />
 | 
				
			||||||
        {{ $t('general.edit') }}
 | 
					        {{ $t('general.edit') }}
 | 
				
			||||||
      </BaseDropdownItem>
 | 
					      </BaseDropdownItem>
 | 
				
			||||||
@ -36,11 +37,12 @@
 | 
				
			|||||||
    <!-- Delete Estimate  -->
 | 
					    <!-- Delete Estimate  -->
 | 
				
			||||||
    <BaseDropdownItem
 | 
					    <BaseDropdownItem
 | 
				
			||||||
      v-if="userStore.hasAbilities(abilities.DELETE_ESTIMATE)"
 | 
					      v-if="userStore.hasAbilities(abilities.DELETE_ESTIMATE)"
 | 
				
			||||||
 | 
					      v-slot="slotProps"
 | 
				
			||||||
      @click="removeEstimate(row.id)"
 | 
					      @click="removeEstimate(row.id)"
 | 
				
			||||||
    >
 | 
					    >
 | 
				
			||||||
      <BaseIcon
 | 
					      <BaseIcon
 | 
				
			||||||
        name="TrashIcon"
 | 
					        name="TrashIcon"
 | 
				
			||||||
        class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					        :class="slotProps.class"
 | 
				
			||||||
      />
 | 
					      />
 | 
				
			||||||
      {{ $t('general.delete') }}
 | 
					      {{ $t('general.delete') }}
 | 
				
			||||||
    </BaseDropdownItem>
 | 
					    </BaseDropdownItem>
 | 
				
			||||||
@ -53,10 +55,10 @@
 | 
				
			|||||||
      "
 | 
					      "
 | 
				
			||||||
      :to="`estimates/${row.id}/view`"
 | 
					      :to="`estimates/${row.id}/view`"
 | 
				
			||||||
    >
 | 
					    >
 | 
				
			||||||
      <BaseDropdownItem>
 | 
					      <BaseDropdownItem v-slot="slotProps">
 | 
				
			||||||
        <BaseIcon
 | 
					        <BaseIcon
 | 
				
			||||||
          name="EyeIcon"
 | 
					          name="EyeIcon"
 | 
				
			||||||
          class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					          :class="slotProps.class"
 | 
				
			||||||
        />
 | 
					        />
 | 
				
			||||||
        {{ $t('general.view') }}
 | 
					        {{ $t('general.view') }}
 | 
				
			||||||
      </BaseDropdownItem>
 | 
					      </BaseDropdownItem>
 | 
				
			||||||
@ -65,11 +67,12 @@
 | 
				
			|||||||
    <!-- Convert into Invoice  -->
 | 
					    <!-- Convert into Invoice  -->
 | 
				
			||||||
    <BaseDropdownItem
 | 
					    <BaseDropdownItem
 | 
				
			||||||
      v-if="userStore.hasAbilities(abilities.CREATE_INVOICE)"
 | 
					      v-if="userStore.hasAbilities(abilities.CREATE_INVOICE)"
 | 
				
			||||||
 | 
					      v-slot="slotProps"
 | 
				
			||||||
      @click="convertInToinvoice(row.id)"
 | 
					      @click="convertInToinvoice(row.id)"
 | 
				
			||||||
    >
 | 
					    >
 | 
				
			||||||
      <BaseIcon
 | 
					      <BaseIcon
 | 
				
			||||||
        name="DocumentTextIcon"
 | 
					        name="DocumentTextIcon"
 | 
				
			||||||
        class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					        :class="slotProps.class"
 | 
				
			||||||
      />
 | 
					      />
 | 
				
			||||||
      {{ $t('estimates.convert_to_invoice') }}
 | 
					      {{ $t('estimates.convert_to_invoice') }}
 | 
				
			||||||
    </BaseDropdownItem>
 | 
					    </BaseDropdownItem>
 | 
				
			||||||
@ -81,11 +84,12 @@
 | 
				
			|||||||
        route.name !== 'estimates.view' &&
 | 
					        route.name !== 'estimates.view' &&
 | 
				
			||||||
        userStore.hasAbilities(abilities.SEND_ESTIMATE)
 | 
					        userStore.hasAbilities(abilities.SEND_ESTIMATE)
 | 
				
			||||||
      "
 | 
					      "
 | 
				
			||||||
 | 
					      v-slot="slotProps"
 | 
				
			||||||
      @click="onMarkAsSent(row.id)"
 | 
					      @click="onMarkAsSent(row.id)"
 | 
				
			||||||
    >
 | 
					    >
 | 
				
			||||||
      <BaseIcon
 | 
					      <BaseIcon
 | 
				
			||||||
        name="CheckCircleIcon"
 | 
					        name="CheckCircleIcon"
 | 
				
			||||||
        class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					        :class="slotProps.class"
 | 
				
			||||||
      />
 | 
					      />
 | 
				
			||||||
      {{ $t('estimates.mark_as_sent') }}
 | 
					      {{ $t('estimates.mark_as_sent') }}
 | 
				
			||||||
    </BaseDropdownItem>
 | 
					    </BaseDropdownItem>
 | 
				
			||||||
@ -97,20 +101,21 @@
 | 
				
			|||||||
        route.name !== 'estimates.view' &&
 | 
					        route.name !== 'estimates.view' &&
 | 
				
			||||||
        userStore.hasAbilities(abilities.SEND_ESTIMATE)
 | 
					        userStore.hasAbilities(abilities.SEND_ESTIMATE)
 | 
				
			||||||
      "
 | 
					      "
 | 
				
			||||||
 | 
					      v-slot="slotProps"
 | 
				
			||||||
      @click="sendEstimate(row)"
 | 
					      @click="sendEstimate(row)"
 | 
				
			||||||
    >
 | 
					    >
 | 
				
			||||||
      <BaseIcon
 | 
					      <BaseIcon
 | 
				
			||||||
        name="PaperAirplaneIcon"
 | 
					        name="PaperAirplaneIcon"
 | 
				
			||||||
        class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					        :class="slotProps.class"
 | 
				
			||||||
      />
 | 
					      />
 | 
				
			||||||
      {{ $t('estimates.send_estimate') }}
 | 
					      {{ $t('estimates.send_estimate') }}
 | 
				
			||||||
    </BaseDropdownItem>
 | 
					    </BaseDropdownItem>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    <!-- Resend Estimate -->
 | 
					    <!-- Resend Estimate -->
 | 
				
			||||||
    <BaseDropdownItem v-if="canResendEstimate(row)" @click="sendEstimate(row)">
 | 
					    <BaseDropdownItem v-if="canResendEstimate(row)" v-slot="slotProps"  @click="sendEstimate(row)">
 | 
				
			||||||
      <BaseIcon
 | 
					      <BaseIcon
 | 
				
			||||||
        name="PaperAirplaneIcon"
 | 
					        name="PaperAirplaneIcon"
 | 
				
			||||||
        class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					        :class="slotProps.class"
 | 
				
			||||||
      />
 | 
					      />
 | 
				
			||||||
      {{ $t('estimates.resend_estimate') }}
 | 
					      {{ $t('estimates.resend_estimate') }}
 | 
				
			||||||
    </BaseDropdownItem>
 | 
					    </BaseDropdownItem>
 | 
				
			||||||
@ -121,11 +126,12 @@
 | 
				
			|||||||
        row.status !== 'ACCEPTED' &&
 | 
					        row.status !== 'ACCEPTED' &&
 | 
				
			||||||
        userStore.hasAbilities(abilities.EDIT_ESTIMATE)
 | 
					        userStore.hasAbilities(abilities.EDIT_ESTIMATE)
 | 
				
			||||||
      "
 | 
					      "
 | 
				
			||||||
 | 
					      v-slot="slotProps"
 | 
				
			||||||
      @click="onMarkAsAccepted(row.id)"
 | 
					      @click="onMarkAsAccepted(row.id)"
 | 
				
			||||||
    >
 | 
					    >
 | 
				
			||||||
      <BaseIcon
 | 
					      <BaseIcon
 | 
				
			||||||
        name="CheckCircleIcon"
 | 
					        name="CheckCircleIcon"
 | 
				
			||||||
        class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					        :class="slotProps.class"
 | 
				
			||||||
      />
 | 
					      />
 | 
				
			||||||
      {{ $t('estimates.mark_as_accepted') }}
 | 
					      {{ $t('estimates.mark_as_accepted') }}
 | 
				
			||||||
    </BaseDropdownItem>
 | 
					    </BaseDropdownItem>
 | 
				
			||||||
@ -136,11 +142,12 @@
 | 
				
			|||||||
        row.status !== 'REJECTED' &&
 | 
					        row.status !== 'REJECTED' &&
 | 
				
			||||||
        userStore.hasAbilities(abilities.EDIT_ESTIMATE)
 | 
					        userStore.hasAbilities(abilities.EDIT_ESTIMATE)
 | 
				
			||||||
      "
 | 
					      "
 | 
				
			||||||
 | 
					      v-slot="slotProps"
 | 
				
			||||||
      @click="onMarkAsRejected(row.id)"
 | 
					      @click="onMarkAsRejected(row.id)"
 | 
				
			||||||
    >
 | 
					    >
 | 
				
			||||||
      <BaseIcon
 | 
					      <BaseIcon
 | 
				
			||||||
        name="XCircleIcon"
 | 
					        name="XCircleIcon"
 | 
				
			||||||
        class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					        :class="slotProps.class"
 | 
				
			||||||
      />
 | 
					      />
 | 
				
			||||||
      {{ $t('estimates.mark_as_rejected') }}
 | 
					      {{ $t('estimates.mark_as_rejected') }}
 | 
				
			||||||
    </BaseDropdownItem>
 | 
					    </BaseDropdownItem>
 | 
				
			||||||
 | 
				
			|||||||
@ -13,11 +13,12 @@
 | 
				
			|||||||
    <!-- edit expenseCategory  -->
 | 
					    <!-- edit expenseCategory  -->
 | 
				
			||||||
    <BaseDropdownItem
 | 
					    <BaseDropdownItem
 | 
				
			||||||
      v-if="userStore.hasAbilities(abilities.EDIT_EXPENSE)"
 | 
					      v-if="userStore.hasAbilities(abilities.EDIT_EXPENSE)"
 | 
				
			||||||
 | 
					      v-slot="slotProps"
 | 
				
			||||||
      @click="editExpenseCategory(row.id)"
 | 
					      @click="editExpenseCategory(row.id)"
 | 
				
			||||||
    >
 | 
					    >
 | 
				
			||||||
      <BaseIcon
 | 
					      <BaseIcon
 | 
				
			||||||
        name="PencilIcon"
 | 
					        name="PencilIcon"
 | 
				
			||||||
        class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					        :class="slotProps.class"
 | 
				
			||||||
      />
 | 
					      />
 | 
				
			||||||
      {{ $t('general.edit') }}
 | 
					      {{ $t('general.edit') }}
 | 
				
			||||||
    </BaseDropdownItem>
 | 
					    </BaseDropdownItem>
 | 
				
			||||||
@ -25,11 +26,12 @@
 | 
				
			|||||||
    <!-- delete expenseCategory  -->
 | 
					    <!-- delete expenseCategory  -->
 | 
				
			||||||
    <BaseDropdownItem
 | 
					    <BaseDropdownItem
 | 
				
			||||||
      v-if="userStore.hasAbilities(abilities.DELETE_EXPENSE)"
 | 
					      v-if="userStore.hasAbilities(abilities.DELETE_EXPENSE)"
 | 
				
			||||||
 | 
					      v-slot="slotProps"
 | 
				
			||||||
      @click="removeExpenseCategory(row.id)"
 | 
					      @click="removeExpenseCategory(row.id)"
 | 
				
			||||||
    >
 | 
					    >
 | 
				
			||||||
      <BaseIcon
 | 
					      <BaseIcon
 | 
				
			||||||
        name="TrashIcon"
 | 
					        name="TrashIcon"
 | 
				
			||||||
        class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					        :class="slotProps.class"
 | 
				
			||||||
      />
 | 
					      />
 | 
				
			||||||
      {{ $t('general.delete') }}
 | 
					      {{ $t('general.delete') }}
 | 
				
			||||||
    </BaseDropdownItem>
 | 
					    </BaseDropdownItem>
 | 
				
			||||||
 | 
				
			|||||||
@ -12,10 +12,10 @@
 | 
				
			|||||||
      v-if="userStore.hasAbilities(abilities.EDIT_EXPENSE)"
 | 
					      v-if="userStore.hasAbilities(abilities.EDIT_EXPENSE)"
 | 
				
			||||||
      :to="`/admin/expenses/${row.id}/edit`"
 | 
					      :to="`/admin/expenses/${row.id}/edit`"
 | 
				
			||||||
    >
 | 
					    >
 | 
				
			||||||
      <BaseDropdownItem>
 | 
					      <BaseDropdownItem v-slot="slotProps">
 | 
				
			||||||
        <BaseIcon
 | 
					        <BaseIcon
 | 
				
			||||||
          name="PencilIcon"
 | 
					          name="PencilIcon"
 | 
				
			||||||
          class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					          :class="slotProps.class"
 | 
				
			||||||
        />
 | 
					        />
 | 
				
			||||||
        {{ $t('general.edit') }}
 | 
					        {{ $t('general.edit') }}
 | 
				
			||||||
      </BaseDropdownItem>
 | 
					      </BaseDropdownItem>
 | 
				
			||||||
@ -24,11 +24,12 @@
 | 
				
			|||||||
    <!-- delete expense  -->
 | 
					    <!-- delete expense  -->
 | 
				
			||||||
    <BaseDropdownItem
 | 
					    <BaseDropdownItem
 | 
				
			||||||
      v-if="userStore.hasAbilities(abilities.DELETE_EXPENSE)"
 | 
					      v-if="userStore.hasAbilities(abilities.DELETE_EXPENSE)"
 | 
				
			||||||
 | 
					      v-slot="slotProps"
 | 
				
			||||||
      @click="removeExpense(row.id)"
 | 
					      @click="removeExpense(row.id)"
 | 
				
			||||||
    >
 | 
					    >
 | 
				
			||||||
      <BaseIcon
 | 
					      <BaseIcon
 | 
				
			||||||
        name="TrashIcon"
 | 
					        name="TrashIcon"
 | 
				
			||||||
        class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					        :class="slotProps.class"
 | 
				
			||||||
      />
 | 
					      />
 | 
				
			||||||
      {{ $t('general.delete') }}
 | 
					      {{ $t('general.delete') }}
 | 
				
			||||||
    </BaseDropdownItem>
 | 
					    </BaseDropdownItem>
 | 
				
			||||||
 | 
				
			|||||||
@ -12,20 +12,20 @@
 | 
				
			|||||||
      v-if="userStore.hasAbilities(abilities.EDIT_INVOICE)"
 | 
					      v-if="userStore.hasAbilities(abilities.EDIT_INVOICE)"
 | 
				
			||||||
      :to="`/admin/invoices/${row.id}/edit`"
 | 
					      :to="`/admin/invoices/${row.id}/edit`"
 | 
				
			||||||
    >
 | 
					    >
 | 
				
			||||||
      <BaseDropdownItem v-show="row.allow_edit">
 | 
					      <BaseDropdownItem v-show="row.allow_edit" v-slot="slotProps">
 | 
				
			||||||
        <BaseIcon
 | 
					        <BaseIcon
 | 
				
			||||||
          name="PencilIcon"
 | 
					          name="PencilIcon"
 | 
				
			||||||
          class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					          :class="slotProps.class"
 | 
				
			||||||
        />
 | 
					        />
 | 
				
			||||||
        {{ $t('general.edit') }}
 | 
					        {{ $t('general.edit') }}
 | 
				
			||||||
      </BaseDropdownItem>
 | 
					      </BaseDropdownItem>
 | 
				
			||||||
    </router-link>
 | 
					    </router-link>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    <!-- Copy PDF url  -->
 | 
					    <!-- Copy PDF url  -->
 | 
				
			||||||
    <BaseDropdownItem v-if="route.name === 'invoices.view'" @click="copyPdfUrl">
 | 
					    <BaseDropdownItem v-if="route.name === 'invoices.view'" v-slot="slotProps" @click="copyPdfUrl">
 | 
				
			||||||
      <BaseIcon
 | 
					      <BaseIcon
 | 
				
			||||||
        name="LinkIcon"
 | 
					        name="LinkIcon"
 | 
				
			||||||
        class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					        :class="slotProps.class"
 | 
				
			||||||
      />
 | 
					      />
 | 
				
			||||||
      {{ $t('general.copy_pdf_url') }}
 | 
					      {{ $t('general.copy_pdf_url') }}
 | 
				
			||||||
    </BaseDropdownItem>
 | 
					    </BaseDropdownItem>
 | 
				
			||||||
@ -38,29 +38,29 @@
 | 
				
			|||||||
      "
 | 
					      "
 | 
				
			||||||
      :to="`/admin/invoices/${row.id}/view`"
 | 
					      :to="`/admin/invoices/${row.id}/view`"
 | 
				
			||||||
    >
 | 
					    >
 | 
				
			||||||
      <BaseDropdownItem>
 | 
					      <BaseDropdownItem v-slot="slotProps">
 | 
				
			||||||
        <BaseIcon
 | 
					        <BaseIcon
 | 
				
			||||||
          name="EyeIcon"
 | 
					          name="EyeIcon"
 | 
				
			||||||
          class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					          :class="slotProps.class"
 | 
				
			||||||
        />
 | 
					        />
 | 
				
			||||||
        {{ $t('general.view') }}
 | 
					        {{ $t('general.view') }}
 | 
				
			||||||
      </BaseDropdownItem>
 | 
					      </BaseDropdownItem>
 | 
				
			||||||
    </router-link>
 | 
					    </router-link>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    <!-- Send Invoice Mail  -->
 | 
					    <!-- Send Invoice Mail  -->
 | 
				
			||||||
    <BaseDropdownItem v-if="canSendInvoice(row)" @click="sendInvoice(row)">
 | 
					    <BaseDropdownItem v-if="canSendInvoice(row)" v-slot="slotProps" @click="sendInvoice(row)">
 | 
				
			||||||
      <BaseIcon
 | 
					      <BaseIcon
 | 
				
			||||||
        name="PaperAirplaneIcon"
 | 
					        name="PaperAirplaneIcon"
 | 
				
			||||||
        class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					        :class="slotProps.class"
 | 
				
			||||||
      />
 | 
					      />
 | 
				
			||||||
      {{ $t('invoices.send_invoice') }}
 | 
					      {{ $t('invoices.send_invoice') }}
 | 
				
			||||||
    </BaseDropdownItem>
 | 
					    </BaseDropdownItem>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    <!-- Resend Invoice -->
 | 
					    <!-- Resend Invoice -->
 | 
				
			||||||
    <BaseDropdownItem v-if="canReSendInvoice(row)" @click="sendInvoice(row)">
 | 
					    <BaseDropdownItem v-if="canReSendInvoice(row)" v-slot="slotProps" @click="sendInvoice(row)">
 | 
				
			||||||
      <BaseIcon
 | 
					      <BaseIcon
 | 
				
			||||||
        name="PaperAirplaneIcon"
 | 
					        name="PaperAirplaneIcon"
 | 
				
			||||||
        class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					        :class="slotProps.class"
 | 
				
			||||||
      />
 | 
					      />
 | 
				
			||||||
      {{ $t('invoices.resend_invoice') }}
 | 
					      {{ $t('invoices.resend_invoice') }}
 | 
				
			||||||
    </BaseDropdownItem>
 | 
					    </BaseDropdownItem>
 | 
				
			||||||
@ -69,20 +69,21 @@
 | 
				
			|||||||
    <router-link :to="`/admin/payments/${row.id}/create`">
 | 
					    <router-link :to="`/admin/payments/${row.id}/create`">
 | 
				
			||||||
      <BaseDropdownItem
 | 
					      <BaseDropdownItem
 | 
				
			||||||
        v-if="row.status == 'SENT' && route.name !== 'invoices.view'"
 | 
					        v-if="row.status == 'SENT' && route.name !== 'invoices.view'"
 | 
				
			||||||
 | 
					        v-slot="slotProps"
 | 
				
			||||||
      >
 | 
					      >
 | 
				
			||||||
        <BaseIcon
 | 
					        <BaseIcon
 | 
				
			||||||
          name="CreditCardIcon"
 | 
					          name="CreditCardIcon"
 | 
				
			||||||
          class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					          :class="slotProps.class"
 | 
				
			||||||
        />
 | 
					        />
 | 
				
			||||||
        {{ $t('invoices.record_payment') }}
 | 
					        {{ $t('invoices.record_payment') }}
 | 
				
			||||||
      </BaseDropdownItem>
 | 
					      </BaseDropdownItem>
 | 
				
			||||||
    </router-link>
 | 
					    </router-link>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    <!-- Mark as sent Invoice -->
 | 
					    <!-- Mark as sent Invoice -->
 | 
				
			||||||
    <BaseDropdownItem v-if="canSendInvoice(row)" @click="onMarkAsSent(row.id)">
 | 
					    <BaseDropdownItem v-if="canSendInvoice(row)" v-slot="slotProps" @click="onMarkAsSent(row.id)">
 | 
				
			||||||
      <BaseIcon
 | 
					      <BaseIcon
 | 
				
			||||||
        name="CheckCircleIcon"
 | 
					        name="CheckCircleIcon"
 | 
				
			||||||
        class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					        :class="slotProps.class"
 | 
				
			||||||
      />
 | 
					      />
 | 
				
			||||||
      {{ $t('invoices.mark_as_sent') }}
 | 
					      {{ $t('invoices.mark_as_sent') }}
 | 
				
			||||||
    </BaseDropdownItem>
 | 
					    </BaseDropdownItem>
 | 
				
			||||||
@ -90,11 +91,12 @@
 | 
				
			|||||||
    <!-- Clone Invoice into new invoice  -->
 | 
					    <!-- Clone Invoice into new invoice  -->
 | 
				
			||||||
    <BaseDropdownItem
 | 
					    <BaseDropdownItem
 | 
				
			||||||
      v-if="userStore.hasAbilities(abilities.CREATE_INVOICE)"
 | 
					      v-if="userStore.hasAbilities(abilities.CREATE_INVOICE)"
 | 
				
			||||||
 | 
					      v-slot="slotProps"
 | 
				
			||||||
      @click="cloneInvoiceData(row)"
 | 
					      @click="cloneInvoiceData(row)"
 | 
				
			||||||
    >
 | 
					    >
 | 
				
			||||||
      <BaseIcon
 | 
					      <BaseIcon
 | 
				
			||||||
        name="DocumentTextIcon"
 | 
					        name="DocumentTextIcon"
 | 
				
			||||||
        class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					        :class="slotProps.class"
 | 
				
			||||||
      />
 | 
					      />
 | 
				
			||||||
      {{ $t('invoices.clone_invoice') }}
 | 
					      {{ $t('invoices.clone_invoice') }}
 | 
				
			||||||
    </BaseDropdownItem>
 | 
					    </BaseDropdownItem>
 | 
				
			||||||
@ -102,11 +104,12 @@
 | 
				
			|||||||
    <!--  Delete Invoice  -->
 | 
					    <!--  Delete Invoice  -->
 | 
				
			||||||
    <BaseDropdownItem
 | 
					    <BaseDropdownItem
 | 
				
			||||||
      v-if="userStore.hasAbilities(abilities.DELETE_INVOICE)"
 | 
					      v-if="userStore.hasAbilities(abilities.DELETE_INVOICE)"
 | 
				
			||||||
 | 
					      v-slot="slotProps"
 | 
				
			||||||
      @click="removeInvoice(row.id)"
 | 
					      @click="removeInvoice(row.id)"
 | 
				
			||||||
    >
 | 
					    >
 | 
				
			||||||
      <BaseIcon
 | 
					      <BaseIcon
 | 
				
			||||||
        name="TrashIcon"
 | 
					        name="TrashIcon"
 | 
				
			||||||
        class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					        :class="slotProps.class"
 | 
				
			||||||
      />
 | 
					      />
 | 
				
			||||||
      {{ $t('general.delete') }}
 | 
					      {{ $t('general.delete') }}
 | 
				
			||||||
    </BaseDropdownItem>
 | 
					    </BaseDropdownItem>
 | 
				
			||||||
 | 
				
			|||||||
@ -12,11 +12,8 @@
 | 
				
			|||||||
      v-if="userStore.hasAbilities(abilities.EDIT_ITEM)"
 | 
					      v-if="userStore.hasAbilities(abilities.EDIT_ITEM)"
 | 
				
			||||||
      :to="`/admin/items/${row.id}/edit`"
 | 
					      :to="`/admin/items/${row.id}/edit`"
 | 
				
			||||||
    >
 | 
					    >
 | 
				
			||||||
      <BaseDropdownItem>
 | 
					      <BaseDropdownItem v-slot="slotProps">
 | 
				
			||||||
        <BaseIcon
 | 
					        <BaseIcon name="PencilIcon" :class="slotProps.class" />
 | 
				
			||||||
          name="PencilIcon"
 | 
					 | 
				
			||||||
          class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					 | 
				
			||||||
        />
 | 
					 | 
				
			||||||
        {{ $t('general.edit') }}
 | 
					        {{ $t('general.edit') }}
 | 
				
			||||||
      </BaseDropdownItem>
 | 
					      </BaseDropdownItem>
 | 
				
			||||||
    </router-link>
 | 
					    </router-link>
 | 
				
			||||||
@ -24,12 +21,10 @@
 | 
				
			|||||||
    <!-- delete item  -->
 | 
					    <!-- delete item  -->
 | 
				
			||||||
    <BaseDropdownItem
 | 
					    <BaseDropdownItem
 | 
				
			||||||
      v-if="userStore.hasAbilities(abilities.DELETE_ITEM)"
 | 
					      v-if="userStore.hasAbilities(abilities.DELETE_ITEM)"
 | 
				
			||||||
 | 
					      v-slot="slotProps"
 | 
				
			||||||
      @click="removeItem(row.id)"
 | 
					      @click="removeItem(row.id)"
 | 
				
			||||||
    >
 | 
					    >
 | 
				
			||||||
      <BaseIcon
 | 
					      <BaseIcon name="TrashIcon" :class="slotProps.class" />
 | 
				
			||||||
        name="TrashIcon"
 | 
					 | 
				
			||||||
        class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					 | 
				
			||||||
      />
 | 
					 | 
				
			||||||
      {{ $t('general.delete') }}
 | 
					      {{ $t('general.delete') }}
 | 
				
			||||||
    </BaseDropdownItem>
 | 
					    </BaseDropdownItem>
 | 
				
			||||||
  </BaseDropdown>
 | 
					  </BaseDropdown>
 | 
				
			||||||
 | 
				
			|||||||
@ -10,11 +10,12 @@
 | 
				
			|||||||
    <!-- edit note  -->
 | 
					    <!-- edit note  -->
 | 
				
			||||||
    <BaseDropdownItem
 | 
					    <BaseDropdownItem
 | 
				
			||||||
      v-if="userStore.hasAbilities(abilities.MANAGE_NOTE)"
 | 
					      v-if="userStore.hasAbilities(abilities.MANAGE_NOTE)"
 | 
				
			||||||
 | 
					      v-slot="slotProps"
 | 
				
			||||||
      @click="editNote(row.id)"
 | 
					      @click="editNote(row.id)"
 | 
				
			||||||
    >
 | 
					    >
 | 
				
			||||||
      <BaseIcon
 | 
					      <BaseIcon
 | 
				
			||||||
        name="PencilIcon"
 | 
					        name="PencilIcon"
 | 
				
			||||||
        class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					        :class="slotProps.class"
 | 
				
			||||||
      />
 | 
					      />
 | 
				
			||||||
      {{ $t('general.edit') }}
 | 
					      {{ $t('general.edit') }}
 | 
				
			||||||
    </BaseDropdownItem>
 | 
					    </BaseDropdownItem>
 | 
				
			||||||
@ -22,11 +23,12 @@
 | 
				
			|||||||
    <!-- delete note  -->
 | 
					    <!-- delete note  -->
 | 
				
			||||||
    <BaseDropdownItem
 | 
					    <BaseDropdownItem
 | 
				
			||||||
      v-if="userStore.hasAbilities(abilities.MANAGE_NOTE)"
 | 
					      v-if="userStore.hasAbilities(abilities.MANAGE_NOTE)"
 | 
				
			||||||
 | 
					      v-slot="slotProps"
 | 
				
			||||||
      @click="removeNote(row.id)"
 | 
					      @click="removeNote(row.id)"
 | 
				
			||||||
    >
 | 
					    >
 | 
				
			||||||
      <BaseIcon
 | 
					      <BaseIcon
 | 
				
			||||||
        name="TrashIcon"
 | 
					        name="TrashIcon"
 | 
				
			||||||
        class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					        :class="slotProps.class"
 | 
				
			||||||
      />
 | 
					      />
 | 
				
			||||||
      {{ $t('general.delete') }}
 | 
					      {{ $t('general.delete') }}
 | 
				
			||||||
    </BaseDropdownItem>
 | 
					    </BaseDropdownItem>
 | 
				
			||||||
 | 
				
			|||||||
@ -8,30 +8,31 @@
 | 
				
			|||||||
    </template>
 | 
					    </template>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    <!-- Copy pdf url  -->
 | 
					    <!-- Copy pdf url  -->
 | 
				
			||||||
    <BaseDropdown-item
 | 
					    <BaseDropdownItem
 | 
				
			||||||
      v-if="
 | 
					      v-if="
 | 
				
			||||||
        route.name === 'payments.view' &&
 | 
					        route.name === 'payments.view' &&
 | 
				
			||||||
        userStore.hasAbilities(abilities.VIEW_PAYMENT)
 | 
					        userStore.hasAbilities(abilities.VIEW_PAYMENT)
 | 
				
			||||||
      "
 | 
					      "
 | 
				
			||||||
 | 
					      v-slot="slotProps"
 | 
				
			||||||
      class="rounded-md"
 | 
					      class="rounded-md"
 | 
				
			||||||
      @click="copyPdfUrl"
 | 
					      @click="copyPdfUrl"
 | 
				
			||||||
    >
 | 
					    >
 | 
				
			||||||
      <BaseIcon
 | 
					      <BaseIcon
 | 
				
			||||||
        name="LinkIcon"
 | 
					        name="LinkIcon"
 | 
				
			||||||
        class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					        :class="slotProps.class"
 | 
				
			||||||
      />
 | 
					      />
 | 
				
			||||||
      {{ $t('general.copy_pdf_url') }}
 | 
					      {{ $t('general.copy_pdf_url') }}
 | 
				
			||||||
    </BaseDropdown-item>
 | 
					    </BaseDropdownItem>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    <!-- edit payment  -->
 | 
					    <!-- edit payment  -->
 | 
				
			||||||
    <router-link
 | 
					    <router-link
 | 
				
			||||||
      v-if="userStore.hasAbilities(abilities.EDIT_PAYMENT)"
 | 
					      v-if="userStore.hasAbilities(abilities.EDIT_PAYMENT)"
 | 
				
			||||||
      :to="`/admin/payments/${row.id}/edit`"
 | 
					      :to="`/admin/payments/${row.id}/edit`"
 | 
				
			||||||
    >
 | 
					    >
 | 
				
			||||||
      <BaseDropdownItem>
 | 
					      <BaseDropdownItem v-slot="slotProps">
 | 
				
			||||||
        <BaseIcon
 | 
					        <BaseIcon
 | 
				
			||||||
          name="PencilIcon"
 | 
					          name="PencilIcon"
 | 
				
			||||||
          class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					          :class="slotProps.class"
 | 
				
			||||||
        />
 | 
					        />
 | 
				
			||||||
        {{ $t('general.edit') }}
 | 
					        {{ $t('general.edit') }}
 | 
				
			||||||
      </BaseDropdownItem>
 | 
					      </BaseDropdownItem>
 | 
				
			||||||
@ -45,10 +46,10 @@
 | 
				
			|||||||
      "
 | 
					      "
 | 
				
			||||||
      :to="`/admin/payments/${row.id}/view`"
 | 
					      :to="`/admin/payments/${row.id}/view`"
 | 
				
			||||||
    >
 | 
					    >
 | 
				
			||||||
      <BaseDropdownItem>
 | 
					      <BaseDropdownItem v-slot="slotProps">
 | 
				
			||||||
        <BaseIcon
 | 
					        <BaseIcon
 | 
				
			||||||
          name="EyeIcon"
 | 
					          name="EyeIcon"
 | 
				
			||||||
          class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					          :class="slotProps.class"
 | 
				
			||||||
        />
 | 
					        />
 | 
				
			||||||
        {{ $t('general.view') }}
 | 
					        {{ $t('general.view') }}
 | 
				
			||||||
      </BaseDropdownItem>
 | 
					      </BaseDropdownItem>
 | 
				
			||||||
@ -61,11 +62,12 @@
 | 
				
			|||||||
        route.name !== 'payments.view' &&
 | 
					        route.name !== 'payments.view' &&
 | 
				
			||||||
        userStore.hasAbilities(abilities.SEND_PAYMENT)
 | 
					        userStore.hasAbilities(abilities.SEND_PAYMENT)
 | 
				
			||||||
      "
 | 
					      "
 | 
				
			||||||
 | 
					      v-slot="slotProps"
 | 
				
			||||||
      @click="sendPayment(row)"
 | 
					      @click="sendPayment(row)"
 | 
				
			||||||
    >
 | 
					    >
 | 
				
			||||||
      <BaseIcon
 | 
					      <BaseIcon
 | 
				
			||||||
        name="PaperAirplaneIcon"
 | 
					        name="PaperAirplaneIcon"
 | 
				
			||||||
        class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					        :class="slotProps.class"
 | 
				
			||||||
      />
 | 
					      />
 | 
				
			||||||
      {{ $t('payments.send_payment') }}
 | 
					      {{ $t('payments.send_payment') }}
 | 
				
			||||||
    </BaseDropdownItem>
 | 
					    </BaseDropdownItem>
 | 
				
			||||||
@ -73,11 +75,12 @@
 | 
				
			|||||||
    <!-- delete payment  -->
 | 
					    <!-- delete payment  -->
 | 
				
			||||||
    <BaseDropdownItem
 | 
					    <BaseDropdownItem
 | 
				
			||||||
      v-if="userStore.hasAbilities(abilities.DELETE_PAYMENT)"
 | 
					      v-if="userStore.hasAbilities(abilities.DELETE_PAYMENT)"
 | 
				
			||||||
 | 
					      v-slot="slotProps"
 | 
				
			||||||
      @click="removePayment(row.id)"
 | 
					      @click="removePayment(row.id)"
 | 
				
			||||||
    >
 | 
					    >
 | 
				
			||||||
      <BaseIcon
 | 
					      <BaseIcon
 | 
				
			||||||
        name="TrashIcon"
 | 
					        name="TrashIcon"
 | 
				
			||||||
        class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					        :class="slotProps.class"
 | 
				
			||||||
      />
 | 
					      />
 | 
				
			||||||
      {{ $t('general.delete') }}
 | 
					      {{ $t('general.delete') }}
 | 
				
			||||||
    </BaseDropdownItem>
 | 
					    </BaseDropdownItem>
 | 
				
			||||||
 | 
				
			|||||||
@ -8,19 +8,19 @@
 | 
				
			|||||||
    </template>
 | 
					    </template>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    <!-- edit paymentMode  -->
 | 
					    <!-- edit paymentMode  -->
 | 
				
			||||||
    <BaseDropdownItem @click="editPaymentMode(row.id)">
 | 
					    <BaseDropdownItem v-slot="slotProps"  @click="editPaymentMode(row.id)">
 | 
				
			||||||
      <BaseIcon
 | 
					      <BaseIcon
 | 
				
			||||||
        name="PencilIcon"
 | 
					        name="PencilIcon"
 | 
				
			||||||
        class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					        :class="slotProps.class"
 | 
				
			||||||
      />
 | 
					      />
 | 
				
			||||||
      {{ $t('general.edit') }}
 | 
					      {{ $t('general.edit') }}
 | 
				
			||||||
    </BaseDropdownItem>
 | 
					    </BaseDropdownItem>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    <!-- delete paymentMode  -->
 | 
					    <!-- delete paymentMode  -->
 | 
				
			||||||
    <BaseDropdownItem @click="removePaymentMode(row.id)">
 | 
					    <BaseDropdownItem v-slot="slotProps"  @click="removePaymentMode(row.id)">
 | 
				
			||||||
      <BaseIcon
 | 
					      <BaseIcon
 | 
				
			||||||
        name="TrashIcon"
 | 
					        name="TrashIcon"
 | 
				
			||||||
        class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					        :class="slotProps.class"
 | 
				
			||||||
      />
 | 
					      />
 | 
				
			||||||
      {{ $t('general.delete') }}
 | 
					      {{ $t('general.delete') }}
 | 
				
			||||||
    </BaseDropdownItem>
 | 
					    </BaseDropdownItem>
 | 
				
			||||||
 | 
				
			|||||||
@ -15,10 +15,10 @@
 | 
				
			|||||||
      v-if="userStore.hasAbilities(abilities.EDIT_RECURRING_INVOICE)"
 | 
					      v-if="userStore.hasAbilities(abilities.EDIT_RECURRING_INVOICE)"
 | 
				
			||||||
      :to="`/admin/recurring-invoices/${row.id}/edit`"
 | 
					      :to="`/admin/recurring-invoices/${row.id}/edit`"
 | 
				
			||||||
    >
 | 
					    >
 | 
				
			||||||
      <BaseDropdownItem>
 | 
					      <BaseDropdownItem v-slot="slotProps">
 | 
				
			||||||
        <BaseIcon
 | 
					        <BaseIcon
 | 
				
			||||||
          name="PencilIcon"
 | 
					          name="PencilIcon"
 | 
				
			||||||
          class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					          :class="slotProps.class"
 | 
				
			||||||
        />
 | 
					        />
 | 
				
			||||||
        {{ $t('general.edit') }}
 | 
					        {{ $t('general.edit') }}
 | 
				
			||||||
      </BaseDropdownItem>
 | 
					      </BaseDropdownItem>
 | 
				
			||||||
@ -32,10 +32,10 @@
 | 
				
			|||||||
      "
 | 
					      "
 | 
				
			||||||
      :to="`recurring-invoices/${row.id}/view`"
 | 
					      :to="`recurring-invoices/${row.id}/view`"
 | 
				
			||||||
    >
 | 
					    >
 | 
				
			||||||
      <BaseDropdownItem>
 | 
					      <BaseDropdownItem v-slot="slotProps">
 | 
				
			||||||
        <BaseIcon
 | 
					        <BaseIcon
 | 
				
			||||||
          name="EyeIcon"
 | 
					          name="EyeIcon"
 | 
				
			||||||
          class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					          :class="slotProps.class"
 | 
				
			||||||
        />
 | 
					        />
 | 
				
			||||||
        {{ $t('general.view') }}
 | 
					        {{ $t('general.view') }}
 | 
				
			||||||
      </BaseDropdownItem>
 | 
					      </BaseDropdownItem>
 | 
				
			||||||
@ -44,11 +44,12 @@
 | 
				
			|||||||
    <!-- Delete Recurring Invoice  -->
 | 
					    <!-- Delete Recurring Invoice  -->
 | 
				
			||||||
    <BaseDropdownItem
 | 
					    <BaseDropdownItem
 | 
				
			||||||
      v-if="userStore.hasAbilities(abilities.DELETE_RECURRING_INVOICE)"
 | 
					      v-if="userStore.hasAbilities(abilities.DELETE_RECURRING_INVOICE)"
 | 
				
			||||||
 | 
					      v-slot="slotProps"
 | 
				
			||||||
      @click="removeMultipleRecurringInvoices(row.id)"
 | 
					      @click="removeMultipleRecurringInvoices(row.id)"
 | 
				
			||||||
    >
 | 
					    >
 | 
				
			||||||
      <BaseIcon
 | 
					      <BaseIcon
 | 
				
			||||||
        name="TrashIcon"
 | 
					        name="TrashIcon"
 | 
				
			||||||
        class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					        :class="slotProps.class"
 | 
				
			||||||
      />
 | 
					      />
 | 
				
			||||||
      {{ $t('general.delete') }}
 | 
					      {{ $t('general.delete') }}
 | 
				
			||||||
    </BaseDropdownItem>
 | 
					    </BaseDropdownItem>
 | 
				
			||||||
 | 
				
			|||||||
@ -10,11 +10,12 @@
 | 
				
			|||||||
    <!-- edit role  -->
 | 
					    <!-- edit role  -->
 | 
				
			||||||
    <BaseDropdownItem
 | 
					    <BaseDropdownItem
 | 
				
			||||||
      v-if="userStore.currentUser.is_owner"
 | 
					      v-if="userStore.currentUser.is_owner"
 | 
				
			||||||
 | 
					      v-slot="slotProps"
 | 
				
			||||||
      @click="editRole(row.id)"
 | 
					      @click="editRole(row.id)"
 | 
				
			||||||
    >
 | 
					    >
 | 
				
			||||||
      <BaseIcon
 | 
					      <BaseIcon
 | 
				
			||||||
        name="PencilIcon"
 | 
					        name="PencilIcon"
 | 
				
			||||||
        class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					        :class="slotProps.class"
 | 
				
			||||||
      />
 | 
					      />
 | 
				
			||||||
      {{ $t('general.edit') }}
 | 
					      {{ $t('general.edit') }}
 | 
				
			||||||
    </BaseDropdownItem>
 | 
					    </BaseDropdownItem>
 | 
				
			||||||
@ -22,11 +23,12 @@
 | 
				
			|||||||
    <!-- delete role  -->
 | 
					    <!-- delete role  -->
 | 
				
			||||||
    <BaseDropdownItem
 | 
					    <BaseDropdownItem
 | 
				
			||||||
      v-if="userStore.currentUser.is_owner"
 | 
					      v-if="userStore.currentUser.is_owner"
 | 
				
			||||||
 | 
					      v-slot="slotProps"
 | 
				
			||||||
      @click="removeRole(row.id)"
 | 
					      @click="removeRole(row.id)"
 | 
				
			||||||
    >
 | 
					    >
 | 
				
			||||||
      <BaseIcon
 | 
					      <BaseIcon
 | 
				
			||||||
        name="TrashIcon"
 | 
					        name="TrashIcon"
 | 
				
			||||||
        class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					        :class="slotProps.class"
 | 
				
			||||||
      />
 | 
					      />
 | 
				
			||||||
      {{ $t('general.delete') }}
 | 
					      {{ $t('general.delete') }}
 | 
				
			||||||
    </BaseDropdownItem>
 | 
					    </BaseDropdownItem>
 | 
				
			||||||
 | 
				
			|||||||
@ -10,11 +10,12 @@
 | 
				
			|||||||
    <!-- edit tax-type  -->
 | 
					    <!-- edit tax-type  -->
 | 
				
			||||||
    <BaseDropdownItem
 | 
					    <BaseDropdownItem
 | 
				
			||||||
      v-if="userStore.hasAbilities(abilities.EDIT_TAX_TYPE)"
 | 
					      v-if="userStore.hasAbilities(abilities.EDIT_TAX_TYPE)"
 | 
				
			||||||
 | 
					      v-slot="slotProps"
 | 
				
			||||||
      @click="editTaxType(row.id)"
 | 
					      @click="editTaxType(row.id)"
 | 
				
			||||||
    >
 | 
					    >
 | 
				
			||||||
      <BaseIcon
 | 
					      <BaseIcon
 | 
				
			||||||
        name="PencilIcon"
 | 
					        name="PencilIcon"
 | 
				
			||||||
        class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					        :class="slotProps.class"
 | 
				
			||||||
      />
 | 
					      />
 | 
				
			||||||
      {{ $t('general.edit') }}
 | 
					      {{ $t('general.edit') }}
 | 
				
			||||||
    </BaseDropdownItem>
 | 
					    </BaseDropdownItem>
 | 
				
			||||||
@ -22,11 +23,12 @@
 | 
				
			|||||||
    <!-- delete tax-type  -->
 | 
					    <!-- delete tax-type  -->
 | 
				
			||||||
    <BaseDropdownItem
 | 
					    <BaseDropdownItem
 | 
				
			||||||
      v-if="userStore.hasAbilities(abilities.DELETE_TAX_TYPE)"
 | 
					      v-if="userStore.hasAbilities(abilities.DELETE_TAX_TYPE)"
 | 
				
			||||||
 | 
					      v-slot="slotProps"
 | 
				
			||||||
      @click="removeTaxType(row.id)"
 | 
					      @click="removeTaxType(row.id)"
 | 
				
			||||||
    >
 | 
					    >
 | 
				
			||||||
      <BaseIcon
 | 
					      <BaseIcon
 | 
				
			||||||
        name="TrashIcon"
 | 
					        name="TrashIcon"
 | 
				
			||||||
        class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					        :class="slotProps.class"
 | 
				
			||||||
      />
 | 
					      />
 | 
				
			||||||
      {{ $t('general.delete') }}
 | 
					      {{ $t('general.delete') }}
 | 
				
			||||||
    </BaseDropdownItem>
 | 
					    </BaseDropdownItem>
 | 
				
			||||||
 | 
				
			|||||||
@ -9,20 +9,20 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
    <!-- edit user  -->
 | 
					    <!-- edit user  -->
 | 
				
			||||||
    <router-link :to="`/admin/users/${row.id}/edit`">
 | 
					    <router-link :to="`/admin/users/${row.id}/edit`">
 | 
				
			||||||
      <BaseDropdownItem>
 | 
					      <BaseDropdownItem v-slot="slotProps">
 | 
				
			||||||
        <BaseIcon
 | 
					        <BaseIcon
 | 
				
			||||||
          name="PencilIcon"
 | 
					          name="PencilIcon"
 | 
				
			||||||
          class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					          :class="slotProps.class"
 | 
				
			||||||
        />
 | 
					        />
 | 
				
			||||||
        {{ $t('general.edit') }}
 | 
					        {{ $t('general.edit') }}
 | 
				
			||||||
      </BaseDropdownItem>
 | 
					      </BaseDropdownItem>
 | 
				
			||||||
    </router-link>
 | 
					    </router-link>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    <!-- delete user  -->
 | 
					    <!-- delete user  -->
 | 
				
			||||||
    <BaseDropdownItem @click="removeUser(row.id)">
 | 
					    <BaseDropdownItem v-slot="slotProps" @click="removeUser(row.id)">
 | 
				
			||||||
      <BaseIcon
 | 
					      <BaseIcon
 | 
				
			||||||
        name="TrashIcon"
 | 
					        name="TrashIcon"
 | 
				
			||||||
        class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					        :class="slotProps.class"
 | 
				
			||||||
      />
 | 
					      />
 | 
				
			||||||
      {{ $t('general.delete') }}
 | 
					      {{ $t('general.delete') }}
 | 
				
			||||||
    </BaseDropdownItem>
 | 
					    </BaseDropdownItem>
 | 
				
			||||||
 | 
				
			|||||||
@ -5,7 +5,7 @@
 | 
				
			|||||||
    >
 | 
					    >
 | 
				
			||||||
      <SelectNotePopup :type="type" @select="onSelectNote" />
 | 
					      <SelectNotePopup :type="type" @select="onSelectNote" />
 | 
				
			||||||
    </div>
 | 
					    </div>
 | 
				
			||||||
    <label class="text-gray-800 font-medium mb-4 text-sm">
 | 
					    <label class="text-gray-800 font-medium mb-4 text-sm dark:text-gray-300">
 | 
				
			||||||
      {{ $t('invoices.notes') }}
 | 
					      {{ $t('invoices.notes') }}
 | 
				
			||||||
    </label>
 | 
					    </label>
 | 
				
			||||||
    <BaseCustomInput
 | 
					    <BaseCustomInput
 | 
				
			||||||
 | 
				
			|||||||
@ -29,7 +29,16 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
      <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
 | 
				
			||||||
 | 
					          dark:text-white
 | 
				
			||||||
 | 
					          uppercase
 | 
				
			||||||
 | 
					        "
 | 
				
			||||||
      >
 | 
					      >
 | 
				
			||||||
        <BaseFormatMoney
 | 
					        <BaseFormatMoney
 | 
				
			||||||
          :amount="store.getSubTotal"
 | 
					          :amount="store.getSubTotal"
 | 
				
			||||||
@ -59,7 +68,16 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
      <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
 | 
				
			||||||
 | 
					          dark:text-white
 | 
				
			||||||
 | 
					          uppercase
 | 
				
			||||||
 | 
					        "
 | 
				
			||||||
      >
 | 
					      >
 | 
				
			||||||
        <BaseFormatMoney :amount="tax.amount" :currency="defaultCurrency" />
 | 
					        <BaseFormatMoney :amount="tax.amount" :currency="defaultCurrency" />
 | 
				
			||||||
      </label>
 | 
					      </label>
 | 
				
			||||||
@ -166,7 +184,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" />
 | 
				
			||||||
 | 
				
			|||||||
@ -1,9 +1,18 @@
 | 
				
			|||||||
<template>
 | 
					<template>
 | 
				
			||||||
  <div class="flex items-center justify-between w-full mt-2 text-sm">
 | 
					  <div class="flex items-center justify-between w-full mt-2 text-sm">
 | 
				
			||||||
    <label class="font-semibold leading-5 text-gray-500 uppercase">
 | 
					    <label class="font-semibold leading-5 text-gray-500 uppercase dark:text-gray-300">
 | 
				
			||||||
      {{ tax.name }} ({{ tax.percent }} %)
 | 
					      {{ tax.name }} ({{ tax.percent }} %)
 | 
				
			||||||
    </label>
 | 
					    </label>
 | 
				
			||||||
    <label class="flex items-center justify-center text-lg text-black">
 | 
					    <label
 | 
				
			||||||
 | 
					      class="
 | 
				
			||||||
 | 
					        flex
 | 
				
			||||||
 | 
					        items-center
 | 
				
			||||||
 | 
					        justify-center
 | 
				
			||||||
 | 
					        text-lg
 | 
				
			||||||
 | 
					        text-black
 | 
				
			||||||
 | 
					        dark:text-white
 | 
				
			||||||
 | 
					      "
 | 
				
			||||||
 | 
					    >
 | 
				
			||||||
      <BaseFormatMoney :amount="tax.amount" :currency="currency" />
 | 
					      <BaseFormatMoney :amount="tax.amount" :currency="currency" />
 | 
				
			||||||
 | 
					
 | 
				
			||||||
      <BaseIcon
 | 
					      <BaseIcon
 | 
				
			||||||
 | 
				
			|||||||
@ -96,6 +96,7 @@
 | 
				
			|||||||
                          leading-tight
 | 
					                          leading-tight
 | 
				
			||||||
                          text-gray-700
 | 
					                          text-gray-700
 | 
				
			||||||
                          cursor-pointer
 | 
					                          cursor-pointer
 | 
				
			||||||
 | 
					                          dark:text-gray-300
 | 
				
			||||||
                        "
 | 
					                        "
 | 
				
			||||||
                      >
 | 
					                      >
 | 
				
			||||||
                        {{ taxType.name }}
 | 
					                        {{ taxType.name }}
 | 
				
			||||||
@ -108,6 +109,7 @@
 | 
				
			|||||||
                          font-semibold
 | 
					                          font-semibold
 | 
				
			||||||
                          text-gray-700
 | 
					                          text-gray-700
 | 
				
			||||||
                          cursor-pointer
 | 
					                          cursor-pointer
 | 
				
			||||||
 | 
					                          dark:text-gray-300
 | 
				
			||||||
                        "
 | 
					                        "
 | 
				
			||||||
                      >
 | 
					                      >
 | 
				
			||||||
                        {{ taxType.percent }} %
 | 
					                        {{ taxType.percent }} %
 | 
				
			||||||
 | 
				
			|||||||
@ -1,6 +1,6 @@
 | 
				
			|||||||
<template>
 | 
					<template>
 | 
				
			||||||
  <div>
 | 
					  <div>
 | 
				
			||||||
    <label class="flex text-gray-800 font-medium text-sm mb-2">
 | 
					    <label class="flex text-gray-800 font-medium text-sm mb-2 dark:text-gray-300">
 | 
				
			||||||
      {{ $t('general.select_template') }}
 | 
					      {{ $t('general.select_template') }}
 | 
				
			||||||
      <span class="text-sm text-red-500"> *</span>
 | 
					      <span class="text-sm text-red-500"> *</span>
 | 
				
			||||||
    </label>
 | 
					    </label>
 | 
				
			||||||
 | 
				
			|||||||
@ -57,9 +57,7 @@
 | 
				
			|||||||
          </BaseInputGroup>
 | 
					          </BaseInputGroup>
 | 
				
			||||||
        </BaseInputGrid>
 | 
					        </BaseInputGrid>
 | 
				
			||||||
      </div>
 | 
					      </div>
 | 
				
			||||||
      <div
 | 
					      <BaseModalFooter>
 | 
				
			||||||
        class="z-0 flex justify-end p-4 border-t border-gray-200 border-solid"
 | 
					 | 
				
			||||||
      >
 | 
					 | 
				
			||||||
        <BaseButton
 | 
					        <BaseButton
 | 
				
			||||||
          class="mr-3"
 | 
					          class="mr-3"
 | 
				
			||||||
          variant="primary-outline"
 | 
					          variant="primary-outline"
 | 
				
			||||||
@ -84,7 +82,7 @@
 | 
				
			|||||||
          </template>
 | 
					          </template>
 | 
				
			||||||
          {{ $t('general.create') }}
 | 
					          {{ $t('general.create') }}
 | 
				
			||||||
        </BaseButton>
 | 
					        </BaseButton>
 | 
				
			||||||
      </div>
 | 
					      </BaseModalFooter>
 | 
				
			||||||
    </form>
 | 
					    </form>
 | 
				
			||||||
  </BaseModal>
 | 
					  </BaseModal>
 | 
				
			||||||
</template>
 | 
					</template>
 | 
				
			||||||
 | 
				
			|||||||
@ -47,15 +47,7 @@
 | 
				
			|||||||
        </BaseInputGrid>
 | 
					        </BaseInputGrid>
 | 
				
			||||||
      </div>
 | 
					      </div>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
      <div
 | 
					      <BaseModalFooter>
 | 
				
			||||||
        class="
 | 
					 | 
				
			||||||
          z-0
 | 
					 | 
				
			||||||
          flex
 | 
					 | 
				
			||||||
          justify-end
 | 
					 | 
				
			||||||
          p-4
 | 
					 | 
				
			||||||
          border-t border-gray-200 border-solid border-modal-bg
 | 
					 | 
				
			||||||
        "
 | 
					 | 
				
			||||||
      >
 | 
					 | 
				
			||||||
        <BaseButton
 | 
					        <BaseButton
 | 
				
			||||||
          type="button"
 | 
					          type="button"
 | 
				
			||||||
          variant="primary-outline"
 | 
					          variant="primary-outline"
 | 
				
			||||||
@ -80,7 +72,7 @@
 | 
				
			|||||||
          </template>
 | 
					          </template>
 | 
				
			||||||
          {{ categoryStore.isEdit ? $t('general.update') : $t('general.save') }}
 | 
					          {{ categoryStore.isEdit ? $t('general.update') : $t('general.save') }}
 | 
				
			||||||
        </BaseButton>
 | 
					        </BaseButton>
 | 
				
			||||||
      </div>
 | 
					      </BaseModalFooter>
 | 
				
			||||||
    </form>
 | 
					    </form>
 | 
				
			||||||
  </BaseModal>
 | 
					  </BaseModal>
 | 
				
			||||||
</template>
 | 
					</template>
 | 
				
			||||||
 | 
				
			|||||||
@ -48,6 +48,24 @@
 | 
				
			|||||||
            />
 | 
					            />
 | 
				
			||||||
          </BaseInputGroup>
 | 
					          </BaseInputGroup>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					          <BaseInputGroup
 | 
				
			||||||
 | 
					            :label="$tc('settings.company_info.company_slug')"
 | 
				
			||||||
 | 
					            :help-text="$t('settings.company_info.company_slug_help_text')"
 | 
				
			||||||
 | 
					            :error="
 | 
				
			||||||
 | 
					              v$.newCompanyForm.slug.$error &&
 | 
				
			||||||
 | 
					              v$.newCompanyForm.slug.$errors[0].$message
 | 
				
			||||||
 | 
					            "
 | 
				
			||||||
 | 
					            :content-loading="isFetchingInitialData"
 | 
				
			||||||
 | 
					            required
 | 
				
			||||||
 | 
					          >
 | 
				
			||||||
 | 
					            <BaseInput
 | 
				
			||||||
 | 
					              v-model="newCompanyForm.slug"
 | 
				
			||||||
 | 
					              :invalid="v$.newCompanyForm.slug.$error"
 | 
				
			||||||
 | 
					              :content-loading="isFetchingInitialData"
 | 
				
			||||||
 | 
					              @input="v$.newCompanyForm.slug.$touch()"
 | 
				
			||||||
 | 
					            />
 | 
				
			||||||
 | 
					          </BaseInputGroup>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
          <BaseInputGroup
 | 
					          <BaseInputGroup
 | 
				
			||||||
            :content-loading="isFetchingInitialData"
 | 
					            :content-loading="isFetchingInitialData"
 | 
				
			||||||
            :label="$tc('settings.company_info.country')"
 | 
					            :label="$tc('settings.company_info.country')"
 | 
				
			||||||
@ -98,7 +116,7 @@
 | 
				
			|||||||
        </BaseInputGrid>
 | 
					        </BaseInputGrid>
 | 
				
			||||||
      </div>
 | 
					      </div>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
      <div class="z-0 flex justify-end p-4 bg-gray-50 border-modal-bg">
 | 
					       <BaseModalFooter>
 | 
				
			||||||
        <BaseButton
 | 
					        <BaseButton
 | 
				
			||||||
          class="mr-3 text-sm"
 | 
					          class="mr-3 text-sm"
 | 
				
			||||||
          variant="primary-outline"
 | 
					          variant="primary-outline"
 | 
				
			||||||
@ -123,14 +141,14 @@
 | 
				
			|||||||
          </template>
 | 
					          </template>
 | 
				
			||||||
          {{ $t('general.save') }}
 | 
					          {{ $t('general.save') }}
 | 
				
			||||||
        </BaseButton>
 | 
					        </BaseButton>
 | 
				
			||||||
      </div>
 | 
					      </BaseModalFooter>
 | 
				
			||||||
    </form>
 | 
					    </form>
 | 
				
			||||||
  </BaseModal>
 | 
					  </BaseModal>
 | 
				
			||||||
</template>
 | 
					</template>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
<script setup>
 | 
					<script setup>
 | 
				
			||||||
import { useModalStore } from '@/scripts/stores/modal'
 | 
					import { useModalStore } from '@/scripts/stores/modal'
 | 
				
			||||||
import { computed, onMounted, ref, reactive } from 'vue'
 | 
					import { computed, onMounted, ref, reactive, watch } from 'vue'
 | 
				
			||||||
import { useI18n } from 'vue-i18n'
 | 
					import { useI18n } from 'vue-i18n'
 | 
				
			||||||
import { required, minLength, helpers } from '@vuelidate/validators'
 | 
					import { required, minLength, helpers } from '@vuelidate/validators'
 | 
				
			||||||
import { useVuelidate } from '@vuelidate/core'
 | 
					import { useVuelidate } from '@vuelidate/core'
 | 
				
			||||||
@ -152,6 +170,7 @@ let companyLogoName = ref(null)
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
const newCompanyForm = reactive({
 | 
					const newCompanyForm = reactive({
 | 
				
			||||||
  name: null,
 | 
					  name: null,
 | 
				
			||||||
 | 
					  slug: null,
 | 
				
			||||||
  currency: '',
 | 
					  currency: '',
 | 
				
			||||||
  address: {
 | 
					  address: {
 | 
				
			||||||
    country_id: null,
 | 
					    country_id: null,
 | 
				
			||||||
@ -162,6 +181,9 @@ const modalActive = computed(() => {
 | 
				
			|||||||
  return modalStore.active && modalStore.componentName === 'CompanyModal'
 | 
					  return modalStore.active && modalStore.componentName === 'CompanyModal'
 | 
				
			||||||
})
 | 
					})
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					const slugValidator = (value) => {
 | 
				
			||||||
 | 
					  return value == slugify(value)
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
const rules = {
 | 
					const rules = {
 | 
				
			||||||
  newCompanyForm: {
 | 
					  newCompanyForm: {
 | 
				
			||||||
    name: {
 | 
					    name: {
 | 
				
			||||||
@ -171,6 +193,17 @@ const rules = {
 | 
				
			|||||||
        minLength(3)
 | 
					        minLength(3)
 | 
				
			||||||
      ),
 | 
					      ),
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
 | 
					    slug: {
 | 
				
			||||||
 | 
					      required: helpers.withMessage(t('validation.required'), required),
 | 
				
			||||||
 | 
					      minLength: helpers.withMessage(
 | 
				
			||||||
 | 
					        t('validation.name_min_length', { count: 3 }),
 | 
				
			||||||
 | 
					        minLength(3)
 | 
				
			||||||
 | 
					      ),
 | 
				
			||||||
 | 
					      slugValidator: helpers.withMessage(
 | 
				
			||||||
 | 
					        t('validation.invalid_slug'),
 | 
				
			||||||
 | 
					        slugValidator
 | 
				
			||||||
 | 
					      ),
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
    address: {
 | 
					    address: {
 | 
				
			||||||
      country_id: {
 | 
					      country_id: {
 | 
				
			||||||
        required: helpers.withMessage(t('validation.required'), required),
 | 
					        required: helpers.withMessage(t('validation.required'), required),
 | 
				
			||||||
@ -243,6 +276,7 @@ async function submitCompanyData() {
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
function resetNewCompanyForm() {
 | 
					function resetNewCompanyForm() {
 | 
				
			||||||
  newCompanyForm.name = ''
 | 
					  newCompanyForm.name = ''
 | 
				
			||||||
 | 
					  newCompanyForm.slug = ''
 | 
				
			||||||
  newCompanyForm.currency = ''
 | 
					  newCompanyForm.currency = ''
 | 
				
			||||||
  newCompanyForm.address.country_id = ''
 | 
					  newCompanyForm.address.country_id = ''
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@ -257,4 +291,24 @@ function closeCompanyModal() {
 | 
				
			|||||||
    v$.value.$reset()
 | 
					    v$.value.$reset()
 | 
				
			||||||
  }, 300)
 | 
					  }, 300)
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// watcher for if change company name then auto fill company slug value
 | 
				
			||||||
 | 
					watch(
 | 
				
			||||||
 | 
					  () => newCompanyForm.name,
 | 
				
			||||||
 | 
					  (currentValue) => {
 | 
				
			||||||
 | 
					    newCompanyForm.slug = slugify(currentValue)
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					function slugify(string) {
 | 
				
			||||||
 | 
					  return string
 | 
				
			||||||
 | 
					    .toString()
 | 
				
			||||||
 | 
					    .trim()
 | 
				
			||||||
 | 
					    .toLowerCase()
 | 
				
			||||||
 | 
					    .replace(/\s+/g, '-')
 | 
				
			||||||
 | 
					    .replace(/[^\w\-]+/g, '')
 | 
				
			||||||
 | 
					    .replace(/\-\-+/g, '-')
 | 
				
			||||||
 | 
					    .replace(/^-+/, '')
 | 
				
			||||||
 | 
					    .replace(/-+$/, '')
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
</script>
 | 
					</script>
 | 
				
			||||||
 | 
				
			|||||||
@ -122,7 +122,7 @@
 | 
				
			|||||||
          <BaseTab :title="$t('customers.portal_access')">
 | 
					          <BaseTab :title="$t('customers.portal_access')">
 | 
				
			||||||
            <BaseInputGrid class="col-span-5 lg:col-span-4">
 | 
					            <BaseInputGrid class="col-span-5 lg:col-span-4">
 | 
				
			||||||
              <div class="md:col-span-2">
 | 
					              <div class="md:col-span-2">
 | 
				
			||||||
                <p class="text-sm text-gray-500">
 | 
					                <p class="text-sm text-gray-500 dark:text-gray-300">
 | 
				
			||||||
                  {{ $t('customers.portal_access_text') }}
 | 
					                  {{ $t('customers.portal_access_text') }}
 | 
				
			||||||
                </p>
 | 
					                </p>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@ -425,9 +425,7 @@
 | 
				
			|||||||
        </BaseTabGroup>
 | 
					        </BaseTabGroup>
 | 
				
			||||||
      </div>
 | 
					      </div>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
      <div
 | 
					      <BaseModalFooter>
 | 
				
			||||||
        class="z-0 flex justify-end p-4 border-t border-gray-200 border-solid"
 | 
					 | 
				
			||||||
      >
 | 
					 | 
				
			||||||
        <BaseButton
 | 
					        <BaseButton
 | 
				
			||||||
          class="mr-3 text-sm"
 | 
					          class="mr-3 text-sm"
 | 
				
			||||||
          type="button"
 | 
					          type="button"
 | 
				
			||||||
@ -447,7 +445,7 @@
 | 
				
			|||||||
          </template>
 | 
					          </template>
 | 
				
			||||||
          {{ $t('general.save') }}
 | 
					          {{ $t('general.save') }}
 | 
				
			||||||
        </BaseButton>
 | 
					        </BaseButton>
 | 
				
			||||||
      </div>
 | 
					      </BaseModalFooter>
 | 
				
			||||||
    </form>
 | 
					    </form>
 | 
				
			||||||
  </BaseModal>
 | 
					  </BaseModal>
 | 
				
			||||||
</template>
 | 
					</template>
 | 
				
			||||||
 | 
				
			|||||||
@ -38,7 +38,7 @@
 | 
				
			|||||||
        </BaseInputGroup>
 | 
					        </BaseInputGroup>
 | 
				
			||||||
      </div>
 | 
					      </div>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
      <div class="z-0 flex justify-end p-4 bg-gray-50 border-modal-bg">
 | 
					      <BaseModalFooter>
 | 
				
			||||||
        <BaseButton
 | 
					        <BaseButton
 | 
				
			||||||
          class="mr-3 text-sm"
 | 
					          class="mr-3 text-sm"
 | 
				
			||||||
          variant="primary-outline"
 | 
					          variant="primary-outline"
 | 
				
			||||||
@ -63,7 +63,7 @@
 | 
				
			|||||||
          </template>
 | 
					          </template>
 | 
				
			||||||
          {{ $t('general.delete') }}
 | 
					          {{ $t('general.delete') }}
 | 
				
			||||||
        </BaseButton>
 | 
					        </BaseButton>
 | 
				
			||||||
      </div>
 | 
					      </BaseModalFooter>
 | 
				
			||||||
    </form>
 | 
					    </form>
 | 
				
			||||||
  </BaseModal>
 | 
					  </BaseModal>
 | 
				
			||||||
</template>
 | 
					</template>
 | 
				
			||||||
 | 
				
			|||||||
@ -150,9 +150,7 @@
 | 
				
			|||||||
          @Remove="removeUsedSelectedCurrencies"
 | 
					          @Remove="removeUsedSelectedCurrencies"
 | 
				
			||||||
        />
 | 
					        />
 | 
				
			||||||
      </div>
 | 
					      </div>
 | 
				
			||||||
      <div
 | 
					      <BaseModalFooter>
 | 
				
			||||||
        class="z-0 flex justify-end p-4 border-t border-gray-200 border-solid"
 | 
					 | 
				
			||||||
      >
 | 
					 | 
				
			||||||
        <BaseButton
 | 
					        <BaseButton
 | 
				
			||||||
          class="mr-3"
 | 
					          class="mr-3"
 | 
				
			||||||
          variant="primary-outline"
 | 
					          variant="primary-outline"
 | 
				
			||||||
@ -179,7 +177,7 @@
 | 
				
			|||||||
            exchangeRateStore.isEdit ? $t('general.update') : $t('general.save')
 | 
					            exchangeRateStore.isEdit ? $t('general.update') : $t('general.save')
 | 
				
			||||||
          }}
 | 
					          }}
 | 
				
			||||||
        </BaseButton>
 | 
					        </BaseButton>
 | 
				
			||||||
      </div>
 | 
					      </BaseModalFooter>
 | 
				
			||||||
    </form>
 | 
					    </form>
 | 
				
			||||||
  </BaseModal>
 | 
					  </BaseModal>
 | 
				
			||||||
</template>
 | 
					</template>
 | 
				
			||||||
 | 
				
			|||||||
@ -20,15 +20,7 @@
 | 
				
			|||||||
        @submit="createNewDisk"
 | 
					        @submit="createNewDisk"
 | 
				
			||||||
      >
 | 
					      >
 | 
				
			||||||
        <template #default="slotProps">
 | 
					        <template #default="slotProps">
 | 
				
			||||||
          <div
 | 
					          <BaseModalFooter>
 | 
				
			||||||
            class="
 | 
					 | 
				
			||||||
              z-0
 | 
					 | 
				
			||||||
              flex
 | 
					 | 
				
			||||||
              justify-end
 | 
					 | 
				
			||||||
              p-4
 | 
					 | 
				
			||||||
              border-t border-solid border-gray-light
 | 
					 | 
				
			||||||
            "
 | 
					 | 
				
			||||||
          >
 | 
					 | 
				
			||||||
            <BaseButton
 | 
					            <BaseButton
 | 
				
			||||||
              class="mr-3 text-sm"
 | 
					              class="mr-3 text-sm"
 | 
				
			||||||
              variant="primary-outline"
 | 
					              variant="primary-outline"
 | 
				
			||||||
@ -52,7 +44,7 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
              {{ $t('general.save') }}
 | 
					              {{ $t('general.save') }}
 | 
				
			||||||
            </BaseButton>
 | 
					            </BaseButton>
 | 
				
			||||||
          </div>
 | 
					          </BaseModalFooter>
 | 
				
			||||||
        </template>
 | 
					        </template>
 | 
				
			||||||
      </component>
 | 
					      </component>
 | 
				
			||||||
    </div>
 | 
					    </div>
 | 
				
			||||||
 | 
				
			|||||||
@ -89,9 +89,7 @@
 | 
				
			|||||||
            </BaseInputGroup>
 | 
					            </BaseInputGroup>
 | 
				
			||||||
          </BaseInputGrid>
 | 
					          </BaseInputGrid>
 | 
				
			||||||
        </div>
 | 
					        </div>
 | 
				
			||||||
        <div
 | 
					        <BaseModalFooter>
 | 
				
			||||||
          class="z-0 flex justify-end p-4 border-t border-gray-200 border-solid"
 | 
					 | 
				
			||||||
        >
 | 
					 | 
				
			||||||
          <BaseButton
 | 
					          <BaseButton
 | 
				
			||||||
            class="mr-3"
 | 
					            class="mr-3"
 | 
				
			||||||
            variant="primary-outline"
 | 
					            variant="primary-outline"
 | 
				
			||||||
@ -111,7 +109,7 @@
 | 
				
			|||||||
            </template>
 | 
					            </template>
 | 
				
			||||||
            {{ itemStore.isEdit ? $t('general.update') : $t('general.save') }}
 | 
					            {{ itemStore.isEdit ? $t('general.update') : $t('general.save') }}
 | 
				
			||||||
          </BaseButton>
 | 
					          </BaseButton>
 | 
				
			||||||
        </div>
 | 
					        </BaseModalFooter>
 | 
				
			||||||
      </form>
 | 
					      </form>
 | 
				
			||||||
    </div>
 | 
					    </div>
 | 
				
			||||||
  </BaseModal>
 | 
					  </BaseModal>
 | 
				
			||||||
 | 
				
			|||||||
@ -31,15 +31,7 @@
 | 
				
			|||||||
        </BaseInputGroup>
 | 
					        </BaseInputGroup>
 | 
				
			||||||
      </div>
 | 
					      </div>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
      <div
 | 
					      <BaseModalFooter>
 | 
				
			||||||
        class="
 | 
					 | 
				
			||||||
          z-0
 | 
					 | 
				
			||||||
          flex
 | 
					 | 
				
			||||||
          justify-end
 | 
					 | 
				
			||||||
          p-4
 | 
					 | 
				
			||||||
          border-t border-gray-200 border-solid border-modal-bg
 | 
					 | 
				
			||||||
        "
 | 
					 | 
				
			||||||
      >
 | 
					 | 
				
			||||||
        <BaseButton
 | 
					        <BaseButton
 | 
				
			||||||
          type="button"
 | 
					          type="button"
 | 
				
			||||||
          variant="primary-outline"
 | 
					          variant="primary-outline"
 | 
				
			||||||
@ -66,7 +58,7 @@
 | 
				
			|||||||
            itemStore.isItemUnitEdit ? $t('general.update') : $t('general.save')
 | 
					            itemStore.isItemUnitEdit ? $t('general.update') : $t('general.save')
 | 
				
			||||||
          }}
 | 
					          }}
 | 
				
			||||||
        </BaseButton>
 | 
					        </BaseButton>
 | 
				
			||||||
      </div>
 | 
					      </BaseModalFooter>
 | 
				
			||||||
    </form>
 | 
					    </form>
 | 
				
			||||||
  </BaseModal>
 | 
					  </BaseModal>
 | 
				
			||||||
</template>
 | 
					</template>
 | 
				
			||||||
 | 
				
			|||||||
@ -62,9 +62,7 @@
 | 
				
			|||||||
          </BaseInputGroup>
 | 
					          </BaseInputGroup>
 | 
				
			||||||
        </BaseInputGrid>
 | 
					        </BaseInputGrid>
 | 
				
			||||||
      </div>
 | 
					      </div>
 | 
				
			||||||
      <div
 | 
					     <BaseModalFooter>
 | 
				
			||||||
        class="z-0 flex justify-end p-4 border-t border-gray-200 border-solid"
 | 
					 | 
				
			||||||
      >
 | 
					 | 
				
			||||||
        <BaseButton
 | 
					        <BaseButton
 | 
				
			||||||
          variant="primary-outline"
 | 
					          variant="primary-outline"
 | 
				
			||||||
          type="button"
 | 
					          type="button"
 | 
				
			||||||
@ -84,7 +82,7 @@
 | 
				
			|||||||
          </template>
 | 
					          </template>
 | 
				
			||||||
          {{ $t('general.send') }}
 | 
					          {{ $t('general.send') }}
 | 
				
			||||||
        </BaseButton>
 | 
					        </BaseButton>
 | 
				
			||||||
      </div>
 | 
					      </BaseModalFooter>
 | 
				
			||||||
    </form>
 | 
					    </form>
 | 
				
			||||||
  </BaseModal>
 | 
					  </BaseModal>
 | 
				
			||||||
</template>
 | 
					</template>
 | 
				
			||||||
 | 
				
			|||||||
@ -63,16 +63,7 @@
 | 
				
			|||||||
          </BaseInputGroup>
 | 
					          </BaseInputGroup>
 | 
				
			||||||
        </BaseInputGrid>
 | 
					        </BaseInputGrid>
 | 
				
			||||||
      </div>
 | 
					      </div>
 | 
				
			||||||
      <div
 | 
					     <BaseModalFooter>
 | 
				
			||||||
        class="
 | 
					 | 
				
			||||||
          z-0
 | 
					 | 
				
			||||||
          flex
 | 
					 | 
				
			||||||
          justify-end
 | 
					 | 
				
			||||||
          px-4
 | 
					 | 
				
			||||||
          py-4
 | 
					 | 
				
			||||||
          border-t border-solid border-gray-light
 | 
					 | 
				
			||||||
        "
 | 
					 | 
				
			||||||
      >
 | 
					 | 
				
			||||||
        <BaseButton
 | 
					        <BaseButton
 | 
				
			||||||
          class="mr-2"
 | 
					          class="mr-2"
 | 
				
			||||||
          variant="primary-outline"
 | 
					          variant="primary-outline"
 | 
				
			||||||
@ -93,7 +84,7 @@
 | 
				
			|||||||
          </template>
 | 
					          </template>
 | 
				
			||||||
          {{ noteStore.isEdit ? $t('general.update') : $t('general.save') }}
 | 
					          {{ noteStore.isEdit ? $t('general.update') : $t('general.save') }}
 | 
				
			||||||
        </BaseButton>
 | 
					        </BaseButton>
 | 
				
			||||||
      </div>
 | 
					      </BaseModalFooter>
 | 
				
			||||||
    </form>
 | 
					    </form>
 | 
				
			||||||
  </BaseModal>
 | 
					  </BaseModal>
 | 
				
			||||||
</template>
 | 
					</template>
 | 
				
			||||||
 | 
				
			|||||||
@ -29,9 +29,7 @@
 | 
				
			|||||||
        </BaseInputGroup>
 | 
					        </BaseInputGroup>
 | 
				
			||||||
      </div>
 | 
					      </div>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
      <div
 | 
					      <BaseModalFooter>
 | 
				
			||||||
        class="z-0 flex justify-end p-4 border-t border-gray-200 border-solid"
 | 
					 | 
				
			||||||
      >
 | 
					 | 
				
			||||||
        <BaseButton
 | 
					        <BaseButton
 | 
				
			||||||
          variant="primary-outline"
 | 
					          variant="primary-outline"
 | 
				
			||||||
          class="mr-3"
 | 
					          class="mr-3"
 | 
				
			||||||
@ -56,7 +54,7 @@
 | 
				
			|||||||
              : $t('general.save')
 | 
					              : $t('general.save')
 | 
				
			||||||
          }}
 | 
					          }}
 | 
				
			||||||
        </BaseButton>
 | 
					        </BaseButton>
 | 
				
			||||||
      </div>
 | 
					      </BaseModalFooter>
 | 
				
			||||||
    </form>
 | 
					    </form>
 | 
				
			||||||
  </BaseModal>
 | 
					  </BaseModal>
 | 
				
			||||||
</template>
 | 
					</template>
 | 
				
			||||||
 | 
				
			|||||||
@ -72,7 +72,7 @@
 | 
				
			|||||||
        </div>
 | 
					        </div>
 | 
				
			||||||
      </div>
 | 
					      </div>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
      <div class="border-t border-gray-200 py-3">
 | 
					      <div class="border-t border-gray-200 dark:border-gray-600 py-3">
 | 
				
			||||||
        <div
 | 
					        <div
 | 
				
			||||||
          class="
 | 
					          class="
 | 
				
			||||||
            grid grid-cols-1
 | 
					            grid grid-cols-1
 | 
				
			||||||
@ -89,7 +89,7 @@
 | 
				
			|||||||
            :key="gIndex"
 | 
					            :key="gIndex"
 | 
				
			||||||
            class="flex flex-col space-y-1"
 | 
					            class="flex flex-col space-y-1"
 | 
				
			||||||
          >
 | 
					          >
 | 
				
			||||||
            <p class="text-sm text-gray-500 border-b border-gray-200 pb-1 mb-2">
 | 
					            <p class="text-sm text-gray-500 dark:text-gray-200 border-b dark:border-gray-600 pb-1 mb-2">
 | 
				
			||||||
              {{ gIndex }}
 | 
					              {{ gIndex }}
 | 
				
			||||||
            </p>
 | 
					            </p>
 | 
				
			||||||
            <div
 | 
					            <div
 | 
				
			||||||
@ -116,15 +116,7 @@
 | 
				
			|||||||
          </span>
 | 
					          </span>
 | 
				
			||||||
        </div>
 | 
					        </div>
 | 
				
			||||||
      </div>
 | 
					      </div>
 | 
				
			||||||
      <div
 | 
					      <BaseModalFooter>
 | 
				
			||||||
        class="
 | 
					 | 
				
			||||||
          z-0
 | 
					 | 
				
			||||||
          flex
 | 
					 | 
				
			||||||
          justify-end
 | 
					 | 
				
			||||||
          p-4
 | 
					 | 
				
			||||||
          border-t border-solid border--200 border-modal-bg
 | 
					 | 
				
			||||||
        "
 | 
					 | 
				
			||||||
      >
 | 
					 | 
				
			||||||
        <BaseButton
 | 
					        <BaseButton
 | 
				
			||||||
          class="mr-3 text-sm"
 | 
					          class="mr-3 text-sm"
 | 
				
			||||||
          variant="primary-outline"
 | 
					          variant="primary-outline"
 | 
				
			||||||
@ -144,7 +136,7 @@
 | 
				
			|||||||
          </template>
 | 
					          </template>
 | 
				
			||||||
          {{ !roleStore.isEdit ? $t('general.save') : $t('general.update') }}
 | 
					          {{ !roleStore.isEdit ? $t('general.save') : $t('general.update') }}
 | 
				
			||||||
        </BaseButton>
 | 
					        </BaseButton>
 | 
				
			||||||
      </div>
 | 
					      </BaseModalFooter>
 | 
				
			||||||
    </form>
 | 
					    </form>
 | 
				
			||||||
  </BaseModal>
 | 
					  </BaseModal>
 | 
				
			||||||
</template>
 | 
					</template>
 | 
				
			||||||
 | 
				
			|||||||
@ -70,7 +70,7 @@
 | 
				
			|||||||
      </div>
 | 
					      </div>
 | 
				
			||||||
    </div>
 | 
					    </div>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    <div class="z-0 flex justify-end p-4 border-t border-gray-200 border-solid">
 | 
					    <BaseModalFooter>
 | 
				
			||||||
      <BaseButton class="mr-3" variant="primary-outline" @click="closeModal">
 | 
					      <BaseButton class="mr-3" variant="primary-outline" @click="closeModal">
 | 
				
			||||||
        {{ $t('general.cancel') }}
 | 
					        {{ $t('general.cancel') }}
 | 
				
			||||||
      </BaseButton>
 | 
					      </BaseButton>
 | 
				
			||||||
@ -80,7 +80,7 @@
 | 
				
			|||||||
        </template>
 | 
					        </template>
 | 
				
			||||||
        {{ $t('general.choose') }}
 | 
					        {{ $t('general.choose') }}
 | 
				
			||||||
      </BaseButton>
 | 
					      </BaseButton>
 | 
				
			||||||
    </div>
 | 
					    </BaseModalFooter>
 | 
				
			||||||
  </BaseModal>
 | 
					  </BaseModal>
 | 
				
			||||||
</template>
 | 
					</template>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
				
			|||||||
@ -62,9 +62,7 @@
 | 
				
			|||||||
          </BaseInputGroup>
 | 
					          </BaseInputGroup>
 | 
				
			||||||
        </BaseInputGrid>
 | 
					        </BaseInputGrid>
 | 
				
			||||||
      </div>
 | 
					      </div>
 | 
				
			||||||
      <div
 | 
					      <BaseModalFooter>
 | 
				
			||||||
        class="z-0 flex justify-end p-4 border-t border-gray-200 border-solid"
 | 
					 | 
				
			||||||
      >
 | 
					 | 
				
			||||||
        <BaseButton
 | 
					        <BaseButton
 | 
				
			||||||
          class="mr-3"
 | 
					          class="mr-3"
 | 
				
			||||||
          variant="primary-outline"
 | 
					          variant="primary-outline"
 | 
				
			||||||
@ -85,7 +83,7 @@
 | 
				
			|||||||
          <BaseIcon v-if="!isLoading" name="PhotographIcon" class="h-5 mr-2" />
 | 
					          <BaseIcon v-if="!isLoading" name="PhotographIcon" class="h-5 mr-2" />
 | 
				
			||||||
          {{ $t('general.preview') }}
 | 
					          {{ $t('general.preview') }}
 | 
				
			||||||
        </BaseButton>
 | 
					        </BaseButton>
 | 
				
			||||||
      </div>
 | 
					      </BaseModalFooter>
 | 
				
			||||||
    </form>
 | 
					    </form>
 | 
				
			||||||
    <div v-else>
 | 
					    <div v-else>
 | 
				
			||||||
      <div class="my-6 mx-4 border border-gray-200 relative">
 | 
					      <div class="my-6 mx-4 border border-gray-200 relative">
 | 
				
			||||||
@ -106,9 +104,7 @@
 | 
				
			|||||||
        ></iframe>
 | 
					        ></iframe>
 | 
				
			||||||
      </div>
 | 
					      </div>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
      <div
 | 
					      <BaseModalFooter>
 | 
				
			||||||
        class="z-0 flex justify-end p-4 border-t border-gray-200 border-solid"
 | 
					 | 
				
			||||||
      >
 | 
					 | 
				
			||||||
        <BaseButton
 | 
					        <BaseButton
 | 
				
			||||||
          class="mr-3"
 | 
					          class="mr-3"
 | 
				
			||||||
          variant="primary-outline"
 | 
					          variant="primary-outline"
 | 
				
			||||||
@ -127,7 +123,7 @@
 | 
				
			|||||||
          <BaseIcon v-if="!isLoading" name="PaperAirplaneIcon" class="mr-2" />
 | 
					          <BaseIcon v-if="!isLoading" name="PaperAirplaneIcon" class="mr-2" />
 | 
				
			||||||
          {{ $t('general.send') }}
 | 
					          {{ $t('general.send') }}
 | 
				
			||||||
        </BaseButton>
 | 
					        </BaseButton>
 | 
				
			||||||
      </div>
 | 
					      </BaseModalFooter>
 | 
				
			||||||
    </div>
 | 
					    </div>
 | 
				
			||||||
  </BaseModal>
 | 
					  </BaseModal>
 | 
				
			||||||
</template>
 | 
					</template>
 | 
				
			||||||
 | 
				
			|||||||
@ -65,9 +65,7 @@
 | 
				
			|||||||
          </BaseInputGroup>
 | 
					          </BaseInputGroup>
 | 
				
			||||||
        </BaseInputGrid>
 | 
					        </BaseInputGrid>
 | 
				
			||||||
      </div>
 | 
					      </div>
 | 
				
			||||||
      <div
 | 
					      <BaseModalFooter>
 | 
				
			||||||
        class="z-0 flex justify-end p-4 border-t border-gray-200 border-solid"
 | 
					 | 
				
			||||||
      >
 | 
					 | 
				
			||||||
        <BaseButton
 | 
					        <BaseButton
 | 
				
			||||||
          class="mr-3"
 | 
					          class="mr-3"
 | 
				
			||||||
          variant="primary-outline"
 | 
					          variant="primary-outline"
 | 
				
			||||||
@ -93,7 +91,7 @@
 | 
				
			|||||||
          </template>
 | 
					          </template>
 | 
				
			||||||
          {{ $t('general.preview') }}
 | 
					          {{ $t('general.preview') }}
 | 
				
			||||||
        </BaseButton>
 | 
					        </BaseButton>
 | 
				
			||||||
      </div>
 | 
					      </BaseModalFooter>
 | 
				
			||||||
    </form>
 | 
					    </form>
 | 
				
			||||||
    <div v-else>
 | 
					    <div v-else>
 | 
				
			||||||
      <div class="my-6 mx-4 border border-gray-200 relative">
 | 
					      <div class="my-6 mx-4 border border-gray-200 relative">
 | 
				
			||||||
@ -114,9 +112,7 @@
 | 
				
			|||||||
          style="min-height: 500px"
 | 
					          style="min-height: 500px"
 | 
				
			||||||
        ></iframe>
 | 
					        ></iframe>
 | 
				
			||||||
      </div>
 | 
					      </div>
 | 
				
			||||||
      <div
 | 
					      <BaseModalFooter>
 | 
				
			||||||
        class="z-0 flex justify-end p-4 border-t border-gray-200 border-solid"
 | 
					 | 
				
			||||||
      >
 | 
					 | 
				
			||||||
        <BaseButton
 | 
					        <BaseButton
 | 
				
			||||||
          class="mr-3"
 | 
					          class="mr-3"
 | 
				
			||||||
          variant="primary-outline"
 | 
					          variant="primary-outline"
 | 
				
			||||||
@ -140,7 +136,7 @@
 | 
				
			|||||||
          />
 | 
					          />
 | 
				
			||||||
          {{ $t('general.send') }}
 | 
					          {{ $t('general.send') }}
 | 
				
			||||||
        </BaseButton>
 | 
					        </BaseButton>
 | 
				
			||||||
      </div>
 | 
					      </BaseModalFooter>
 | 
				
			||||||
    </div>
 | 
					    </div>
 | 
				
			||||||
  </BaseModal>
 | 
					  </BaseModal>
 | 
				
			||||||
</template>
 | 
					</template>
 | 
				
			||||||
 | 
				
			|||||||
@ -65,9 +65,7 @@
 | 
				
			|||||||
          </BaseInputGroup>
 | 
					          </BaseInputGroup>
 | 
				
			||||||
        </BaseInputGrid>
 | 
					        </BaseInputGrid>
 | 
				
			||||||
      </div>
 | 
					      </div>
 | 
				
			||||||
      <div
 | 
					      <BaseModalFooter>
 | 
				
			||||||
        class="z-0 flex justify-end p-4 border-t border-gray-200 border-solid"
 | 
					 | 
				
			||||||
      >
 | 
					 | 
				
			||||||
        <BaseButton
 | 
					        <BaseButton
 | 
				
			||||||
          class="mr-3"
 | 
					          class="mr-3"
 | 
				
			||||||
          variant="primary-outline"
 | 
					          variant="primary-outline"
 | 
				
			||||||
@ -93,7 +91,7 @@
 | 
				
			|||||||
          </template>
 | 
					          </template>
 | 
				
			||||||
          {{ $t('general.preview') }}
 | 
					          {{ $t('general.preview') }}
 | 
				
			||||||
        </BaseButton>
 | 
					        </BaseButton>
 | 
				
			||||||
      </div>
 | 
					      </BaseModalFooter>
 | 
				
			||||||
    </form>
 | 
					    </form>
 | 
				
			||||||
    <div v-else>
 | 
					    <div v-else>
 | 
				
			||||||
      <div class="my-6 mx-4 border border-gray-200 relative">
 | 
					      <div class="my-6 mx-4 border border-gray-200 relative">
 | 
				
			||||||
@ -114,9 +112,7 @@
 | 
				
			|||||||
          style="min-height: 500px"
 | 
					          style="min-height: 500px"
 | 
				
			||||||
        ></iframe>
 | 
					        ></iframe>
 | 
				
			||||||
      </div>
 | 
					      </div>
 | 
				
			||||||
      <div
 | 
					      <BaseModalFooter>
 | 
				
			||||||
        class="z-0 flex justify-end p-4 border-t border-gray-200 border-solid"
 | 
					 | 
				
			||||||
      >
 | 
					 | 
				
			||||||
        <BaseButton
 | 
					        <BaseButton
 | 
				
			||||||
          class="mr-3"
 | 
					          class="mr-3"
 | 
				
			||||||
          variant="primary-outline"
 | 
					          variant="primary-outline"
 | 
				
			||||||
@ -140,7 +136,7 @@
 | 
				
			|||||||
          />
 | 
					          />
 | 
				
			||||||
          {{ $t('general.send') }}
 | 
					          {{ $t('general.send') }}
 | 
				
			||||||
        </BaseButton>
 | 
					        </BaseButton>
 | 
				
			||||||
      </div>
 | 
					      </BaseModalFooter>
 | 
				
			||||||
    </div>
 | 
					    </div>
 | 
				
			||||||
  </BaseModal>
 | 
					  </BaseModal>
 | 
				
			||||||
</template>
 | 
					</template>
 | 
				
			||||||
 | 
				
			|||||||
@ -90,15 +90,7 @@
 | 
				
			|||||||
          </BaseInputGroup>
 | 
					          </BaseInputGroup>
 | 
				
			||||||
        </BaseInputGrid>
 | 
					        </BaseInputGrid>
 | 
				
			||||||
      </div>
 | 
					      </div>
 | 
				
			||||||
      <div
 | 
					      <BaseModalFooter>
 | 
				
			||||||
        class="
 | 
					 | 
				
			||||||
          z-0
 | 
					 | 
				
			||||||
          flex
 | 
					 | 
				
			||||||
          justify-end
 | 
					 | 
				
			||||||
          p-4
 | 
					 | 
				
			||||||
          border-t border-solid border--200 border-modal-bg
 | 
					 | 
				
			||||||
        "
 | 
					 | 
				
			||||||
      >
 | 
					 | 
				
			||||||
        <BaseButton
 | 
					        <BaseButton
 | 
				
			||||||
          class="mr-3 text-sm"
 | 
					          class="mr-3 text-sm"
 | 
				
			||||||
          variant="primary-outline"
 | 
					          variant="primary-outline"
 | 
				
			||||||
@ -122,7 +114,7 @@
 | 
				
			|||||||
          </template>
 | 
					          </template>
 | 
				
			||||||
          {{ taxTypeStore.isEdit ? $t('general.update') : $t('general.save') }}
 | 
					          {{ taxTypeStore.isEdit ? $t('general.update') : $t('general.save') }}
 | 
				
			||||||
        </BaseButton>
 | 
					        </BaseButton>
 | 
				
			||||||
      </div>
 | 
					      </BaseModalFooter>
 | 
				
			||||||
    </form>
 | 
					    </form>
 | 
				
			||||||
  </BaseModal>
 | 
					  </BaseModal>
 | 
				
			||||||
</template>
 | 
					</template>
 | 
				
			||||||
 | 
				
			|||||||
@ -87,9 +87,7 @@
 | 
				
			|||||||
        </BaseInputGrid>
 | 
					        </BaseInputGrid>
 | 
				
			||||||
      </div>
 | 
					      </div>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
      <div
 | 
					      <BaseModalFooter>
 | 
				
			||||||
        class="z-0 flex justify-end p-4 border-t border-gray-200 border-solid"
 | 
					 | 
				
			||||||
      >
 | 
					 | 
				
			||||||
        <BaseButton
 | 
					        <BaseButton
 | 
				
			||||||
          class="mr-3 text-sm"
 | 
					          class="mr-3 text-sm"
 | 
				
			||||||
          type="button"
 | 
					          type="button"
 | 
				
			||||||
@ -109,7 +107,7 @@
 | 
				
			|||||||
          </template>
 | 
					          </template>
 | 
				
			||||||
          {{ $t('general.save') }}
 | 
					          {{ $t('general.save') }}
 | 
				
			||||||
        </BaseButton>
 | 
					        </BaseButton>
 | 
				
			||||||
      </div>
 | 
					      </BaseModalFooter>
 | 
				
			||||||
    </form>
 | 
					    </form>
 | 
				
			||||||
  </BaseModal>
 | 
					  </BaseModal>
 | 
				
			||||||
</template>
 | 
					</template>
 | 
				
			||||||
 | 
				
			|||||||
@ -172,15 +172,7 @@
 | 
				
			|||||||
        </div>
 | 
					        </div>
 | 
				
			||||||
      </div>
 | 
					      </div>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
      <div
 | 
					      <BaseModalFooter>
 | 
				
			||||||
        class="
 | 
					 | 
				
			||||||
          z-0
 | 
					 | 
				
			||||||
          flex
 | 
					 | 
				
			||||||
          justify-end
 | 
					 | 
				
			||||||
          p-4
 | 
					 | 
				
			||||||
          border-t border-solid border-gray-light border-modal-bg
 | 
					 | 
				
			||||||
        "
 | 
					 | 
				
			||||||
      >
 | 
					 | 
				
			||||||
        <BaseButton
 | 
					        <BaseButton
 | 
				
			||||||
          class="mr-3"
 | 
					          class="mr-3"
 | 
				
			||||||
          type="button"
 | 
					          type="button"
 | 
				
			||||||
@ -207,7 +199,7 @@
 | 
				
			|||||||
            !customFieldStore.isEdit ? $t('general.save') : $t('general.update')
 | 
					            !customFieldStore.isEdit ? $t('general.save') : $t('general.update')
 | 
				
			||||||
          }}
 | 
					          }}
 | 
				
			||||||
        </BaseButton>
 | 
					        </BaseButton>
 | 
				
			||||||
      </div>
 | 
					      </BaseModalFooter>
 | 
				
			||||||
    </form>
 | 
					    </form>
 | 
				
			||||||
  </BaseModal>
 | 
					  </BaseModal>
 | 
				
			||||||
</template>
 | 
					</template>
 | 
				
			||||||
 | 
				
			|||||||
@ -153,7 +153,7 @@
 | 
				
			|||||||
          <BaseSwitch v-model="set_as_default" class="flex" />
 | 
					          <BaseSwitch v-model="set_as_default" class="flex" />
 | 
				
			||||||
        </div>
 | 
					        </div>
 | 
				
			||||||
        <div class="ml-4 right">
 | 
					        <div class="ml-4 right">
 | 
				
			||||||
          <p class="p-0 mb-1 text-base leading-snug text-black box-title">
 | 
					          <p class="p-0 mb-1 text-base leading-snug text-black dark:text-white box-title">
 | 
				
			||||||
            {{ $t('settings.disk.is_default') }}
 | 
					            {{ $t('settings.disk.is_default') }}
 | 
				
			||||||
          </p>
 | 
					          </p>
 | 
				
			||||||
        </div>
 | 
					        </div>
 | 
				
			||||||
 | 
				
			|||||||
@ -132,7 +132,7 @@
 | 
				
			|||||||
          <BaseSwitch v-model="set_as_default" class="flex" />
 | 
					          <BaseSwitch v-model="set_as_default" class="flex" />
 | 
				
			||||||
        </div>
 | 
					        </div>
 | 
				
			||||||
        <div class="ml-4 right">
 | 
					        <div class="ml-4 right">
 | 
				
			||||||
          <p class="p-0 mb-1 text-base leading-snug text-black box-title">
 | 
					          <p class="p-0 mb-1 text-base leading-snug text-black dark:text-white box-title">
 | 
				
			||||||
            {{ $t('settings.disk.is_default') }}
 | 
					            {{ $t('settings.disk.is_default') }}
 | 
				
			||||||
          </p>
 | 
					          </p>
 | 
				
			||||||
        </div>
 | 
					        </div>
 | 
				
			||||||
 | 
				
			|||||||
@ -63,7 +63,7 @@
 | 
				
			|||||||
        </div>
 | 
					        </div>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        <div class="ml-4 right">
 | 
					        <div class="ml-4 right">
 | 
				
			||||||
          <p class="p-0 mb-1 text-base leading-snug text-black box-title">
 | 
					          <p class="p-0 mb-1 text-base leading-snug text-black dark:text-white box-title">
 | 
				
			||||||
            {{ $t('settings.disk.is_default') }}
 | 
					            {{ $t('settings.disk.is_default') }}
 | 
				
			||||||
          </p>
 | 
					          </p>
 | 
				
			||||||
        </div>
 | 
					        </div>
 | 
				
			||||||
 | 
				
			|||||||
@ -134,7 +134,7 @@
 | 
				
			|||||||
          <BaseSwitch v-model="set_as_default" class="flex" />
 | 
					          <BaseSwitch v-model="set_as_default" class="flex" />
 | 
				
			||||||
        </div>
 | 
					        </div>
 | 
				
			||||||
        <div class="ml-4 right">
 | 
					        <div class="ml-4 right">
 | 
				
			||||||
          <p class="p-0 mb-1 text-base leading-snug text-black box-title">
 | 
					          <p class="p-0 mb-1 text-base leading-snug text-black dark:text-white box-title">
 | 
				
			||||||
            {{ $t('settings.disk.is_default') }}
 | 
					            {{ $t('settings.disk.is_default') }}
 | 
				
			||||||
          </p>
 | 
					          </p>
 | 
				
			||||||
        </div>
 | 
					        </div>
 | 
				
			||||||
 | 
				
			|||||||
@ -15,8 +15,17 @@
 | 
				
			|||||||
      bg-gradient-to-r
 | 
					      bg-gradient-to-r
 | 
				
			||||||
      from-primary-500
 | 
					      from-primary-500
 | 
				
			||||||
      to-primary-400
 | 
					      to-primary-400
 | 
				
			||||||
 | 
					      dark:from-gray-700/70 dark:to-gray-800/70
 | 
				
			||||||
 | 
					      bg-primary-500
 | 
				
			||||||
 | 
					      dark:bg-transparent
 | 
				
			||||||
 | 
					      dark:backdrop-blur-xl
 | 
				
			||||||
 | 
					      dark:shadow-glass
 | 
				
			||||||
 | 
					      dark:border
 | 
				
			||||||
 | 
					      dark:border-white/10
 | 
				
			||||||
    "
 | 
					    "
 | 
				
			||||||
  >
 | 
					  >
 | 
				
			||||||
 | 
					    <BaseDarkHighlight />
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    <router-link
 | 
					    <router-link
 | 
				
			||||||
      to="/admin/dashboard"
 | 
					      to="/admin/dashboard"
 | 
				
			||||||
      class="
 | 
					      class="
 | 
				
			||||||
@ -53,6 +62,7 @@
 | 
				
			|||||||
        cursor-pointer
 | 
					        cursor-pointer
 | 
				
			||||||
        md:hidden md:ml-0
 | 
					        md:hidden md:ml-0
 | 
				
			||||||
        hover:bg-gray-100
 | 
					        hover:bg-gray-100
 | 
				
			||||||
 | 
					        dark:bg-gray-800 dark:border-gray-500 dark:border
 | 
				
			||||||
      "
 | 
					      "
 | 
				
			||||||
      @click.prevent="onToggle"
 | 
					      @click.prevent="onToggle"
 | 
				
			||||||
    >
 | 
					    >
 | 
				
			||||||
@ -64,7 +74,7 @@
 | 
				
			|||||||
        v-if="hasCreateAbilities"
 | 
					        v-if="hasCreateAbilities"
 | 
				
			||||||
        class="relative hidden float-left m-0 md:block"
 | 
					        class="relative hidden float-left m-0 md:block"
 | 
				
			||||||
      >
 | 
					      >
 | 
				
			||||||
        <BaseDropdown width-class="w-48">
 | 
					        <BaseDropdown width-class="w-48" >
 | 
				
			||||||
          <template #activator>
 | 
					          <template #activator>
 | 
				
			||||||
            <div
 | 
					            <div
 | 
				
			||||||
              class="
 | 
					              class="
 | 
				
			||||||
@ -78,19 +88,21 @@
 | 
				
			|||||||
                bg-white
 | 
					                bg-white
 | 
				
			||||||
                rounded
 | 
					                rounded
 | 
				
			||||||
                md:h-9 md:w-9
 | 
					                md:h-9 md:w-9
 | 
				
			||||||
 | 
					                dark:bg-gray-700 dark:border-gray-500 dark:border
 | 
				
			||||||
              "
 | 
					              "
 | 
				
			||||||
            >
 | 
					            >
 | 
				
			||||||
              <BaseIcon name="PlusIcon" class="w-5 h-5 text-gray-600" />
 | 
					              <BaseIcon name="PlusIcon" class="w-5 h-5 text-gray-600 dark:text-white" />
 | 
				
			||||||
            </div>
 | 
					            </div>
 | 
				
			||||||
          </template>
 | 
					          </template>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
          <router-link to="/admin/invoices/create">
 | 
					          <router-link to="/admin/invoices/create">
 | 
				
			||||||
            <BaseDropdownItem
 | 
					            <BaseDropdownItem
 | 
				
			||||||
              v-if="userStore.hasAbilities(abilities.CREATE_INVOICE)"
 | 
					              v-if="userStore.hasAbilities(abilities.CREATE_INVOICE)"
 | 
				
			||||||
 | 
					              v-slot="slotProps"
 | 
				
			||||||
            >
 | 
					            >
 | 
				
			||||||
              <BaseIcon
 | 
					              <BaseIcon
 | 
				
			||||||
                name="DocumentTextIcon"
 | 
					                name="DocumentTextIcon"
 | 
				
			||||||
                class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					                :class="slotProps.class"
 | 
				
			||||||
                aria-hidden="true"
 | 
					                aria-hidden="true"
 | 
				
			||||||
              />
 | 
					              />
 | 
				
			||||||
              {{ $t('invoices.new_invoice') }}
 | 
					              {{ $t('invoices.new_invoice') }}
 | 
				
			||||||
@ -99,10 +111,11 @@
 | 
				
			|||||||
          <router-link to="/admin/estimates/create">
 | 
					          <router-link to="/admin/estimates/create">
 | 
				
			||||||
            <BaseDropdownItem
 | 
					            <BaseDropdownItem
 | 
				
			||||||
              v-if="userStore.hasAbilities(abilities.CREATE_ESTIMATE)"
 | 
					              v-if="userStore.hasAbilities(abilities.CREATE_ESTIMATE)"
 | 
				
			||||||
 | 
					              v-slot="slotProps"
 | 
				
			||||||
            >
 | 
					            >
 | 
				
			||||||
              <BaseIcon
 | 
					              <BaseIcon
 | 
				
			||||||
                name="DocumentIcon"
 | 
					                name="DocumentIcon"
 | 
				
			||||||
                class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					                :class="slotProps.class"
 | 
				
			||||||
                aria-hidden="true"
 | 
					                aria-hidden="true"
 | 
				
			||||||
              />
 | 
					              />
 | 
				
			||||||
              {{ $t('estimates.new_estimate') }}
 | 
					              {{ $t('estimates.new_estimate') }}
 | 
				
			||||||
@ -112,10 +125,11 @@
 | 
				
			|||||||
          <router-link to="/admin/customers/create">
 | 
					          <router-link to="/admin/customers/create">
 | 
				
			||||||
            <BaseDropdownItem
 | 
					            <BaseDropdownItem
 | 
				
			||||||
              v-if="userStore.hasAbilities(abilities.CREATE_CUSTOMER)"
 | 
					              v-if="userStore.hasAbilities(abilities.CREATE_CUSTOMER)"
 | 
				
			||||||
 | 
					              v-slot="slotProps"
 | 
				
			||||||
            >
 | 
					            >
 | 
				
			||||||
              <BaseIcon
 | 
					              <BaseIcon
 | 
				
			||||||
                name="UserIcon"
 | 
					                name="UserIcon"
 | 
				
			||||||
                class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					                :class="slotProps.class"
 | 
				
			||||||
                aria-hidden="true"
 | 
					                aria-hidden="true"
 | 
				
			||||||
              />
 | 
					              />
 | 
				
			||||||
              {{ $t('customers.new_customer') }}
 | 
					              {{ $t('customers.new_customer') }}
 | 
				
			||||||
@ -148,20 +162,20 @@
 | 
				
			|||||||
          </template>
 | 
					          </template>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
          <router-link to="/admin/settings/account-settings">
 | 
					          <router-link to="/admin/settings/account-settings">
 | 
				
			||||||
            <BaseDropdownItem>
 | 
					            <BaseDropdownItem v-slot="slotProps">
 | 
				
			||||||
              <BaseIcon
 | 
					              <BaseIcon
 | 
				
			||||||
                name="CogIcon"
 | 
					                name="CogIcon"
 | 
				
			||||||
                class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					                :class="slotProps.class"
 | 
				
			||||||
                aria-hidden="true"
 | 
					                aria-hidden="true"
 | 
				
			||||||
              />
 | 
					              />
 | 
				
			||||||
              {{ $t('navigation.settings') }}
 | 
					              {{ $t('navigation.settings') }}
 | 
				
			||||||
            </BaseDropdownItem>
 | 
					            </BaseDropdownItem>
 | 
				
			||||||
          </router-link>
 | 
					          </router-link>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
          <BaseDropdownItem @click="logout">
 | 
					          <BaseDropdownItem v-slot="slotProps" @click="logout">
 | 
				
			||||||
            <BaseIcon
 | 
					            <BaseIcon
 | 
				
			||||||
              name="LogoutIcon"
 | 
					              name="LogoutIcon"
 | 
				
			||||||
              class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					              :class="slotProps.class"
 | 
				
			||||||
              aria-hidden="true"
 | 
					              aria-hidden="true"
 | 
				
			||||||
            />
 | 
					            />
 | 
				
			||||||
            {{ $t('navigation.logout') }}
 | 
					            {{ $t('navigation.logout') }}
 | 
				
			||||||
 | 
				
			|||||||
@ -15,7 +15,9 @@
 | 
				
			|||||||
        leave-from="opacity-100"
 | 
					        leave-from="opacity-100"
 | 
				
			||||||
        leave-to="opacity-0"
 | 
					        leave-to="opacity-0"
 | 
				
			||||||
      >
 | 
					      >
 | 
				
			||||||
        <DialogOverlay class="fixed inset-0 bg-gray-600 bg-opacity-75" />
 | 
					        <DialogOverlay
 | 
				
			||||||
 | 
					          class="fixed inset-0 bg-gray-600 bg-opacity-75 dark:bg-gray-900/90"
 | 
				
			||||||
 | 
					        />
 | 
				
			||||||
      </TransitionChild>
 | 
					      </TransitionChild>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
      <TransitionChild
 | 
					      <TransitionChild
 | 
				
			||||||
@ -27,7 +29,9 @@
 | 
				
			|||||||
        leave-from="translate-x-0"
 | 
					        leave-from="translate-x-0"
 | 
				
			||||||
        leave-to="-translate-x-full"
 | 
					        leave-to="-translate-x-full"
 | 
				
			||||||
      >
 | 
					      >
 | 
				
			||||||
        <div class="relative flex flex-col flex-1 w-full max-w-xs bg-white">
 | 
					        <div
 | 
				
			||||||
 | 
					          class="relative flex flex-col flex-1 w-full max-w-xs bg-white dark:bg-gray-800"
 | 
				
			||||||
 | 
					        >
 | 
				
			||||||
          <TransitionChild
 | 
					          <TransitionChild
 | 
				
			||||||
            as="template"
 | 
					            as="template"
 | 
				
			||||||
            enter="ease-in-out duration-300"
 | 
					            enter="ease-in-out duration-300"
 | 
				
			||||||
@ -40,18 +44,17 @@
 | 
				
			|||||||
            <div class="absolute top-0 right-0 pt-2 -mr-12">
 | 
					            <div class="absolute top-0 right-0 pt-2 -mr-12">
 | 
				
			||||||
              <button
 | 
					              <button
 | 
				
			||||||
                class="
 | 
					                class="
 | 
				
			||||||
                  flex
 | 
					                flex
 | 
				
			||||||
                  items-center
 | 
					                items-center
 | 
				
			||||||
                  justify-center
 | 
					                justify-center
 | 
				
			||||||
                  w-10
 | 
					                w-10
 | 
				
			||||||
                  h-10
 | 
					                h-10
 | 
				
			||||||
                  ml-1
 | 
					                ml-1
 | 
				
			||||||
                  rounded-full
 | 
					                rounded-full
 | 
				
			||||||
                  focus:outline-none
 | 
					                focus:outline-none
 | 
				
			||||||
                  focus:ring-2
 | 
					                focus:ring-2
 | 
				
			||||||
                  focus:ring-inset
 | 
					                focus:ring-inset
 | 
				
			||||||
                  focus:ring-white
 | 
					                focus:ring-white"
 | 
				
			||||||
                "
 | 
					 | 
				
			||||||
                @click="globalStore.setSidebarVisibility(false)"
 | 
					                @click="globalStore.setSidebarVisibility(false)"
 | 
				
			||||||
              >
 | 
					              >
 | 
				
			||||||
                <span class="sr-only">Close sidebar</span>
 | 
					                <span class="sr-only">Close sidebar</span>
 | 
				
			||||||
@ -82,8 +85,8 @@
 | 
				
			|||||||
                :to="item.link"
 | 
					                :to="item.link"
 | 
				
			||||||
                :class="[
 | 
					                :class="[
 | 
				
			||||||
                  hasActiveUrl(item.link)
 | 
					                  hasActiveUrl(item.link)
 | 
				
			||||||
                    ? 'text-primary-500 border-primary-500 bg-gray-100 '
 | 
					                    ? 'text-primary-500 border-primary-500 bg-gray-100 dark:shadow-glass dark:backdrop-blur-xl dark:hover:bg-gray-700  dark:bg-gray-700/50 dark:text-primary-400 dark:font-medium'
 | 
				
			||||||
                    : 'text-black',
 | 
					                    : 'text-black dark:text-gray-300',
 | 
				
			||||||
                  'cursor-pointer px-0 pl-4 py-3 border-transparent flex items-center border-l-4 border-solid text-sm not-italic font-medium',
 | 
					                  'cursor-pointer px-0 pl-4 py-3 border-transparent flex items-center border-l-4 border-solid text-sm not-italic font-medium',
 | 
				
			||||||
                ]"
 | 
					                ]"
 | 
				
			||||||
                @click="globalStore.setSidebarVisibility(false)"
 | 
					                @click="globalStore.setSidebarVisibility(false)"
 | 
				
			||||||
@ -100,6 +103,10 @@
 | 
				
			|||||||
                />
 | 
					                />
 | 
				
			||||||
                {{ $t(item.title) }}
 | 
					                {{ $t(item.title) }}
 | 
				
			||||||
              </router-link>
 | 
					              </router-link>
 | 
				
			||||||
 | 
					              <LightDarkSwitch
 | 
				
			||||||
 | 
					                :show-label="false"
 | 
				
			||||||
 | 
					                class="absolute right-6 top-6 !w-auto"
 | 
				
			||||||
 | 
					              />
 | 
				
			||||||
            </nav>
 | 
					            </nav>
 | 
				
			||||||
          </div>
 | 
					          </div>
 | 
				
			||||||
        </div>
 | 
					        </div>
 | 
				
			||||||
@ -113,17 +120,16 @@
 | 
				
			|||||||
  <!-- DESKTOP MENU -->
 | 
					  <!-- DESKTOP MENU -->
 | 
				
			||||||
  <div
 | 
					  <div
 | 
				
			||||||
    class="
 | 
					    class="
 | 
				
			||||||
      hidden
 | 
					    hidden
 | 
				
			||||||
      w-56
 | 
					    w-56
 | 
				
			||||||
      h-screen
 | 
					    h-screen
 | 
				
			||||||
      pb-32
 | 
					    bg-white
 | 
				
			||||||
      overflow-y-auto
 | 
					    border-r border-gray-200 border-solid
 | 
				
			||||||
      bg-white
 | 
					    xl:w-64
 | 
				
			||||||
      border-r border-gray-200 border-solid
 | 
					    md:fixed md:flex md:flex-col md:inset-y-0
 | 
				
			||||||
      xl:w-64
 | 
					    pt-16
 | 
				
			||||||
      md:fixed md:flex md:flex-col md:inset-y-0
 | 
					    dark:border-gray-800
 | 
				
			||||||
      pt-16
 | 
					    dark:bg-gray-800/80"
 | 
				
			||||||
    "
 | 
					 | 
				
			||||||
  >
 | 
					  >
 | 
				
			||||||
    <div
 | 
					    <div
 | 
				
			||||||
      v-for="menu in globalStore.menuGroups"
 | 
					      v-for="menu in globalStore.menuGroups"
 | 
				
			||||||
@ -136,8 +142,8 @@
 | 
				
			|||||||
        :to="item.link"
 | 
					        :to="item.link"
 | 
				
			||||||
        :class="[
 | 
					        :class="[
 | 
				
			||||||
          hasActiveUrl(item.link)
 | 
					          hasActiveUrl(item.link)
 | 
				
			||||||
            ? 'text-primary-500 border-primary-500 bg-gray-100 '
 | 
					            ? 'text-primary-500 border-primary-500 bg-gray-100 dark:border-primary-400 dark:shadow-glass dark:backdrop-blur-xl dark:hover:bg-gray-700 dark:bg-gray-700/50 dark:text-primary-400 dark:font-medium'
 | 
				
			||||||
            : 'text-black',
 | 
					            : 'text-black dark:hover:bg-transparent dark:hover:text-white dark:text-gray-300',
 | 
				
			||||||
          'cursor-pointer px-0 pl-6 hover:bg-gray-50 py-3 group flex items-center border-l-4 border-solid border-transparent text-sm not-italic font-medium',
 | 
					          'cursor-pointer px-0 pl-6 hover:bg-gray-50 py-3 group flex items-center border-l-4 border-solid border-transparent text-sm not-italic font-medium',
 | 
				
			||||||
        ]"
 | 
					        ]"
 | 
				
			||||||
      >
 | 
					      >
 | 
				
			||||||
@ -145,8 +151,8 @@
 | 
				
			|||||||
          :name="item.icon"
 | 
					          :name="item.icon"
 | 
				
			||||||
          :class="[
 | 
					          :class="[
 | 
				
			||||||
            hasActiveUrl(item.link)
 | 
					            hasActiveUrl(item.link)
 | 
				
			||||||
              ? 'text-primary-500 group-hover:text-primary-500 '
 | 
					              ? 'text-primary-500 group-hover:text-primary-500 dark:text-primary-400 dark:group-hover:text-primary-500 '
 | 
				
			||||||
              : 'text-gray-400 group-hover:text-black',
 | 
					              : 'text-gray-400 group-hover:text-black dark:text-gray-400 dark:group-hover:text-white',
 | 
				
			||||||
            'mr-4 shrink-0 h-5 w-5 ',
 | 
					            'mr-4 shrink-0 h-5 w-5 ',
 | 
				
			||||||
          ]"
 | 
					          ]"
 | 
				
			||||||
        />
 | 
					        />
 | 
				
			||||||
@ -154,6 +160,9 @@
 | 
				
			|||||||
        {{ $t(item.title) }}
 | 
					        {{ $t(item.title) }}
 | 
				
			||||||
      </router-link>
 | 
					      </router-link>
 | 
				
			||||||
    </div>
 | 
					    </div>
 | 
				
			||||||
 | 
					    <LightDarkSwitch
 | 
				
			||||||
 | 
					      class="absolute bottom-0 py-4 border-t border-gray-200 dark:border-gray-700"
 | 
				
			||||||
 | 
					    />
 | 
				
			||||||
  </div>
 | 
					  </div>
 | 
				
			||||||
</template>
 | 
					</template>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@ -169,6 +178,7 @@ import {
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
import { useRoute } from 'vue-router'
 | 
					import { useRoute } from 'vue-router'
 | 
				
			||||||
import { useGlobalStore } from '@/scripts/admin/stores/global'
 | 
					import { useGlobalStore } from '@/scripts/admin/stores/global'
 | 
				
			||||||
 | 
					import LightDarkSwitch from '@/scripts/components/LightDarkSwitcher.vue'
 | 
				
			||||||
 | 
					
 | 
				
			||||||
const route = useRoute()
 | 
					const route = useRoute()
 | 
				
			||||||
const globalStore = useGlobalStore()
 | 
					const globalStore = useGlobalStore()
 | 
				
			||||||
 | 
				
			|||||||
@ -184,6 +184,20 @@ export const useCompanyStore = (useWindow = false) => {
 | 
				
			|||||||
      setDefaultCurrency(data) {
 | 
					      setDefaultCurrency(data) {
 | 
				
			||||||
        this.defaultCurrency = data.currency
 | 
					        this.defaultCurrency = data.currency
 | 
				
			||||||
      },
 | 
					      },
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      checkCompanyHasCurrencyTransactions() {
 | 
				
			||||||
 | 
					        return new Promise((resolve, reject) => {
 | 
				
			||||||
 | 
					          axios
 | 
				
			||||||
 | 
					            .get(`/api/v1/company/has-transactions`)
 | 
				
			||||||
 | 
					            .then((response) => {
 | 
				
			||||||
 | 
					              resolve(response)
 | 
				
			||||||
 | 
					            })
 | 
				
			||||||
 | 
					            .catch((err) => {
 | 
				
			||||||
 | 
					              handleError(err)
 | 
				
			||||||
 | 
					              reject(err)
 | 
				
			||||||
 | 
					            })
 | 
				
			||||||
 | 
					        })
 | 
				
			||||||
 | 
					      },
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
  })()
 | 
					  })()
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
				
			|||||||
@ -34,6 +34,7 @@ export const useGlobalStore = (useWindow = false) => {
 | 
				
			|||||||
      isAppLoaded: false,
 | 
					      isAppLoaded: false,
 | 
				
			||||||
      isSidebarOpen: false,
 | 
					      isSidebarOpen: false,
 | 
				
			||||||
      areCurrenciesLoading: false,
 | 
					      areCurrenciesLoading: false,
 | 
				
			||||||
 | 
					      isDarkModeOn: false,
 | 
				
			||||||
 | 
					
 | 
				
			||||||
      downloadReport: null,
 | 
					      downloadReport: null,
 | 
				
			||||||
    }),
 | 
					    }),
 | 
				
			||||||
@ -70,8 +71,8 @@ export const useGlobalStore = (useWindow = false) => {
 | 
				
			|||||||
              moduleStore.apiToken = response.data.global_settings.api_token
 | 
					              moduleStore.apiToken = response.data.global_settings.api_token
 | 
				
			||||||
              moduleStore.enableModules = response.data.modules
 | 
					              moduleStore.enableModules = response.data.modules
 | 
				
			||||||
 | 
					
 | 
				
			||||||
                // company store
 | 
					              // company store
 | 
				
			||||||
                companyStore.companies = response.data.companies
 | 
					              companyStore.companies = response.data.companies
 | 
				
			||||||
              companyStore.selectedCompany = response.data.current_company
 | 
					              companyStore.selectedCompany = response.data.current_company
 | 
				
			||||||
              companyStore.setSelectedCompany(response.data.current_company)
 | 
					              companyStore.setSelectedCompany(response.data.current_company)
 | 
				
			||||||
              companyStore.selectedCompanySettings =
 | 
					              companyStore.selectedCompanySettings =
 | 
				
			||||||
 | 
				
			|||||||
@ -171,7 +171,7 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
          <BaseInputGrid class="col-span-5 lg:col-span-4">
 | 
					          <BaseInputGrid class="col-span-5 lg:col-span-4">
 | 
				
			||||||
            <div class="md:col-span-2">
 | 
					            <div class="md:col-span-2">
 | 
				
			||||||
              <p class="text-sm text-gray-500">
 | 
					              <p class="text-sm text-gray-500 dark:text-gray-300">
 | 
				
			||||||
                {{ $t('customers.portal_access_text') }}
 | 
					                {{ $t('customers.portal_access_text') }}
 | 
				
			||||||
              </p>
 | 
					              </p>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
				
			|||||||
@ -1,5 +1,5 @@
 | 
				
			|||||||
<template>
 | 
					<template>
 | 
				
			||||||
  <div class="pt-6 mt-5 border-t border-solid lg:pt-8 md:pt-4 border-gray-200">
 | 
					  <div class="pt-6 mt-5 border-t border-solid lg:pt-8 md:pt-4 border-gray-200 dark:border-gray-600">
 | 
				
			||||||
    <!-- Basic Info -->
 | 
					    <!-- Basic Info -->
 | 
				
			||||||
    <BaseHeading>
 | 
					    <BaseHeading>
 | 
				
			||||||
      {{ $t('customers.basic_info') }}
 | 
					      {{ $t('customers.basic_info') }}
 | 
				
			||||||
 | 
				
			|||||||
@ -2,8 +2,23 @@
 | 
				
			|||||||
  <div>
 | 
					  <div>
 | 
				
			||||||
    <div
 | 
					    <div
 | 
				
			||||||
      v-if="dashboardStore.isDashboardDataLoaded"
 | 
					      v-if="dashboardStore.isDashboardDataLoaded"
 | 
				
			||||||
      class="grid grid-cols-10 mt-8 bg-white rounded shadow"
 | 
					      class="
 | 
				
			||||||
 | 
					        grid
 | 
				
			||||||
 | 
					        grid-cols-10
 | 
				
			||||||
 | 
					        mt-8
 | 
				
			||||||
 | 
					        bg-white
 | 
				
			||||||
 | 
					        rounded shadow
 | 
				
			||||||
 | 
					        dark:text-white
 | 
				
			||||||
 | 
					        dark:backdrop-blur-xl
 | 
				
			||||||
 | 
					        dark:shadow-glass
 | 
				
			||||||
 | 
					        dark:border
 | 
				
			||||||
 | 
					        dark:bg-opacity-70
 | 
				
			||||||
 | 
					        dark:border-white/10
 | 
				
			||||||
 | 
					        dark:bg-gray-800
 | 
				
			||||||
 | 
					        relative
 | 
				
			||||||
 | 
					      "
 | 
				
			||||||
    >
 | 
					    >
 | 
				
			||||||
 | 
					      <BaseDarkHighlight />
 | 
				
			||||||
      <!-- Chart -->
 | 
					      <!-- Chart -->
 | 
				
			||||||
      <div
 | 
					      <div
 | 
				
			||||||
        class="
 | 
					        class="
 | 
				
			||||||
@ -54,6 +69,7 @@
 | 
				
			|||||||
          lg:border-t-0 lg:text-right lg:col-span-3
 | 
					          lg:border-t-0 lg:text-right lg:col-span-3
 | 
				
			||||||
          xl:col-span-2
 | 
					          xl:col-span-2
 | 
				
			||||||
          lg:grid-cols-1
 | 
					          lg:grid-cols-1
 | 
				
			||||||
 | 
					          dark:border-white/10
 | 
				
			||||||
        "
 | 
					        "
 | 
				
			||||||
      >
 | 
					      >
 | 
				
			||||||
        <div class="p-6">
 | 
					        <div class="p-6">
 | 
				
			||||||
@ -96,15 +112,7 @@
 | 
				
			|||||||
          </span>
 | 
					          </span>
 | 
				
			||||||
          <br />
 | 
					          <br />
 | 
				
			||||||
          <span
 | 
					          <span
 | 
				
			||||||
            class="
 | 
					            class="block mt-1 text-xl font-semibold leading-8 lg:text-2xl text-red-400"
 | 
				
			||||||
              block
 | 
					 | 
				
			||||||
              mt-1
 | 
					 | 
				
			||||||
              text-xl
 | 
					 | 
				
			||||||
              font-semibold
 | 
					 | 
				
			||||||
              leading-8
 | 
					 | 
				
			||||||
              lg:text-2xl
 | 
					 | 
				
			||||||
              text-red-400
 | 
					 | 
				
			||||||
            "
 | 
					 | 
				
			||||||
          >
 | 
					          >
 | 
				
			||||||
            <BaseFormatMoney
 | 
					            <BaseFormatMoney
 | 
				
			||||||
              :amount="dashboardStore.totalExpenses"
 | 
					              :amount="dashboardStore.totalExpenses"
 | 
				
			||||||
@ -116,8 +124,10 @@
 | 
				
			|||||||
          class="
 | 
					          class="
 | 
				
			||||||
            col-span-3
 | 
					            col-span-3
 | 
				
			||||||
            p-6
 | 
					            p-6
 | 
				
			||||||
            border-t border-gray-200 border-solid
 | 
					            border-t
 | 
				
			||||||
 | 
					            border-gray-200 border-solid
 | 
				
			||||||
            lg:col-span-1
 | 
					            lg:col-span-1
 | 
				
			||||||
 | 
					            dark:border-white/10
 | 
				
			||||||
          "
 | 
					          "
 | 
				
			||||||
        >
 | 
					        >
 | 
				
			||||||
          <span class="text-xs leading-5 lg:text-sm">
 | 
					          <span class="text-xs leading-5 lg:text-sm">
 | 
				
			||||||
@ -132,7 +142,7 @@
 | 
				
			|||||||
              font-semibold
 | 
					              font-semibold
 | 
				
			||||||
              leading-8
 | 
					              leading-8
 | 
				
			||||||
              lg:text-2xl
 | 
					              lg:text-2xl
 | 
				
			||||||
              text-primary-500
 | 
					              text-primary-500 dark:text-primary-400
 | 
				
			||||||
            "
 | 
					            "
 | 
				
			||||||
          >
 | 
					          >
 | 
				
			||||||
            <BaseFormatMoney
 | 
					            <BaseFormatMoney
 | 
				
			||||||
 | 
				
			|||||||
@ -1,6 +1,6 @@
 | 
				
			|||||||
<template>
 | 
					<template>
 | 
				
			||||||
  <BaseContentPlaceholders
 | 
					  <BaseContentPlaceholders
 | 
				
			||||||
    class="grid grid-cols-10 mt-8 bg-white rounded shadow"
 | 
					    class="grid grid-cols-10 mt-8 bg-white rounded shadow dark:bg-gray-800"
 | 
				
			||||||
  >
 | 
					  >
 | 
				
			||||||
    <!-- Chart -->
 | 
					    <!-- Chart -->
 | 
				
			||||||
    <div
 | 
					    <div
 | 
				
			||||||
@ -29,6 +29,7 @@
 | 
				
			|||||||
        text-center
 | 
					        text-center
 | 
				
			||||||
        border-t border-l border-gray-200 border-solid
 | 
					        border-t border-l border-gray-200 border-solid
 | 
				
			||||||
        lg:border-t-0 lg:text-right lg:col-span-3
 | 
					        lg:border-t-0 lg:text-right lg:col-span-3
 | 
				
			||||||
 | 
					        dark:border-gray-600
 | 
				
			||||||
        xl:col-span-2
 | 
					        xl:col-span-2
 | 
				
			||||||
        lg:grid-cols-1
 | 
					        lg:grid-cols-1
 | 
				
			||||||
      "
 | 
					      "
 | 
				
			||||||
@ -77,6 +78,7 @@
 | 
				
			|||||||
          col-span-3
 | 
					          col-span-3
 | 
				
			||||||
          p-6
 | 
					          p-6
 | 
				
			||||||
          border-t border-gray-200 border-solid
 | 
					          border-t border-gray-200 border-solid
 | 
				
			||||||
 | 
					          dark:border-gray-600
 | 
				
			||||||
          lg:justify-end lg:items-end lg:col-span-1
 | 
					          lg:justify-end lg:items-end lg:col-span-1
 | 
				
			||||||
        "
 | 
					        "
 | 
				
			||||||
      >
 | 
					      >
 | 
				
			||||||
 | 
				
			|||||||
@ -12,18 +12,24 @@
 | 
				
			|||||||
      hover:bg-gray-50
 | 
					      hover:bg-gray-50
 | 
				
			||||||
      xl:p-4
 | 
					      xl:p-4
 | 
				
			||||||
      lg:col-span-2
 | 
					      lg:col-span-2
 | 
				
			||||||
 | 
					      dark:backdrop-blur-xl
 | 
				
			||||||
 | 
					      dark:shadow-glass
 | 
				
			||||||
 | 
					      dark:border
 | 
				
			||||||
 | 
					      dark:border-white/10
 | 
				
			||||||
 | 
					      dark:bg-gray-800/70
 | 
				
			||||||
    "
 | 
					    "
 | 
				
			||||||
    :class="{ 'lg:!col-span-3': large }"
 | 
					    :class="{ 'lg:!col-span-3': large }"
 | 
				
			||||||
    :to="route"
 | 
					    :to="route"
 | 
				
			||||||
  >
 | 
					  >
 | 
				
			||||||
    <div>
 | 
					    <div>
 | 
				
			||||||
      <span class="text-xl font-semibold leading-tight text-black xl:text-3xl">
 | 
					      <span class="text-xl font-semibold leading-tight text-black xl:text-3xl dark:text-white">
 | 
				
			||||||
        <slot />
 | 
					        <slot />
 | 
				
			||||||
      </span>
 | 
					      </span>
 | 
				
			||||||
      <span class="block mt-1 text-sm leading-tight text-gray-500 xl:text-lg">
 | 
					      <span class="block mt-1 text-sm leading-tight text-gray-500 xl:text-lg dark:text-gray-300">
 | 
				
			||||||
        {{ label }}
 | 
					        {{ label }}
 | 
				
			||||||
      </span>
 | 
					      </span>
 | 
				
			||||||
    </div>
 | 
					    </div>
 | 
				
			||||||
 | 
					    <BaseDarkHighlight class="!bg-highlight/[.17] !top-5" />
 | 
				
			||||||
    <div class="flex items-center">
 | 
					    <div class="flex items-center">
 | 
				
			||||||
      <component :is="iconComponent" class="w-10 h-10 xl:w-12 xl:h-12" />
 | 
					      <component :is="iconComponent" class="w-10 h-10 xl:w-12 xl:h-12" />
 | 
				
			||||||
    </div>
 | 
					    </div>
 | 
				
			||||||
 | 
				
			|||||||
@ -1,7 +1,7 @@
 | 
				
			|||||||
<template>
 | 
					<template>
 | 
				
			||||||
  <BaseContentPlaceholders
 | 
					  <BaseContentPlaceholders
 | 
				
			||||||
    :rounded="true"
 | 
					    :rounded="true"
 | 
				
			||||||
    class="relative flex justify-between w-full p-3 bg-white rounded shadow lg:col-span-3 xl:p-4"
 | 
					    class="relative flex justify-between w-full p-3 bg-white rounded shadow lg:col-span-3 xl:p-4 dark:bg-gray-800"
 | 
				
			||||||
  >
 | 
					  >
 | 
				
			||||||
    <div>
 | 
					    <div>
 | 
				
			||||||
      <BaseContentPlaceholdersText
 | 
					      <BaseContentPlaceholdersText
 | 
				
			||||||
 | 
				
			|||||||
@ -12,6 +12,7 @@
 | 
				
			|||||||
      shadow
 | 
					      shadow
 | 
				
			||||||
      lg:col-span-2
 | 
					      lg:col-span-2
 | 
				
			||||||
      xl:p-4
 | 
					      xl:p-4
 | 
				
			||||||
 | 
					      dark:bg-gray-800
 | 
				
			||||||
    "
 | 
					    "
 | 
				
			||||||
  >
 | 
					  >
 | 
				
			||||||
    <div>
 | 
					    <div>
 | 
				
			||||||
 | 
				
			|||||||
@ -130,6 +130,7 @@
 | 
				
			|||||||
          mt-5
 | 
					          mt-5
 | 
				
			||||||
          list-none
 | 
					          list-none
 | 
				
			||||||
          border-b-2 border-gray-200 border-solid
 | 
					          border-b-2 border-gray-200 border-solid
 | 
				
			||||||
 | 
					          dark:border-gray-600
 | 
				
			||||||
        "
 | 
					        "
 | 
				
			||||||
      >
 | 
					      >
 | 
				
			||||||
        <!-- Tabs -->
 | 
					        <!-- Tabs -->
 | 
				
			||||||
 | 
				
			|||||||
@ -32,6 +32,8 @@
 | 
				
			|||||||
          :content-loading="isLoading"
 | 
					          :content-loading="isLoading"
 | 
				
			||||||
          :calendar-button="true"
 | 
					          :calendar-button="true"
 | 
				
			||||||
          calendar-button-icon="calendar"
 | 
					          calendar-button-icon="calendar"
 | 
				
			||||||
 | 
					          :show-extra-options="true"
 | 
				
			||||||
 | 
					          :source-date="estimateStore.newEstimate.estimate_date"
 | 
				
			||||||
        />
 | 
					        />
 | 
				
			||||||
      </BaseInputGroup>
 | 
					      </BaseInputGroup>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
				
			|||||||
@ -34,6 +34,24 @@
 | 
				
			|||||||
          />
 | 
					          />
 | 
				
			||||||
        </BaseInputGroup>
 | 
					        </BaseInputGroup>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        <BaseInputGroup
 | 
				
			||||||
 | 
					          :label="$tc('wizard.company_slug')"
 | 
				
			||||||
 | 
					          :help-text="$t('wizard.company_slug_help_text')"
 | 
				
			||||||
 | 
					          :error="
 | 
				
			||||||
 | 
					            v$.companyForm.slug.$error &&
 | 
				
			||||||
 | 
					            v$.companyForm.slug.$errors[0].$message
 | 
				
			||||||
 | 
					          "
 | 
				
			||||||
 | 
					          required
 | 
				
			||||||
 | 
					        >
 | 
				
			||||||
 | 
					          <BaseInput
 | 
				
			||||||
 | 
					            v-model="companyForm.slug"
 | 
				
			||||||
 | 
					            :invalid="v$.companyForm.slug.$error"
 | 
				
			||||||
 | 
					            type="text"
 | 
				
			||||||
 | 
					            name="slug"
 | 
				
			||||||
 | 
					            @input="v$.companyForm.slug.$touch()"
 | 
				
			||||||
 | 
					          />
 | 
				
			||||||
 | 
					        </BaseInputGroup>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        <BaseInputGroup
 | 
					        <BaseInputGroup
 | 
				
			||||||
          :label="$t('wizard.country')"
 | 
					          :label="$t('wizard.country')"
 | 
				
			||||||
          :error="
 | 
					          :error="
 | 
				
			||||||
@ -57,9 +75,7 @@
 | 
				
			|||||||
            track-by="name"
 | 
					            track-by="name"
 | 
				
			||||||
          />
 | 
					          />
 | 
				
			||||||
        </BaseInputGroup>
 | 
					        </BaseInputGroup>
 | 
				
			||||||
      </div>
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
      <div class="grid grid-cols-1 gap-4 mb-4 md:grid-cols-2 md:mb-6">
 | 
					 | 
				
			||||||
        <BaseInputGroup :label="$t('wizard.state')">
 | 
					        <BaseInputGroup :label="$t('wizard.state')">
 | 
				
			||||||
          <BaseInput
 | 
					          <BaseInput
 | 
				
			||||||
            v-model="companyForm.address.state"
 | 
					            v-model="companyForm.address.state"
 | 
				
			||||||
@ -144,9 +160,9 @@
 | 
				
			|||||||
</template>
 | 
					</template>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
<script setup>
 | 
					<script setup>
 | 
				
			||||||
import { ref, computed, onMounted, reactive } from 'vue'
 | 
					import { ref, computed, onMounted, reactive, watch } from 'vue'
 | 
				
			||||||
import { useI18n } from 'vue-i18n'
 | 
					import { useI18n } from 'vue-i18n'
 | 
				
			||||||
import { required, maxLength, helpers } from '@vuelidate/validators'
 | 
					import { required, minLength, maxLength, helpers } from '@vuelidate/validators'
 | 
				
			||||||
import { useVuelidate } from '@vuelidate/core'
 | 
					import { useVuelidate } from '@vuelidate/core'
 | 
				
			||||||
import { useGlobalStore } from '@/scripts/admin/stores/global'
 | 
					import { useGlobalStore } from '@/scripts/admin/stores/global'
 | 
				
			||||||
import { useCompanyStore } from '@/scripts/admin/stores/company'
 | 
					import { useCompanyStore } from '@/scripts/admin/stores/company'
 | 
				
			||||||
@ -162,6 +178,7 @@ let logoFileName = ref(null)
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
const companyForm = reactive({
 | 
					const companyForm = reactive({
 | 
				
			||||||
  name: null,
 | 
					  name: null,
 | 
				
			||||||
 | 
					  slug: null,
 | 
				
			||||||
  address: {
 | 
					  address: {
 | 
				
			||||||
    address_street_1: '',
 | 
					    address_street_1: '',
 | 
				
			||||||
    address_street_2: '',
 | 
					    address_street_2: '',
 | 
				
			||||||
@ -188,10 +205,28 @@ onMounted(async () => {
 | 
				
			|||||||
  })?.id
 | 
					  })?.id
 | 
				
			||||||
})
 | 
					})
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					const slugValidator = (value) => {
 | 
				
			||||||
 | 
					  return value == slugify(value)
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
const rules = {
 | 
					const rules = {
 | 
				
			||||||
  companyForm: {
 | 
					  companyForm: {
 | 
				
			||||||
    name: {
 | 
					    name: {
 | 
				
			||||||
      required: helpers.withMessage(t('validation.required'), required),
 | 
					      required: helpers.withMessage(t('validation.required'), required),
 | 
				
			||||||
 | 
					      minLength: helpers.withMessage(
 | 
				
			||||||
 | 
					        t('validation.name_min_length', { count: 3 }),
 | 
				
			||||||
 | 
					        minLength(3)
 | 
				
			||||||
 | 
					      ),
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    slug: {
 | 
				
			||||||
 | 
					      required: helpers.withMessage(t('validation.required'), required),
 | 
				
			||||||
 | 
					      minLength: helpers.withMessage(
 | 
				
			||||||
 | 
					        t('validation.name_min_length', { count: 3 }),
 | 
				
			||||||
 | 
					        minLength(3)
 | 
				
			||||||
 | 
					      ),
 | 
				
			||||||
 | 
					      slugValidator: helpers.withMessage(
 | 
				
			||||||
 | 
					        t('validation.invalid_slug'),
 | 
				
			||||||
 | 
					        slugValidator
 | 
				
			||||||
 | 
					      ),
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    address: {
 | 
					    address: {
 | 
				
			||||||
      country_id: {
 | 
					      country_id: {
 | 
				
			||||||
@ -249,4 +284,24 @@ async function next() {
 | 
				
			|||||||
    emit('next', 7)
 | 
					    emit('next', 7)
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					// watcher for if change company name then auto fill company slug value
 | 
				
			||||||
 | 
					watch(
 | 
				
			||||||
 | 
					  () => companyForm.name,
 | 
				
			||||||
 | 
					  (currentValue) => {
 | 
				
			||||||
 | 
					    companyForm.slug = slugify(currentValue)
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					function slugify(string) {
 | 
				
			||||||
 | 
					  return string
 | 
				
			||||||
 | 
					    .toString()
 | 
				
			||||||
 | 
					    .trim()
 | 
				
			||||||
 | 
					    .toLowerCase()
 | 
				
			||||||
 | 
					    .replace(/\s+/g, '-')
 | 
				
			||||||
 | 
					    .replace(/[^\w\-]+/g, '')
 | 
				
			||||||
 | 
					    .replace(/\-\-+/g, '-')
 | 
				
			||||||
 | 
					    .replace(/^-+/, '')
 | 
				
			||||||
 | 
					    .replace(/-+$/, '')
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
</script>
 | 
					</script>
 | 
				
			||||||
 | 
				
			|||||||
@ -56,7 +56,7 @@
 | 
				
			|||||||
        <BaseMultiselect
 | 
					        <BaseMultiselect
 | 
				
			||||||
          v-model="filters.status"
 | 
					          v-model="filters.status"
 | 
				
			||||||
          :groups="true"
 | 
					          :groups="true"
 | 
				
			||||||
          :options="status"
 | 
					          :options="invoiceStatus"
 | 
				
			||||||
          searchable
 | 
					          searchable
 | 
				
			||||||
          :placeholder="$t('general.select_a_status')"
 | 
					          :placeholder="$t('general.select_a_status')"
 | 
				
			||||||
          @update:modelValue="setActiveTab"
 | 
					          @update:modelValue="setActiveTab"
 | 
				
			||||||
@ -127,14 +127,31 @@
 | 
				
			|||||||
          mt-5
 | 
					          mt-5
 | 
				
			||||||
          list-none
 | 
					          list-none
 | 
				
			||||||
          border-b-2 border-gray-200 border-solid
 | 
					          border-b-2 border-gray-200 border-solid
 | 
				
			||||||
 | 
					          dark:border-gray-600
 | 
				
			||||||
        "
 | 
					        "
 | 
				
			||||||
      >
 | 
					      >
 | 
				
			||||||
        <!-- Tabs -->
 | 
					        <!-- Tabs -->
 | 
				
			||||||
        <BaseTabGroup class="-mb-5" @change="setStatusFilter">
 | 
					        <BaseTabGroup
 | 
				
			||||||
          <BaseTab :title="$t('general.all')" filter="" />
 | 
					          class="-mb-5"
 | 
				
			||||||
          <BaseTab :title="$t('general.draft')" filter="DRAFT" />
 | 
					          :selected-index="selectedIndex"
 | 
				
			||||||
          <BaseTab :title="$t('general.sent')" filter="SENT" />
 | 
					          @change="changeTabStatus"
 | 
				
			||||||
          <BaseTab :title="$t('general.due')" filter="DUE" />
 | 
					        >
 | 
				
			||||||
 | 
					          <BaseTab
 | 
				
			||||||
 | 
					            :title="invoiceTabStatus[0].title"
 | 
				
			||||||
 | 
					            :tab-status="invoiceTabStatus[0].value"
 | 
				
			||||||
 | 
					          />
 | 
				
			||||||
 | 
					          <BaseTab
 | 
				
			||||||
 | 
					            :title="invoiceTabStatus[1].title"
 | 
				
			||||||
 | 
					            :tab-status="invoiceTabStatus[1].value"
 | 
				
			||||||
 | 
					          />
 | 
				
			||||||
 | 
					          <BaseTab
 | 
				
			||||||
 | 
					            :title="invoiceTabStatus[2].title"
 | 
				
			||||||
 | 
					            :tab-status="invoiceTabStatus[2].value"
 | 
				
			||||||
 | 
					          />
 | 
				
			||||||
 | 
					          <BaseTab
 | 
				
			||||||
 | 
					            :title="invoiceTabStatus[3].title"
 | 
				
			||||||
 | 
					            :tab-status="invoiceTabStatus[3].value"
 | 
				
			||||||
 | 
					          />
 | 
				
			||||||
        </BaseTabGroup>
 | 
					        </BaseTabGroup>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        <BaseDropdown
 | 
					        <BaseDropdown
 | 
				
			||||||
@ -289,10 +306,10 @@ const utils = inject('$utils')
 | 
				
			|||||||
const table = ref(null)
 | 
					const table = ref(null)
 | 
				
			||||||
const showFilters = ref(false)
 | 
					const showFilters = ref(false)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
const status = ref([
 | 
					const invoiceStatus = ref([
 | 
				
			||||||
  {
 | 
					  {
 | 
				
			||||||
    label: 'Status',
 | 
					    label: 'Status',
 | 
				
			||||||
    options: ['DRAFT', 'DUE', 'SENT', 'VIEWED', 'COMPLETED'],
 | 
					    options: ['DRAFT', 'SENT', 'VIEWED', 'COMPLETED'],
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
  {
 | 
					  {
 | 
				
			||||||
    label: 'Paid Status',
 | 
					    label: 'Paid Status',
 | 
				
			||||||
@ -300,10 +317,29 @@ const status = ref([
 | 
				
			|||||||
  },
 | 
					  },
 | 
				
			||||||
  ,
 | 
					  ,
 | 
				
			||||||
])
 | 
					])
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					const invoiceTabStatus = {
 | 
				
			||||||
 | 
					  0: {
 | 
				
			||||||
 | 
					    title: t('general.all'),
 | 
				
			||||||
 | 
					    value: '',
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  1: {
 | 
				
			||||||
 | 
					    title: t('general.draft'),
 | 
				
			||||||
 | 
					    value: 'DRAFT',
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  2: {
 | 
				
			||||||
 | 
					    title: t('general.sent'),
 | 
				
			||||||
 | 
					    value: 'SENT',
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  3: {
 | 
				
			||||||
 | 
					    title: t('general.due'),
 | 
				
			||||||
 | 
					    value: 'DUE',
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
const isRequestOngoing = ref(true)
 | 
					const isRequestOngoing = ref(true)
 | 
				
			||||||
const activeTab = ref('general.draft')
 | 
					 | 
				
			||||||
const router = useRouter()
 | 
					const router = useRouter()
 | 
				
			||||||
const userStore = useUserStore()
 | 
					const userStore = useUserStore()
 | 
				
			||||||
 | 
					const selectedIndex = ref(0)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
let filters = reactive({
 | 
					let filters = reactive({
 | 
				
			||||||
  customer_id: '',
 | 
					  customer_id: '',
 | 
				
			||||||
@ -311,6 +347,7 @@ let filters = reactive({
 | 
				
			|||||||
  from_date: '',
 | 
					  from_date: '',
 | 
				
			||||||
  to_date: '',
 | 
					  to_date: '',
 | 
				
			||||||
  invoice_number: '',
 | 
					  invoice_number: '',
 | 
				
			||||||
 | 
					  tab_status: '',
 | 
				
			||||||
})
 | 
					})
 | 
				
			||||||
 | 
					
 | 
				
			||||||
const showEmptyScreen = computed(
 | 
					const showEmptyScreen = computed(
 | 
				
			||||||
@ -401,6 +438,7 @@ async function fetchData({ page, filter, sort }) {
 | 
				
			|||||||
    from_date: filters.from_date,
 | 
					    from_date: filters.from_date,
 | 
				
			||||||
    to_date: filters.to_date,
 | 
					    to_date: filters.to_date,
 | 
				
			||||||
    invoice_number: filters.invoice_number,
 | 
					    invoice_number: filters.invoice_number,
 | 
				
			||||||
 | 
					    tab_status: filters.tab_status,
 | 
				
			||||||
    orderByField: sort.fieldName || 'created_at',
 | 
					    orderByField: sort.fieldName || 'created_at',
 | 
				
			||||||
    orderBy: sort.order || 'desc',
 | 
					    orderBy: sort.order || 'desc',
 | 
				
			||||||
    page,
 | 
					    page,
 | 
				
			||||||
@ -423,29 +461,9 @@ async function fetchData({ page, filter, sort }) {
 | 
				
			|||||||
  }
 | 
					  }
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
function setStatusFilter(val) {
 | 
					function changeTabStatus(val, index) {
 | 
				
			||||||
  if (activeTab.value == val.title) {
 | 
					  filters.tab_status = val['tab-status']
 | 
				
			||||||
    return true
 | 
					  selectedIndex.value = index
 | 
				
			||||||
  }
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  activeTab.value = val.title
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
  switch (val.title) {
 | 
					 | 
				
			||||||
    case t('general.draft'):
 | 
					 | 
				
			||||||
      filters.status = 'DRAFT'
 | 
					 | 
				
			||||||
      break
 | 
					 | 
				
			||||||
    case t('general.sent'):
 | 
					 | 
				
			||||||
      filters.status = 'SENT'
 | 
					 | 
				
			||||||
      break
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    case t('general.due'):
 | 
					 | 
				
			||||||
      filters.status = 'DUE'
 | 
					 | 
				
			||||||
      break
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    default:
 | 
					 | 
				
			||||||
      filters.status = ''
 | 
					 | 
				
			||||||
      break
 | 
					 | 
				
			||||||
  }
 | 
					 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
function setFilters() {
 | 
					function setFilters() {
 | 
				
			||||||
@ -463,8 +481,6 @@ function clearFilter() {
 | 
				
			|||||||
  filters.from_date = ''
 | 
					  filters.from_date = ''
 | 
				
			||||||
  filters.to_date = ''
 | 
					  filters.to_date = ''
 | 
				
			||||||
  filters.invoice_number = ''
 | 
					  filters.invoice_number = ''
 | 
				
			||||||
 | 
					 | 
				
			||||||
  activeTab.value = t('general.all')
 | 
					 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
async function removeMultipleInvoices() {
 | 
					async function removeMultipleInvoices() {
 | 
				
			||||||
@ -505,39 +521,21 @@ function toggleFilter() {
 | 
				
			|||||||
function setActiveTab(val) {
 | 
					function setActiveTab(val) {
 | 
				
			||||||
  switch (val) {
 | 
					  switch (val) {
 | 
				
			||||||
    case 'DRAFT':
 | 
					    case 'DRAFT':
 | 
				
			||||||
      activeTab.value = t('general.draft')
 | 
					      selectedIndex.value = 1
 | 
				
			||||||
      break
 | 
					      break
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    case 'SENT':
 | 
					    case 'SENT':
 | 
				
			||||||
      activeTab.value = t('general.sent')
 | 
					    case 'VIEWED':
 | 
				
			||||||
      break
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    case 'DUE':
 | 
					 | 
				
			||||||
      activeTab.value = t('general.due')
 | 
					 | 
				
			||||||
      break
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    case 'COMPLETED':
 | 
					    case 'COMPLETED':
 | 
				
			||||||
      activeTab.value = t('invoices.completed')
 | 
					 | 
				
			||||||
      break
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    case 'PAID':
 | 
					    case 'PAID':
 | 
				
			||||||
      activeTab.value = t('invoices.paid')
 | 
					      selectedIndex.value = 2
 | 
				
			||||||
      break
 | 
					      break
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    case 'UNPAID':
 | 
					    case 'UNPAID':
 | 
				
			||||||
      activeTab.value = t('invoices.unpaid')
 | 
					 | 
				
			||||||
      break
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    case 'PARTIALLY_PAID':
 | 
					    case 'PARTIALLY_PAID':
 | 
				
			||||||
      activeTab.value = t('invoices.partially_paid')
 | 
					      selectedIndex.value = 3
 | 
				
			||||||
      break
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    case 'VIEWED':
 | 
					 | 
				
			||||||
      activeTab.value = t('invoices.viewed')
 | 
					 | 
				
			||||||
      break
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    default:
 | 
					 | 
				
			||||||
      activeTab.value = t('general.all')
 | 
					 | 
				
			||||||
      break
 | 
					      break
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
 | 
					  filters.tab_status = invoiceTabStatus[selectedIndex.value].value
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
</script>
 | 
					</script>
 | 
				
			||||||
 | 
				
			|||||||
@ -32,6 +32,8 @@
 | 
				
			|||||||
          :content-loading="isLoading"
 | 
					          :content-loading="isLoading"
 | 
				
			||||||
          :calendar-button="true"
 | 
					          :calendar-button="true"
 | 
				
			||||||
          calendar-button-icon="calendar"
 | 
					          calendar-button-icon="calendar"
 | 
				
			||||||
 | 
					          :show-extra-options="true"
 | 
				
			||||||
 | 
					          :source-date="invoiceStore.newInvoice.invoice_date"
 | 
				
			||||||
        />
 | 
					        />
 | 
				
			||||||
      </BaseInputGroup>
 | 
					      </BaseInputGroup>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
				
			|||||||
@ -53,7 +53,7 @@
 | 
				
			|||||||
          </div>
 | 
					          </div>
 | 
				
			||||||
        </div>
 | 
					        </div>
 | 
				
			||||||
        <div v-else class="mt-24">
 | 
					        <div v-else class="mt-24">
 | 
				
			||||||
          <label class="flex items-center justify-center text-gray-500">
 | 
					          <label class="flex items-center justify-center text-gray-500 dark:text-gray-300">
 | 
				
			||||||
            {{ $t('modules.no_modules_installed') }}
 | 
					            {{ $t('modules.no_modules_installed') }}
 | 
				
			||||||
          </label>
 | 
					          </label>
 | 
				
			||||||
        </div>
 | 
					        </div>
 | 
				
			||||||
@ -61,10 +61,10 @@
 | 
				
			|||||||
    </div>
 | 
					    </div>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    <BaseCard v-else class="mt-6">
 | 
					    <BaseCard v-else class="mt-6">
 | 
				
			||||||
      <h6 class="text-gray-900 text-lg font-medium">
 | 
					      <h6 class="text-gray-900 text-lg font-medium dark:text-white">
 | 
				
			||||||
        {{ $t('modules.connect_installation') }}
 | 
					        {{ $t('modules.connect_installation') }}
 | 
				
			||||||
      </h6>
 | 
					      </h6>
 | 
				
			||||||
      <p class="mt-1 text-sm text-gray-500">
 | 
					      <p class="mt-1 text-sm text-gray-500 dark:text-gray-400">
 | 
				
			||||||
        {{
 | 
					        {{
 | 
				
			||||||
          $t('modules.api_token_description', {
 | 
					          $t('modules.api_token_description', {
 | 
				
			||||||
            url: globalStore.config.base_url.replace(/^http:\/\//, ''),
 | 
					            url: globalStore.config.base_url.replace(/^http:\/\//, ''),
 | 
				
			||||||
 | 
				
			|||||||
@ -82,9 +82,9 @@
 | 
				
			|||||||
            required
 | 
					            required
 | 
				
			||||||
          >
 | 
					          >
 | 
				
			||||||
            <BaseCustomerSelectInput
 | 
					            <BaseCustomerSelectInput
 | 
				
			||||||
 | 
					              v-if="!isLoadingContent"
 | 
				
			||||||
              v-model="paymentStore.currentPayment.customer_id"
 | 
					              v-model="paymentStore.currentPayment.customer_id"
 | 
				
			||||||
              :content-loading="isLoadingContent"
 | 
					              :content-loading="isLoadingContent"
 | 
				
			||||||
              v-if="!isLoadingContent"
 | 
					 | 
				
			||||||
              :invalid="v$.currentPayment.customer_id.$error"
 | 
					              :invalid="v$.currentPayment.customer_id.$error"
 | 
				
			||||||
              :placeholder="$t('customers.select_a_customer')"
 | 
					              :placeholder="$t('customers.select_a_customer')"
 | 
				
			||||||
              show-action
 | 
					              show-action
 | 
				
			||||||
@ -215,7 +215,7 @@
 | 
				
			|||||||
            <SelectNotePopup type="Payment" @select="onSelectNote" />
 | 
					            <SelectNotePopup type="Payment" @select="onSelectNote" />
 | 
				
			||||||
          </div>
 | 
					          </div>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
          <label class="mb-4 text-sm font-medium text-gray-800">
 | 
					          <label class="mb-4 text-sm font-medium text-gray-800 dark:text-gray-300">
 | 
				
			||||||
            {{ $t('estimates.notes') }}
 | 
					            {{ $t('estimates.notes') }}
 | 
				
			||||||
          </label>
 | 
					          </label>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@ -423,7 +423,7 @@ function onCustomerChange(customer_id) {
 | 
				
			|||||||
  if (customer_id) {
 | 
					  if (customer_id) {
 | 
				
			||||||
    let data = {
 | 
					    let data = {
 | 
				
			||||||
      customer_id: customer_id,
 | 
					      customer_id: customer_id,
 | 
				
			||||||
      status: 'DUE',
 | 
					      tab_status: 'DUE',
 | 
				
			||||||
      limit: 'all',
 | 
					      limit: 'all',
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@ -446,7 +446,11 @@ function onCustomerChange(customer_id) {
 | 
				
			|||||||
          paymentStore.currentPayment.selectedCustomer = res2.data.data
 | 
					          paymentStore.currentPayment.selectedCustomer = res2.data.data
 | 
				
			||||||
          paymentStore.currentPayment.customer = res2.data.data
 | 
					          paymentStore.currentPayment.customer = res2.data.data
 | 
				
			||||||
          paymentStore.currentPayment.currency = res2.data.data.currency
 | 
					          paymentStore.currentPayment.currency = res2.data.data.currency
 | 
				
			||||||
          if(isEdit.value && !customerStore.editCustomer && paymentStore.currentPayment.customer_id) {
 | 
					          if (
 | 
				
			||||||
 | 
					            isEdit.value &&
 | 
				
			||||||
 | 
					            !customerStore.editCustomer &&
 | 
				
			||||||
 | 
					            paymentStore.currentPayment.customer_id
 | 
				
			||||||
 | 
					          ) {
 | 
				
			||||||
            customerStore.editCustomer = res2.data.data
 | 
					            customerStore.editCustomer = res2.data.data
 | 
				
			||||||
          }
 | 
					          }
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
 | 
				
			|||||||
@ -121,6 +121,7 @@
 | 
				
			|||||||
          mt-5
 | 
					          mt-5
 | 
				
			||||||
          list-none
 | 
					          list-none
 | 
				
			||||||
          border-b-2 border-gray-200 border-solid
 | 
					          border-b-2 border-gray-200 border-solid
 | 
				
			||||||
 | 
					          dark:border-gray-600
 | 
				
			||||||
        "
 | 
					        "
 | 
				
			||||||
      >
 | 
					      >
 | 
				
			||||||
        <!-- Tabs -->
 | 
					        <!-- Tabs -->
 | 
				
			||||||
 | 
				
			|||||||
@ -16,11 +16,11 @@
 | 
				
			|||||||
      </div>
 | 
					      </div>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
      <div class="ml-2">
 | 
					      <div class="ml-2">
 | 
				
			||||||
        <p class="p-0 mb-1 leading-snug text-left text-black">
 | 
					        <p class="p-0 mb-1 leading-snug text-left text-black dark:text-white">
 | 
				
			||||||
          {{ $t('recurring_invoices.send_automatically') }}
 | 
					          {{ $t('recurring_invoices.send_automatically') }}
 | 
				
			||||||
        </p>
 | 
					        </p>
 | 
				
			||||||
        <p
 | 
					        <p
 | 
				
			||||||
          class="p-0 m-0 text-xs leading-tight text-left text-gray-500"
 | 
					          class="p-0 m-0 text-xs leading-tight text-left text-gray-500 dark:text-gray-400"
 | 
				
			||||||
          style="max-width: 480px"
 | 
					          style="max-width: 480px"
 | 
				
			||||||
        >
 | 
					        >
 | 
				
			||||||
          {{ $t('recurring_invoices.send_automatically_desc') }}
 | 
					          {{ $t('recurring_invoices.send_automatically_desc') }}
 | 
				
			||||||
 | 
				
			|||||||
@ -51,14 +51,14 @@
 | 
				
			|||||||
            </div>
 | 
					            </div>
 | 
				
			||||||
          </template>
 | 
					          </template>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
          <BaseDropdownItem @click="onDownloadBckup(row.data)">
 | 
					          <BaseDropdownItem v-slot="slotProps" @click="onDownloadBckup(row.data)">
 | 
				
			||||||
            <BaseIcon name="CloudDownloadIcon" class="mr-3 text-gray-600" />
 | 
					            <BaseIcon name="CloudDownloadIcon" :class="slotProps.class" />
 | 
				
			||||||
 | 
					
 | 
				
			||||||
            {{ $t('general.download') }}
 | 
					            {{ $t('general.download') }}
 | 
				
			||||||
          </BaseDropdownItem>
 | 
					          </BaseDropdownItem>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
          <BaseDropdownItem @click="onRemoveBackup(row.data)">
 | 
					          <BaseDropdownItem v-slot="slotProps" @click="onRemoveBackup(row.data)">
 | 
				
			||||||
            <BaseIcon name="TrashIcon" class="mr-3 text-gray-600" />
 | 
					            <BaseIcon name="TrashIcon" :class="slotProps.class" />
 | 
				
			||||||
            {{ $t('general.delete') }}
 | 
					            {{ $t('general.delete') }}
 | 
				
			||||||
          </BaseDropdownItem>
 | 
					          </BaseDropdownItem>
 | 
				
			||||||
        </BaseDropdown>
 | 
					        </BaseDropdown>
 | 
				
			||||||
 | 
				
			|||||||
@ -28,6 +28,19 @@
 | 
				
			|||||||
          />
 | 
					          />
 | 
				
			||||||
        </BaseInputGroup>
 | 
					        </BaseInputGroup>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        <BaseInputGroup
 | 
				
			||||||
 | 
					          :label="$tc('settings.company_info.company_slug')"
 | 
				
			||||||
 | 
					          :help-text="$t('settings.company_info.company_slug_help_text')"
 | 
				
			||||||
 | 
					          :error="v$.slug.$error && v$.slug.$errors[0].$message"
 | 
				
			||||||
 | 
					          required
 | 
				
			||||||
 | 
					        >
 | 
				
			||||||
 | 
					          <BaseInput
 | 
				
			||||||
 | 
					            v-model="companyForm.slug"
 | 
				
			||||||
 | 
					            :invalid="v$.slug.$error"
 | 
				
			||||||
 | 
					            @blur="v$.slug.$touch()"
 | 
				
			||||||
 | 
					          />
 | 
				
			||||||
 | 
					        </BaseInputGroup>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        <BaseInputGroup :label="$tc('settings.company_info.phone')">
 | 
					        <BaseInputGroup :label="$tc('settings.company_info.phone')">
 | 
				
			||||||
          <BaseInput v-model="companyForm.address.phone" />
 | 
					          <BaseInput v-model="companyForm.address.phone" />
 | 
				
			||||||
        </BaseInputGroup>
 | 
					        </BaseInputGroup>
 | 
				
			||||||
@ -100,10 +113,10 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
      <div v-if="companyStore.companies.length !== 1" class="py-5">
 | 
					      <div v-if="companyStore.companies.length !== 1" class="py-5">
 | 
				
			||||||
        <BaseDivider class="my-4" />
 | 
					        <BaseDivider class="my-4" />
 | 
				
			||||||
        <h3 class="text-lg leading-6 font-medium text-gray-900">
 | 
					        <h3 class="text-lg leading-6 font-medium text-gray-900 dark:text-white">
 | 
				
			||||||
          {{ $tc('settings.company_info.delete_company') }}
 | 
					          {{ $tc('settings.company_info.delete_company') }}
 | 
				
			||||||
        </h3>
 | 
					        </h3>
 | 
				
			||||||
        <div class="mt-2 max-w-xl text-sm text-gray-500">
 | 
					        <div class="mt-2 max-w-xl text-sm text-gray-500 dark:text-gray-400">
 | 
				
			||||||
          <p>
 | 
					          <p>
 | 
				
			||||||
            {{ $tc('settings.company_info.delete_company_description') }}
 | 
					            {{ $tc('settings.company_info.delete_company_description') }}
 | 
				
			||||||
          </p>
 | 
					          </p>
 | 
				
			||||||
@ -160,6 +173,7 @@ let isSaving = ref(false)
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
const companyForm = reactive({
 | 
					const companyForm = reactive({
 | 
				
			||||||
  name: null,
 | 
					  name: null,
 | 
				
			||||||
 | 
					  slug: null,
 | 
				
			||||||
  logo: null,
 | 
					  logo: null,
 | 
				
			||||||
  address: {
 | 
					  address: {
 | 
				
			||||||
    address_street_1: '',
 | 
					    address_street_1: '',
 | 
				
			||||||
@ -193,7 +207,14 @@ const rules = computed(() => {
 | 
				
			|||||||
    name: {
 | 
					    name: {
 | 
				
			||||||
      required: helpers.withMessage(t('validation.required'), required),
 | 
					      required: helpers.withMessage(t('validation.required'), required),
 | 
				
			||||||
      minLength: helpers.withMessage(
 | 
					      minLength: helpers.withMessage(
 | 
				
			||||||
        t('validation.name_min_length'),
 | 
					        t('validation.name_min_length', { count: 3 }),
 | 
				
			||||||
 | 
					        minLength(3)
 | 
				
			||||||
 | 
					      ),
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    slug: {
 | 
				
			||||||
 | 
					      required: helpers.withMessage(t('validation.required'), required),
 | 
				
			||||||
 | 
					      minLength: helpers.withMessage(
 | 
				
			||||||
 | 
					        t('validation.name_min_length', { count: 3 }),
 | 
				
			||||||
        minLength(3)
 | 
					        minLength(3)
 | 
				
			||||||
      ),
 | 
					      ),
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
 | 
				
			|||||||
@ -27,7 +27,7 @@
 | 
				
			|||||||
    >
 | 
					    >
 | 
				
			||||||
      <template #cell-name="{ row }">
 | 
					      <template #cell-name="{ row }">
 | 
				
			||||||
        {{ row.data.name }}
 | 
					        {{ row.data.name }}
 | 
				
			||||||
        <span class="text-xs text-gray-500"> ({{ row.data.slug }})</span>
 | 
					        <span class="text-xs text-gray-500 dark:text-gray-400"> ({{ row.data.slug }})</span>
 | 
				
			||||||
      </template>
 | 
					      </template>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
      <template #cell-is_required="{ row }">
 | 
					      <template #cell-is_required="{ row }">
 | 
				
			||||||
 | 
				
			|||||||
@ -7,7 +7,7 @@
 | 
				
			|||||||
          {{ $t('settings.menu_title.exchange_rate') }}
 | 
					          {{ $t('settings.menu_title.exchange_rate') }}
 | 
				
			||||||
        </h6>
 | 
					        </h6>
 | 
				
			||||||
        <p
 | 
					        <p
 | 
				
			||||||
          class="mt-2 text-sm leading-snug text-left text-gray-500"
 | 
					          class="mt-2 text-sm leading-snug text-left text-gray-500 dark:text-gray-400"
 | 
				
			||||||
          style="max-width: 680px"
 | 
					          style="max-width: 680px"
 | 
				
			||||||
        >
 | 
					        >
 | 
				
			||||||
          {{ $t('settings.exchange_rate.providers_description') }}
 | 
					          {{ $t('settings.exchange_rate.providers_description') }}
 | 
				
			||||||
 | 
				
			|||||||
@ -45,27 +45,30 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
          <BaseDropdownItem
 | 
					          <BaseDropdownItem
 | 
				
			||||||
            v-if="!row.data.set_as_default"
 | 
					            v-if="!row.data.set_as_default"
 | 
				
			||||||
 | 
					            v-slot="slotProps"
 | 
				
			||||||
            @click="setDefaultDiskData(row.data.id)"
 | 
					            @click="setDefaultDiskData(row.data.id)"
 | 
				
			||||||
          >
 | 
					          >
 | 
				
			||||||
            <BaseIcon class="mr-3 tetx-gray-600" name="CheckCircleIcon" />
 | 
					            <BaseIcon :class="slotProps.class" name="CheckCircleIcon" />
 | 
				
			||||||
 | 
					
 | 
				
			||||||
            {{ $t('settings.disk.set_default_disk') }}
 | 
					            {{ $t('settings.disk.set_default_disk') }}
 | 
				
			||||||
          </BaseDropdownItem>
 | 
					          </BaseDropdownItem>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
          <BaseDropdownItem
 | 
					          <BaseDropdownItem
 | 
				
			||||||
            v-if="row.data.type !== 'SYSTEM'"
 | 
					            v-if="row.data.type !== 'SYSTEM'"
 | 
				
			||||||
 | 
					            v-slot="slotProps"
 | 
				
			||||||
            @click="openEditDiskModal(row.data)"
 | 
					            @click="openEditDiskModal(row.data)"
 | 
				
			||||||
          >
 | 
					          >
 | 
				
			||||||
            <BaseIcon name="PencilIcon" class="mr-3 text-gray-600" />
 | 
					            <BaseIcon name="PencilIcon" :class="slotProps.class" />
 | 
				
			||||||
 | 
					
 | 
				
			||||||
            {{ $t('general.edit') }}
 | 
					            {{ $t('general.edit') }}
 | 
				
			||||||
          </BaseDropdownItem>
 | 
					          </BaseDropdownItem>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
          <BaseDropdownItem
 | 
					          <BaseDropdownItem
 | 
				
			||||||
            v-if="row.data.type !== 'SYSTEM' && !row.data.set_as_default"
 | 
					            v-if="row.data.type !== 'SYSTEM' && !row.data.set_as_default"
 | 
				
			||||||
 | 
					            v-slot="slotProps"
 | 
				
			||||||
            @click="removeDisk(row.data.id)"
 | 
					            @click="removeDisk(row.data.id)"
 | 
				
			||||||
          >
 | 
					          >
 | 
				
			||||||
            <BaseIcon name="TrashIcon" class="mr-3 text-gray-600" />
 | 
					            <BaseIcon name="TrashIcon" :class="slotProps.class" />
 | 
				
			||||||
            {{ $t('general.delete') }}
 | 
					            {{ $t('general.delete') }}
 | 
				
			||||||
          </BaseDropdownItem>
 | 
					          </BaseDropdownItem>
 | 
				
			||||||
        </BaseDropdown>
 | 
					        </BaseDropdown>
 | 
				
			||||||
 | 
				
			|||||||
@ -8,7 +8,11 @@
 | 
				
			|||||||
        <BaseInputGroup
 | 
					        <BaseInputGroup
 | 
				
			||||||
          :content-loading="isFetchingInitialData"
 | 
					          :content-loading="isFetchingInitialData"
 | 
				
			||||||
          :label="$tc('settings.preferences.currency')"
 | 
					          :label="$tc('settings.preferences.currency')"
 | 
				
			||||||
          :help-text="$t('settings.preferences.company_currency_unchangeable')"
 | 
					          :help-text="
 | 
				
			||||||
 | 
					            isCurrencyDisabled
 | 
				
			||||||
 | 
					              ? $t('settings.preferences.company_currency_unchangeable')
 | 
				
			||||||
 | 
					              : ''
 | 
				
			||||||
 | 
					          "
 | 
				
			||||||
          :error="v$.currency.$error && v$.currency.$errors[0].$message"
 | 
					          :error="v$.currency.$error && v$.currency.$errors[0].$message"
 | 
				
			||||||
          required
 | 
					          required
 | 
				
			||||||
        >
 | 
					        >
 | 
				
			||||||
@ -21,7 +25,7 @@
 | 
				
			|||||||
            :searchable="true"
 | 
					            :searchable="true"
 | 
				
			||||||
            track-by="name"
 | 
					            track-by="name"
 | 
				
			||||||
            :invalid="v$.currency.$error"
 | 
					            :invalid="v$.currency.$error"
 | 
				
			||||||
            disabled
 | 
					            :disabled="isCurrencyDisabled"
 | 
				
			||||||
            class="w-full"
 | 
					            class="w-full"
 | 
				
			||||||
          >
 | 
					          >
 | 
				
			||||||
          </BaseMultiselect>
 | 
					          </BaseMultiselect>
 | 
				
			||||||
@ -187,6 +191,7 @@ const { t, tm } = useI18n()
 | 
				
			|||||||
let isSaving = ref(false)
 | 
					let isSaving = ref(false)
 | 
				
			||||||
let isDataSaving = ref(false)
 | 
					let isDataSaving = ref(false)
 | 
				
			||||||
let isFetchingInitialData = ref(false)
 | 
					let isFetchingInitialData = ref(false)
 | 
				
			||||||
 | 
					let isCurrencyDisabled = ref(true)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
const settingsForm = reactive({ ...companyStore.selectedCompanySettings })
 | 
					const settingsForm = reactive({ ...companyStore.selectedCompanySettings })
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@ -282,10 +287,14 @@ setInitialData()
 | 
				
			|||||||
async function setInitialData() {
 | 
					async function setInitialData() {
 | 
				
			||||||
  isFetchingInitialData.value = true
 | 
					  isFetchingInitialData.value = true
 | 
				
			||||||
  Promise.all([
 | 
					  Promise.all([
 | 
				
			||||||
 | 
					    companyStore.checkCompanyHasCurrencyTransactions(),
 | 
				
			||||||
    globalStore.fetchCurrencies(),
 | 
					    globalStore.fetchCurrencies(),
 | 
				
			||||||
    globalStore.fetchDateFormats(),
 | 
					    globalStore.fetchDateFormats(),
 | 
				
			||||||
    globalStore.fetchTimeZones(),
 | 
					    globalStore.fetchTimeZones(),
 | 
				
			||||||
  ]).then(([res1]) => {
 | 
					  ]).then(([res1]) => {
 | 
				
			||||||
 | 
					    if (res1.data?.has_transactions == false) {
 | 
				
			||||||
 | 
					      isCurrencyDisabled.value = false
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
    isFetchingInitialData.value = false
 | 
					    isFetchingInitialData.value = false
 | 
				
			||||||
  })
 | 
					  })
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
				
			|||||||
@ -4,23 +4,14 @@
 | 
				
			|||||||
    :description="$t('settings.update_app.description')"
 | 
					    :description="$t('settings.update_app.description')"
 | 
				
			||||||
  >
 | 
					  >
 | 
				
			||||||
    <div class="pb-8 ml-0">
 | 
					    <div class="pb-8 ml-0">
 | 
				
			||||||
      <label class="text-sm not-italic font-medium input-label">
 | 
					      <label
 | 
				
			||||||
 | 
					        class="text-sm not-italic font-medium input-label dark:text-gray-300"
 | 
				
			||||||
 | 
					      >
 | 
				
			||||||
        {{ $t('settings.update_app.current_version') }}
 | 
					        {{ $t('settings.update_app.current_version') }}
 | 
				
			||||||
      </label>
 | 
					      </label>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
      <div
 | 
					      <div
 | 
				
			||||||
        class="
 | 
					        class="box-border flex w-16 p-3 my-2 text-sm text-gray-600 bg-gray-200 border border-gray-200 border-solid dark:bg-gray-600 dark:text-gray-200 dark:border-gray-500 rounded-md version"
 | 
				
			||||||
          box-border
 | 
					 | 
				
			||||||
          flex
 | 
					 | 
				
			||||||
          w-16
 | 
					 | 
				
			||||||
          p-3
 | 
					 | 
				
			||||||
          my-2
 | 
					 | 
				
			||||||
          text-sm text-gray-600
 | 
					 | 
				
			||||||
          bg-gray-200
 | 
					 | 
				
			||||||
          border border-gray-200 border-solid
 | 
					 | 
				
			||||||
          rounded-md
 | 
					 | 
				
			||||||
          version
 | 
					 | 
				
			||||||
        "
 | 
					 | 
				
			||||||
      >
 | 
					      >
 | 
				
			||||||
        {{ currentVersion }}
 | 
					        {{ currentVersion }}
 | 
				
			||||||
      </div>
 | 
					      </div>
 | 
				
			||||||
@ -42,20 +33,20 @@
 | 
				
			|||||||
          {{ $t('settings.update_app.avail_update') }}
 | 
					          {{ $t('settings.update_app.avail_update') }}
 | 
				
			||||||
        </BaseHeading>
 | 
					        </BaseHeading>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        <div class="rounded-md bg-primary-50 p-4 mb-3">
 | 
					        <div class="rounded-md bg-primary-50 p-4 mb-3 dark:bg-gray-600">
 | 
				
			||||||
          <div class="flex">
 | 
					          <div class="flex">
 | 
				
			||||||
            <div class="shrink-0">
 | 
					            <div class="shrink-0">
 | 
				
			||||||
              <BaseIcon
 | 
					              <BaseIcon
 | 
				
			||||||
                name="InformationCircleIcon"
 | 
					                name="InformationCircleIcon"
 | 
				
			||||||
                class="h-5 w-5 text-primary-400"
 | 
					                class="h-5 w-5 text-primary-400 dark:text-primary-300"
 | 
				
			||||||
                aria-hidden="true"
 | 
					                aria-hidden="true"
 | 
				
			||||||
              />
 | 
					              />
 | 
				
			||||||
            </div>
 | 
					            </div>
 | 
				
			||||||
            <div class="ml-3">
 | 
					            <div class="ml-3">
 | 
				
			||||||
              <h3 class="text-sm font-medium text-primary-800">
 | 
					              <h3 class="text-sm font-medium text-primary-800 dark:text-primary-300">
 | 
				
			||||||
                {{ $t('general.note') }}
 | 
					                {{ $t('general.note') }}
 | 
				
			||||||
              </h3>
 | 
					              </h3>
 | 
				
			||||||
              <div class="mt-2 text-sm text-primary-700">
 | 
					              <div class="mt-2 text-sm text-primary-700 dark:text-primary-400">
 | 
				
			||||||
                <p>
 | 
					                <p>
 | 
				
			||||||
                  {{ $t('settings.update_app.update_warning') }}
 | 
					                  {{ $t('settings.update_app.update_warning') }}
 | 
				
			||||||
                </p>
 | 
					                </p>
 | 
				
			||||||
@ -75,26 +66,20 @@
 | 
				
			|||||||
            w-16
 | 
					            w-16
 | 
				
			||||||
            p-3
 | 
					            p-3
 | 
				
			||||||
            my-2
 | 
					            my-2
 | 
				
			||||||
            text-sm text-gray-600
 | 
					            text-sm
 | 
				
			||||||
            bg-gray-200
 | 
					            text-gray-600 bg-gray-200
 | 
				
			||||||
            border border-gray-200 border-solid
 | 
					            border border-gray-200 border-solid
 | 
				
			||||||
            rounded-md
 | 
					            rounded-md
 | 
				
			||||||
            version
 | 
					            version
 | 
				
			||||||
 | 
					            dark:bg-gray-600 dark:text-gray-200
 | 
				
			||||||
 | 
					            dark:border-gray-500
 | 
				
			||||||
          "
 | 
					          "
 | 
				
			||||||
        >
 | 
					        >
 | 
				
			||||||
          {{ updateData.version }}
 | 
					          {{ updateData.version }}
 | 
				
			||||||
        </div>
 | 
					        </div>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        <div
 | 
					        <div
 | 
				
			||||||
          class="
 | 
					          class="pl-5 mt-4 mb-8 text-sm leading-snug text-gray-500 update-description"
 | 
				
			||||||
            pl-5
 | 
					 | 
				
			||||||
            mt-4
 | 
					 | 
				
			||||||
            mb-8
 | 
					 | 
				
			||||||
            text-sm
 | 
					 | 
				
			||||||
            leading-snug
 | 
					 | 
				
			||||||
            text-gray-500
 | 
					 | 
				
			||||||
            update-description
 | 
					 | 
				
			||||||
          "
 | 
					 | 
				
			||||||
          style="white-space: pre-wrap; max-width: 480px"
 | 
					          style="white-space: pre-wrap; max-width: 480px"
 | 
				
			||||||
          v-html="description"
 | 
					          v-html="description"
 | 
				
			||||||
        ></div>
 | 
					        ></div>
 | 
				
			||||||
@ -150,14 +135,7 @@
 | 
				
			|||||||
        <li
 | 
					        <li
 | 
				
			||||||
          v-for="step in updateSteps"
 | 
					          v-for="step in updateSteps"
 | 
				
			||||||
          :key="step.stepUrl"
 | 
					          :key="step.stepUrl"
 | 
				
			||||||
          class="
 | 
					          class="flex justify-between w-full py-3 border-b border-gray-200 border-solid last:border-b-0"
 | 
				
			||||||
            flex
 | 
					 | 
				
			||||||
            justify-between
 | 
					 | 
				
			||||||
            w-full
 | 
					 | 
				
			||||||
            py-3
 | 
					 | 
				
			||||||
            border-b border-gray-200 border-solid
 | 
					 | 
				
			||||||
            last:border-b-0
 | 
					 | 
				
			||||||
          "
 | 
					 | 
				
			||||||
        >
 | 
					        >
 | 
				
			||||||
          <p class="m-0 text-sm leading-8">{{ $t(step.translationKey) }}</p>
 | 
					          <p class="m-0 text-sm leading-8">{{ $t(step.translationKey) }}</p>
 | 
				
			||||||
          <div class="flex flex-row items-center">
 | 
					          <div class="flex flex-row items-center">
 | 
				
			||||||
 | 
				
			|||||||
@ -1,12 +1,12 @@
 | 
				
			|||||||
<template>
 | 
					<template>
 | 
				
			||||||
  <h6 class="text-gray-900 text-lg font-medium">
 | 
					  <BaseHeading
 | 
				
			||||||
    {{ $t(`settings.customization.${type}s.${type}_number_format`) }}
 | 
					    type="heading-title"
 | 
				
			||||||
  </h6>
 | 
					    :subtitle="
 | 
				
			||||||
  <p class="mt-1 text-sm text-gray-500">
 | 
					 | 
				
			||||||
    {{
 | 
					 | 
				
			||||||
      $t(`settings.customization.${type}s.${type}_number_format_description`)
 | 
					      $t(`settings.customization.${type}s.${type}_number_format_description`)
 | 
				
			||||||
    }}
 | 
					    "
 | 
				
			||||||
  </p>
 | 
					  >
 | 
				
			||||||
 | 
					    {{ $t(`settings.customization.${type}s.${type}_number_format`) }}
 | 
				
			||||||
 | 
					  </BaseHeading>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  <div class="overflow-x-auto">
 | 
					  <div class="overflow-x-auto">
 | 
				
			||||||
    <table class="w-full mt-6 table-fixed">
 | 
					    <table class="w-full mt-6 table-fixed">
 | 
				
			||||||
@ -29,6 +29,7 @@
 | 
				
			|||||||
              leading-5
 | 
					              leading-5
 | 
				
			||||||
              text-left text-gray-700
 | 
					              text-left text-gray-700
 | 
				
			||||||
              border-t border-b border-gray-200 border-solid
 | 
					              border-t border-b border-gray-200 border-solid
 | 
				
			||||||
 | 
					              dark:border-gray-600
 | 
				
			||||||
            "
 | 
					            "
 | 
				
			||||||
          ></th>
 | 
					          ></th>
 | 
				
			||||||
          <th
 | 
					          <th
 | 
				
			||||||
@ -41,6 +42,7 @@
 | 
				
			|||||||
              leading-5
 | 
					              leading-5
 | 
				
			||||||
              text-left text-gray-700
 | 
					              text-left text-gray-700
 | 
				
			||||||
              border-t border-b border-gray-200 border-solid
 | 
					              border-t border-b border-gray-200 border-solid
 | 
				
			||||||
 | 
					              dark:text-gray-300 dark:border-gray-600
 | 
				
			||||||
            "
 | 
					            "
 | 
				
			||||||
          >
 | 
					          >
 | 
				
			||||||
            Component
 | 
					            Component
 | 
				
			||||||
@ -55,6 +57,7 @@
 | 
				
			|||||||
              leading-5
 | 
					              leading-5
 | 
				
			||||||
              text-left text-gray-700
 | 
					              text-left text-gray-700
 | 
				
			||||||
              border-t border-b border-gray-200 border-solid
 | 
					              border-t border-b border-gray-200 border-solid
 | 
				
			||||||
 | 
					              dark:text-gray-300 dark:border-gray-600
 | 
				
			||||||
            "
 | 
					            "
 | 
				
			||||||
          >
 | 
					          >
 | 
				
			||||||
            Parameter
 | 
					            Parameter
 | 
				
			||||||
@ -69,13 +72,14 @@
 | 
				
			|||||||
              leading-5
 | 
					              leading-5
 | 
				
			||||||
              text-left text-gray-700
 | 
					              text-left text-gray-700
 | 
				
			||||||
              border-t border-b border-gray-200 border-solid
 | 
					              border-t border-b border-gray-200 border-solid
 | 
				
			||||||
 | 
					              dark:border-gray-600
 | 
				
			||||||
            "
 | 
					            "
 | 
				
			||||||
          ></th>
 | 
					          ></th>
 | 
				
			||||||
        </tr>
 | 
					        </tr>
 | 
				
			||||||
      </thead>
 | 
					      </thead>
 | 
				
			||||||
      <draggable
 | 
					      <draggable
 | 
				
			||||||
        v-model="selectedFields"
 | 
					        v-model="selectedFields"
 | 
				
			||||||
        class="divide-y divide-gray-200"
 | 
					        class="divide-y divide-gray-200 dark:divide-gray-600"
 | 
				
			||||||
        item-key="id"
 | 
					        item-key="id"
 | 
				
			||||||
        tag="tbody"
 | 
					        tag="tbody"
 | 
				
			||||||
        handle=".handle"
 | 
					        handle=".handle"
 | 
				
			||||||
@ -97,12 +101,13 @@
 | 
				
			|||||||
                  whitespace-nowrap
 | 
					                  whitespace-nowrap
 | 
				
			||||||
                  mr-2
 | 
					                  mr-2
 | 
				
			||||||
                  min-w-[200px]
 | 
					                  min-w-[200px]
 | 
				
			||||||
 | 
					                  dark:text-primary-400
 | 
				
			||||||
                "
 | 
					                "
 | 
				
			||||||
              >
 | 
					              >
 | 
				
			||||||
                {{ element.label }}
 | 
					                {{ element.label }}
 | 
				
			||||||
              </label>
 | 
					              </label>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
              <p class="text-xs text-gray-500 mt-1">
 | 
					              <p class="text-xs text-gray-500 dark:text-gray-400 mt-1">
 | 
				
			||||||
                {{ element.description }}
 | 
					                {{ element.description }}
 | 
				
			||||||
              </p>
 | 
					              </p>
 | 
				
			||||||
            </td>
 | 
					            </td>
 | 
				
			||||||
 | 
				
			|||||||
@ -1,10 +1,12 @@
 | 
				
			|||||||
<template>
 | 
					<template>
 | 
				
			||||||
  <h6 class="text-gray-900 text-lg font-medium">
 | 
					  <BaseHeading
 | 
				
			||||||
 | 
					    type="heading-title"
 | 
				
			||||||
 | 
					    :subtitle="
 | 
				
			||||||
 | 
					      $t('settings.customization.estimates.convert_estimate_description')
 | 
				
			||||||
 | 
					    "
 | 
				
			||||||
 | 
					    >
 | 
				
			||||||
    {{ $tc('settings.customization.estimates.convert_estimate_options') }}
 | 
					    {{ $tc('settings.customization.estimates.convert_estimate_options') }}
 | 
				
			||||||
  </h6>
 | 
					  </BaseHeading>
 | 
				
			||||||
  <p class="mt-1 text-sm text-gray-500">
 | 
					 | 
				
			||||||
    {{ $t('settings.customization.estimates.convert_estimate_description') }}
 | 
					 | 
				
			||||||
  </p>
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
  <BaseInputGroup required>
 | 
					  <BaseInputGroup required>
 | 
				
			||||||
    <BaseRadio
 | 
					    <BaseRadio
 | 
				
			||||||
 | 
				
			|||||||
@ -1,11 +1,13 @@
 | 
				
			|||||||
<template>
 | 
					<template>
 | 
				
			||||||
  <form @submit.prevent="submitForm">
 | 
					  <form @submit.prevent="submitForm">
 | 
				
			||||||
    <h6 class="text-gray-900 text-lg font-medium">
 | 
					    <BaseHeading
 | 
				
			||||||
 | 
					      type="heading-title"
 | 
				
			||||||
 | 
					      :subtitle="
 | 
				
			||||||
 | 
					        $t('settings.customization.estimates.default_formats_description')
 | 
				
			||||||
 | 
					      "
 | 
				
			||||||
 | 
					    >
 | 
				
			||||||
      {{ $t('settings.customization.estimates.default_formats') }}
 | 
					      {{ $t('settings.customization.estimates.default_formats') }}
 | 
				
			||||||
    </h6>
 | 
					    </BaseHeading>
 | 
				
			||||||
    <p class="mt-1 text-sm text-gray-500 mb-2">
 | 
					 | 
				
			||||||
      {{ $t('settings.customization.estimates.default_formats_description') }}
 | 
					 | 
				
			||||||
    </p>
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
    <BaseInputGroup
 | 
					    <BaseInputGroup
 | 
				
			||||||
      :label="
 | 
					      :label="
 | 
				
			||||||
 | 
				
			|||||||
@ -1,11 +1,13 @@
 | 
				
			|||||||
<template>
 | 
					<template>
 | 
				
			||||||
  <form @submit.prevent="submitForm">
 | 
					  <form @submit.prevent="submitForm">
 | 
				
			||||||
    <h6 class="text-gray-900 text-lg font-medium">
 | 
					    <BaseHeading
 | 
				
			||||||
 | 
					      type="heading-title"
 | 
				
			||||||
 | 
					      :subtitle="
 | 
				
			||||||
 | 
					        $t('settings.customization.estimates.expiry_date_description')
 | 
				
			||||||
 | 
					      "
 | 
				
			||||||
 | 
					    >
 | 
				
			||||||
      {{ $t('settings.customization.estimates.expiry_date') }}
 | 
					      {{ $t('settings.customization.estimates.expiry_date') }}
 | 
				
			||||||
    </h6>
 | 
					    </BaseHeading>
 | 
				
			||||||
    <p class="mt-1 text-sm text-gray-500 mb-2">
 | 
					 | 
				
			||||||
      {{ $t('settings.customization.estimates.expiry_date_description') }}
 | 
					 | 
				
			||||||
    </p>
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
    <BaseSwitchSection
 | 
					    <BaseSwitchSection
 | 
				
			||||||
      v-model="expiryDateAutoField"
 | 
					      v-model="expiryDateAutoField"
 | 
				
			||||||
 | 
				
			|||||||
@ -1,11 +1,13 @@
 | 
				
			|||||||
<template>
 | 
					<template>
 | 
				
			||||||
  <form @submit.prevent="submitForm">
 | 
					  <form @submit.prevent="submitForm">
 | 
				
			||||||
    <h6 class="text-gray-900 text-lg font-medium">
 | 
					    <BaseHeading
 | 
				
			||||||
 | 
					      type="heading-title"
 | 
				
			||||||
 | 
					      :subtitle="
 | 
				
			||||||
 | 
					        $t('settings.customization.invoices.default_formats_description')
 | 
				
			||||||
 | 
					      "
 | 
				
			||||||
 | 
					    >
 | 
				
			||||||
      {{ $t('settings.customization.invoices.default_formats') }}
 | 
					      {{ $t('settings.customization.invoices.default_formats') }}
 | 
				
			||||||
    </h6>
 | 
					    </BaseHeading>
 | 
				
			||||||
    <p class="mt-1 text-sm text-gray-500 mb-2">
 | 
					 | 
				
			||||||
      {{ $t('settings.customization.invoices.default_formats_description') }}
 | 
					 | 
				
			||||||
    </p>
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
    <BaseInputGroup
 | 
					    <BaseInputGroup
 | 
				
			||||||
      :label="$t('settings.customization.invoices.default_invoice_email_body')"
 | 
					      :label="$t('settings.customization.invoices.default_invoice_email_body')"
 | 
				
			||||||
 | 
				
			|||||||
@ -1,11 +1,13 @@
 | 
				
			|||||||
<template>
 | 
					<template>
 | 
				
			||||||
  <form @submit.prevent="submitForm">
 | 
					  <form @submit.prevent="submitForm">
 | 
				
			||||||
    <h6 class="text-gray-900 text-lg font-medium">
 | 
					    <BaseHeading
 | 
				
			||||||
      {{ $t('settings.customization.invoices.due_date') }}
 | 
					    type="heading-title"
 | 
				
			||||||
    </h6>
 | 
					    :subtitle="
 | 
				
			||||||
    <p class="mt-1 text-sm text-gray-500 mb-2">
 | 
					      $t('settings.customization.invoices.due_date_description')
 | 
				
			||||||
      {{ $t('settings.customization.invoices.due_date_description') }}
 | 
					    "
 | 
				
			||||||
    </p>
 | 
					  >
 | 
				
			||||||
 | 
					    {{ $t('settings.customization.invoices.due_date') }}
 | 
				
			||||||
 | 
					  </BaseHeading>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    <BaseSwitchSection
 | 
					    <BaseSwitchSection
 | 
				
			||||||
      v-model="dueDateAutoField"
 | 
					      v-model="dueDateAutoField"
 | 
				
			||||||
 | 
				
			|||||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user