mirror of
https://github.com/crater-invoice/crater.git
synced 2025-10-28 12:11:08 -04:00
Compare commits
1 Commits
dark-dropd
...
dark-selec
| Author | SHA1 | Date | |
|---|---|---|---|
| 5116ba3ee1 |
@ -7,12 +7,11 @@
|
|||||||
<!-- 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="slotProps.class"
|
class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
|
||||||
/>
|
/>
|
||||||
{{ $t('general.edit') }}
|
{{ $t('general.edit') }}
|
||||||
</BaseDropdownItem>
|
</BaseDropdownItem>
|
||||||
@ -20,12 +19,11 @@
|
|||||||
<!-- 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="slotProps.class"
|
class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
|
||||||
/>
|
/>
|
||||||
{{ $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 v-slot="slotProps">
|
<BaseDropdownItem>
|
||||||
<BaseIcon
|
<BaseIcon
|
||||||
name="PencilIcon"
|
name="PencilIcon"
|
||||||
:class="slotProps.class"
|
class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
|
||||||
/>
|
/>
|
||||||
{{ $t('general.edit') }}
|
{{ $t('general.edit') }}
|
||||||
</BaseDropdownItem>
|
</BaseDropdownItem>
|
||||||
@ -29,10 +29,10 @@
|
|||||||
"
|
"
|
||||||
:to="`customers/${row.id}/view`"
|
:to="`customers/${row.id}/view`"
|
||||||
>
|
>
|
||||||
<BaseDropdownItem v-slot="slotProps">
|
<BaseDropdownItem>
|
||||||
<BaseIcon
|
<BaseIcon
|
||||||
name="EyeIcon"
|
name="EyeIcon"
|
||||||
:class="slotProps.class"
|
class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
|
||||||
/>
|
/>
|
||||||
{{ $t('general.view') }}
|
{{ $t('general.view') }}
|
||||||
</BaseDropdownItem>
|
</BaseDropdownItem>
|
||||||
@ -41,12 +41,11 @@
|
|||||||
<!-- 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="slotProps.class"
|
class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
|
||||||
/>
|
/>
|
||||||
{{ $t('general.delete') }}
|
{{ $t('general.delete') }}
|
||||||
</BaseDropdownItem>
|
</BaseDropdownItem>
|
||||||
|
|||||||
@ -10,12 +10,11 @@
|
|||||||
<!-- 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="slotProps.class"
|
class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
|
||||||
/>
|
/>
|
||||||
{{ $t('general.copy_pdf_url') }}
|
{{ $t('general.copy_pdf_url') }}
|
||||||
</BaseDropdownItem>
|
</BaseDropdownItem>
|
||||||
@ -25,10 +24,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 v-slot="slotProps">
|
<BaseDropdownItem>
|
||||||
<BaseIcon
|
<BaseIcon
|
||||||
name="PencilIcon"
|
name="PencilIcon"
|
||||||
:class="slotProps.class"
|
class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
|
||||||
/>
|
/>
|
||||||
{{ $t('general.edit') }}
|
{{ $t('general.edit') }}
|
||||||
</BaseDropdownItem>
|
</BaseDropdownItem>
|
||||||
@ -37,12 +36,11 @@
|
|||||||
<!-- 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="slotProps.class"
|
class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
|
||||||
/>
|
/>
|
||||||
{{ $t('general.delete') }}
|
{{ $t('general.delete') }}
|
||||||
</BaseDropdownItem>
|
</BaseDropdownItem>
|
||||||
@ -55,10 +53,10 @@
|
|||||||
"
|
"
|
||||||
:to="`estimates/${row.id}/view`"
|
:to="`estimates/${row.id}/view`"
|
||||||
>
|
>
|
||||||
<BaseDropdownItem v-slot="slotProps">
|
<BaseDropdownItem>
|
||||||
<BaseIcon
|
<BaseIcon
|
||||||
name="EyeIcon"
|
name="EyeIcon"
|
||||||
:class="slotProps.class"
|
class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
|
||||||
/>
|
/>
|
||||||
{{ $t('general.view') }}
|
{{ $t('general.view') }}
|
||||||
</BaseDropdownItem>
|
</BaseDropdownItem>
|
||||||
@ -67,12 +65,11 @@
|
|||||||
<!-- 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="slotProps.class"
|
class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
|
||||||
/>
|
/>
|
||||||
{{ $t('estimates.convert_to_invoice') }}
|
{{ $t('estimates.convert_to_invoice') }}
|
||||||
</BaseDropdownItem>
|
</BaseDropdownItem>
|
||||||
@ -84,12 +81,11 @@
|
|||||||
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="slotProps.class"
|
class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
|
||||||
/>
|
/>
|
||||||
{{ $t('estimates.mark_as_sent') }}
|
{{ $t('estimates.mark_as_sent') }}
|
||||||
</BaseDropdownItem>
|
</BaseDropdownItem>
|
||||||
@ -101,21 +97,20 @@
|
|||||||
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="slotProps.class"
|
class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
|
||||||
/>
|
/>
|
||||||
{{ $t('estimates.send_estimate') }}
|
{{ $t('estimates.send_estimate') }}
|
||||||
</BaseDropdownItem>
|
</BaseDropdownItem>
|
||||||
|
|
||||||
<!-- Resend Estimate -->
|
<!-- Resend Estimate -->
|
||||||
<BaseDropdownItem v-if="canResendEstimate(row)" v-slot="slotProps" @click="sendEstimate(row)">
|
<BaseDropdownItem v-if="canResendEstimate(row)" @click="sendEstimate(row)">
|
||||||
<BaseIcon
|
<BaseIcon
|
||||||
name="PaperAirplaneIcon"
|
name="PaperAirplaneIcon"
|
||||||
:class="slotProps.class"
|
class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
|
||||||
/>
|
/>
|
||||||
{{ $t('estimates.resend_estimate') }}
|
{{ $t('estimates.resend_estimate') }}
|
||||||
</BaseDropdownItem>
|
</BaseDropdownItem>
|
||||||
@ -126,12 +121,11 @@
|
|||||||
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="slotProps.class"
|
class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
|
||||||
/>
|
/>
|
||||||
{{ $t('estimates.mark_as_accepted') }}
|
{{ $t('estimates.mark_as_accepted') }}
|
||||||
</BaseDropdownItem>
|
</BaseDropdownItem>
|
||||||
@ -142,12 +136,11 @@
|
|||||||
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="slotProps.class"
|
class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
|
||||||
/>
|
/>
|
||||||
{{ $t('estimates.mark_as_rejected') }}
|
{{ $t('estimates.mark_as_rejected') }}
|
||||||
</BaseDropdownItem>
|
</BaseDropdownItem>
|
||||||
|
|||||||
@ -13,12 +13,11 @@
|
|||||||
<!-- 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="slotProps.class"
|
class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
|
||||||
/>
|
/>
|
||||||
{{ $t('general.edit') }}
|
{{ $t('general.edit') }}
|
||||||
</BaseDropdownItem>
|
</BaseDropdownItem>
|
||||||
@ -26,12 +25,11 @@
|
|||||||
<!-- 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="slotProps.class"
|
class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
|
||||||
/>
|
/>
|
||||||
{{ $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 v-slot="slotProps">
|
<BaseDropdownItem>
|
||||||
<BaseIcon
|
<BaseIcon
|
||||||
name="PencilIcon"
|
name="PencilIcon"
|
||||||
:class="slotProps.class"
|
class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
|
||||||
/>
|
/>
|
||||||
{{ $t('general.edit') }}
|
{{ $t('general.edit') }}
|
||||||
</BaseDropdownItem>
|
</BaseDropdownItem>
|
||||||
@ -24,12 +24,11 @@
|
|||||||
<!-- 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="slotProps.class"
|
class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
|
||||||
/>
|
/>
|
||||||
{{ $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" v-slot="slotProps">
|
<BaseDropdownItem v-show="row.allow_edit">
|
||||||
<BaseIcon
|
<BaseIcon
|
||||||
name="PencilIcon"
|
name="PencilIcon"
|
||||||
:class="slotProps.class"
|
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>
|
||||||
|
|
||||||
<!-- Copy PDF url -->
|
<!-- Copy PDF url -->
|
||||||
<BaseDropdownItem v-if="route.name === 'invoices.view'" v-slot="slotProps" @click="copyPdfUrl">
|
<BaseDropdownItem v-if="route.name === 'invoices.view'" @click="copyPdfUrl">
|
||||||
<BaseIcon
|
<BaseIcon
|
||||||
name="LinkIcon"
|
name="LinkIcon"
|
||||||
:class="slotProps.class"
|
class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
|
||||||
/>
|
/>
|
||||||
{{ $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 v-slot="slotProps">
|
<BaseDropdownItem>
|
||||||
<BaseIcon
|
<BaseIcon
|
||||||
name="EyeIcon"
|
name="EyeIcon"
|
||||||
:class="slotProps.class"
|
class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
|
||||||
/>
|
/>
|
||||||
{{ $t('general.view') }}
|
{{ $t('general.view') }}
|
||||||
</BaseDropdownItem>
|
</BaseDropdownItem>
|
||||||
</router-link>
|
</router-link>
|
||||||
|
|
||||||
<!-- Send Invoice Mail -->
|
<!-- Send Invoice Mail -->
|
||||||
<BaseDropdownItem v-if="canSendInvoice(row)" v-slot="slotProps" @click="sendInvoice(row)">
|
<BaseDropdownItem v-if="canSendInvoice(row)" @click="sendInvoice(row)">
|
||||||
<BaseIcon
|
<BaseIcon
|
||||||
name="PaperAirplaneIcon"
|
name="PaperAirplaneIcon"
|
||||||
:class="slotProps.class"
|
class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
|
||||||
/>
|
/>
|
||||||
{{ $t('invoices.send_invoice') }}
|
{{ $t('invoices.send_invoice') }}
|
||||||
</BaseDropdownItem>
|
</BaseDropdownItem>
|
||||||
|
|
||||||
<!-- Resend Invoice -->
|
<!-- Resend Invoice -->
|
||||||
<BaseDropdownItem v-if="canReSendInvoice(row)" v-slot="slotProps" @click="sendInvoice(row)">
|
<BaseDropdownItem v-if="canReSendInvoice(row)" @click="sendInvoice(row)">
|
||||||
<BaseIcon
|
<BaseIcon
|
||||||
name="PaperAirplaneIcon"
|
name="PaperAirplaneIcon"
|
||||||
:class="slotProps.class"
|
class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
|
||||||
/>
|
/>
|
||||||
{{ $t('invoices.resend_invoice') }}
|
{{ $t('invoices.resend_invoice') }}
|
||||||
</BaseDropdownItem>
|
</BaseDropdownItem>
|
||||||
@ -69,21 +69,20 @@
|
|||||||
<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="slotProps.class"
|
class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
|
||||||
/>
|
/>
|
||||||
{{ $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)" v-slot="slotProps" @click="onMarkAsSent(row.id)">
|
<BaseDropdownItem v-if="canSendInvoice(row)" @click="onMarkAsSent(row.id)">
|
||||||
<BaseIcon
|
<BaseIcon
|
||||||
name="CheckCircleIcon"
|
name="CheckCircleIcon"
|
||||||
:class="slotProps.class"
|
class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
|
||||||
/>
|
/>
|
||||||
{{ $t('invoices.mark_as_sent') }}
|
{{ $t('invoices.mark_as_sent') }}
|
||||||
</BaseDropdownItem>
|
</BaseDropdownItem>
|
||||||
@ -91,12 +90,11 @@
|
|||||||
<!-- 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="slotProps.class"
|
class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
|
||||||
/>
|
/>
|
||||||
{{ $t('invoices.clone_invoice') }}
|
{{ $t('invoices.clone_invoice') }}
|
||||||
</BaseDropdownItem>
|
</BaseDropdownItem>
|
||||||
@ -104,12 +102,11 @@
|
|||||||
<!-- 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="slotProps.class"
|
class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
|
||||||
/>
|
/>
|
||||||
{{ $t('general.delete') }}
|
{{ $t('general.delete') }}
|
||||||
</BaseDropdownItem>
|
</BaseDropdownItem>
|
||||||
|
|||||||
@ -12,8 +12,11 @@
|
|||||||
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 v-slot="slotProps">
|
<BaseDropdownItem>
|
||||||
<BaseIcon name="PencilIcon" :class="slotProps.class" />
|
<BaseIcon
|
||||||
|
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>
|
||||||
@ -21,10 +24,12 @@
|
|||||||
<!-- 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 name="TrashIcon" :class="slotProps.class" />
|
<BaseIcon
|
||||||
|
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,12 +10,11 @@
|
|||||||
<!-- 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="slotProps.class"
|
class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
|
||||||
/>
|
/>
|
||||||
{{ $t('general.edit') }}
|
{{ $t('general.edit') }}
|
||||||
</BaseDropdownItem>
|
</BaseDropdownItem>
|
||||||
@ -23,12 +22,11 @@
|
|||||||
<!-- 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="slotProps.class"
|
class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
|
||||||
/>
|
/>
|
||||||
{{ $t('general.delete') }}
|
{{ $t('general.delete') }}
|
||||||
</BaseDropdownItem>
|
</BaseDropdownItem>
|
||||||
|
|||||||
@ -8,31 +8,30 @@
|
|||||||
</template>
|
</template>
|
||||||
|
|
||||||
<!-- Copy pdf url -->
|
<!-- Copy pdf url -->
|
||||||
<BaseDropdownItem
|
<BaseDropdown-item
|
||||||
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="slotProps.class"
|
class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
|
||||||
/>
|
/>
|
||||||
{{ $t('general.copy_pdf_url') }}
|
{{ $t('general.copy_pdf_url') }}
|
||||||
</BaseDropdownItem>
|
</BaseDropdown-item>
|
||||||
|
|
||||||
<!-- 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 v-slot="slotProps">
|
<BaseDropdownItem>
|
||||||
<BaseIcon
|
<BaseIcon
|
||||||
name="PencilIcon"
|
name="PencilIcon"
|
||||||
:class="slotProps.class"
|
class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
|
||||||
/>
|
/>
|
||||||
{{ $t('general.edit') }}
|
{{ $t('general.edit') }}
|
||||||
</BaseDropdownItem>
|
</BaseDropdownItem>
|
||||||
@ -46,10 +45,10 @@
|
|||||||
"
|
"
|
||||||
:to="`/admin/payments/${row.id}/view`"
|
:to="`/admin/payments/${row.id}/view`"
|
||||||
>
|
>
|
||||||
<BaseDropdownItem v-slot="slotProps">
|
<BaseDropdownItem>
|
||||||
<BaseIcon
|
<BaseIcon
|
||||||
name="EyeIcon"
|
name="EyeIcon"
|
||||||
:class="slotProps.class"
|
class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
|
||||||
/>
|
/>
|
||||||
{{ $t('general.view') }}
|
{{ $t('general.view') }}
|
||||||
</BaseDropdownItem>
|
</BaseDropdownItem>
|
||||||
@ -62,12 +61,11 @@
|
|||||||
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="slotProps.class"
|
class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
|
||||||
/>
|
/>
|
||||||
{{ $t('payments.send_payment') }}
|
{{ $t('payments.send_payment') }}
|
||||||
</BaseDropdownItem>
|
</BaseDropdownItem>
|
||||||
@ -75,12 +73,11 @@
|
|||||||
<!-- 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="slotProps.class"
|
class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
|
||||||
/>
|
/>
|
||||||
{{ $t('general.delete') }}
|
{{ $t('general.delete') }}
|
||||||
</BaseDropdownItem>
|
</BaseDropdownItem>
|
||||||
|
|||||||
@ -8,19 +8,19 @@
|
|||||||
</template>
|
</template>
|
||||||
|
|
||||||
<!-- edit paymentMode -->
|
<!-- edit paymentMode -->
|
||||||
<BaseDropdownItem v-slot="slotProps" @click="editPaymentMode(row.id)">
|
<BaseDropdownItem @click="editPaymentMode(row.id)">
|
||||||
<BaseIcon
|
<BaseIcon
|
||||||
name="PencilIcon"
|
name="PencilIcon"
|
||||||
:class="slotProps.class"
|
class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
|
||||||
/>
|
/>
|
||||||
{{ $t('general.edit') }}
|
{{ $t('general.edit') }}
|
||||||
</BaseDropdownItem>
|
</BaseDropdownItem>
|
||||||
|
|
||||||
<!-- delete paymentMode -->
|
<!-- delete paymentMode -->
|
||||||
<BaseDropdownItem v-slot="slotProps" @click="removePaymentMode(row.id)">
|
<BaseDropdownItem @click="removePaymentMode(row.id)">
|
||||||
<BaseIcon
|
<BaseIcon
|
||||||
name="TrashIcon"
|
name="TrashIcon"
|
||||||
:class="slotProps.class"
|
class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
|
||||||
/>
|
/>
|
||||||
{{ $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 v-slot="slotProps">
|
<BaseDropdownItem>
|
||||||
<BaseIcon
|
<BaseIcon
|
||||||
name="PencilIcon"
|
name="PencilIcon"
|
||||||
:class="slotProps.class"
|
class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
|
||||||
/>
|
/>
|
||||||
{{ $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 v-slot="slotProps">
|
<BaseDropdownItem>
|
||||||
<BaseIcon
|
<BaseIcon
|
||||||
name="EyeIcon"
|
name="EyeIcon"
|
||||||
:class="slotProps.class"
|
class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
|
||||||
/>
|
/>
|
||||||
{{ $t('general.view') }}
|
{{ $t('general.view') }}
|
||||||
</BaseDropdownItem>
|
</BaseDropdownItem>
|
||||||
@ -44,12 +44,11 @@
|
|||||||
<!-- 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="slotProps.class"
|
class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
|
||||||
/>
|
/>
|
||||||
{{ $t('general.delete') }}
|
{{ $t('general.delete') }}
|
||||||
</BaseDropdownItem>
|
</BaseDropdownItem>
|
||||||
|
|||||||
@ -10,12 +10,11 @@
|
|||||||
<!-- 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="slotProps.class"
|
class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
|
||||||
/>
|
/>
|
||||||
{{ $t('general.edit') }}
|
{{ $t('general.edit') }}
|
||||||
</BaseDropdownItem>
|
</BaseDropdownItem>
|
||||||
@ -23,12 +22,11 @@
|
|||||||
<!-- 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="slotProps.class"
|
class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
|
||||||
/>
|
/>
|
||||||
{{ $t('general.delete') }}
|
{{ $t('general.delete') }}
|
||||||
</BaseDropdownItem>
|
</BaseDropdownItem>
|
||||||
|
|||||||
@ -10,12 +10,11 @@
|
|||||||
<!-- 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="slotProps.class"
|
class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
|
||||||
/>
|
/>
|
||||||
{{ $t('general.edit') }}
|
{{ $t('general.edit') }}
|
||||||
</BaseDropdownItem>
|
</BaseDropdownItem>
|
||||||
@ -23,12 +22,11 @@
|
|||||||
<!-- 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="slotProps.class"
|
class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
|
||||||
/>
|
/>
|
||||||
{{ $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 v-slot="slotProps">
|
<BaseDropdownItem>
|
||||||
<BaseIcon
|
<BaseIcon
|
||||||
name="PencilIcon"
|
name="PencilIcon"
|
||||||
:class="slotProps.class"
|
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>
|
||||||
|
|
||||||
<!-- delete user -->
|
<!-- delete user -->
|
||||||
<BaseDropdownItem v-slot="slotProps" @click="removeUser(row.id)">
|
<BaseDropdownItem @click="removeUser(row.id)">
|
||||||
<BaseIcon
|
<BaseIcon
|
||||||
name="TrashIcon"
|
name="TrashIcon"
|
||||||
:class="slotProps.class"
|
class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
|
||||||
/>
|
/>
|
||||||
{{ $t('general.delete') }}
|
{{ $t('general.delete') }}
|
||||||
</BaseDropdownItem>
|
</BaseDropdownItem>
|
||||||
|
|||||||
@ -24,8 +24,6 @@
|
|||||||
dark:border-white/10
|
dark:border-white/10
|
||||||
"
|
"
|
||||||
>
|
>
|
||||||
<BaseDarkHighlight />
|
|
||||||
|
|
||||||
<router-link
|
<router-link
|
||||||
to="/admin/dashboard"
|
to="/admin/dashboard"
|
||||||
class="
|
class="
|
||||||
@ -74,7 +72,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="
|
||||||
@ -88,21 +86,19 @@
|
|||||||
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 dark:text-white" />
|
<BaseIcon name="PlusIcon" class="w-5 h-5 text-gray-600" />
|
||||||
</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="slotProps.class"
|
class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
|
||||||
aria-hidden="true"
|
aria-hidden="true"
|
||||||
/>
|
/>
|
||||||
{{ $t('invoices.new_invoice') }}
|
{{ $t('invoices.new_invoice') }}
|
||||||
@ -111,11 +107,10 @@
|
|||||||
<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="slotProps.class"
|
class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
|
||||||
aria-hidden="true"
|
aria-hidden="true"
|
||||||
/>
|
/>
|
||||||
{{ $t('estimates.new_estimate') }}
|
{{ $t('estimates.new_estimate') }}
|
||||||
@ -125,11 +120,10 @@
|
|||||||
<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="slotProps.class"
|
class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
|
||||||
aria-hidden="true"
|
aria-hidden="true"
|
||||||
/>
|
/>
|
||||||
{{ $t('customers.new_customer') }}
|
{{ $t('customers.new_customer') }}
|
||||||
@ -162,20 +156,20 @@
|
|||||||
</template>
|
</template>
|
||||||
|
|
||||||
<router-link to="/admin/settings/account-settings">
|
<router-link to="/admin/settings/account-settings">
|
||||||
<BaseDropdownItem v-slot="slotProps">
|
<BaseDropdownItem>
|
||||||
<BaseIcon
|
<BaseIcon
|
||||||
name="CogIcon"
|
name="CogIcon"
|
||||||
:class="slotProps.class"
|
class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
|
||||||
aria-hidden="true"
|
aria-hidden="true"
|
||||||
/>
|
/>
|
||||||
{{ $t('navigation.settings') }}
|
{{ $t('navigation.settings') }}
|
||||||
</BaseDropdownItem>
|
</BaseDropdownItem>
|
||||||
</router-link>
|
</router-link>
|
||||||
|
|
||||||
<BaseDropdownItem v-slot="slotProps" @click="logout">
|
<BaseDropdownItem @click="logout">
|
||||||
<BaseIcon
|
<BaseIcon
|
||||||
name="LogoutIcon"
|
name="LogoutIcon"
|
||||||
:class="slotProps.class"
|
class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
|
||||||
aria-hidden="true"
|
aria-hidden="true"
|
||||||
/>
|
/>
|
||||||
{{ $t('navigation.logout') }}
|
{{ $t('navigation.logout') }}
|
||||||
|
|||||||
@ -51,14 +51,14 @@
|
|||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<BaseDropdownItem v-slot="slotProps" @click="onDownloadBckup(row.data)">
|
<BaseDropdownItem @click="onDownloadBckup(row.data)">
|
||||||
<BaseIcon name="CloudDownloadIcon" :class="slotProps.class" />
|
<BaseIcon name="CloudDownloadIcon" class="mr-3 text-gray-600" />
|
||||||
|
|
||||||
{{ $t('general.download') }}
|
{{ $t('general.download') }}
|
||||||
</BaseDropdownItem>
|
</BaseDropdownItem>
|
||||||
|
|
||||||
<BaseDropdownItem v-slot="slotProps" @click="onRemoveBackup(row.data)">
|
<BaseDropdownItem @click="onRemoveBackup(row.data)">
|
||||||
<BaseIcon name="TrashIcon" :class="slotProps.class" />
|
<BaseIcon name="TrashIcon" class="mr-3 text-gray-600" />
|
||||||
{{ $t('general.delete') }}
|
{{ $t('general.delete') }}
|
||||||
</BaseDropdownItem>
|
</BaseDropdownItem>
|
||||||
</BaseDropdown>
|
</BaseDropdown>
|
||||||
|
|||||||
@ -45,30 +45,27 @@
|
|||||||
|
|
||||||
<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="slotProps.class" name="CheckCircleIcon" />
|
<BaseIcon class="mr-3 tetx-gray-600" 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="slotProps.class" />
|
<BaseIcon name="PencilIcon" class="mr-3 text-gray-600" />
|
||||||
|
|
||||||
{{ $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="slotProps.class" />
|
<BaseIcon name="TrashIcon" class="mr-3 text-gray-600" />
|
||||||
{{ $t('general.delete') }}
|
{{ $t('general.delete') }}
|
||||||
</BaseDropdownItem>
|
</BaseDropdownItem>
|
||||||
</BaseDropdown>
|
</BaseDropdown>
|
||||||
|
|||||||
@ -1,23 +1,21 @@
|
|||||||
<template>
|
<template>
|
||||||
<div ref="companySwitchBar" class="relative rounded dark:text-white">
|
<div ref="companySwitchBar" class="relative rounded">
|
||||||
<CompanyModal />
|
<CompanyModal />
|
||||||
|
|
||||||
<div
|
<div
|
||||||
class="
|
class="
|
||||||
flex
|
flex
|
||||||
items-center
|
items-center
|
||||||
justify-center
|
justify-center
|
||||||
px-3
|
px-3
|
||||||
h-8
|
h-8
|
||||||
md:h-9
|
md:h-9
|
||||||
ml-2
|
ml-2
|
||||||
text-sm
|
text-sm text-white
|
||||||
text-white
|
bg-white
|
||||||
bg-white
|
rounded
|
||||||
rounded
|
cursor-pointer
|
||||||
cursor-pointer
|
bg-opacity-20
|
||||||
bg-opacity-20
|
|
||||||
dark:bg-gray-700
|
|
||||||
"
|
"
|
||||||
@click="isShow = !isShow"
|
@click="isShow = !isShow"
|
||||||
>
|
>
|
||||||
@ -40,42 +38,28 @@
|
|||||||
>
|
>
|
||||||
<div
|
<div
|
||||||
v-if="isShow"
|
v-if="isShow"
|
||||||
class="
|
class="absolute right-0 mt-2 bg-white rounded-md shadow-lg"
|
||||||
absolute
|
|
||||||
right-0
|
|
||||||
mt-2
|
|
||||||
bg-white
|
|
||||||
rounded-md
|
|
||||||
shadow-lg
|
|
||||||
dark:border
|
|
||||||
dark:border-white/10
|
|
||||||
dark:text-white
|
|
||||||
dark:bg-gray-800/[.95]
|
|
||||||
dark:shadow-glass
|
|
||||||
dark:backdrop-blur-xl
|
|
||||||
"
|
|
||||||
>
|
>
|
||||||
<BaseDarkHighlight class="z-[-1] top-0 left-0" />
|
|
||||||
<div
|
<div
|
||||||
class="
|
class="
|
||||||
overflow-y-auto
|
overflow-y-auto
|
||||||
scrollbar-thin
|
scrollbar-thin scrollbar-thumb-rounded-full
|
||||||
scrollbar-thumb-rounded-full
|
w-[250px]
|
||||||
w-[250px] max-h-[350px]
|
max-h-[350px]
|
||||||
scrollbar-thumb-gray-300
|
scrollbar-thumb-gray-300 scrollbar-track-gray-10
|
||||||
scrollbar-track-gray-10
|
pb-4
|
||||||
pb-4
|
|
||||||
"
|
"
|
||||||
>
|
>
|
||||||
<label
|
<label
|
||||||
class="
|
class="
|
||||||
px-3
|
px-3
|
||||||
py-2
|
py-2
|
||||||
text-xs
|
text-xs
|
||||||
font-semibold
|
font-semibold
|
||||||
text-gray-400
|
text-gray-400
|
||||||
mb-0.5
|
mb-0.5
|
||||||
block uppercase
|
block
|
||||||
|
uppercase
|
||||||
"
|
"
|
||||||
>
|
>
|
||||||
{{ $t('company_switcher.label') }}
|
{{ $t('company_switcher.label') }}
|
||||||
@ -84,13 +68,13 @@
|
|||||||
<div
|
<div
|
||||||
v-if="companyStore.companies.length < 1"
|
v-if="companyStore.companies.length < 1"
|
||||||
class="
|
class="
|
||||||
flex flex-col
|
flex flex-col
|
||||||
items-center
|
items-center
|
||||||
justify-center
|
justify-center
|
||||||
p-2
|
p-2
|
||||||
px-3
|
px-3
|
||||||
mt-4
|
mt-4
|
||||||
text-base text-gray-400
|
text-base text-gray-400
|
||||||
"
|
"
|
||||||
>
|
>
|
||||||
<BaseIcon name="ExclamationCircleIcon" class="h-5 text-gray-400" />
|
<BaseIcon name="ExclamationCircleIcon" class="h-5 text-gray-400" />
|
||||||
@ -102,17 +86,14 @@
|
|||||||
v-for="(company, index) in companyStore.companies"
|
v-for="(company, index) in companyStore.companies"
|
||||||
:key="index"
|
:key="index"
|
||||||
class="
|
class="
|
||||||
p-2
|
p-2
|
||||||
px-3
|
px-3
|
||||||
rounded-md
|
rounded-md
|
||||||
cursor-pointer
|
cursor-pointer
|
||||||
hover:bg-gray-100 hover:text-primary-500
|
hover:bg-gray-100 hover:text-primary-500
|
||||||
dark:hover:bg-gray-700
|
|
||||||
text-gray-900
|
|
||||||
dark:text-white
|
|
||||||
"
|
"
|
||||||
:class="{
|
:class="{
|
||||||
'bg-gray-100 text-primary-500 dark:bg-gray-700':
|
'bg-gray-100 text-primary-500':
|
||||||
companyStore.selectedCompany.id === company.id,
|
companyStore.selectedCompany.id === company.id,
|
||||||
}"
|
}"
|
||||||
@click="changeCompany(company)"
|
@click="changeCompany(company)"
|
||||||
@ -120,19 +101,18 @@
|
|||||||
<div class="flex items-center">
|
<div class="flex items-center">
|
||||||
<span
|
<span
|
||||||
class="
|
class="
|
||||||
flex
|
flex
|
||||||
items-center
|
items-center
|
||||||
justify-center
|
justify-center
|
||||||
mr-3
|
mr-3
|
||||||
overflow-hidden
|
overflow-hidden
|
||||||
text-sm
|
text-base
|
||||||
font-semibold
|
font-semibold
|
||||||
bg-gray-200
|
bg-gray-200
|
||||||
rounded-md
|
rounded-md
|
||||||
w-9
|
w-9
|
||||||
h-9
|
h-9
|
||||||
text-primary-500
|
text-primary-500
|
||||||
dark:bg-gray-900
|
|
||||||
"
|
"
|
||||||
>
|
>
|
||||||
<span v-if="!company.logo">
|
<span v-if="!company.logo">
|
||||||
@ -156,17 +136,15 @@
|
|||||||
<div
|
<div
|
||||||
v-if="userStore.currentUser.is_owner"
|
v-if="userStore.currentUser.is_owner"
|
||||||
class="
|
class="
|
||||||
flex
|
flex
|
||||||
items-center
|
items-center
|
||||||
justify-center
|
justify-center
|
||||||
p-4
|
p-4
|
||||||
pl-3
|
pl-3
|
||||||
border-t-2
|
border-t-2 border-gray-100
|
||||||
border-gray-100
|
cursor-pointer
|
||||||
cursor-pointer
|
text-primary-400
|
||||||
text-primary-400
|
hover:text-primary-500
|
||||||
hover:text-primary-500
|
|
||||||
dark:border-gray-600
|
|
||||||
"
|
"
|
||||||
@click="addNewCompany"
|
@click="addNewCompany"
|
||||||
>
|
>
|
||||||
|
|||||||
@ -1,5 +1,5 @@
|
|||||||
<template>
|
<template>
|
||||||
<div ref="searchBar" class="hidden rounded md:block relative dark:text-white">
|
<div ref="searchBar" class="hidden rounded md:block relative">
|
||||||
<div>
|
<div>
|
||||||
<BaseInput
|
<BaseInput
|
||||||
v-model="name"
|
v-model="name"
|
||||||
@ -41,11 +41,6 @@
|
|||||||
w-[300px]
|
w-[300px]
|
||||||
h-[200px]
|
h-[200px]
|
||||||
right-0
|
right-0
|
||||||
dark:border-white/10
|
|
||||||
dark:text-white
|
|
||||||
dark:bg-gray-800/[.95]
|
|
||||||
dark:shadow-glass
|
|
||||||
dark:backdrop-blur-xl
|
|
||||||
"
|
"
|
||||||
>
|
>
|
||||||
<div
|
<div
|
||||||
@ -73,7 +68,7 @@
|
|||||||
<div
|
<div
|
||||||
v-for="(customer, index) in usersStore.customerList"
|
v-for="(customer, index) in usersStore.customerList"
|
||||||
:key="index"
|
:key="index"
|
||||||
class="p-2 hover:bg-gray-100 cursor-pointer rounded-md dark:hover:bg-gray-700/40"
|
class="p-2 hover:bg-gray-100 cursor-pointer rounded-md"
|
||||||
>
|
>
|
||||||
<router-link
|
<router-link
|
||||||
:to="{ path: `/admin/customers/${customer.id}/view` }"
|
:to="{ path: `/admin/customers/${customer.id}/view` }"
|
||||||
@ -92,7 +87,6 @@
|
|||||||
bg-gray-200
|
bg-gray-200
|
||||||
rounded-full
|
rounded-full
|
||||||
text-primary-500
|
text-primary-500
|
||||||
dark:bg-gray-600
|
|
||||||
"
|
"
|
||||||
>
|
>
|
||||||
{{ initGenerator(customer.name) }}
|
{{ initGenerator(customer.name) }}
|
||||||
@ -122,7 +116,7 @@
|
|||||||
<div
|
<div
|
||||||
v-for="(user, index) in usersStore.userList"
|
v-for="(user, index) in usersStore.userList"
|
||||||
:key="index"
|
:key="index"
|
||||||
class="p-2 hover:bg-gray-100 cursor-pointer rounded-md dark:hover:bg-gray-700/40"
|
class="p-2 hover:bg-gray-100 cursor-pointer rounded-md"
|
||||||
>
|
>
|
||||||
<router-link
|
<router-link
|
||||||
:to="{ path: `/admin/users/${user.id}/edit` }"
|
:to="{ path: `/admin/users/${user.id}/edit` }"
|
||||||
|
|||||||
@ -69,8 +69,7 @@ const props = defineProps({
|
|||||||
})
|
})
|
||||||
|
|
||||||
const containerClasses = computed(() => {
|
const containerClasses = computed(() => {
|
||||||
const baseClass = `dark:border dark:border-white/10 dark:text-white dark:bg-gray-800 dark:shadow-glass
|
const baseClass = `origin-top-right rounded-md shadow-lg bg-white ring-1 ring-black ring-opacity-5 divide-y divide-gray-100 focus:outline-none`
|
||||||
origin-top-right rounded-md shadow-lg bg-white ring-1 ring-black ring-opacity-5 divide-y divide-gray-100 focus:outline-none`
|
|
||||||
return `${baseClass} ${props.containerClass}`
|
return `${baseClass} ${props.containerClass}`
|
||||||
})
|
})
|
||||||
|
|
||||||
|
|||||||
@ -2,20 +2,16 @@
|
|||||||
<MenuItem v-slot="{ active }" v-bind="$attrs">
|
<MenuItem v-slot="{ active }" v-bind="$attrs">
|
||||||
<a
|
<a
|
||||||
href="#"
|
href="#"
|
||||||
class="group flex items-center px-4 py-2 text-sm font-normal"
|
|
||||||
:class="[
|
:class="[
|
||||||
active
|
active ? 'bg-gray-100 text-gray-900' : 'text-gray-700',
|
||||||
? 'bg-gray-100 text-gray-900 dark:text-white dark:bg-gray-700'
|
'group flex items-center px-4 py-2 text-sm font-normal',
|
||||||
: 'text-gray-700 dark:text-gray-200',
|
|
||||||
]"
|
]"
|
||||||
>
|
>
|
||||||
<slot :active="active" :class="defaultIconClass" />
|
<slot :active="active" />
|
||||||
</a>
|
</a>
|
||||||
</MenuItem>
|
</MenuItem>
|
||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script setup>
|
<script setup>
|
||||||
import { MenuItem } from '@headlessui/vue'
|
import { MenuItem } from '@headlessui/vue'
|
||||||
const defaultIconClass =
|
|
||||||
'w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500 dark:text-gray-400 dark:group-hover:text-white'
|
|
||||||
</script>
|
</script>
|
||||||
|
|||||||
@ -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"
|
class="block text-sm not-italic font-medium text-gray-800 mb-0.5 dark:text-white"
|
||||||
>
|
>
|
||||||
{{ label }}
|
{{ label }}
|
||||||
</ListboxLabel>
|
</ListboxLabel>
|
||||||
@ -28,6 +28,7 @@
|
|||||||
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
|
||||||
@ -89,6 +90,7 @@
|
|||||||
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
|
||||||
@ -100,7 +102,7 @@
|
|||||||
>
|
>
|
||||||
<li
|
<li
|
||||||
:class="[
|
:class="[
|
||||||
active ? 'text-white bg-primary-600' : 'text-gray-900',
|
active ? 'text-white bg-primary-600' : 'text-gray-900 dark:text-white',
|
||||||
'cursor-default select-none relative py-2 pl-3 pr-9',
|
'cursor-default select-none relative py-2 pl-3 pr-9',
|
||||||
]"
|
]"
|
||||||
>
|
>
|
||||||
|
|||||||
Reference in New Issue
Block a user