mirror of
https://github.com/crater-invoice/crater.git
synced 2025-10-28 04:01:10 -04:00
v6 update
This commit is contained in:
144
resources/scripts/admin/views/customers/View.vue
Normal file
144
resources/scripts/admin/views/customers/View.vue
Normal file
@ -0,0 +1,144 @@
|
||||
<template>
|
||||
<BasePage class="xl:pl-96">
|
||||
<BasePageHeader :title="pageTitle">
|
||||
<template #actions>
|
||||
<router-link
|
||||
v-if="userStore.hasAbilities(abilities.EDIT_CUSTOMER)"
|
||||
:to="`/admin/customers/${route.params.id}/edit`"
|
||||
>
|
||||
<BaseButton
|
||||
class="mr-3"
|
||||
variant="primary-outline"
|
||||
:content-loading="isLoading"
|
||||
>
|
||||
{{ $t('general.edit') }}
|
||||
</BaseButton>
|
||||
</router-link>
|
||||
|
||||
<BaseDropdown
|
||||
v-if="canCreateTransaction()"
|
||||
position="bottom-end"
|
||||
:content-loading="isLoading"
|
||||
>
|
||||
<template #activator>
|
||||
<BaseButton
|
||||
class="mr-3"
|
||||
variant="primary"
|
||||
:content-loading="isLoading"
|
||||
>
|
||||
{{ $t('customers.new_transaction') }}
|
||||
</BaseButton>
|
||||
</template>
|
||||
|
||||
<router-link
|
||||
v-if="userStore.hasAbilities(abilities.CREATE_ESTIMATE)"
|
||||
:to="`/admin/estimates/create?customer=${$route.params.id}`"
|
||||
>
|
||||
<BaseDropdownItem class="">
|
||||
<BaseIcon name="DocumentIcon" class="mr-3 text-gray-600" />
|
||||
{{ $t('estimates.new_estimate') }}
|
||||
</BaseDropdownItem>
|
||||
</router-link>
|
||||
|
||||
<router-link
|
||||
v-if="userStore.hasAbilities(abilities.CREATE_INVOICE)"
|
||||
:to="`/admin/invoices/create?customer=${$route.params.id}`"
|
||||
>
|
||||
<BaseDropdownItem>
|
||||
<BaseIcon name="DocumentTextIcon" class="mr-3 text-gray-600" />
|
||||
{{ $t('invoices.new_invoice') }}
|
||||
</BaseDropdownItem>
|
||||
</router-link>
|
||||
|
||||
<router-link
|
||||
v-if="userStore.hasAbilities(abilities.CREATE_PAYMENT)"
|
||||
:to="`/admin/payments/create?customer=${$route.params.id}`"
|
||||
>
|
||||
<BaseDropdownItem>
|
||||
<BaseIcon name="CreditCardIcon" class="mr-3 text-gray-600" />
|
||||
{{ $t('payments.new_payment') }}
|
||||
</BaseDropdownItem>
|
||||
</router-link>
|
||||
|
||||
<router-link
|
||||
v-if="userStore.hasAbilities(abilities.CREATE_EXPENSE)"
|
||||
:to="`/admin/expenses/create?customer=${$route.params.id}`"
|
||||
>
|
||||
<BaseDropdownItem>
|
||||
<BaseIcon name="CalculatorIcon" class="mr-3 text-gray-600" />
|
||||
{{ $t('expenses.new_expense') }}
|
||||
</BaseDropdownItem>
|
||||
</router-link>
|
||||
</BaseDropdown>
|
||||
|
||||
<CustomerDropdown
|
||||
v-if="hasAtleastOneAbility()"
|
||||
:class="{
|
||||
'ml-3': isLoading,
|
||||
}"
|
||||
:row="customerStore.selectedViewCustomer"
|
||||
:load-data="refreshData"
|
||||
/>
|
||||
</template>
|
||||
</BasePageHeader>
|
||||
|
||||
<!-- Customer View Sidebar -->
|
||||
<CustomerViewSidebar />
|
||||
|
||||
<!-- Chart -->
|
||||
<CustomerChart />
|
||||
</BasePage>
|
||||
</template>
|
||||
|
||||
<script setup>
|
||||
import CustomerViewSidebar from './partials/CustomerViewSidebar.vue'
|
||||
import CustomerChart from './partials/CustomerChart.vue'
|
||||
import { ref, computed, inject } from 'vue'
|
||||
import { useRouter, useRoute } from 'vue-router'
|
||||
import { useI18n } from 'vue-i18n'
|
||||
import { useCustomerStore } from '@/scripts/admin/stores/customer'
|
||||
import { useDialogStore } from '@/scripts/stores/dialog'
|
||||
import { useUserStore } from '@/scripts/admin/stores/user'
|
||||
import CustomerDropdown from '@/scripts/admin/components/dropdowns/CustomerIndexDropdown.vue'
|
||||
import abilities from '@/scripts/admin/stub/abilities'
|
||||
|
||||
const utils = inject('utils')
|
||||
const dialogStore = useDialogStore()
|
||||
const customerStore = useCustomerStore()
|
||||
const userStore = useUserStore()
|
||||
const { t } = useI18n()
|
||||
|
||||
const router = useRouter()
|
||||
const route = useRoute()
|
||||
const customer = ref(null)
|
||||
|
||||
const pageTitle = computed(() => {
|
||||
return customerStore.selectedViewCustomer.customer
|
||||
? customerStore.selectedViewCustomer.customer.name
|
||||
: ''
|
||||
})
|
||||
|
||||
let isLoading = computed(() => {
|
||||
return customerStore.isFetchingViewData
|
||||
})
|
||||
|
||||
function canCreateTransaction() {
|
||||
return userStore.hasAbilities([
|
||||
abilities.CREATE_ESTIMATE,
|
||||
abilities.CREATE_INVOICE,
|
||||
abilities.CREATE_PAYMENT,
|
||||
abilities.CREATE_EXPENSE,
|
||||
])
|
||||
}
|
||||
|
||||
function hasAtleastOneAbility() {
|
||||
return userStore.hasAbilities([
|
||||
abilities.DELETE_CUSTOMER,
|
||||
abilities.EDIT_CUSTOMER,
|
||||
])
|
||||
}
|
||||
|
||||
function refreshData() {
|
||||
router.push('/admin/customers')
|
||||
}
|
||||
</script>
|
||||
Reference in New Issue
Block a user