mirror of
https://github.com/crater-invoice/crater.git
synced 2025-10-28 12:11:08 -04:00
Compare commits
3 Commits
dark-label
...
dark-statu
| Author | SHA1 | Date | |
|---|---|---|---|
| e06ac0f7a3 | |||
| 8841bcf499 | |||
| 503b9d6a8f |
@ -7,7 +7,6 @@
|
|||||||
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
|
||||||
@ -20,7 +19,6 @@
|
|||||||
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,7 +91,6 @@
|
|||||||
leading-tight
|
leading-tight
|
||||||
text-gray-700
|
text-gray-700
|
||||||
cursor-pointer
|
cursor-pointer
|
||||||
dark:text-gray-400
|
|
||||||
"
|
"
|
||||||
>
|
>
|
||||||
{{ note.name }}
|
{{ note.name }}
|
||||||
|
|||||||
@ -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 dark:text-gray-300">
|
<label class="text-gray-800 font-medium mb-4 text-sm">
|
||||||
{{ $t('invoices.notes') }}
|
{{ $t('invoices.notes') }}
|
||||||
</label>
|
</label>
|
||||||
<BaseCustomInput
|
<BaseCustomInput
|
||||||
|
|||||||
@ -29,16 +29,7 @@
|
|||||||
|
|
||||||
<label
|
<label
|
||||||
v-else
|
v-else
|
||||||
class="
|
class="flex items-center justify-center m-0 text-lg text-black uppercase "
|
||||||
flex
|
|
||||||
items-center
|
|
||||||
justify-center
|
|
||||||
m-0
|
|
||||||
text-lg
|
|
||||||
text-black
|
|
||||||
dark:text-white
|
|
||||||
uppercase
|
|
||||||
"
|
|
||||||
>
|
>
|
||||||
<BaseFormatMoney
|
<BaseFormatMoney
|
||||||
:amount="store.getSubTotal"
|
:amount="store.getSubTotal"
|
||||||
@ -68,16 +59,7 @@
|
|||||||
|
|
||||||
<label
|
<label
|
||||||
v-else-if="store[storeProp].tax_per_item === 'YES'"
|
v-else-if="store[storeProp].tax_per_item === 'YES'"
|
||||||
class="
|
class="flex items-center justify-center m-0 text-lg text-black uppercase "
|
||||||
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>
|
||||||
@ -184,15 +166,7 @@
|
|||||||
</div>
|
</div>
|
||||||
|
|
||||||
<div
|
<div
|
||||||
class="
|
class="flex items-center justify-between w-full pt-2 mt-5 border-t border-gray-200 border-solid "
|
||||||
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,18 +1,9 @@
|
|||||||
<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 dark:text-gray-300">
|
<label class="font-semibold leading-5 text-gray-500 uppercase">
|
||||||
{{ tax.name }} ({{ tax.percent }} %)
|
{{ tax.name }} ({{ tax.percent }} %)
|
||||||
</label>
|
</label>
|
||||||
<label
|
<label class="flex items-center justify-center text-lg text-black">
|
||||||
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,7 +96,6 @@
|
|||||||
leading-tight
|
leading-tight
|
||||||
text-gray-700
|
text-gray-700
|
||||||
cursor-pointer
|
cursor-pointer
|
||||||
dark:text-gray-300
|
|
||||||
"
|
"
|
||||||
>
|
>
|
||||||
{{ taxType.name }}
|
{{ taxType.name }}
|
||||||
@ -109,7 +108,6 @@
|
|||||||
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 dark:text-gray-300">
|
<label class="flex text-gray-800 font-medium text-sm mb-2">
|
||||||
{{ $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>
|
||||||
|
|||||||
@ -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 dark:text-gray-300">
|
<p class="text-sm text-gray-500">
|
||||||
{{ $t('customers.portal_access_text') }}
|
{{ $t('customers.portal_access_text') }}
|
||||||
</p>
|
</p>
|
||||||
|
|
||||||
|
|||||||
@ -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 dark:text-gray-300">
|
<p class="text-sm text-gray-500">
|
||||||
{{ $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 dark:border-gray-600">
|
<div class="pt-6 mt-5 border-t border-solid lg:pt-8 md:pt-4 border-gray-200">
|
||||||
<!-- Basic Info -->
|
<!-- Basic Info -->
|
||||||
<BaseHeading>
|
<BaseHeading>
|
||||||
{{ $t('customers.basic_info') }}
|
{{ $t('customers.basic_info') }}
|
||||||
|
|||||||
@ -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 dark:text-gray-300">
|
<label class="flex items-center justify-center text-gray-500">
|
||||||
{{ $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 dark:text-white">
|
<h6 class="text-gray-900 text-lg font-medium">
|
||||||
{{ $t('modules.connect_installation') }}
|
{{ $t('modules.connect_installation') }}
|
||||||
</h6>
|
</h6>
|
||||||
<p class="mt-1 text-sm text-gray-500 dark:text-gray-400">
|
<p class="mt-1 text-sm text-gray-500">
|
||||||
{{
|
{{
|
||||||
$t('modules.api_token_description', {
|
$t('modules.api_token_description', {
|
||||||
url: globalStore.config.base_url.replace(/^http:\/\//, ''),
|
url: globalStore.config.base_url.replace(/^http:\/\//, ''),
|
||||||
|
|||||||
@ -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 dark:text-gray-300">
|
<label class="mb-4 text-sm font-medium text-gray-800">
|
||||||
{{ $t('estimates.notes') }}
|
{{ $t('estimates.notes') }}
|
||||||
</label>
|
</label>
|
||||||
|
|
||||||
|
|||||||
@ -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 dark:text-white">
|
<p class="p-0 mb-1 leading-snug text-left text-black">
|
||||||
{{ $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 dark:text-gray-400"
|
class="p-0 m-0 text-xs leading-tight text-left text-gray-500"
|
||||||
style="max-width: 480px"
|
style="max-width: 480px"
|
||||||
>
|
>
|
||||||
{{ $t('recurring_invoices.send_automatically_desc') }}
|
{{ $t('recurring_invoices.send_automatically_desc') }}
|
||||||
|
|||||||
@ -113,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 dark:text-white">
|
<h3 class="text-lg leading-6 font-medium text-gray-900">
|
||||||
{{ $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 dark:text-gray-400">
|
<div class="mt-2 max-w-xl text-sm text-gray-500">
|
||||||
<p>
|
<p>
|
||||||
{{ $tc('settings.company_info.delete_company_description') }}
|
{{ $tc('settings.company_info.delete_company_description') }}
|
||||||
</p>
|
</p>
|
||||||
|
|||||||
@ -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 dark:text-gray-400"> ({{ row.data.slug }})</span>
|
<span class="text-xs text-gray-500"> ({{ row.data.slug }})</span>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<template #cell-is_required="{ row }">
|
<template #cell-is_required="{ row }">
|
||||||
@ -60,7 +60,7 @@
|
|||||||
<CustomFieldDropdown
|
<CustomFieldDropdown
|
||||||
:row="row.data"
|
:row="row.data"
|
||||||
:table="table"
|
:table="table"
|
||||||
:load-data="refreshTable"
|
:load-data="refreshTable"
|
||||||
/>
|
/>
|
||||||
</template>
|
</template>
|
||||||
</BaseTable>
|
</BaseTable>
|
||||||
|
|||||||
@ -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 dark:text-gray-400"
|
class="mt-2 text-sm leading-snug text-left text-gray-500"
|
||||||
style="max-width: 680px"
|
style="max-width: 680px"
|
||||||
>
|
>
|
||||||
{{ $t('settings.exchange_rate.providers_description') }}
|
{{ $t('settings.exchange_rate.providers_description') }}
|
||||||
|
|||||||
@ -4,14 +4,23 @@
|
|||||||
: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
|
<label class="text-sm not-italic font-medium input-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="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"
|
class="
|
||||||
|
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>
|
||||||
@ -33,20 +42,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 dark:bg-gray-600">
|
<div class="rounded-md bg-primary-50 p-4 mb-3">
|
||||||
<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 dark:text-primary-300"
|
class="h-5 w-5 text-primary-400"
|
||||||
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 dark:text-primary-300">
|
<h3 class="text-sm font-medium text-primary-800">
|
||||||
{{ $t('general.note') }}
|
{{ $t('general.note') }}
|
||||||
</h3>
|
</h3>
|
||||||
<div class="mt-2 text-sm text-primary-700 dark:text-primary-400">
|
<div class="mt-2 text-sm text-primary-700">
|
||||||
<p>
|
<p>
|
||||||
{{ $t('settings.update_app.update_warning') }}
|
{{ $t('settings.update_app.update_warning') }}
|
||||||
</p>
|
</p>
|
||||||
@ -66,20 +75,26 @@
|
|||||||
w-16
|
w-16
|
||||||
p-3
|
p-3
|
||||||
my-2
|
my-2
|
||||||
text-sm
|
text-sm text-gray-600
|
||||||
text-gray-600 bg-gray-200
|
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="pl-5 mt-4 mb-8 text-sm leading-snug text-gray-500 update-description"
|
class="
|
||||||
|
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>
|
||||||
@ -135,7 +150,14 @@
|
|||||||
<li
|
<li
|
||||||
v-for="step in updateSteps"
|
v-for="step in updateSteps"
|
||||||
:key="step.stepUrl"
|
:key="step.stepUrl"
|
||||||
class="flex justify-between w-full py-3 border-b border-gray-200 border-solid last:border-b-0"
|
class="
|
||||||
|
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>
|
||||||
<BaseHeading
|
<h6 class="text-gray-900 text-lg font-medium">
|
||||||
type="heading-title"
|
|
||||||
:subtitle="
|
|
||||||
$t(`settings.customization.${type}s.${type}_number_format_description`)
|
|
||||||
"
|
|
||||||
>
|
|
||||||
{{ $t(`settings.customization.${type}s.${type}_number_format`) }}
|
{{ $t(`settings.customization.${type}s.${type}_number_format`) }}
|
||||||
</BaseHeading>
|
</h6>
|
||||||
|
<p class="mt-1 text-sm text-gray-500">
|
||||||
|
{{
|
||||||
|
$t(`settings.customization.${type}s.${type}_number_format_description`)
|
||||||
|
}}
|
||||||
|
</p>
|
||||||
|
|
||||||
<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,7 +29,6 @@
|
|||||||
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
|
||||||
@ -42,7 +41,6 @@
|
|||||||
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
|
||||||
@ -57,7 +55,6 @@
|
|||||||
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
|
||||||
@ -72,14 +69,13 @@
|
|||||||
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 dark:divide-gray-600"
|
class="divide-y divide-gray-200"
|
||||||
item-key="id"
|
item-key="id"
|
||||||
tag="tbody"
|
tag="tbody"
|
||||||
handle=".handle"
|
handle=".handle"
|
||||||
@ -101,13 +97,12 @@
|
|||||||
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 dark:text-gray-400 mt-1">
|
<p class="text-xs text-gray-500 mt-1">
|
||||||
{{ element.description }}
|
{{ element.description }}
|
||||||
</p>
|
</p>
|
||||||
</td>
|
</td>
|
||||||
|
|||||||
@ -1,12 +1,10 @@
|
|||||||
<template>
|
<template>
|
||||||
<BaseHeading
|
<h6 class="text-gray-900 text-lg font-medium">
|
||||||
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') }}
|
||||||
</BaseHeading>
|
</h6>
|
||||||
|
<p class="mt-1 text-sm text-gray-500">
|
||||||
|
{{ $t('settings.customization.estimates.convert_estimate_description') }}
|
||||||
|
</p>
|
||||||
|
|
||||||
<BaseInputGroup required>
|
<BaseInputGroup required>
|
||||||
<BaseRadio
|
<BaseRadio
|
||||||
|
|||||||
@ -1,13 +1,11 @@
|
|||||||
<template>
|
<template>
|
||||||
<form @submit.prevent="submitForm">
|
<form @submit.prevent="submitForm">
|
||||||
<BaseHeading
|
<h6 class="text-gray-900 text-lg font-medium">
|
||||||
type="heading-title"
|
|
||||||
:subtitle="
|
|
||||||
$t('settings.customization.estimates.default_formats_description')
|
|
||||||
"
|
|
||||||
>
|
|
||||||
{{ $t('settings.customization.estimates.default_formats') }}
|
{{ $t('settings.customization.estimates.default_formats') }}
|
||||||
</BaseHeading>
|
</h6>
|
||||||
|
<p class="mt-1 text-sm text-gray-500 mb-2">
|
||||||
|
{{ $t('settings.customization.estimates.default_formats_description') }}
|
||||||
|
</p>
|
||||||
|
|
||||||
<BaseInputGroup
|
<BaseInputGroup
|
||||||
:label="
|
:label="
|
||||||
|
|||||||
@ -1,13 +1,11 @@
|
|||||||
<template>
|
<template>
|
||||||
<form @submit.prevent="submitForm">
|
<form @submit.prevent="submitForm">
|
||||||
<BaseHeading
|
<h6 class="text-gray-900 text-lg font-medium">
|
||||||
type="heading-title"
|
|
||||||
:subtitle="
|
|
||||||
$t('settings.customization.estimates.expiry_date_description')
|
|
||||||
"
|
|
||||||
>
|
|
||||||
{{ $t('settings.customization.estimates.expiry_date') }}
|
{{ $t('settings.customization.estimates.expiry_date') }}
|
||||||
</BaseHeading>
|
</h6>
|
||||||
|
<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,13 +1,11 @@
|
|||||||
<template>
|
<template>
|
||||||
<form @submit.prevent="submitForm">
|
<form @submit.prevent="submitForm">
|
||||||
<BaseHeading
|
<h6 class="text-gray-900 text-lg font-medium">
|
||||||
type="heading-title"
|
|
||||||
:subtitle="
|
|
||||||
$t('settings.customization.invoices.default_formats_description')
|
|
||||||
"
|
|
||||||
>
|
|
||||||
{{ $t('settings.customization.invoices.default_formats') }}
|
{{ $t('settings.customization.invoices.default_formats') }}
|
||||||
</BaseHeading>
|
</h6>
|
||||||
|
<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,13 +1,11 @@
|
|||||||
<template>
|
<template>
|
||||||
<form @submit.prevent="submitForm">
|
<form @submit.prevent="submitForm">
|
||||||
<BaseHeading
|
<h6 class="text-gray-900 text-lg font-medium">
|
||||||
type="heading-title"
|
{{ $t('settings.customization.invoices.due_date') }}
|
||||||
:subtitle="
|
</h6>
|
||||||
$t('settings.customization.invoices.due_date_description')
|
<p class="mt-1 text-sm text-gray-500 mb-2">
|
||||||
"
|
{{ $t('settings.customization.invoices.due_date_description') }}
|
||||||
>
|
</p>
|
||||||
{{ $t('settings.customization.invoices.due_date') }}
|
|
||||||
</BaseHeading>
|
|
||||||
|
|
||||||
<BaseSwitchSection
|
<BaseSwitchSection
|
||||||
v-model="dueDateAutoField"
|
v-model="dueDateAutoField"
|
||||||
|
|||||||
@ -1,12 +1,10 @@
|
|||||||
<template>
|
<template>
|
||||||
<BaseHeading
|
<h6 class="text-gray-900 text-lg font-medium">
|
||||||
type="heading-title"
|
|
||||||
:subtitle="
|
|
||||||
$t('settings.customization.invoices.retrospective_edits_description')
|
|
||||||
"
|
|
||||||
>
|
|
||||||
{{ $tc('settings.customization.invoices.retrospective_edits') }}
|
{{ $tc('settings.customization.invoices.retrospective_edits') }}
|
||||||
</BaseHeading>
|
</h6>
|
||||||
|
<p class="mt-1 text-sm text-gray-500">
|
||||||
|
{{ $t('settings.customization.invoices.retrospective_edits_description') }}
|
||||||
|
</p>
|
||||||
|
|
||||||
<BaseInputGroup required>
|
<BaseInputGroup required>
|
||||||
<BaseRadio
|
<BaseRadio
|
||||||
|
|||||||
@ -1,13 +1,11 @@
|
|||||||
<template>
|
<template>
|
||||||
<form @submit.prevent="submitForm">
|
<form @submit.prevent="submitForm">
|
||||||
<BaseHeading
|
<h6 class="text-gray-900 text-lg font-medium">
|
||||||
type="heading-title"
|
|
||||||
:subtitle="
|
|
||||||
$t('settings.customization.payments.default_formats_description')
|
|
||||||
"
|
|
||||||
>
|
|
||||||
{{ $t('settings.customization.payments.default_formats') }}
|
{{ $t('settings.customization.payments.default_formats') }}
|
||||||
</BaseHeading>
|
</h6>
|
||||||
|
<p class="mt-1 text-sm text-gray-500 mb-2">
|
||||||
|
{{ $t('settings.customization.payments.default_formats_description') }}
|
||||||
|
</p>
|
||||||
|
|
||||||
<BaseInputGroup
|
<BaseInputGroup
|
||||||
:label="$t('settings.customization.payments.default_payment_email_body')"
|
:label="$t('settings.customization.payments.default_payment_email_body')"
|
||||||
|
|||||||
@ -439,7 +439,7 @@ export default {
|
|||||||
container:
|
container:
|
||||||
'p-0 relative mx-auto w-full flex items-center justify-end box-border cursor-pointer border border-gray-200 dark:border-gray-600 rounded-md bg-white dark:bg-gray-700 text-sm leading-snug outline-none max-h-10',
|
'p-0 relative mx-auto w-full flex items-center justify-end box-border cursor-pointer border border-gray-200 dark:border-gray-600 rounded-md bg-white dark:bg-gray-700 text-sm leading-snug outline-none max-h-10',
|
||||||
containerDisabled:
|
containerDisabled:
|
||||||
'bg-gray-200 !text-gray-800 dark:!text-gray-800 !dark:text-gray-500 !cursor-not-allowed dark:opacity-50',
|
'bg-gray-200 bg-opacity-50 !text-gray-400 dark:!text-gray-800 !dark:text-gray-500 !cursor-default dark:opacity-25',
|
||||||
containerOpen: '',
|
containerOpen: '',
|
||||||
containerOpenTop: '',
|
containerOpenTop: '',
|
||||||
containerActive: 'ring-1 ring-primary-400 border-primary-400',
|
containerActive: 'ring-1 ring-primary-400 border-primary-400',
|
||||||
|
|||||||
@ -15,12 +15,12 @@
|
|||||||
v-if="label"
|
v-if="label"
|
||||||
:for="id"
|
:for="id"
|
||||||
:class="`font-medium ${
|
:class="`font-medium ${
|
||||||
disabled ? 'text-gray-400 cursor-not-allowed' : 'text-gray-600 dark:text-white'
|
disabled ? 'text-gray-400 cursor-not-allowed' : 'text-gray-600'
|
||||||
} cursor-pointer `"
|
} cursor-pointer `"
|
||||||
>
|
>
|
||||||
{{ label }}
|
{{ label }}
|
||||||
</label>
|
</label>
|
||||||
<p v-if="description" class="text-gray-500 dark:text-gray-400">{{ description }}</p>
|
<p v-if="description" class="text-gray-500">{{ description }}</p>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
@ -51,7 +51,7 @@ const props = defineProps({
|
|||||||
},
|
},
|
||||||
checkboxClass: {
|
checkboxClass: {
|
||||||
type: String,
|
type: String,
|
||||||
default: 'w-4 h-4 border-gray-300 rounded cursor-pointer dark:bg-gray-600 dark:border-gray-500',
|
default: 'w-4 h-4 border-gray-300 rounded cursor-pointer',
|
||||||
},
|
},
|
||||||
setInitialValue: {
|
setInitialValue: {
|
||||||
type: Boolean,
|
type: Boolean,
|
||||||
|
|||||||
@ -40,7 +40,6 @@
|
|||||||
font-normal
|
font-normal
|
||||||
cursor-pointer
|
cursor-pointer
|
||||||
hover:bg-gray-100
|
hover:bg-gray-100
|
||||||
dark:hover:bg-gray-700/60
|
|
||||||
rounded
|
rounded
|
||||||
ml-1
|
ml-1
|
||||||
py-0.5
|
py-0.5
|
||||||
|
|||||||
@ -1,7 +1,7 @@
|
|||||||
<template>
|
<template>
|
||||||
<div
|
<div
|
||||||
v-if="address"
|
v-if="address"
|
||||||
class="text-sm font-bold leading-5 text-black non-italic space-y-1 dark:text-white"
|
class="text-sm font-bold leading-5 text-black non-italic space-y-1"
|
||||||
>
|
>
|
||||||
<p v-if="address?.address_street_1">{{ address?.address_street_1 }},</p>
|
<p v-if="address?.address_street_1">{{ address?.address_street_1 }},</p>
|
||||||
|
|
||||||
|
|||||||
@ -20,7 +20,6 @@
|
|||||||
border border-gray-200 border-solid
|
border border-gray-200 border-solid
|
||||||
min-h-[170px]
|
min-h-[170px]
|
||||||
rounded-md
|
rounded-md
|
||||||
dark:border-white/10 dark:bg-gray-800/50
|
|
||||||
"
|
"
|
||||||
@click.stop
|
@click.stop
|
||||||
>
|
>
|
||||||
@ -28,7 +27,7 @@
|
|||||||
<BaseText
|
<BaseText
|
||||||
:text="selectedCustomer.name"
|
:text="selectedCustomer.name"
|
||||||
:length="30"
|
:length="30"
|
||||||
class="flex-1 text-base font-medium text-left text-gray-900 dark:text-white"
|
class="flex-1 text-base font-medium text-left text-gray-900"
|
||||||
/>
|
/>
|
||||||
<div class="flex">
|
<div class="flex">
|
||||||
<a
|
<a
|
||||||
@ -193,7 +192,6 @@
|
|||||||
border border-gray-200 border-solid
|
border border-gray-200 border-solid
|
||||||
rounded-md
|
rounded-md
|
||||||
min-h-[170px]
|
min-h-[170px]
|
||||||
dark:border-white/10 dark:bg-gray-700/60 dark:text-white
|
|
||||||
"
|
"
|
||||||
>
|
>
|
||||||
<BaseIcon
|
<BaseIcon
|
||||||
@ -209,12 +207,11 @@
|
|||||||
bg-gray-200
|
bg-gray-200
|
||||||
rounded-full
|
rounded-full
|
||||||
font-base
|
font-base
|
||||||
dark:bg-gray-700
|
|
||||||
"
|
"
|
||||||
/>
|
/>
|
||||||
|
|
||||||
<div class="mt-1">
|
<div class="mt-1">
|
||||||
<label class="text-lg font-medium text-gray-900 dark:text-white">
|
<label class="text-lg font-medium text-gray-900">
|
||||||
{{ $t('customers.new_customer') }}
|
{{ $t('customers.new_customer') }}
|
||||||
<span class="text-red-500"> * </span>
|
<span class="text-red-500"> * </span>
|
||||||
</label>
|
</label>
|
||||||
@ -249,11 +246,6 @@
|
|||||||
shadow-lg
|
shadow-lg
|
||||||
ring-1 ring-black ring-opacity-5
|
ring-1 ring-black ring-opacity-5
|
||||||
bg-white
|
bg-white
|
||||||
dark:border
|
|
||||||
dark:border-white/10
|
|
||||||
dark:bg-gray-800
|
|
||||||
dark:text-white
|
|
||||||
dark:shadow-glass
|
|
||||||
"
|
"
|
||||||
>
|
>
|
||||||
<div class="relative">
|
<div class="relative">
|
||||||
@ -273,7 +265,6 @@
|
|||||||
overflow-auto
|
overflow-auto
|
||||||
list
|
list
|
||||||
border-t border-gray-200
|
border-t border-gray-200
|
||||||
dark:border-white/10
|
|
||||||
"
|
"
|
||||||
>
|
>
|
||||||
<li
|
<li
|
||||||
@ -289,7 +280,6 @@
|
|||||||
hover:cursor-pointer hover:bg-gray-100
|
hover:cursor-pointer hover:bg-gray-100
|
||||||
focus:outline-none focus:bg-gray-100
|
focus:outline-none focus:bg-gray-100
|
||||||
last:border-b-0
|
last:border-b-0
|
||||||
dark:border-white/10 dark:hover:bg-gray-700/30
|
|
||||||
"
|
"
|
||||||
@click="selectNewCustomer(customer.id, close)"
|
@click="selectNewCustomer(customer.id, close)"
|
||||||
>
|
>
|
||||||
@ -309,7 +299,6 @@
|
|||||||
bg-gray-300
|
bg-gray-300
|
||||||
rounded-full
|
rounded-full
|
||||||
avatar
|
avatar
|
||||||
dark:bg-gray-600
|
|
||||||
"
|
"
|
||||||
>
|
>
|
||||||
{{ initGenerator(customer.name) }}
|
{{ initGenerator(customer.name) }}
|
||||||
@ -344,9 +333,9 @@
|
|||||||
</li>
|
</li>
|
||||||
<div
|
<div
|
||||||
v-if="customerStore.customers.length === 0"
|
v-if="customerStore.customers.length === 0"
|
||||||
class="flex justify-center p-5 text-gray-400 dark:text-gray-300"
|
class="flex justify-center p-5 text-gray-400"
|
||||||
>
|
>
|
||||||
<label class="text-base text-gray-500 cursor-pointer dark:text-gray-300">
|
<label class="text-base text-gray-500 cursor-pointer">
|
||||||
{{ $t('customers.no_customers_found') }}
|
{{ $t('customers.no_customers_found') }}
|
||||||
</label>
|
</label>
|
||||||
</div>
|
</div>
|
||||||
@ -368,10 +357,6 @@
|
|||||||
border-none
|
border-none
|
||||||
outline-none
|
outline-none
|
||||||
focus:bg-gray-300
|
focus:bg-gray-300
|
||||||
dark:bg-gray-600/70
|
|
||||||
dark:shadow-glass
|
|
||||||
dark:backdrop-blur-xl
|
|
||||||
dark:hover:bg-gray-600/80
|
|
||||||
"
|
"
|
||||||
@click="openCustomerModal"
|
@click="openCustomerModal"
|
||||||
>
|
>
|
||||||
|
|||||||
@ -10,7 +10,7 @@
|
|||||||
{{ label }}
|
{{ label }}
|
||||||
</BaseLabel>
|
</BaseLabel>
|
||||||
|
|
||||||
<p class="text-sm font-bold leading-5 text-black non-italic dark:text-white">
|
<p class="text-sm font-bold leading-5 text-black non-italic">
|
||||||
{{ value }}
|
{{ value }}
|
||||||
|
|
||||||
<slot />
|
<slot />
|
||||||
|
|||||||
@ -1,3 +1,3 @@
|
|||||||
<template>
|
<template>
|
||||||
<div class="w-full h-px bg-gray-300 dark:bg-gray-600" />
|
<hr class="w-full text-gray-300" />
|
||||||
</template>
|
</template>
|
||||||
|
|||||||
@ -1,24 +1,18 @@
|
|||||||
<template>
|
<template>
|
||||||
<div class="flex flex-col items-center justify-center mt-16">
|
<div class="flex flex-col items-center justify-center mt-16">
|
||||||
<div class="relative">
|
<div class="flex flex-col items-center justify-center">
|
||||||
<BaseDarkHighlight class="bg-highlight/[.07] top-2" />
|
<slot></slot>
|
||||||
|
</div>
|
||||||
<div class="relative z-5 flex flex-col items-center">
|
<div class="mt-2">
|
||||||
<div class="flex flex-col items-center justify-center">
|
<label class="font-medium">{{ title }}</label>
|
||||||
<slot />
|
</div>
|
||||||
</div>
|
<div class="mt-2">
|
||||||
<div class="mt-2">
|
<label class="text-gray-500">
|
||||||
<label class="font-medium">{{ title }}</label>
|
{{ description }}
|
||||||
</div>
|
</label>
|
||||||
<div class="mt-2 text-center md:text-left">
|
</div>
|
||||||
<label class="text-gray-500 dark:text-gray-400">
|
<div class="mt-6">
|
||||||
{{ description }}
|
<slot name="actions" />
|
||||||
</label>
|
|
||||||
</div>
|
|
||||||
<div class="mt-6">
|
|
||||||
<slot name="actions" />
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
|
|||||||
@ -1,18 +1,11 @@
|
|||||||
<template>
|
<template>
|
||||||
<div
|
<div class="rounded-md bg-red-50 p-4">
|
||||||
class="
|
|
||||||
rounded-md
|
|
||||||
bg-red-50
|
|
||||||
p-4
|
|
||||||
dark:border dark:border-red-400 dark:bg-transparent
|
|
||||||
"
|
|
||||||
>
|
|
||||||
<div class="flex">
|
<div class="flex">
|
||||||
<div class="shrink-0">
|
<div class="shrink-0">
|
||||||
<XCircleIcon class="h-5 w-5 text-red-400 dark:text-red-500" aria-hidden="true" />
|
<XCircleIcon class="h-5 w-5 text-red-400" aria-hidden="true" />
|
||||||
</div>
|
</div>
|
||||||
<div class="ml-3">
|
<div class="ml-3">
|
||||||
<h3 class="text-sm font-medium text-red-800 dark:text-red-500">
|
<h3 class="text-sm font-medium text-red-800">
|
||||||
{{ errorTitle }}
|
{{ errorTitle }}
|
||||||
</h3>
|
</h3>
|
||||||
<div class="mt-2 text-sm text-red-700">
|
<div class="mt-2 text-sm text-red-700">
|
||||||
|
|||||||
@ -2,21 +2,6 @@
|
|||||||
<h6 :class="typeClass">
|
<h6 :class="typeClass">
|
||||||
<slot />
|
<slot />
|
||||||
</h6>
|
</h6>
|
||||||
|
|
||||||
<p
|
|
||||||
v-if="subtitle"
|
|
||||||
class="
|
|
||||||
mt-2
|
|
||||||
text-sm
|
|
||||||
leading-snug
|
|
||||||
text-gray-500
|
|
||||||
dark:text-gray-400
|
|
||||||
max-w-[680px]
|
|
||||||
"
|
|
||||||
>
|
|
||||||
{{ subtitle }}
|
|
||||||
</p>
|
|
||||||
|
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script setup>
|
<script setup>
|
||||||
@ -29,16 +14,12 @@ const props = defineProps({
|
|||||||
return ['section-title', 'heading-title'].indexOf(value) !== -1
|
return ['section-title', 'heading-title'].indexOf(value) !== -1
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
subtitle: {
|
|
||||||
type: String,
|
|
||||||
default: '',
|
|
||||||
},
|
|
||||||
})
|
})
|
||||||
|
|
||||||
const typeClass = computed(() => {
|
const typeClass = computed(() => {
|
||||||
return {
|
return {
|
||||||
'text-gray-900 text-lg font-medium dark:text-white': props.type === 'heading-title',
|
'text-gray-900 text-lg font-medium': props.type === 'heading-title',
|
||||||
'text-gray-500 uppercase text-base dark:text-gray-300': props.type === 'section-title',
|
'text-gray-500 uppercase text-base': props.type === 'section-title',
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
</script>
|
</script>
|
||||||
|
|||||||
@ -15,7 +15,6 @@
|
|||||||
text-gray-800
|
text-gray-800
|
||||||
whitespace-nowrap
|
whitespace-nowrap
|
||||||
justify-between
|
justify-between
|
||||||
dark:text-gray-300
|
|
||||||
"
|
"
|
||||||
>
|
>
|
||||||
<div>
|
<div>
|
||||||
@ -32,7 +31,7 @@
|
|||||||
</label>
|
</label>
|
||||||
<div :class="inputContainerClasses">
|
<div :class="inputContainerClasses">
|
||||||
<slot></slot>
|
<slot></slot>
|
||||||
<span v-if="helpText" class="text-gray-500 text-xs mt-1 font-light dark:text-gray-400">
|
<span v-if="helpText" class="text-gray-500 text-xs mt-1 font-light">
|
||||||
{{ helpText }}
|
{{ helpText }}
|
||||||
</span>
|
</span>
|
||||||
<span v-if="error" class="block mt-0.5 text-sm text-red-500">
|
<span v-if="error" class="block mt-0.5 text-sm text-red-500">
|
||||||
|
|||||||
@ -12,7 +12,6 @@
|
|||||||
bg-gray-200
|
bg-gray-200
|
||||||
border border-gray-200 border-solid
|
border border-gray-200 border-solid
|
||||||
rounded
|
rounded
|
||||||
dark:bg-gray-900/70 dark:border-gray-700
|
|
||||||
"
|
"
|
||||||
>
|
>
|
||||||
{{ item.name }}
|
{{ item.name }}
|
||||||
|
|||||||
@ -1,5 +1,5 @@
|
|||||||
<template>
|
<template>
|
||||||
<label class="text-sm not-italic font-medium leading-5 text-gray-500 dark:text-gray-300">
|
<label class="text-sm not-italic font-medium leading-5 text-primary-800">
|
||||||
<slot />
|
<slot />
|
||||||
</label>
|
</label>
|
||||||
</template>
|
</template>
|
||||||
|
|||||||
@ -39,7 +39,7 @@ const props = defineProps({
|
|||||||
inputClass: {
|
inputClass: {
|
||||||
type: String,
|
type: String,
|
||||||
default:
|
default:
|
||||||
'font-base block w-full sm:text-sm border-gray-200 rounded-md text-black dark:bg-gray-700 dark:border-gray-600 dark:text-white dark:placeholder-gray-500',
|
'font-base block w-full sm:text-sm border-gray-200 rounded-md text-black',
|
||||||
},
|
},
|
||||||
disabled: {
|
disabled: {
|
||||||
type: Boolean,
|
type: Boolean,
|
||||||
@ -86,7 +86,7 @@ const currencyBindings = computed(() => {
|
|||||||
|
|
||||||
const invalidClass = computed(() => {
|
const invalidClass = computed(() => {
|
||||||
if (props.invalid) {
|
if (props.invalid) {
|
||||||
return 'border-red-500 dark:border-red-500 ring-red-500 dark:ring-red-500 focus:ring-red-500 dark:focus:ring-red-500 focus:border-red-500 dark:focus:border-red-500'
|
return 'border-red-500 ring-red-500 focus:ring-red-500 focus:border-red-500'
|
||||||
}
|
}
|
||||||
return 'focus:ring-primary-400 focus:border-primary-400'
|
return 'focus:ring-primary-400 focus:border-primary-400'
|
||||||
})
|
})
|
||||||
|
|||||||
@ -19,7 +19,7 @@
|
|||||||
]"
|
]"
|
||||||
aria-hidden="true"
|
aria-hidden="true"
|
||||||
>
|
>
|
||||||
<span class="rounded-full w-1.5 h-1.5" :class="{ 'bg-white': checked }"/>
|
<span class="rounded-full bg-white w-1.5 h-1.5" />
|
||||||
</span>
|
</span>
|
||||||
<div class="flex flex-col ml-3">
|
<div class="flex flex-col ml-3">
|
||||||
<RadioGroupLabel
|
<RadioGroupLabel
|
||||||
@ -66,11 +66,11 @@ const props = defineProps({
|
|||||||
},
|
},
|
||||||
checkedStateClass: {
|
checkedStateClass: {
|
||||||
type: String,
|
type: String,
|
||||||
default: 'bg-primary-600 ',
|
default: 'bg-primary-600',
|
||||||
},
|
},
|
||||||
unCheckedStateClass: {
|
unCheckedStateClass: {
|
||||||
type: String,
|
type: String,
|
||||||
default: 'bg-white dark:bg-transparent',
|
default: 'bg-white ',
|
||||||
},
|
},
|
||||||
optionGroupActiveStateClass: {
|
optionGroupActiveStateClass: {
|
||||||
type: String,
|
type: String,
|
||||||
@ -78,16 +78,16 @@ const props = defineProps({
|
|||||||
},
|
},
|
||||||
checkedStateLabelClass: {
|
checkedStateLabelClass: {
|
||||||
type: String,
|
type: String,
|
||||||
default: 'text-primary-900 dark:text-primary-400',
|
default: 'text-primary-900 ',
|
||||||
},
|
},
|
||||||
unCheckedStateLabelClass: {
|
unCheckedStateLabelClass: {
|
||||||
type: String,
|
type: String,
|
||||||
default: 'text-gray-900 dark:text-white',
|
default: 'text-gray-900',
|
||||||
},
|
},
|
||||||
optionGroupClass: {
|
optionGroupClass: {
|
||||||
type: String,
|
type: String,
|
||||||
default:
|
default:
|
||||||
'h-4 w-4 mt-0.5 cursor-pointer rounded-full border flex items-center justify-center dark:border-gray-600',
|
'h-4 w-4 mt-0.5 cursor-pointer rounded-full border flex items-center justify-center',
|
||||||
},
|
},
|
||||||
optionGroupLabelClass: {
|
optionGroupLabelClass: {
|
||||||
type: String,
|
type: String,
|
||||||
|
|||||||
@ -11,10 +11,6 @@
|
|||||||
bg-gray-200
|
bg-gray-200
|
||||||
cursor-pointer
|
cursor-pointer
|
||||||
text-primary-400
|
text-primary-400
|
||||||
dark:bg-gray-600/70
|
|
||||||
dark:backdrop-blur-xl
|
|
||||||
dark:shadow-glass
|
|
||||||
dark:hover:bg-gray-600/80
|
|
||||||
"
|
"
|
||||||
>
|
>
|
||||||
<slot />
|
<slot />
|
||||||
|
|||||||
@ -12,7 +12,7 @@
|
|||||||
>
|
>
|
||||||
<ListboxLabel
|
<ListboxLabel
|
||||||
v-if="label"
|
v-if="label"
|
||||||
class="block text-sm not-italic font-medium text-gray-800 mb-0.5 dark:text-white"
|
class="block text-sm not-italic font-medium text-gray-800 mb-0.5"
|
||||||
>
|
>
|
||||||
{{ label }}
|
{{ label }}
|
||||||
</ListboxLabel>
|
</ListboxLabel>
|
||||||
@ -28,7 +28,6 @@
|
|||||||
pr-10
|
pr-10
|
||||||
text-left
|
text-left
|
||||||
bg-white
|
bg-white
|
||||||
dark:bg-gray-700
|
|
||||||
border border-gray-200
|
border border-gray-200
|
||||||
rounded-md
|
rounded-md
|
||||||
shadow-sm
|
shadow-sm
|
||||||
@ -90,7 +89,6 @@
|
|||||||
ring-1 ring-black ring-opacity-5
|
ring-1 ring-black ring-opacity-5
|
||||||
focus:outline-none
|
focus:outline-none
|
||||||
sm:text-sm
|
sm:text-sm
|
||||||
dark:bg-gray-700
|
|
||||||
"
|
"
|
||||||
>
|
>
|
||||||
<ListboxOption
|
<ListboxOption
|
||||||
@ -102,7 +100,7 @@
|
|||||||
>
|
>
|
||||||
<li
|
<li
|
||||||
:class="[
|
:class="[
|
||||||
active ? 'text-white bg-primary-600' : 'text-gray-900 dark:text-white',
|
active ? 'text-white bg-primary-600' : 'text-gray-900',
|
||||||
'cursor-default select-none relative py-2 pl-3 pr-9',
|
'cursor-default select-none relative py-2 pl-3 pr-9',
|
||||||
]"
|
]"
|
||||||
>
|
>
|
||||||
|
|||||||
@ -11,7 +11,7 @@
|
|||||||
mt-2
|
mt-2
|
||||||
text-sm
|
text-sm
|
||||||
leading-snug
|
leading-snug
|
||||||
text-left text-gray-500 dark:text-gray-400
|
text-left text-gray-500
|
||||||
max-w-[680px]
|
max-w-[680px]
|
||||||
"
|
"
|
||||||
>
|
>
|
||||||
|
|||||||
@ -45,7 +45,7 @@ const props = defineProps({
|
|||||||
defaultInputClass: {
|
defaultInputClass: {
|
||||||
type: String,
|
type: String,
|
||||||
default:
|
default:
|
||||||
'box-border w-full px-3 py-2 text-sm not-italic font-normal leading-snug text-left text-black placeholder-gray-400 bg-white border border-gray-200 dark:border-gray-600 border-solid rounded outline-none dark:bg-gray-700 dark:text-white',
|
'box-border w-full px-3 py-2 text-sm not-italic font-normal leading-snug text-left text-black placeholder-gray-400 bg-white border border-gray-200 border-solid rounded outline-none',
|
||||||
},
|
},
|
||||||
autosize: {
|
autosize: {
|
||||||
type: Boolean,
|
type: Boolean,
|
||||||
|
|||||||
@ -10,14 +10,13 @@
|
|||||||
bg-white
|
bg-white
|
||||||
border-t border-gray-200
|
border-t border-gray-200
|
||||||
sm:px-6
|
sm:px-6
|
||||||
dark:bg-transparent dark:border-white/10
|
|
||||||
"
|
"
|
||||||
>
|
>
|
||||||
<div class="flex justify-between flex-1 sm:hidden">
|
<div class="flex justify-between flex-1 sm:hidden">
|
||||||
<a
|
<a
|
||||||
href="#"
|
href="#"
|
||||||
:class="{
|
:class="{
|
||||||
'disabled cursor-normal pointer-events-none !bg-gray-100 !text-gray-400 dark:!bg-gray-800 dark:!text-gray-500':
|
'disabled cursor-normal pointer-events-none !bg-gray-100 !text-gray-400':
|
||||||
pagination.currentPage === 1,
|
pagination.currentPage === 1,
|
||||||
}"
|
}"
|
||||||
class="
|
class="
|
||||||
@ -33,7 +32,6 @@
|
|||||||
border border-gray-300
|
border border-gray-300
|
||||||
rounded-md
|
rounded-md
|
||||||
hover:bg-gray-50
|
hover:bg-gray-50
|
||||||
dark:bg-gray-800 dark:border-gray-600 dark:text-gray-300
|
|
||||||
"
|
"
|
||||||
@click="pageClicked(pagination.currentPage - 1)"
|
@click="pageClicked(pagination.currentPage - 1)"
|
||||||
>
|
>
|
||||||
@ -42,7 +40,7 @@
|
|||||||
<a
|
<a
|
||||||
href="#"
|
href="#"
|
||||||
:class="{
|
:class="{
|
||||||
'disabled cursor-default pointer-events-none !bg-gray-100 !text-gray-400 dark:!bg-gray-800 dark:!text-gray-500':
|
'disabled cursor-default pointer-events-none !bg-gray-100 !text-gray-400':
|
||||||
pagination.currentPage === pagination.totalPages,
|
pagination.currentPage === pagination.totalPages,
|
||||||
}"
|
}"
|
||||||
class="
|
class="
|
||||||
@ -59,7 +57,6 @@
|
|||||||
border border-gray-300
|
border border-gray-300
|
||||||
rounded-md
|
rounded-md
|
||||||
hover:bg-gray-50
|
hover:bg-gray-50
|
||||||
dark:bg-gray-800 dark:border-gray-600 dark:text-gray-300
|
|
||||||
"
|
"
|
||||||
@click="pageClicked(pagination.currentPage + 1)"
|
@click="pageClicked(pagination.currentPage + 1)"
|
||||||
>
|
>
|
||||||
@ -68,12 +65,12 @@
|
|||||||
</div>
|
</div>
|
||||||
<div class="hidden sm:flex-1 sm:flex sm:items-center sm:justify-between">
|
<div class="hidden sm:flex-1 sm:flex sm:items-center sm:justify-between">
|
||||||
<div>
|
<div>
|
||||||
<p class="text-sm text-gray-700 dark:text-gray-400">
|
<p class="text-sm text-gray-700">
|
||||||
Showing
|
Showing
|
||||||
{{ ' ' }}
|
{{ ' ' }}
|
||||||
<span
|
<span
|
||||||
v-if="pagination.limit && pagination.currentPage"
|
v-if="pagination.limit && pagination.currentPage"
|
||||||
class="font-medium dark:text-gray-200"
|
class="font-medium"
|
||||||
>
|
>
|
||||||
{{
|
{{
|
||||||
pagination.currentPage * pagination.limit - (pagination.limit - 1)
|
pagination.currentPage * pagination.limit - (pagination.limit - 1)
|
||||||
@ -84,7 +81,7 @@
|
|||||||
{{ ' ' }}
|
{{ ' ' }}
|
||||||
<span
|
<span
|
||||||
v-if="pagination.limit && pagination.currentPage"
|
v-if="pagination.limit && pagination.currentPage"
|
||||||
class="font-medium dark:text-gray-200"
|
class="font-medium"
|
||||||
>
|
>
|
||||||
<span
|
<span
|
||||||
v-if="
|
v-if="
|
||||||
@ -101,7 +98,7 @@
|
|||||||
{{ ' ' }}
|
{{ ' ' }}
|
||||||
of
|
of
|
||||||
{{ ' ' }}
|
{{ ' ' }}
|
||||||
<span v-if="pagination.totalCount" class="font-medium dark:text-gray-200">
|
<span v-if="pagination.totalCount" class="font-medium">
|
||||||
{{ pagination.totalCount }}
|
{{ pagination.totalCount }}
|
||||||
</span>
|
</span>
|
||||||
{{ ' ' }}
|
{{ ' ' }}
|
||||||
@ -116,7 +113,7 @@
|
|||||||
<a
|
<a
|
||||||
href="#"
|
href="#"
|
||||||
:class="{
|
:class="{
|
||||||
'disabled cursor-normal pointer-events-none !bg-gray-100 !text-gray-400 dark:!bg-gray-800 dark:!text-gray-500':
|
'disabled cursor-normal pointer-events-none !bg-gray-100 !text-gray-400':
|
||||||
pagination.currentPage === 1,
|
pagination.currentPage === 1,
|
||||||
}"
|
}"
|
||||||
class="
|
class="
|
||||||
@ -132,7 +129,6 @@
|
|||||||
border border-gray-300
|
border border-gray-300
|
||||||
rounded-l-md
|
rounded-l-md
|
||||||
hover:bg-gray-50
|
hover:bg-gray-50
|
||||||
dark:border-gray-600 dark:bg-gray-800 dark:text-gray-300
|
|
||||||
"
|
"
|
||||||
@click="pageClicked(pagination.currentPage - 1)"
|
@click="pageClicked(pagination.currentPage - 1)"
|
||||||
>
|
>
|
||||||
@ -144,9 +140,9 @@
|
|||||||
href="#"
|
href="#"
|
||||||
aria-current="page"
|
aria-current="page"
|
||||||
:class="{
|
:class="{
|
||||||
'z-10 bg-primary-50 border-primary-500 text-primary-600 dark:bg-primary-500 dark:text-white':
|
'z-10 bg-primary-50 border-primary-500 text-primary-600':
|
||||||
isActive(1),
|
isActive(1),
|
||||||
'bg-white border-gray-300 text-gray-500 hover:bg-gray-50 dark:border-gray-600 dark:bg-gray-800 dark:text-gray-300':
|
'bg-white border-gray-300 text-gray-500 hover:bg-gray-50':
|
||||||
!isActive(1),
|
!isActive(1),
|
||||||
}"
|
}"
|
||||||
class="
|
class="
|
||||||
@ -177,7 +173,6 @@
|
|||||||
text-gray-700
|
text-gray-700
|
||||||
bg-white
|
bg-white
|
||||||
border border-gray-300
|
border border-gray-300
|
||||||
dark:border-gray-600 dark:bg-gray-800 dark:text-gray-300
|
|
||||||
"
|
"
|
||||||
>
|
>
|
||||||
...
|
...
|
||||||
@ -187,9 +182,9 @@
|
|||||||
:key="page"
|
:key="page"
|
||||||
href="#"
|
href="#"
|
||||||
:class="{
|
:class="{
|
||||||
'z-10 bg-primary-50 border-primary-500 text-primary-600 dark:bg-primary-500 dark:text-white':
|
'z-10 bg-primary-50 border-primary-500 text-primary-600':
|
||||||
isActive(page),
|
isActive(page),
|
||||||
'bg-white border-gray-300 text-gray-500 hover:bg-gray-50 dark:border-gray-600 dark:bg-gray-800 dark:text-gray-300':
|
'bg-white border-gray-300 text-gray-500 hover:bg-gray-50':
|
||||||
!isActive(page),
|
!isActive(page),
|
||||||
disabled: page === '...',
|
disabled: page === '...',
|
||||||
}"
|
}"
|
||||||
@ -225,7 +220,6 @@
|
|||||||
text-gray-700
|
text-gray-700
|
||||||
bg-white
|
bg-white
|
||||||
border border-gray-300
|
border border-gray-300
|
||||||
dark:border-gray-600 dark:bg-gray-800 dark:text-gray-300
|
|
||||||
"
|
"
|
||||||
>
|
>
|
||||||
...
|
...
|
||||||
@ -235,9 +229,9 @@
|
|||||||
href="#"
|
href="#"
|
||||||
aria-current="page"
|
aria-current="page"
|
||||||
:class="{
|
:class="{
|
||||||
'z-10 bg-primary-50 border-primary-500 text-primary-600 dark:bg-primary-500 dark:text-white':
|
'z-10 bg-primary-50 border-primary-500 text-primary-600':
|
||||||
isActive(pagination.totalPages),
|
isActive(pagination.totalPages),
|
||||||
'bg-white border-gray-300 text-gray-500 hover:bg-gray-50 dark:border-gray-600 dark:bg-gray-800 dark:text-gray-300':
|
'bg-white border-gray-300 text-gray-500 hover:bg-gray-50':
|
||||||
!isActive(pagination.totalPages),
|
!isActive(pagination.totalPages),
|
||||||
}"
|
}"
|
||||||
class="
|
class="
|
||||||
@ -269,10 +263,9 @@
|
|||||||
border border-gray-300
|
border border-gray-300
|
||||||
rounded-r-md
|
rounded-r-md
|
||||||
hover:bg-gray-50
|
hover:bg-gray-50
|
||||||
dark:border-gray-600 dark:bg-gray-800 dark:text-gray-300
|
|
||||||
"
|
"
|
||||||
:class="{
|
:class="{
|
||||||
'disabled cursor-default pointer-events-none !bg-gray-100 !text-gray-400 dark:!bg-gray-800 dark:!text-gray-500':
|
'disabled cursor-default pointer-events-none !bg-gray-100 !text-gray-400':
|
||||||
pagination.currentPage === pagination.totalPages,
|
pagination.currentPage === pagination.totalPages,
|
||||||
}"
|
}"
|
||||||
@click="pageClicked(pagination.currentPage + 1)"
|
@click="pageClicked(pagination.currentPage + 1)"
|
||||||
|
|||||||
@ -1,8 +1,6 @@
|
|||||||
<template>
|
<template>
|
||||||
<div
|
<div
|
||||||
:class="success || info
|
:class="success || info ? 'bg-white' : 'bg-red-50'"
|
||||||
? 'bg-white dark:border dark:border-white/10 dark:text-white dark:bg-gray-800/[.80] dark:shadow-glass dark:backdrop-blur-sm'
|
|
||||||
: 'bg-red-50 dark:bg-red-400/[.70] dark:shadow-glass dark:backdrop-blur-sm'"
|
|
||||||
class="
|
class="
|
||||||
max-w-sm
|
max-w-sm
|
||||||
mb-3
|
mb-3
|
||||||
@ -50,7 +48,7 @@
|
|||||||
</svg>
|
</svg>
|
||||||
<svg
|
<svg
|
||||||
v-if="error"
|
v-if="error"
|
||||||
class="w-6 h-6 text-red-400 dark:text-white"
|
class="w-6 h-6 text-red-400"
|
||||||
fill="currentColor"
|
fill="currentColor"
|
||||||
viewBox="0 0 24 24"
|
viewBox="0 0 24 24"
|
||||||
>
|
>
|
||||||
@ -64,9 +62,7 @@
|
|||||||
<div class="flex-1 w-0 ml-3 text-left">
|
<div class="flex-1 w-0 ml-3 text-left">
|
||||||
<p
|
<p
|
||||||
:class="`text-sm leading-5 font-medium ${
|
:class="`text-sm leading-5 font-medium ${
|
||||||
success || info
|
success || info ? 'text-gray-900' : 'text-red-800'
|
||||||
? 'text-gray-900 dark:text-white'
|
|
||||||
: 'text-red-800 dark:text-white'
|
|
||||||
}`"
|
}`"
|
||||||
>
|
>
|
||||||
{{
|
{{
|
||||||
@ -79,9 +75,7 @@
|
|||||||
</p>
|
</p>
|
||||||
<p
|
<p
|
||||||
:class="`mt-1 text-sm leading-5 ${
|
:class="`mt-1 text-sm leading-5 ${
|
||||||
success || info
|
success || info ? 'text-gray-500' : 'text-red-700'
|
||||||
? 'text-gray-500 dark:text-gray-400'
|
|
||||||
: 'text-red-700 dark:text-red-200'
|
|
||||||
}`"
|
}`"
|
||||||
>
|
>
|
||||||
{{
|
{{
|
||||||
@ -98,7 +92,7 @@
|
|||||||
:class="
|
:class="
|
||||||
success || info
|
success || info
|
||||||
? ' text-gray-400 focus:text-gray-500'
|
? ' text-gray-400 focus:text-gray-500'
|
||||||
: 'text-red-400 focus:text-red-500 dark:text-red-100'
|
: 'text-red-400 focus:text-red-500'
|
||||||
"
|
"
|
||||||
class="
|
class="
|
||||||
inline-flex
|
inline-flex
|
||||||
|
|||||||
Reference in New Issue
Block a user