Compare commits

..

2 Commits

Author SHA1 Message Date
cba602655d Converted <label> in <BaseLabel> 2023-03-23 17:24:03 +05:30
87495e8055 added dark-mode in BaseInputGroup and BaseLabel 2023-03-22 10:16:06 +05:30
38 changed files with 300 additions and 372 deletions

View File

@ -83,25 +83,25 @@
@click="selectNote(index, close)" @click="selectNote(index, close)"
> >
<div class="flex justify-between px-2"> <div class="flex justify-between px-2">
<label <BaseLabel
class=" class="
m-0 !m-0
text-base !text-base
font-semibold !font-semibold
leading-tight !leading-tight
text-gray-700 !text-gray-700
cursor-pointer !cursor-pointer
" "
> >
{{ note.name }} {{ note.name }}
</label> </BaseLabel>
</div> </div>
</div> </div>
</div> </div>
<div v-else class="flex justify-center p-5 text-gray-400"> <div v-else class="flex justify-center p-5 text-gray-400">
<label class="text-base text-gray-500"> <BaseLabel class="!text-base !text-gray-500">
{{ $t('general.no_note_found') }} {{ $t('general.no_note_found') }}
</label> </BaseLabel>
</div> </div>
</div> </div>
<button <button
@ -122,19 +122,18 @@
@click="openNoteModal" @click="openNoteModal"
> >
<BaseIcon name="CheckCircleIcon" class="text-primary-400" /> <BaseIcon name="CheckCircleIcon" class="text-primary-400" />
<label <BaseLabel
class=" class="
m-0 !m-0
ml-3 !ml-3
text-sm !leading-none
leading-none !cursor-pointer
cursor-pointer !font-base
font-base !text-primary-400
text-primary-400
" "
> >
{{ $t('settings.customization.notes.add_new_note') }} {{ $t('settings.customization.notes.add_new_note') }}
</label> </BaseLabel>
</button> </button>
</div> </div>
</PopoverPanel> </PopoverPanel>

View File

@ -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>

View File

@ -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>

View File

@ -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>

View File

@ -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>

View File

@ -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>

View File

@ -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>

View File

@ -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>

View File

@ -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>

View File

@ -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>

View File

@ -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>

View File

@ -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>

View File

@ -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>

View File

@ -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>

View File

@ -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>

View File

@ -1,9 +1,9 @@
<template> <template>
<div class="flex items-center justify-between mb-3"> <div class="flex items-center justify-between mb-3">
<div class="flex items-center text-base" style="flex: 4"> <div class="flex items-center text-base" style="flex: 4">
<label class="pr-2 mb-0" align="right"> <BaseLabel class="!pr-2 !mb-0" align="right">
{{ $t('invoices.item.tax') }} {{ $t('invoices.item.tax') }}
</label> </BaseLabel>
<BaseMultiselect <BaseMultiselect
v-model="selectedTax" v-model="selectedTax"
@ -35,9 +35,9 @@
> >
<BaseIcon name="CheckCircleIcon" class="h-5 text-primary-400" /> <BaseIcon name="CheckCircleIcon" class="h-5 text-primary-400" />
<label <BaseLabel
class="ml-2 text-sm leading-none cursor-pointer text-primary-400" class="!ml-2 !leading-none !cursor-pointer !text-primary-400"
>{{ $t('invoices.add_new_tax') }}</label >{{ $t('invoices.add_new_tax') }}</BaseLabel
> >
</button> </button>
</template> </template>

View File

@ -5,9 +5,9 @@
> >
<SelectNotePopup :type="type" @select="onSelectNote" /> <SelectNotePopup :type="type" @select="onSelectNote" />
</div> </div>
<label class="text-gray-800 font-medium mb-4 text-sm"> <BaseLabel class="!text-gray-800 !mb-4 ">
{{ $t('invoices.notes') }} {{ $t('invoices.notes') }}
</label> </BaseLabel>
<BaseCustomInput <BaseCustomInput
v-model="store[storeProp].notes" v-model="store[storeProp].notes"
:content-loading="store.isFetchingInitialSettings" :content-loading="store.isFetchingInitialSettings"

View File

@ -16,12 +16,12 @@
<BaseContentPlaceholders v-if="isLoading"> <BaseContentPlaceholders v-if="isLoading">
<BaseContentPlaceholdersText :lines="1" class="w-16 h-5" /> <BaseContentPlaceholdersText :lines="1" class="w-16 h-5" />
</BaseContentPlaceholders> </BaseContentPlaceholders>
<label <BaseLabel
v-else v-else
class="text-sm font-semibold leading-5 text-gray-400 uppercase" class="!font-semibold !text-gray-400 !uppercase"
> >
{{ $t('estimates.sub_total') }} {{ $t('estimates.sub_total') }}
</label> </BaseLabel>
<BaseContentPlaceholders v-if="isLoading"> <BaseContentPlaceholders v-if="isLoading">
<BaseContentPlaceholdersText :lines="1" class="w-16 h-5" /> <BaseContentPlaceholdersText :lines="1" class="w-16 h-5" />
@ -29,7 +29,7 @@
<label <label
v-else v-else
class="flex items-center justify-center m-0 text-lg text-black uppercase " class="flex items-center justify-center m-0 text-lg text-black dark:text-white uppercase "
> >
<BaseFormatMoney <BaseFormatMoney
:amount="store.getSubTotal" :amount="store.getSubTotal"
@ -48,7 +48,7 @@
</BaseContentPlaceholders> </BaseContentPlaceholders>
<label <label
v-else-if="store[storeProp].tax_per_item === 'YES'" v-else-if="store[storeProp].tax_per_item === 'YES'"
class="m-0 text-sm font-semibold leading-5 text-gray-500 uppercase" class="m-0 text-sm font-semibold leading-5 text-gray-500 uppercase dark:text-gray-400"
> >
{{ tax.name }} - {{ tax.percent }}% {{ tax.name }} - {{ tax.percent }}%
</label> </label>
@ -59,7 +59,7 @@
<label <label
v-else-if="store[storeProp].tax_per_item === 'YES'" v-else-if="store[storeProp].tax_per_item === 'YES'"
class="flex items-center justify-center m-0 text-lg text-black uppercase " class="flex items-center justify-center m-0 text-lg text-black dark:text-white uppercase "
> >
<BaseFormatMoney :amount="tax.amount" :currency="defaultCurrency" /> <BaseFormatMoney :amount="tax.amount" :currency="defaultCurrency" />
</label> </label>
@ -75,12 +75,12 @@
<BaseContentPlaceholders v-if="isLoading"> <BaseContentPlaceholders v-if="isLoading">
<BaseContentPlaceholdersText :lines="1" class="w-16 h-5" /> <BaseContentPlaceholdersText :lines="1" class="w-16 h-5" />
</BaseContentPlaceholders> </BaseContentPlaceholders>
<label <BaseLabel
v-else v-else
class="text-sm font-semibold leading-5 text-gray-400 uppercase" class=" !font-semibold !text-gray-400 !uppercase"
> >
{{ $t('estimates.discount') }} {{ $t('estimates.discount') }}
</label> </BaseLabel>
<BaseContentPlaceholders v-if="isLoading"> <BaseContentPlaceholders v-if="isLoading">
<BaseContentPlaceholdersText <BaseContentPlaceholdersText
:lines="1" :lines="1"
@ -171,21 +171,21 @@
<BaseContentPlaceholders v-if="isLoading"> <BaseContentPlaceholders v-if="isLoading">
<BaseContentPlaceholdersText :lines="1" class="w-16 h-5" /> <BaseContentPlaceholdersText :lines="1" class="w-16 h-5" />
</BaseContentPlaceholders> </BaseContentPlaceholders>
<label <BaseLabel
v-else v-else
class="m-0 text-sm font-semibold leading-5 text-gray-400 uppercase" class="!m-0 !font-semibold !text-gray-400 !uppercase"
>{{ $t('estimates.total') }} {{ $t('estimates.amount') }}:</label >{{ $t('estimates.total') }} {{ $t('estimates.amount') }}:</BaseLabel
> >
<BaseContentPlaceholders v-if="isLoading"> <BaseContentPlaceholders v-if="isLoading">
<BaseContentPlaceholdersText :lines="1" class="w-16 h-5" /> <BaseContentPlaceholdersText :lines="1" class="w-16 h-5" />
</BaseContentPlaceholders> </BaseContentPlaceholders>
<label <BaseLabel
v-else v-else
class="flex items-center justify-center text-lg uppercase text-primary-400" class="!flex !items-center !justify-center !text-lg !uppercase !text-primary-400"
> >
<BaseFormatMoney :amount="store.getTotal" :currency="defaultCurrency" /> <BaseFormatMoney :amount="store.getTotal" :currency="defaultCurrency" />
</label> </BaseLabel>
</div> </div>
</div> </div>
</template> </template>

View File

@ -1,9 +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"> <BaseLabel class="!font-semibold !text-gray-500 !uppercase">
{{ tax.name }} ({{ tax.percent }} %) {{ tax.name }} ({{ tax.percent }} %)
</label> </BaseLabel>
<label class="flex items-center justify-center text-lg text-black"> <label class="flex items-center justify-center text-lg text-black dark:text-white">
<BaseFormatMoney :amount="tax.amount" :currency="currency" /> <BaseFormatMoney :amount="tax.amount" :currency="currency" />
<BaseIcon <BaseIcon

View File

@ -88,38 +88,37 @@
@click="selectTaxType(taxType, close)" @click="selectTaxType(taxType, close)"
> >
<div class="flex justify-between px-2"> <div class="flex justify-between px-2">
<label <BaseLabel
class=" class="
m-0 !m-0
text-base !text-base
font-semibold !font-semibold
leading-tight !leading-tight
text-gray-700 !cursor-pointer
cursor-pointer
" "
> >
{{ taxType.name }} {{ taxType.name }}
</label> </BaseLabel>
<label <BaseLabel
class=" class="
m-0 !m-0
text-base !text-base
font-semibold !font-semibold
text-gray-700 !text-gray-700
cursor-pointer !cursor-pointer
" "
> >
{{ taxType.percent }} % {{ taxType.percent }} %
</label> </BaseLabel>
</div> </div>
</div> </div>
</div> </div>
<div v-else class="flex justify-center p-5 text-gray-400"> <div v-else class="flex justify-center p-5 text-gray-400">
<label class="text-base text-gray-500 cursor-pointer"> <BaseLabel class="!text-base !text-gray-500 !cursor-pointer">
{{ $t('general.no_tax_found') }} {{ $t('general.no_tax_found') }}
</label> </BaseLabel>
</div> </div>
</div> </div>
@ -142,19 +141,18 @@
@click="openTaxTypeModal" @click="openTaxTypeModal"
> >
<BaseIcon name="CheckCircleIcon" class="text-primary-400" /> <BaseIcon name="CheckCircleIcon" class="text-primary-400" />
<label <BaseLabel
class=" class="
m-0 !m-0
ml-3 !ml-3
text-sm !leading-none
leading-none !cursor-pointer
cursor-pointer !font-base
font-base !text-primary-400
text-primary-400
" "
> >
{{ $t('estimates.add_new_tax') }} {{ $t('estimates.add_new_tax') }}
</label> </BaseLabel>
</button> </button>
</div> </div>
</PopoverPanel> </PopoverPanel>

View File

@ -1,9 +1,9 @@
<template> <template>
<div> <div>
<label class="flex text-gray-800 font-medium text-sm mb-2"> <BaseLabel class="!flex !text-gray-800 !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> </BaseLabel>
<BaseButton <BaseButton
type="button" type="button"
class="flex justify-center w-full text-sm lg:w-auto hover:bg-gray-200" class="flex justify-center w-full text-sm lg:w-auto hover:bg-gray-200"

View File

@ -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') }}

View File

@ -53,7 +53,7 @@
</div> </div>
</div> </div>
<div v-else class="mt-24"> <div v-else class="mt-24">
<label class="flex items-center justify-center text-gray-500"> <label class="flex items-center justify-center text-gray-500 dark:text-gray-300">
{{ $t('modules.no_modules_installed') }} {{ $t('modules.no_modules_installed') }}
</label> </label>
</div> </div>

View File

@ -215,9 +215,9 @@
<SelectNotePopup type="Payment" @select="onSelectNote" /> <SelectNotePopup type="Payment" @select="onSelectNote" />
</div> </div>
<label class="mb-4 text-sm font-medium text-gray-800"> <BaseLabel class="!mb-4 !text-gray-800">
{{ $t('estimates.notes') }} {{ $t('estimates.notes') }}
</label> </BaseLabel>
<BaseCustomInput <BaseCustomInput
v-model="paymentStore.currentPayment.notes" v-model="paymentStore.currentPayment.notes"

View File

@ -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>

View File

@ -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>

View File

@ -4,9 +4,9 @@
:description="$t('settings.update_app.description')" :description="$t('settings.update_app.description')"
> >
<div class="pb-8 ml-0"> <div class="pb-8 ml-0">
<label class="text-sm not-italic font-medium input-label"> <BaseLabel class="!input-label">
{{ $t('settings.update_app.current_version') }} {{ $t('settings.update_app.current_version') }}
</label> </BaseLabel>
<div <div
class=" class="
@ -64,9 +64,9 @@
</div> </div>
</div> </div>
<label class="text-sm not-italic font-medium input-label"> <BaseLabel class="!input-label">
{{ $t('settings.update_app.next_version') }} {{ $t('settings.update_app.next_version') }}
</label> </BaseLabel>
<br /> <br />
<div <div
class=" class="
@ -99,9 +99,9 @@
v-html="description" v-html="description"
></div> ></div>
<label class="text-sm not-italic font-medium input-label"> <BaseLabel class=" !input-label">
{{ $t('settings.update_app.requirements') }} {{ $t('settings.update_app.requirements') }}
</label> </BaseLabel>
<table class="w-1/2 mt-2 border-2 border-gray-200 BaseTable-fixed"> <table class="w-1/2 mt-2 border-2 border-gray-200 BaseTable-fixed">
<tr <tr

View File

@ -97,6 +97,7 @@
whitespace-nowrap whitespace-nowrap
mr-2 mr-2
min-w-[200px] min-w-[200px]
dark:text-primary-400
" "
> >
{{ element.label }} {{ element.label }}

View File

@ -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,57 +38,43 @@
> >
<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 <BaseLabel
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') }}
</label> </BaseLabel>
<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"
> >

View File

@ -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
@ -67,13 +62,13 @@
</div> </div>
<div v-else> <div v-else>
<div v-if="usersStore.customerList.length > 0"> <div v-if="usersStore.customerList.length > 0">
<label class="text-sm text-gray-400 mb-0.5 block px-2 uppercase"> <BaseLabel class="!text-gray-400 !mb-0.5 !block !px-2 !uppercase">
{{ $t('global_search.customers') }} {{ $t('global_search.customers') }}
</label> </BaseLabel>
<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) }}
@ -114,15 +108,15 @@
</div> </div>
<div v-if="usersStore.userList.length > 0" class="mt-2"> <div v-if="usersStore.userList.length > 0" class="mt-2">
<label <BaseLabel
class="text-sm text-gray-400 mb-2 block px-2 mb-0.5 uppercase" class="!text-gray-400 !mb-2 !block !px-2 !uppercase"
> >
{{ $t('global_search.users') }} {{ $t('global_search.users') }}
</label> </BaseLabel>
<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` }"

View File

@ -15,7 +15,7 @@
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' disabled ? 'text-gray-400 cursor-not-allowed' : 'text-gray-600 dark:text-white'
} cursor-pointer `" } cursor-pointer `"
> >
{{ label }} {{ label }}

View File

@ -69,31 +69,29 @@
</div> </div>
<div class="grid grid-cols-2 gap-8 mt-2"> <div class="grid grid-cols-2 gap-8 mt-2">
<div v-if="selectedCustomer.billing" class="flex flex-col"> <div v-if="selectedCustomer.billing" class="flex flex-col">
<label <BaseLabel
class=" class="
mb-1 !mb-1
text-sm !text-left !text-gray-400
font-medium !uppercase
text-left text-gray-400 !whitespace-nowrap
uppercase
whitespace-nowrap
" "
> >
{{ $t('general.bill_to') }} {{ $t('general.bill_to') }}
</label> </BaseLabel>
<div <div
v-if="selectedCustomer.billing" v-if="selectedCustomer.billing"
class="flex flex-col flex-1 p-0 text-left" class="flex flex-col flex-1 p-0 text-left"
> >
<label <BaseLabel
v-if="selectedCustomer.billing.name" v-if="selectedCustomer.billing.name"
class="relative w-11/12 text-sm truncate" class="!relative !w-11/12 !truncate"
> >
{{ selectedCustomer.billing.name }} {{ selectedCustomer.billing.name }}
</label> </BaseLabel>
<label class="relative w-11/12 text-sm truncate"> <BaseLabel class="!relative !w-11/12 !truncate">
<span v-if="selectedCustomer.billing.city"> <span v-if="selectedCustomer.billing.city">
{{ selectedCustomer.billing.city }} {{ selectedCustomer.billing.city }}
</span> </span>
@ -108,42 +106,40 @@
<span v-if="selectedCustomer.billing.state"> <span v-if="selectedCustomer.billing.state">
{{ selectedCustomer.billing.state }} {{ selectedCustomer.billing.state }}
</span> </span>
</label> </BaseLabel>
<label <BaseLabel
v-if="selectedCustomer.billing.zip" v-if="selectedCustomer.billing.zip"
class="relative w-11/12 text-sm truncate" class="!relative !w-11/12 !truncate"
> >
{{ selectedCustomer.billing.zip }} {{ selectedCustomer.billing.zip }}
</label> </BaseLabel>
</div> </div>
</div> </div>
<div v-if="selectedCustomer.shipping" class="flex flex-col"> <div v-if="selectedCustomer.shipping" class="flex flex-col">
<label <BaseLabel
class=" class="
mb-1 !mb-1
text-sm !text-left !text-gray-400
font-medium !uppercase
text-left text-gray-400 !whitespace-nowrap
uppercase
whitespace-nowrap
" "
> >
{{ $t('general.ship_to') }} {{ $t('general.ship_to') }}
</label> </BaseLabel>
<div <div
v-if="selectedCustomer.shipping" v-if="selectedCustomer.shipping"
class="flex flex-col flex-1 p-0 text-left" class="flex flex-col flex-1 p-0 text-left"
> >
<label <BaseLabel
v-if="selectedCustomer.shipping.name" v-if="selectedCustomer.shipping.name"
class="relative w-11/12 text-sm truncate" class="!relative !w-11/12 !truncate"
> >
{{ selectedCustomer.shipping.name }} {{ selectedCustomer.shipping.name }}
</label> </BaseLabel>
<label class="relative w-11/12 text-sm truncate"> <BaseLabel class="!relative !w-11/12 !truncate">
<span v-if="selectedCustomer.shipping.city"> <span v-if="selectedCustomer.shipping.city">
{{ selectedCustomer.shipping.city }} {{ selectedCustomer.shipping.city }}
</span> </span>
@ -158,13 +154,13 @@
<span v-if="selectedCustomer.shipping.state"> <span v-if="selectedCustomer.shipping.state">
{{ selectedCustomer.shipping.state }} {{ selectedCustomer.shipping.state }}
</span> </span>
</label> </BaseLabel>
<label <BaseLabel
v-if="selectedCustomer.shipping.zip" v-if="selectedCustomer.shipping.zip"
class="relative w-11/12 text-sm truncate" class="!relative !w-11/12 !text-sm !truncate"
> >
{{ selectedCustomer.shipping.zip }} {{ selectedCustomer.shipping.zip }}
</label> </BaseLabel>
</div> </div>
</div> </div>
</div> </div>
@ -211,7 +207,7 @@
/> />
<div class="mt-1"> <div class="mt-1">
<label class="text-lg font-medium text-gray-900"> <label class="text-lg font-medium text-gray-900 dark:text-white">
{{ $t('customers.new_customer') }} {{ $t('customers.new_customer') }}
<span class="text-red-500"> * </span> <span class="text-red-500"> * </span>
</label> </label>
@ -335,9 +331,9 @@
v-if="customerStore.customers.length === 0" v-if="customerStore.customers.length === 0"
class="flex justify-center p-5 text-gray-400" class="flex justify-center p-5 text-gray-400"
> >
<label class="text-base text-gray-500 cursor-pointer"> <BaseLabel class="!text-base !text-gray-500 !cursor-pointer">
{{ $t('customers.no_customers_found') }} {{ $t('customers.no_customers_found') }}
</label> </BaseLabel>
</div> </div>
</ul> </ul>
</div> </div>
@ -362,19 +358,18 @@
> >
<BaseIcon name="UserAddIcon" class="text-primary-400" /> <BaseIcon name="UserAddIcon" class="text-primary-400" />
<label <BaseLabel
class=" class="
m-0 !m-0
ml-3 !ml-3
text-sm !leading-none
leading-none !cursor-pointer
cursor-pointer !font-base
font-base !text-primary-400
text-primary-400
" "
> >
{{ $t('customers.add_new_customer') }} {{ $t('customers.add_new_customer') }}
</label> </BaseLabel>
</button> </button>
</PopoverPanel> </PopoverPanel>
</div> </div>

View File

@ -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}`
}) })

View File

@ -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>

View File

@ -4,10 +4,10 @@
<slot></slot> <slot></slot>
</div> </div>
<div class="mt-2"> <div class="mt-2">
<label class="font-medium">{{ title }}</label> <BaseLabel >{{ title }}</BaseLabel>
</div> </div>
<div class="mt-2"> <div class="mt-2">
<label class="text-gray-500"> <label class="text-gray-500 dark:text-gray-400">
{{ description }} {{ description }}
</label> </label>
</div> </div>

View File

@ -20,6 +20,7 @@
hover:text-gray-700 hover:text-gray-700
top-2.5 top-2.5
right-3.5 right-3.5
dark:text-gray-300
" "
@click="$emit('clear')" @click="$emit('clear')"
> >

View File

@ -3,18 +3,15 @@
<BaseContentPlaceholders v-if="contentLoading"> <BaseContentPlaceholders v-if="contentLoading">
<BaseContentPlaceholdersText :lines="1" :class="contentLoadClass" /> <BaseContentPlaceholdersText :lines="1" :class="contentLoadClass" />
</BaseContentPlaceholders> </BaseContentPlaceholders>
<label <BaseLabel
v-else-if="label" v-else-if="label"
:class="labelClasses" :class="labelClasses"
class=" class="
flex !flex
text-sm !items-center
not-italic !text-gray-800
items-center !whitespace-nowrap
font-medium !justify-between
text-gray-800
whitespace-nowrap
justify-between
" "
> >
<div> <div>
@ -28,10 +25,10 @@
name="InformationCircleIcon" name="InformationCircleIcon"
class="h-4 text-gray-400 cursor-pointer hover:text-gray-600" class="h-4 text-gray-400 cursor-pointer hover:text-gray-600"
/> />
</label> </BaseLabel>
<div :class="inputContainerClasses"> <div :class="inputContainerClasses">
<slot></slot> <slot></slot>
<span v-if="helpText" class="text-gray-500 text-xs mt-1 font-light"> <span v-if="helpText" class="text-gray-500 text-xs mt-1 font-light dark:text-gray-400">
{{ 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">

View File

@ -1,5 +1,5 @@
<template> <template>
<label class="text-sm not-italic font-medium leading-5 text-primary-800"> <label class="text-sm not-italic font-medium leading-5 text-primary-800 dark:!text-gray-300">
<slot /> <slot />
</label> </label>
</template> </template>