mirror of
				https://github.com/crater-invoice/crater.git
				synced 2025-11-03 22:13:18 -05:00 
			
		
		
		
	Compare commits
	
		
			35 Commits
		
	
	
		
			dark-base-
			...
			dark-view-
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 5ce6844028 | |||
| 8a5632c7d6 | |||
| 1a4309ca69 | |||
| 3b3da13218 | |||
| 5440b0f354 | |||
| c541114992 | |||
| db89a93faa | |||
| 9249105ad6 | |||
| 238cdb3c25 | |||
| 55bf70c868 | |||
| 0c5adff9b4 | |||
| 3d5732ee26 | |||
| 5aa7decdbe | |||
| 5c67780870 | |||
| ba7f619c67 | |||
| 82efad71c0 | |||
| 826ef72faa | |||
| 2adaa7a84a | |||
| 13557ea075 | |||
| ce88c772d1 | |||
| a32d36363d | |||
| f874b3507d | |||
| c36d25931f | |||
| 1e6c3b287f | |||
| 0462ff60a0 | |||
| 29a135adaf | |||
| 1aceb2c672 | |||
| fb9fab641d | |||
| 8f2edc220b | |||
| d14ab013ad | |||
| f6639f5863 | |||
| c5acf1343e | |||
| 0321ca5515 | |||
| bd345949e5 | |||
| b4b00ebdd6 | 
@ -7,6 +7,7 @@
 | 
				
			|||||||
      py-2
 | 
					      py-2
 | 
				
			||||||
      rounded-lg
 | 
					      rounded-lg
 | 
				
			||||||
      bg-opacity-40 bg-gray-300
 | 
					      bg-opacity-40 bg-gray-300
 | 
				
			||||||
 | 
					      dark:bg-gray-700 dark:border-gray-600
 | 
				
			||||||
      whitespace-nowrap
 | 
					      whitespace-nowrap
 | 
				
			||||||
      flex-col
 | 
					      flex-col
 | 
				
			||||||
      mt-1
 | 
					      mt-1
 | 
				
			||||||
@ -19,6 +20,7 @@
 | 
				
			|||||||
        text-sm
 | 
					        text-sm
 | 
				
			||||||
        font-medium
 | 
					        font-medium
 | 
				
			||||||
        text-black
 | 
					        text-black
 | 
				
			||||||
 | 
					        dark:text-white
 | 
				
			||||||
        truncate
 | 
					        truncate
 | 
				
			||||||
        select-all select-color
 | 
					        select-all select-color
 | 
				
			||||||
      "
 | 
					      "
 | 
				
			||||||
 | 
				
			|||||||
@ -43,6 +43,12 @@
 | 
				
			|||||||
            max-w-full
 | 
					            max-w-full
 | 
				
			||||||
            left-0
 | 
					            left-0
 | 
				
			||||||
            top-3
 | 
					            top-3
 | 
				
			||||||
 | 
					            bg-white
 | 
				
			||||||
 | 
					            dark:border
 | 
				
			||||||
 | 
					            dark:border-white/10
 | 
				
			||||||
 | 
					            dark:text-white
 | 
				
			||||||
 | 
					            dark:bg-gray-800
 | 
				
			||||||
 | 
					            dark:shadow-glass
 | 
				
			||||||
          "
 | 
					          "
 | 
				
			||||||
        >
 | 
					        >
 | 
				
			||||||
          <div
 | 
					          <div
 | 
				
			||||||
@ -53,7 +59,7 @@
 | 
				
			|||||||
              ring-1 ring-black ring-opacity-5
 | 
					              ring-1 ring-black ring-opacity-5
 | 
				
			||||||
            "
 | 
					            "
 | 
				
			||||||
          >
 | 
					          >
 | 
				
			||||||
            <div class="relative grid bg-white">
 | 
					            <div class="relative grid bg-white dark:bg-gray-800">
 | 
				
			||||||
              <div class="relative p-4">
 | 
					              <div class="relative p-4">
 | 
				
			||||||
                <BaseInput
 | 
					                <BaseInput
 | 
				
			||||||
                  v-model="textSearch"
 | 
					                  v-model="textSearch"
 | 
				
			||||||
@ -66,7 +72,7 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
              <div
 | 
					              <div
 | 
				
			||||||
                v-if="filteredNotes.length > 0"
 | 
					                v-if="filteredNotes.length > 0"
 | 
				
			||||||
                class="relative flex flex-col overflow-auto list max-h-36"
 | 
					                class="relative flex flex-col overflow-auto list max-h-36 dark:border-white/10"
 | 
				
			||||||
              >
 | 
					              >
 | 
				
			||||||
                <div
 | 
					                <div
 | 
				
			||||||
                  v-for="(note, index) in filteredNotes"
 | 
					                  v-for="(note, index) in filteredNotes"
 | 
				
			||||||
@ -79,6 +85,8 @@
 | 
				
			|||||||
                    cursor-pointer
 | 
					                    cursor-pointer
 | 
				
			||||||
                    hover:bg-gray-100 hover:cursor-pointer
 | 
					                    hover:bg-gray-100 hover:cursor-pointer
 | 
				
			||||||
                    last:border-b-0
 | 
					                    last:border-b-0
 | 
				
			||||||
 | 
					                    dark:border-gray-600
 | 
				
			||||||
 | 
					                    dark:border-white/10 dark:hover:bg-gray-700/30
 | 
				
			||||||
                  "
 | 
					                  "
 | 
				
			||||||
                  @click="selectNote(index, close)"
 | 
					                  @click="selectNote(index, close)"
 | 
				
			||||||
                >
 | 
					                >
 | 
				
			||||||
@ -91,6 +99,7 @@
 | 
				
			|||||||
                        leading-tight
 | 
					                        leading-tight
 | 
				
			||||||
                        text-gray-700
 | 
					                        text-gray-700
 | 
				
			||||||
                        cursor-pointer
 | 
					                        cursor-pointer
 | 
				
			||||||
 | 
					                        dark:text-gray-400
 | 
				
			||||||
                      "
 | 
					                      "
 | 
				
			||||||
                    >
 | 
					                    >
 | 
				
			||||||
                      {{ note.name }}
 | 
					                      {{ note.name }}
 | 
				
			||||||
@ -118,6 +127,10 @@
 | 
				
			|||||||
                bg-gray-200
 | 
					                bg-gray-200
 | 
				
			||||||
                border-none
 | 
					                border-none
 | 
				
			||||||
                outline-none
 | 
					                outline-none
 | 
				
			||||||
 | 
					                dark:bg-gray-600/70
 | 
				
			||||||
 | 
					                dark:backdrop-blur-xl
 | 
				
			||||||
 | 
					                dark:shadow-glass
 | 
				
			||||||
 | 
					                dark:hover:bg-gray-600/80
 | 
				
			||||||
              "
 | 
					              "
 | 
				
			||||||
              @click="openNoteModal"
 | 
					              @click="openNoteModal"
 | 
				
			||||||
            >
 | 
					            >
 | 
				
			||||||
 | 
				
			|||||||
@ -6,8 +6,17 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
<script setup>
 | 
					<script setup>
 | 
				
			||||||
import Chart from 'chart.js'
 | 
					import Chart from 'chart.js'
 | 
				
			||||||
import { ref, reactive, computed, onMounted, watchEffect, inject } from 'vue'
 | 
					import {
 | 
				
			||||||
 | 
					  ref,
 | 
				
			||||||
 | 
					  reactive,
 | 
				
			||||||
 | 
					  computed,
 | 
				
			||||||
 | 
					  onMounted,
 | 
				
			||||||
 | 
					  watchEffect,
 | 
				
			||||||
 | 
					  inject,
 | 
				
			||||||
 | 
					  watch,
 | 
				
			||||||
 | 
					} from 'vue'
 | 
				
			||||||
import { useCompanyStore } from '@/scripts/admin/stores/company'
 | 
					import { useCompanyStore } from '@/scripts/admin/stores/company'
 | 
				
			||||||
 | 
					import { useGlobalStore } from '@/scripts/admin/stores/global'
 | 
				
			||||||
 | 
					
 | 
				
			||||||
const utils = inject('utils')
 | 
					const utils = inject('utils')
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@ -44,9 +53,11 @@ const props = defineProps({
 | 
				
			|||||||
  },
 | 
					  },
 | 
				
			||||||
})
 | 
					})
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					const isDarkModeOn = document.documentElement.classList.contains('dark')
 | 
				
			||||||
let myLineChart = null
 | 
					let myLineChart = null
 | 
				
			||||||
const graph = ref(null)
 | 
					const graph = ref(null)
 | 
				
			||||||
const companyStore = useCompanyStore()
 | 
					const companyStore = useCompanyStore()
 | 
				
			||||||
 | 
					const globalStore = useGlobalStore()
 | 
				
			||||||
const defaultCurrency = computed(() => {
 | 
					const defaultCurrency = computed(() => {
 | 
				
			||||||
  return companyStore.selectedCompanyCurrency
 | 
					  return companyStore.selectedCompanyCurrency
 | 
				
			||||||
})
 | 
					})
 | 
				
			||||||
@ -60,6 +71,14 @@ watchEffect(() => {
 | 
				
			|||||||
  }
 | 
					  }
 | 
				
			||||||
})
 | 
					})
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					watch(
 | 
				
			||||||
 | 
					  () => globalStore.isDarkModeOn,
 | 
				
			||||||
 | 
					  () => {
 | 
				
			||||||
 | 
					    myLineChart.reset()
 | 
				
			||||||
 | 
					    updateColors()
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
onMounted(() => {
 | 
					onMounted(() => {
 | 
				
			||||||
  let context = graph.value.getContext('2d')
 | 
					  let context = graph.value.getContext('2d')
 | 
				
			||||||
  let options = reactive({
 | 
					  let options = reactive({
 | 
				
			||||||
@ -81,6 +100,8 @@ onMounted(() => {
 | 
				
			|||||||
    },
 | 
					    },
 | 
				
			||||||
  })
 | 
					  })
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  const salesColor = globalStore.isDarkModeOn ? '#ffffff' : '#040405'
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  let data = reactive({
 | 
					  let data = reactive({
 | 
				
			||||||
    labels: props.labels,
 | 
					    labels: props.labels,
 | 
				
			||||||
    datasets: [
 | 
					    datasets: [
 | 
				
			||||||
@ -89,16 +110,16 @@ onMounted(() => {
 | 
				
			|||||||
        fill: false,
 | 
					        fill: false,
 | 
				
			||||||
        lineTension: 0.3,
 | 
					        lineTension: 0.3,
 | 
				
			||||||
        backgroundColor: 'rgba(230, 254, 249)',
 | 
					        backgroundColor: 'rgba(230, 254, 249)',
 | 
				
			||||||
        borderColor: '#040405',
 | 
					        borderColor: salesColor,
 | 
				
			||||||
        borderCapStyle: 'butt',
 | 
					        borderCapStyle: 'butt',
 | 
				
			||||||
        borderDash: [],
 | 
					        borderDash: [],
 | 
				
			||||||
        borderDashOffset: 0.0,
 | 
					        borderDashOffset: 0.0,
 | 
				
			||||||
        borderJoinStyle: 'miter',
 | 
					        borderJoinStyle: 'miter',
 | 
				
			||||||
        pointBorderColor: '#040405',
 | 
					        pointBorderColor: salesColor,
 | 
				
			||||||
        pointBackgroundColor: '#fff',
 | 
					        pointBackgroundColor: '#fff',
 | 
				
			||||||
        pointBorderWidth: 1,
 | 
					        pointBorderWidth: 1,
 | 
				
			||||||
        pointHoverRadius: 5,
 | 
					        pointHoverRadius: 5,
 | 
				
			||||||
        pointHoverBackgroundColor: '#040405',
 | 
					        pointHoverBackgroundColor: salesColor,
 | 
				
			||||||
        pointHoverBorderColor: 'rgba(220,220,220,1)',
 | 
					        pointHoverBorderColor: 'rgba(220,220,220,1)',
 | 
				
			||||||
        pointHoverBorderWidth: 2,
 | 
					        pointHoverBorderWidth: 2,
 | 
				
			||||||
        pointRadius: 4,
 | 
					        pointRadius: 4,
 | 
				
			||||||
@ -194,4 +215,12 @@ function update() {
 | 
				
			|||||||
    lazy: true,
 | 
					    lazy: true,
 | 
				
			||||||
  })
 | 
					  })
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					function updateColors() {
 | 
				
			||||||
 | 
					  const newColor = globalStore.isDarkModeOn ? '#ffffff' : '#040405'
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  myLineChart.data.datasets[0].borderColor = newColor
 | 
				
			||||||
 | 
					  myLineChart.data.datasets[0].pointBorderColor = newColor
 | 
				
			||||||
 | 
					  myLineChart.data.datasets[0].pointHoverBackgroundColor = newColor
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
</script>
 | 
					</script>
 | 
				
			||||||
 | 
				
			|||||||
@ -50,21 +50,11 @@
 | 
				
			|||||||
          </BaseInputGroup>
 | 
					          </BaseInputGroup>
 | 
				
			||||||
        </template>
 | 
					        </template>
 | 
				
			||||||
      </ValidateEach>
 | 
					      </ValidateEach>
 | 
				
			||||||
      <div
 | 
					      <BaseModalFooter>
 | 
				
			||||||
        slot="footer"
 | 
					 | 
				
			||||||
        class="
 | 
					 | 
				
			||||||
          z-0
 | 
					 | 
				
			||||||
          flex
 | 
					 | 
				
			||||||
          justify-end
 | 
					 | 
				
			||||||
          mt-4
 | 
					 | 
				
			||||||
          pt-4
 | 
					 | 
				
			||||||
          border-t border-gray-200 border-solid border-modal-bg
 | 
					 | 
				
			||||||
        "
 | 
					 | 
				
			||||||
      >
 | 
					 | 
				
			||||||
        <BaseButton :loading="isSaving" variant="primary" type="submit">
 | 
					        <BaseButton :loading="isSaving" variant="primary" type="submit">
 | 
				
			||||||
          {{ $t('general.save') }}
 | 
					          {{ $t('general.save') }}
 | 
				
			||||||
        </BaseButton>
 | 
					        </BaseButton>
 | 
				
			||||||
      </div>
 | 
					      </BaseModalFooter>
 | 
				
			||||||
    </form>
 | 
					    </form>
 | 
				
			||||||
  </BaseCard>
 | 
					  </BaseCard>
 | 
				
			||||||
</template>
 | 
					</template>
 | 
				
			||||||
 | 
				
			|||||||
@ -7,11 +7,12 @@
 | 
				
			|||||||
    <!-- edit customField  -->
 | 
					    <!-- edit customField  -->
 | 
				
			||||||
    <BaseDropdownItem
 | 
					    <BaseDropdownItem
 | 
				
			||||||
      v-if="userStore.hasAbilities(abilities.EDIT_CUSTOM_FIELDS)"
 | 
					      v-if="userStore.hasAbilities(abilities.EDIT_CUSTOM_FIELDS)"
 | 
				
			||||||
 | 
					      v-slot="slotProps"
 | 
				
			||||||
      @click="editCustomField(row.id)"
 | 
					      @click="editCustomField(row.id)"
 | 
				
			||||||
    >
 | 
					    >
 | 
				
			||||||
      <BaseIcon
 | 
					      <BaseIcon
 | 
				
			||||||
        name="PencilIcon"
 | 
					        name="PencilIcon"
 | 
				
			||||||
        class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					        :class="slotProps.class"
 | 
				
			||||||
      />
 | 
					      />
 | 
				
			||||||
      {{ $t('general.edit') }}
 | 
					      {{ $t('general.edit') }}
 | 
				
			||||||
    </BaseDropdownItem>
 | 
					    </BaseDropdownItem>
 | 
				
			||||||
@ -19,11 +20,12 @@
 | 
				
			|||||||
    <!-- delete customField  -->
 | 
					    <!-- delete customField  -->
 | 
				
			||||||
    <BaseDropdownItem
 | 
					    <BaseDropdownItem
 | 
				
			||||||
      v-if="userStore.hasAbilities(abilities.DELETE_CUSTOM_FIELDS)"
 | 
					      v-if="userStore.hasAbilities(abilities.DELETE_CUSTOM_FIELDS)"
 | 
				
			||||||
 | 
					      v-slot="slotProps"
 | 
				
			||||||
      @click="removeCustomField(row.id)"
 | 
					      @click="removeCustomField(row.id)"
 | 
				
			||||||
    >
 | 
					    >
 | 
				
			||||||
      <BaseIcon
 | 
					      <BaseIcon
 | 
				
			||||||
        name="TrashIcon"
 | 
					        name="TrashIcon"
 | 
				
			||||||
        class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					        :class="slotProps.class"
 | 
				
			||||||
      />
 | 
					      />
 | 
				
			||||||
      {{ $t('general.delete') }}
 | 
					      {{ $t('general.delete') }}
 | 
				
			||||||
    </BaseDropdownItem>
 | 
					    </BaseDropdownItem>
 | 
				
			||||||
 | 
				
			|||||||
@ -12,10 +12,10 @@
 | 
				
			|||||||
      v-if="userStore.hasAbilities(abilities.EDIT_CUSTOMER)"
 | 
					      v-if="userStore.hasAbilities(abilities.EDIT_CUSTOMER)"
 | 
				
			||||||
      :to="`/admin/customers/${row.id}/edit`"
 | 
					      :to="`/admin/customers/${row.id}/edit`"
 | 
				
			||||||
    >
 | 
					    >
 | 
				
			||||||
      <BaseDropdownItem>
 | 
					      <BaseDropdownItem v-slot="slotProps">
 | 
				
			||||||
        <BaseIcon
 | 
					        <BaseIcon
 | 
				
			||||||
          name="PencilIcon"
 | 
					          name="PencilIcon"
 | 
				
			||||||
          class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					          :class="slotProps.class"
 | 
				
			||||||
        />
 | 
					        />
 | 
				
			||||||
        {{ $t('general.edit') }}
 | 
					        {{ $t('general.edit') }}
 | 
				
			||||||
      </BaseDropdownItem>
 | 
					      </BaseDropdownItem>
 | 
				
			||||||
@ -29,10 +29,10 @@
 | 
				
			|||||||
      "
 | 
					      "
 | 
				
			||||||
      :to="`customers/${row.id}/view`"
 | 
					      :to="`customers/${row.id}/view`"
 | 
				
			||||||
    >
 | 
					    >
 | 
				
			||||||
      <BaseDropdownItem>
 | 
					      <BaseDropdownItem v-slot="slotProps">
 | 
				
			||||||
        <BaseIcon
 | 
					        <BaseIcon
 | 
				
			||||||
          name="EyeIcon"
 | 
					          name="EyeIcon"
 | 
				
			||||||
          class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					          :class="slotProps.class"
 | 
				
			||||||
        />
 | 
					        />
 | 
				
			||||||
        {{ $t('general.view') }}
 | 
					        {{ $t('general.view') }}
 | 
				
			||||||
      </BaseDropdownItem>
 | 
					      </BaseDropdownItem>
 | 
				
			||||||
@ -41,11 +41,12 @@
 | 
				
			|||||||
    <!-- Delete Customer  -->
 | 
					    <!-- Delete Customer  -->
 | 
				
			||||||
    <BaseDropdownItem
 | 
					    <BaseDropdownItem
 | 
				
			||||||
      v-if="userStore.hasAbilities(abilities.DELETE_CUSTOMER)"
 | 
					      v-if="userStore.hasAbilities(abilities.DELETE_CUSTOMER)"
 | 
				
			||||||
 | 
					      v-slot="slotProps"
 | 
				
			||||||
      @click="removeCustomer(row.id)"
 | 
					      @click="removeCustomer(row.id)"
 | 
				
			||||||
    >
 | 
					    >
 | 
				
			||||||
      <BaseIcon
 | 
					      <BaseIcon
 | 
				
			||||||
        name="TrashIcon"
 | 
					        name="TrashIcon"
 | 
				
			||||||
        class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					        :class="slotProps.class"
 | 
				
			||||||
      />
 | 
					      />
 | 
				
			||||||
      {{ $t('general.delete') }}
 | 
					      {{ $t('general.delete') }}
 | 
				
			||||||
    </BaseDropdownItem>
 | 
					    </BaseDropdownItem>
 | 
				
			||||||
 | 
				
			|||||||
@ -10,11 +10,12 @@
 | 
				
			|||||||
    <!-- Copy PDF url  -->
 | 
					    <!-- Copy PDF url  -->
 | 
				
			||||||
    <BaseDropdownItem
 | 
					    <BaseDropdownItem
 | 
				
			||||||
      v-if="route.name === 'estimates.view'"
 | 
					      v-if="route.name === 'estimates.view'"
 | 
				
			||||||
 | 
					      v-slot="slotProps"
 | 
				
			||||||
      @click="copyPdfUrl"
 | 
					      @click="copyPdfUrl"
 | 
				
			||||||
    >
 | 
					    >
 | 
				
			||||||
      <BaseIcon
 | 
					      <BaseIcon
 | 
				
			||||||
        name="LinkIcon"
 | 
					        name="LinkIcon"
 | 
				
			||||||
        class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					        :class="slotProps.class"
 | 
				
			||||||
      />
 | 
					      />
 | 
				
			||||||
      {{ $t('general.copy_pdf_url') }}
 | 
					      {{ $t('general.copy_pdf_url') }}
 | 
				
			||||||
    </BaseDropdownItem>
 | 
					    </BaseDropdownItem>
 | 
				
			||||||
@ -24,10 +25,10 @@
 | 
				
			|||||||
      v-if="userStore.hasAbilities(abilities.EDIT_ESTIMATE)"
 | 
					      v-if="userStore.hasAbilities(abilities.EDIT_ESTIMATE)"
 | 
				
			||||||
      :to="`/admin/estimates/${row.id}/edit`"
 | 
					      :to="`/admin/estimates/${row.id}/edit`"
 | 
				
			||||||
    >
 | 
					    >
 | 
				
			||||||
      <BaseDropdownItem>
 | 
					      <BaseDropdownItem v-slot="slotProps">
 | 
				
			||||||
        <BaseIcon
 | 
					        <BaseIcon
 | 
				
			||||||
          name="PencilIcon"
 | 
					          name="PencilIcon"
 | 
				
			||||||
          class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					          :class="slotProps.class"
 | 
				
			||||||
        />
 | 
					        />
 | 
				
			||||||
        {{ $t('general.edit') }}
 | 
					        {{ $t('general.edit') }}
 | 
				
			||||||
      </BaseDropdownItem>
 | 
					      </BaseDropdownItem>
 | 
				
			||||||
@ -36,11 +37,12 @@
 | 
				
			|||||||
    <!-- Delete Estimate  -->
 | 
					    <!-- Delete Estimate  -->
 | 
				
			||||||
    <BaseDropdownItem
 | 
					    <BaseDropdownItem
 | 
				
			||||||
      v-if="userStore.hasAbilities(abilities.DELETE_ESTIMATE)"
 | 
					      v-if="userStore.hasAbilities(abilities.DELETE_ESTIMATE)"
 | 
				
			||||||
 | 
					      v-slot="slotProps"
 | 
				
			||||||
      @click="removeEstimate(row.id)"
 | 
					      @click="removeEstimate(row.id)"
 | 
				
			||||||
    >
 | 
					    >
 | 
				
			||||||
      <BaseIcon
 | 
					      <BaseIcon
 | 
				
			||||||
        name="TrashIcon"
 | 
					        name="TrashIcon"
 | 
				
			||||||
        class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					        :class="slotProps.class"
 | 
				
			||||||
      />
 | 
					      />
 | 
				
			||||||
      {{ $t('general.delete') }}
 | 
					      {{ $t('general.delete') }}
 | 
				
			||||||
    </BaseDropdownItem>
 | 
					    </BaseDropdownItem>
 | 
				
			||||||
@ -53,10 +55,10 @@
 | 
				
			|||||||
      "
 | 
					      "
 | 
				
			||||||
      :to="`estimates/${row.id}/view`"
 | 
					      :to="`estimates/${row.id}/view`"
 | 
				
			||||||
    >
 | 
					    >
 | 
				
			||||||
      <BaseDropdownItem>
 | 
					      <BaseDropdownItem v-slot="slotProps">
 | 
				
			||||||
        <BaseIcon
 | 
					        <BaseIcon
 | 
				
			||||||
          name="EyeIcon"
 | 
					          name="EyeIcon"
 | 
				
			||||||
          class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					          :class="slotProps.class"
 | 
				
			||||||
        />
 | 
					        />
 | 
				
			||||||
        {{ $t('general.view') }}
 | 
					        {{ $t('general.view') }}
 | 
				
			||||||
      </BaseDropdownItem>
 | 
					      </BaseDropdownItem>
 | 
				
			||||||
@ -65,11 +67,12 @@
 | 
				
			|||||||
    <!-- Convert into Invoice  -->
 | 
					    <!-- Convert into Invoice  -->
 | 
				
			||||||
    <BaseDropdownItem
 | 
					    <BaseDropdownItem
 | 
				
			||||||
      v-if="userStore.hasAbilities(abilities.CREATE_INVOICE)"
 | 
					      v-if="userStore.hasAbilities(abilities.CREATE_INVOICE)"
 | 
				
			||||||
 | 
					      v-slot="slotProps"
 | 
				
			||||||
      @click="convertInToinvoice(row.id)"
 | 
					      @click="convertInToinvoice(row.id)"
 | 
				
			||||||
    >
 | 
					    >
 | 
				
			||||||
      <BaseIcon
 | 
					      <BaseIcon
 | 
				
			||||||
        name="DocumentTextIcon"
 | 
					        name="DocumentTextIcon"
 | 
				
			||||||
        class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					        :class="slotProps.class"
 | 
				
			||||||
      />
 | 
					      />
 | 
				
			||||||
      {{ $t('estimates.convert_to_invoice') }}
 | 
					      {{ $t('estimates.convert_to_invoice') }}
 | 
				
			||||||
    </BaseDropdownItem>
 | 
					    </BaseDropdownItem>
 | 
				
			||||||
@ -81,11 +84,12 @@
 | 
				
			|||||||
        route.name !== 'estimates.view' &&
 | 
					        route.name !== 'estimates.view' &&
 | 
				
			||||||
        userStore.hasAbilities(abilities.SEND_ESTIMATE)
 | 
					        userStore.hasAbilities(abilities.SEND_ESTIMATE)
 | 
				
			||||||
      "
 | 
					      "
 | 
				
			||||||
 | 
					      v-slot="slotProps"
 | 
				
			||||||
      @click="onMarkAsSent(row.id)"
 | 
					      @click="onMarkAsSent(row.id)"
 | 
				
			||||||
    >
 | 
					    >
 | 
				
			||||||
      <BaseIcon
 | 
					      <BaseIcon
 | 
				
			||||||
        name="CheckCircleIcon"
 | 
					        name="CheckCircleIcon"
 | 
				
			||||||
        class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					        :class="slotProps.class"
 | 
				
			||||||
      />
 | 
					      />
 | 
				
			||||||
      {{ $t('estimates.mark_as_sent') }}
 | 
					      {{ $t('estimates.mark_as_sent') }}
 | 
				
			||||||
    </BaseDropdownItem>
 | 
					    </BaseDropdownItem>
 | 
				
			||||||
@ -97,20 +101,21 @@
 | 
				
			|||||||
        route.name !== 'estimates.view' &&
 | 
					        route.name !== 'estimates.view' &&
 | 
				
			||||||
        userStore.hasAbilities(abilities.SEND_ESTIMATE)
 | 
					        userStore.hasAbilities(abilities.SEND_ESTIMATE)
 | 
				
			||||||
      "
 | 
					      "
 | 
				
			||||||
 | 
					      v-slot="slotProps"
 | 
				
			||||||
      @click="sendEstimate(row)"
 | 
					      @click="sendEstimate(row)"
 | 
				
			||||||
    >
 | 
					    >
 | 
				
			||||||
      <BaseIcon
 | 
					      <BaseIcon
 | 
				
			||||||
        name="PaperAirplaneIcon"
 | 
					        name="PaperAirplaneIcon"
 | 
				
			||||||
        class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					        :class="slotProps.class"
 | 
				
			||||||
      />
 | 
					      />
 | 
				
			||||||
      {{ $t('estimates.send_estimate') }}
 | 
					      {{ $t('estimates.send_estimate') }}
 | 
				
			||||||
    </BaseDropdownItem>
 | 
					    </BaseDropdownItem>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    <!-- Resend Estimate -->
 | 
					    <!-- Resend Estimate -->
 | 
				
			||||||
    <BaseDropdownItem v-if="canResendEstimate(row)" @click="sendEstimate(row)">
 | 
					    <BaseDropdownItem v-if="canResendEstimate(row)" v-slot="slotProps"  @click="sendEstimate(row)">
 | 
				
			||||||
      <BaseIcon
 | 
					      <BaseIcon
 | 
				
			||||||
        name="PaperAirplaneIcon"
 | 
					        name="PaperAirplaneIcon"
 | 
				
			||||||
        class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					        :class="slotProps.class"
 | 
				
			||||||
      />
 | 
					      />
 | 
				
			||||||
      {{ $t('estimates.resend_estimate') }}
 | 
					      {{ $t('estimates.resend_estimate') }}
 | 
				
			||||||
    </BaseDropdownItem>
 | 
					    </BaseDropdownItem>
 | 
				
			||||||
@ -121,11 +126,12 @@
 | 
				
			|||||||
        row.status !== 'ACCEPTED' &&
 | 
					        row.status !== 'ACCEPTED' &&
 | 
				
			||||||
        userStore.hasAbilities(abilities.EDIT_ESTIMATE)
 | 
					        userStore.hasAbilities(abilities.EDIT_ESTIMATE)
 | 
				
			||||||
      "
 | 
					      "
 | 
				
			||||||
 | 
					      v-slot="slotProps"
 | 
				
			||||||
      @click="onMarkAsAccepted(row.id)"
 | 
					      @click="onMarkAsAccepted(row.id)"
 | 
				
			||||||
    >
 | 
					    >
 | 
				
			||||||
      <BaseIcon
 | 
					      <BaseIcon
 | 
				
			||||||
        name="CheckCircleIcon"
 | 
					        name="CheckCircleIcon"
 | 
				
			||||||
        class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					        :class="slotProps.class"
 | 
				
			||||||
      />
 | 
					      />
 | 
				
			||||||
      {{ $t('estimates.mark_as_accepted') }}
 | 
					      {{ $t('estimates.mark_as_accepted') }}
 | 
				
			||||||
    </BaseDropdownItem>
 | 
					    </BaseDropdownItem>
 | 
				
			||||||
@ -136,11 +142,12 @@
 | 
				
			|||||||
        row.status !== 'REJECTED' &&
 | 
					        row.status !== 'REJECTED' &&
 | 
				
			||||||
        userStore.hasAbilities(abilities.EDIT_ESTIMATE)
 | 
					        userStore.hasAbilities(abilities.EDIT_ESTIMATE)
 | 
				
			||||||
      "
 | 
					      "
 | 
				
			||||||
 | 
					      v-slot="slotProps"
 | 
				
			||||||
      @click="onMarkAsRejected(row.id)"
 | 
					      @click="onMarkAsRejected(row.id)"
 | 
				
			||||||
    >
 | 
					    >
 | 
				
			||||||
      <BaseIcon
 | 
					      <BaseIcon
 | 
				
			||||||
        name="XCircleIcon"
 | 
					        name="XCircleIcon"
 | 
				
			||||||
        class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					        :class="slotProps.class"
 | 
				
			||||||
      />
 | 
					      />
 | 
				
			||||||
      {{ $t('estimates.mark_as_rejected') }}
 | 
					      {{ $t('estimates.mark_as_rejected') }}
 | 
				
			||||||
    </BaseDropdownItem>
 | 
					    </BaseDropdownItem>
 | 
				
			||||||
 | 
				
			|||||||
@ -13,11 +13,12 @@
 | 
				
			|||||||
    <!-- edit expenseCategory  -->
 | 
					    <!-- edit expenseCategory  -->
 | 
				
			||||||
    <BaseDropdownItem
 | 
					    <BaseDropdownItem
 | 
				
			||||||
      v-if="userStore.hasAbilities(abilities.EDIT_EXPENSE)"
 | 
					      v-if="userStore.hasAbilities(abilities.EDIT_EXPENSE)"
 | 
				
			||||||
 | 
					      v-slot="slotProps"
 | 
				
			||||||
      @click="editExpenseCategory(row.id)"
 | 
					      @click="editExpenseCategory(row.id)"
 | 
				
			||||||
    >
 | 
					    >
 | 
				
			||||||
      <BaseIcon
 | 
					      <BaseIcon
 | 
				
			||||||
        name="PencilIcon"
 | 
					        name="PencilIcon"
 | 
				
			||||||
        class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					        :class="slotProps.class"
 | 
				
			||||||
      />
 | 
					      />
 | 
				
			||||||
      {{ $t('general.edit') }}
 | 
					      {{ $t('general.edit') }}
 | 
				
			||||||
    </BaseDropdownItem>
 | 
					    </BaseDropdownItem>
 | 
				
			||||||
@ -25,11 +26,12 @@
 | 
				
			|||||||
    <!-- delete expenseCategory  -->
 | 
					    <!-- delete expenseCategory  -->
 | 
				
			||||||
    <BaseDropdownItem
 | 
					    <BaseDropdownItem
 | 
				
			||||||
      v-if="userStore.hasAbilities(abilities.DELETE_EXPENSE)"
 | 
					      v-if="userStore.hasAbilities(abilities.DELETE_EXPENSE)"
 | 
				
			||||||
 | 
					      v-slot="slotProps"
 | 
				
			||||||
      @click="removeExpenseCategory(row.id)"
 | 
					      @click="removeExpenseCategory(row.id)"
 | 
				
			||||||
    >
 | 
					    >
 | 
				
			||||||
      <BaseIcon
 | 
					      <BaseIcon
 | 
				
			||||||
        name="TrashIcon"
 | 
					        name="TrashIcon"
 | 
				
			||||||
        class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					        :class="slotProps.class"
 | 
				
			||||||
      />
 | 
					      />
 | 
				
			||||||
      {{ $t('general.delete') }}
 | 
					      {{ $t('general.delete') }}
 | 
				
			||||||
    </BaseDropdownItem>
 | 
					    </BaseDropdownItem>
 | 
				
			||||||
 | 
				
			|||||||
@ -12,10 +12,10 @@
 | 
				
			|||||||
      v-if="userStore.hasAbilities(abilities.EDIT_EXPENSE)"
 | 
					      v-if="userStore.hasAbilities(abilities.EDIT_EXPENSE)"
 | 
				
			||||||
      :to="`/admin/expenses/${row.id}/edit`"
 | 
					      :to="`/admin/expenses/${row.id}/edit`"
 | 
				
			||||||
    >
 | 
					    >
 | 
				
			||||||
      <BaseDropdownItem>
 | 
					      <BaseDropdownItem v-slot="slotProps">
 | 
				
			||||||
        <BaseIcon
 | 
					        <BaseIcon
 | 
				
			||||||
          name="PencilIcon"
 | 
					          name="PencilIcon"
 | 
				
			||||||
          class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					          :class="slotProps.class"
 | 
				
			||||||
        />
 | 
					        />
 | 
				
			||||||
        {{ $t('general.edit') }}
 | 
					        {{ $t('general.edit') }}
 | 
				
			||||||
      </BaseDropdownItem>
 | 
					      </BaseDropdownItem>
 | 
				
			||||||
@ -24,11 +24,12 @@
 | 
				
			|||||||
    <!-- delete expense  -->
 | 
					    <!-- delete expense  -->
 | 
				
			||||||
    <BaseDropdownItem
 | 
					    <BaseDropdownItem
 | 
				
			||||||
      v-if="userStore.hasAbilities(abilities.DELETE_EXPENSE)"
 | 
					      v-if="userStore.hasAbilities(abilities.DELETE_EXPENSE)"
 | 
				
			||||||
 | 
					      v-slot="slotProps"
 | 
				
			||||||
      @click="removeExpense(row.id)"
 | 
					      @click="removeExpense(row.id)"
 | 
				
			||||||
    >
 | 
					    >
 | 
				
			||||||
      <BaseIcon
 | 
					      <BaseIcon
 | 
				
			||||||
        name="TrashIcon"
 | 
					        name="TrashIcon"
 | 
				
			||||||
        class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					        :class="slotProps.class"
 | 
				
			||||||
      />
 | 
					      />
 | 
				
			||||||
      {{ $t('general.delete') }}
 | 
					      {{ $t('general.delete') }}
 | 
				
			||||||
    </BaseDropdownItem>
 | 
					    </BaseDropdownItem>
 | 
				
			||||||
 | 
				
			|||||||
@ -12,20 +12,20 @@
 | 
				
			|||||||
      v-if="userStore.hasAbilities(abilities.EDIT_INVOICE)"
 | 
					      v-if="userStore.hasAbilities(abilities.EDIT_INVOICE)"
 | 
				
			||||||
      :to="`/admin/invoices/${row.id}/edit`"
 | 
					      :to="`/admin/invoices/${row.id}/edit`"
 | 
				
			||||||
    >
 | 
					    >
 | 
				
			||||||
      <BaseDropdownItem v-show="row.allow_edit">
 | 
					      <BaseDropdownItem v-show="row.allow_edit" v-slot="slotProps">
 | 
				
			||||||
        <BaseIcon
 | 
					        <BaseIcon
 | 
				
			||||||
          name="PencilIcon"
 | 
					          name="PencilIcon"
 | 
				
			||||||
          class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					          :class="slotProps.class"
 | 
				
			||||||
        />
 | 
					        />
 | 
				
			||||||
        {{ $t('general.edit') }}
 | 
					        {{ $t('general.edit') }}
 | 
				
			||||||
      </BaseDropdownItem>
 | 
					      </BaseDropdownItem>
 | 
				
			||||||
    </router-link>
 | 
					    </router-link>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    <!-- Copy PDF url  -->
 | 
					    <!-- Copy PDF url  -->
 | 
				
			||||||
    <BaseDropdownItem v-if="route.name === 'invoices.view'" @click="copyPdfUrl">
 | 
					    <BaseDropdownItem v-if="route.name === 'invoices.view'" v-slot="slotProps" @click="copyPdfUrl">
 | 
				
			||||||
      <BaseIcon
 | 
					      <BaseIcon
 | 
				
			||||||
        name="LinkIcon"
 | 
					        name="LinkIcon"
 | 
				
			||||||
        class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					        :class="slotProps.class"
 | 
				
			||||||
      />
 | 
					      />
 | 
				
			||||||
      {{ $t('general.copy_pdf_url') }}
 | 
					      {{ $t('general.copy_pdf_url') }}
 | 
				
			||||||
    </BaseDropdownItem>
 | 
					    </BaseDropdownItem>
 | 
				
			||||||
@ -38,29 +38,29 @@
 | 
				
			|||||||
      "
 | 
					      "
 | 
				
			||||||
      :to="`/admin/invoices/${row.id}/view`"
 | 
					      :to="`/admin/invoices/${row.id}/view`"
 | 
				
			||||||
    >
 | 
					    >
 | 
				
			||||||
      <BaseDropdownItem>
 | 
					      <BaseDropdownItem v-slot="slotProps">
 | 
				
			||||||
        <BaseIcon
 | 
					        <BaseIcon
 | 
				
			||||||
          name="EyeIcon"
 | 
					          name="EyeIcon"
 | 
				
			||||||
          class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					          :class="slotProps.class"
 | 
				
			||||||
        />
 | 
					        />
 | 
				
			||||||
        {{ $t('general.view') }}
 | 
					        {{ $t('general.view') }}
 | 
				
			||||||
      </BaseDropdownItem>
 | 
					      </BaseDropdownItem>
 | 
				
			||||||
    </router-link>
 | 
					    </router-link>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    <!-- Send Invoice Mail  -->
 | 
					    <!-- Send Invoice Mail  -->
 | 
				
			||||||
    <BaseDropdownItem v-if="canSendInvoice(row)" @click="sendInvoice(row)">
 | 
					    <BaseDropdownItem v-if="canSendInvoice(row)" v-slot="slotProps" @click="sendInvoice(row)">
 | 
				
			||||||
      <BaseIcon
 | 
					      <BaseIcon
 | 
				
			||||||
        name="PaperAirplaneIcon"
 | 
					        name="PaperAirplaneIcon"
 | 
				
			||||||
        class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					        :class="slotProps.class"
 | 
				
			||||||
      />
 | 
					      />
 | 
				
			||||||
      {{ $t('invoices.send_invoice') }}
 | 
					      {{ $t('invoices.send_invoice') }}
 | 
				
			||||||
    </BaseDropdownItem>
 | 
					    </BaseDropdownItem>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    <!-- Resend Invoice -->
 | 
					    <!-- Resend Invoice -->
 | 
				
			||||||
    <BaseDropdownItem v-if="canReSendInvoice(row)" @click="sendInvoice(row)">
 | 
					    <BaseDropdownItem v-if="canReSendInvoice(row)" v-slot="slotProps" @click="sendInvoice(row)">
 | 
				
			||||||
      <BaseIcon
 | 
					      <BaseIcon
 | 
				
			||||||
        name="PaperAirplaneIcon"
 | 
					        name="PaperAirplaneIcon"
 | 
				
			||||||
        class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					        :class="slotProps.class"
 | 
				
			||||||
      />
 | 
					      />
 | 
				
			||||||
      {{ $t('invoices.resend_invoice') }}
 | 
					      {{ $t('invoices.resend_invoice') }}
 | 
				
			||||||
    </BaseDropdownItem>
 | 
					    </BaseDropdownItem>
 | 
				
			||||||
@ -69,20 +69,21 @@
 | 
				
			|||||||
    <router-link :to="`/admin/payments/${row.id}/create`">
 | 
					    <router-link :to="`/admin/payments/${row.id}/create`">
 | 
				
			||||||
      <BaseDropdownItem
 | 
					      <BaseDropdownItem
 | 
				
			||||||
        v-if="row.status == 'SENT' && route.name !== 'invoices.view'"
 | 
					        v-if="row.status == 'SENT' && route.name !== 'invoices.view'"
 | 
				
			||||||
 | 
					        v-slot="slotProps"
 | 
				
			||||||
      >
 | 
					      >
 | 
				
			||||||
        <BaseIcon
 | 
					        <BaseIcon
 | 
				
			||||||
          name="CreditCardIcon"
 | 
					          name="CreditCardIcon"
 | 
				
			||||||
          class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					          :class="slotProps.class"
 | 
				
			||||||
        />
 | 
					        />
 | 
				
			||||||
        {{ $t('invoices.record_payment') }}
 | 
					        {{ $t('invoices.record_payment') }}
 | 
				
			||||||
      </BaseDropdownItem>
 | 
					      </BaseDropdownItem>
 | 
				
			||||||
    </router-link>
 | 
					    </router-link>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    <!-- Mark as sent Invoice -->
 | 
					    <!-- Mark as sent Invoice -->
 | 
				
			||||||
    <BaseDropdownItem v-if="canSendInvoice(row)" @click="onMarkAsSent(row.id)">
 | 
					    <BaseDropdownItem v-if="canSendInvoice(row)" v-slot="slotProps" @click="onMarkAsSent(row.id)">
 | 
				
			||||||
      <BaseIcon
 | 
					      <BaseIcon
 | 
				
			||||||
        name="CheckCircleIcon"
 | 
					        name="CheckCircleIcon"
 | 
				
			||||||
        class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					        :class="slotProps.class"
 | 
				
			||||||
      />
 | 
					      />
 | 
				
			||||||
      {{ $t('invoices.mark_as_sent') }}
 | 
					      {{ $t('invoices.mark_as_sent') }}
 | 
				
			||||||
    </BaseDropdownItem>
 | 
					    </BaseDropdownItem>
 | 
				
			||||||
@ -90,11 +91,12 @@
 | 
				
			|||||||
    <!-- Clone Invoice into new invoice  -->
 | 
					    <!-- Clone Invoice into new invoice  -->
 | 
				
			||||||
    <BaseDropdownItem
 | 
					    <BaseDropdownItem
 | 
				
			||||||
      v-if="userStore.hasAbilities(abilities.CREATE_INVOICE)"
 | 
					      v-if="userStore.hasAbilities(abilities.CREATE_INVOICE)"
 | 
				
			||||||
 | 
					      v-slot="slotProps"
 | 
				
			||||||
      @click="cloneInvoiceData(row)"
 | 
					      @click="cloneInvoiceData(row)"
 | 
				
			||||||
    >
 | 
					    >
 | 
				
			||||||
      <BaseIcon
 | 
					      <BaseIcon
 | 
				
			||||||
        name="DocumentTextIcon"
 | 
					        name="DocumentTextIcon"
 | 
				
			||||||
        class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					        :class="slotProps.class"
 | 
				
			||||||
      />
 | 
					      />
 | 
				
			||||||
      {{ $t('invoices.clone_invoice') }}
 | 
					      {{ $t('invoices.clone_invoice') }}
 | 
				
			||||||
    </BaseDropdownItem>
 | 
					    </BaseDropdownItem>
 | 
				
			||||||
@ -102,11 +104,12 @@
 | 
				
			|||||||
    <!--  Delete Invoice  -->
 | 
					    <!--  Delete Invoice  -->
 | 
				
			||||||
    <BaseDropdownItem
 | 
					    <BaseDropdownItem
 | 
				
			||||||
      v-if="userStore.hasAbilities(abilities.DELETE_INVOICE)"
 | 
					      v-if="userStore.hasAbilities(abilities.DELETE_INVOICE)"
 | 
				
			||||||
 | 
					      v-slot="slotProps"
 | 
				
			||||||
      @click="removeInvoice(row.id)"
 | 
					      @click="removeInvoice(row.id)"
 | 
				
			||||||
    >
 | 
					    >
 | 
				
			||||||
      <BaseIcon
 | 
					      <BaseIcon
 | 
				
			||||||
        name="TrashIcon"
 | 
					        name="TrashIcon"
 | 
				
			||||||
        class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					        :class="slotProps.class"
 | 
				
			||||||
      />
 | 
					      />
 | 
				
			||||||
      {{ $t('general.delete') }}
 | 
					      {{ $t('general.delete') }}
 | 
				
			||||||
    </BaseDropdownItem>
 | 
					    </BaseDropdownItem>
 | 
				
			||||||
 | 
				
			|||||||
@ -12,11 +12,8 @@
 | 
				
			|||||||
      v-if="userStore.hasAbilities(abilities.EDIT_ITEM)"
 | 
					      v-if="userStore.hasAbilities(abilities.EDIT_ITEM)"
 | 
				
			||||||
      :to="`/admin/items/${row.id}/edit`"
 | 
					      :to="`/admin/items/${row.id}/edit`"
 | 
				
			||||||
    >
 | 
					    >
 | 
				
			||||||
      <BaseDropdownItem>
 | 
					      <BaseDropdownItem v-slot="slotProps">
 | 
				
			||||||
        <BaseIcon
 | 
					        <BaseIcon name="PencilIcon" :class="slotProps.class" />
 | 
				
			||||||
          name="PencilIcon"
 | 
					 | 
				
			||||||
          class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					 | 
				
			||||||
        />
 | 
					 | 
				
			||||||
        {{ $t('general.edit') }}
 | 
					        {{ $t('general.edit') }}
 | 
				
			||||||
      </BaseDropdownItem>
 | 
					      </BaseDropdownItem>
 | 
				
			||||||
    </router-link>
 | 
					    </router-link>
 | 
				
			||||||
@ -24,12 +21,10 @@
 | 
				
			|||||||
    <!-- delete item  -->
 | 
					    <!-- delete item  -->
 | 
				
			||||||
    <BaseDropdownItem
 | 
					    <BaseDropdownItem
 | 
				
			||||||
      v-if="userStore.hasAbilities(abilities.DELETE_ITEM)"
 | 
					      v-if="userStore.hasAbilities(abilities.DELETE_ITEM)"
 | 
				
			||||||
 | 
					      v-slot="slotProps"
 | 
				
			||||||
      @click="removeItem(row.id)"
 | 
					      @click="removeItem(row.id)"
 | 
				
			||||||
    >
 | 
					    >
 | 
				
			||||||
      <BaseIcon
 | 
					      <BaseIcon name="TrashIcon" :class="slotProps.class" />
 | 
				
			||||||
        name="TrashIcon"
 | 
					 | 
				
			||||||
        class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					 | 
				
			||||||
      />
 | 
					 | 
				
			||||||
      {{ $t('general.delete') }}
 | 
					      {{ $t('general.delete') }}
 | 
				
			||||||
    </BaseDropdownItem>
 | 
					    </BaseDropdownItem>
 | 
				
			||||||
  </BaseDropdown>
 | 
					  </BaseDropdown>
 | 
				
			||||||
 | 
				
			|||||||
@ -10,11 +10,12 @@
 | 
				
			|||||||
    <!-- edit note  -->
 | 
					    <!-- edit note  -->
 | 
				
			||||||
    <BaseDropdownItem
 | 
					    <BaseDropdownItem
 | 
				
			||||||
      v-if="userStore.hasAbilities(abilities.MANAGE_NOTE)"
 | 
					      v-if="userStore.hasAbilities(abilities.MANAGE_NOTE)"
 | 
				
			||||||
 | 
					      v-slot="slotProps"
 | 
				
			||||||
      @click="editNote(row.id)"
 | 
					      @click="editNote(row.id)"
 | 
				
			||||||
    >
 | 
					    >
 | 
				
			||||||
      <BaseIcon
 | 
					      <BaseIcon
 | 
				
			||||||
        name="PencilIcon"
 | 
					        name="PencilIcon"
 | 
				
			||||||
        class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					        :class="slotProps.class"
 | 
				
			||||||
      />
 | 
					      />
 | 
				
			||||||
      {{ $t('general.edit') }}
 | 
					      {{ $t('general.edit') }}
 | 
				
			||||||
    </BaseDropdownItem>
 | 
					    </BaseDropdownItem>
 | 
				
			||||||
@ -22,11 +23,12 @@
 | 
				
			|||||||
    <!-- delete note  -->
 | 
					    <!-- delete note  -->
 | 
				
			||||||
    <BaseDropdownItem
 | 
					    <BaseDropdownItem
 | 
				
			||||||
      v-if="userStore.hasAbilities(abilities.MANAGE_NOTE)"
 | 
					      v-if="userStore.hasAbilities(abilities.MANAGE_NOTE)"
 | 
				
			||||||
 | 
					      v-slot="slotProps"
 | 
				
			||||||
      @click="removeNote(row.id)"
 | 
					      @click="removeNote(row.id)"
 | 
				
			||||||
    >
 | 
					    >
 | 
				
			||||||
      <BaseIcon
 | 
					      <BaseIcon
 | 
				
			||||||
        name="TrashIcon"
 | 
					        name="TrashIcon"
 | 
				
			||||||
        class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					        :class="slotProps.class"
 | 
				
			||||||
      />
 | 
					      />
 | 
				
			||||||
      {{ $t('general.delete') }}
 | 
					      {{ $t('general.delete') }}
 | 
				
			||||||
    </BaseDropdownItem>
 | 
					    </BaseDropdownItem>
 | 
				
			||||||
 | 
				
			|||||||
@ -8,30 +8,31 @@
 | 
				
			|||||||
    </template>
 | 
					    </template>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    <!-- Copy pdf url  -->
 | 
					    <!-- Copy pdf url  -->
 | 
				
			||||||
    <BaseDropdown-item
 | 
					    <BaseDropdownItem
 | 
				
			||||||
      v-if="
 | 
					      v-if="
 | 
				
			||||||
        route.name === 'payments.view' &&
 | 
					        route.name === 'payments.view' &&
 | 
				
			||||||
        userStore.hasAbilities(abilities.VIEW_PAYMENT)
 | 
					        userStore.hasAbilities(abilities.VIEW_PAYMENT)
 | 
				
			||||||
      "
 | 
					      "
 | 
				
			||||||
 | 
					      v-slot="slotProps"
 | 
				
			||||||
      class="rounded-md"
 | 
					      class="rounded-md"
 | 
				
			||||||
      @click="copyPdfUrl"
 | 
					      @click="copyPdfUrl"
 | 
				
			||||||
    >
 | 
					    >
 | 
				
			||||||
      <BaseIcon
 | 
					      <BaseIcon
 | 
				
			||||||
        name="LinkIcon"
 | 
					        name="LinkIcon"
 | 
				
			||||||
        class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					        :class="slotProps.class"
 | 
				
			||||||
      />
 | 
					      />
 | 
				
			||||||
      {{ $t('general.copy_pdf_url') }}
 | 
					      {{ $t('general.copy_pdf_url') }}
 | 
				
			||||||
    </BaseDropdown-item>
 | 
					    </BaseDropdownItem>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    <!-- edit payment  -->
 | 
					    <!-- edit payment  -->
 | 
				
			||||||
    <router-link
 | 
					    <router-link
 | 
				
			||||||
      v-if="userStore.hasAbilities(abilities.EDIT_PAYMENT)"
 | 
					      v-if="userStore.hasAbilities(abilities.EDIT_PAYMENT)"
 | 
				
			||||||
      :to="`/admin/payments/${row.id}/edit`"
 | 
					      :to="`/admin/payments/${row.id}/edit`"
 | 
				
			||||||
    >
 | 
					    >
 | 
				
			||||||
      <BaseDropdownItem>
 | 
					      <BaseDropdownItem v-slot="slotProps">
 | 
				
			||||||
        <BaseIcon
 | 
					        <BaseIcon
 | 
				
			||||||
          name="PencilIcon"
 | 
					          name="PencilIcon"
 | 
				
			||||||
          class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					          :class="slotProps.class"
 | 
				
			||||||
        />
 | 
					        />
 | 
				
			||||||
        {{ $t('general.edit') }}
 | 
					        {{ $t('general.edit') }}
 | 
				
			||||||
      </BaseDropdownItem>
 | 
					      </BaseDropdownItem>
 | 
				
			||||||
@ -45,10 +46,10 @@
 | 
				
			|||||||
      "
 | 
					      "
 | 
				
			||||||
      :to="`/admin/payments/${row.id}/view`"
 | 
					      :to="`/admin/payments/${row.id}/view`"
 | 
				
			||||||
    >
 | 
					    >
 | 
				
			||||||
      <BaseDropdownItem>
 | 
					      <BaseDropdownItem v-slot="slotProps">
 | 
				
			||||||
        <BaseIcon
 | 
					        <BaseIcon
 | 
				
			||||||
          name="EyeIcon"
 | 
					          name="EyeIcon"
 | 
				
			||||||
          class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					          :class="slotProps.class"
 | 
				
			||||||
        />
 | 
					        />
 | 
				
			||||||
        {{ $t('general.view') }}
 | 
					        {{ $t('general.view') }}
 | 
				
			||||||
      </BaseDropdownItem>
 | 
					      </BaseDropdownItem>
 | 
				
			||||||
@ -61,11 +62,12 @@
 | 
				
			|||||||
        route.name !== 'payments.view' &&
 | 
					        route.name !== 'payments.view' &&
 | 
				
			||||||
        userStore.hasAbilities(abilities.SEND_PAYMENT)
 | 
					        userStore.hasAbilities(abilities.SEND_PAYMENT)
 | 
				
			||||||
      "
 | 
					      "
 | 
				
			||||||
 | 
					      v-slot="slotProps"
 | 
				
			||||||
      @click="sendPayment(row)"
 | 
					      @click="sendPayment(row)"
 | 
				
			||||||
    >
 | 
					    >
 | 
				
			||||||
      <BaseIcon
 | 
					      <BaseIcon
 | 
				
			||||||
        name="PaperAirplaneIcon"
 | 
					        name="PaperAirplaneIcon"
 | 
				
			||||||
        class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					        :class="slotProps.class"
 | 
				
			||||||
      />
 | 
					      />
 | 
				
			||||||
      {{ $t('payments.send_payment') }}
 | 
					      {{ $t('payments.send_payment') }}
 | 
				
			||||||
    </BaseDropdownItem>
 | 
					    </BaseDropdownItem>
 | 
				
			||||||
@ -73,11 +75,12 @@
 | 
				
			|||||||
    <!-- delete payment  -->
 | 
					    <!-- delete payment  -->
 | 
				
			||||||
    <BaseDropdownItem
 | 
					    <BaseDropdownItem
 | 
				
			||||||
      v-if="userStore.hasAbilities(abilities.DELETE_PAYMENT)"
 | 
					      v-if="userStore.hasAbilities(abilities.DELETE_PAYMENT)"
 | 
				
			||||||
 | 
					      v-slot="slotProps"
 | 
				
			||||||
      @click="removePayment(row.id)"
 | 
					      @click="removePayment(row.id)"
 | 
				
			||||||
    >
 | 
					    >
 | 
				
			||||||
      <BaseIcon
 | 
					      <BaseIcon
 | 
				
			||||||
        name="TrashIcon"
 | 
					        name="TrashIcon"
 | 
				
			||||||
        class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					        :class="slotProps.class"
 | 
				
			||||||
      />
 | 
					      />
 | 
				
			||||||
      {{ $t('general.delete') }}
 | 
					      {{ $t('general.delete') }}
 | 
				
			||||||
    </BaseDropdownItem>
 | 
					    </BaseDropdownItem>
 | 
				
			||||||
 | 
				
			|||||||
@ -8,19 +8,19 @@
 | 
				
			|||||||
    </template>
 | 
					    </template>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    <!-- edit paymentMode  -->
 | 
					    <!-- edit paymentMode  -->
 | 
				
			||||||
    <BaseDropdownItem @click="editPaymentMode(row.id)">
 | 
					    <BaseDropdownItem v-slot="slotProps"  @click="editPaymentMode(row.id)">
 | 
				
			||||||
      <BaseIcon
 | 
					      <BaseIcon
 | 
				
			||||||
        name="PencilIcon"
 | 
					        name="PencilIcon"
 | 
				
			||||||
        class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					        :class="slotProps.class"
 | 
				
			||||||
      />
 | 
					      />
 | 
				
			||||||
      {{ $t('general.edit') }}
 | 
					      {{ $t('general.edit') }}
 | 
				
			||||||
    </BaseDropdownItem>
 | 
					    </BaseDropdownItem>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    <!-- delete paymentMode  -->
 | 
					    <!-- delete paymentMode  -->
 | 
				
			||||||
    <BaseDropdownItem @click="removePaymentMode(row.id)">
 | 
					    <BaseDropdownItem v-slot="slotProps"  @click="removePaymentMode(row.id)">
 | 
				
			||||||
      <BaseIcon
 | 
					      <BaseIcon
 | 
				
			||||||
        name="TrashIcon"
 | 
					        name="TrashIcon"
 | 
				
			||||||
        class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					        :class="slotProps.class"
 | 
				
			||||||
      />
 | 
					      />
 | 
				
			||||||
      {{ $t('general.delete') }}
 | 
					      {{ $t('general.delete') }}
 | 
				
			||||||
    </BaseDropdownItem>
 | 
					    </BaseDropdownItem>
 | 
				
			||||||
 | 
				
			|||||||
@ -15,10 +15,10 @@
 | 
				
			|||||||
      v-if="userStore.hasAbilities(abilities.EDIT_RECURRING_INVOICE)"
 | 
					      v-if="userStore.hasAbilities(abilities.EDIT_RECURRING_INVOICE)"
 | 
				
			||||||
      :to="`/admin/recurring-invoices/${row.id}/edit`"
 | 
					      :to="`/admin/recurring-invoices/${row.id}/edit`"
 | 
				
			||||||
    >
 | 
					    >
 | 
				
			||||||
      <BaseDropdownItem>
 | 
					      <BaseDropdownItem v-slot="slotProps">
 | 
				
			||||||
        <BaseIcon
 | 
					        <BaseIcon
 | 
				
			||||||
          name="PencilIcon"
 | 
					          name="PencilIcon"
 | 
				
			||||||
          class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					          :class="slotProps.class"
 | 
				
			||||||
        />
 | 
					        />
 | 
				
			||||||
        {{ $t('general.edit') }}
 | 
					        {{ $t('general.edit') }}
 | 
				
			||||||
      </BaseDropdownItem>
 | 
					      </BaseDropdownItem>
 | 
				
			||||||
@ -32,10 +32,10 @@
 | 
				
			|||||||
      "
 | 
					      "
 | 
				
			||||||
      :to="`recurring-invoices/${row.id}/view`"
 | 
					      :to="`recurring-invoices/${row.id}/view`"
 | 
				
			||||||
    >
 | 
					    >
 | 
				
			||||||
      <BaseDropdownItem>
 | 
					      <BaseDropdownItem v-slot="slotProps">
 | 
				
			||||||
        <BaseIcon
 | 
					        <BaseIcon
 | 
				
			||||||
          name="EyeIcon"
 | 
					          name="EyeIcon"
 | 
				
			||||||
          class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					          :class="slotProps.class"
 | 
				
			||||||
        />
 | 
					        />
 | 
				
			||||||
        {{ $t('general.view') }}
 | 
					        {{ $t('general.view') }}
 | 
				
			||||||
      </BaseDropdownItem>
 | 
					      </BaseDropdownItem>
 | 
				
			||||||
@ -44,11 +44,12 @@
 | 
				
			|||||||
    <!-- Delete Recurring Invoice  -->
 | 
					    <!-- Delete Recurring Invoice  -->
 | 
				
			||||||
    <BaseDropdownItem
 | 
					    <BaseDropdownItem
 | 
				
			||||||
      v-if="userStore.hasAbilities(abilities.DELETE_RECURRING_INVOICE)"
 | 
					      v-if="userStore.hasAbilities(abilities.DELETE_RECURRING_INVOICE)"
 | 
				
			||||||
 | 
					      v-slot="slotProps"
 | 
				
			||||||
      @click="removeMultipleRecurringInvoices(row.id)"
 | 
					      @click="removeMultipleRecurringInvoices(row.id)"
 | 
				
			||||||
    >
 | 
					    >
 | 
				
			||||||
      <BaseIcon
 | 
					      <BaseIcon
 | 
				
			||||||
        name="TrashIcon"
 | 
					        name="TrashIcon"
 | 
				
			||||||
        class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					        :class="slotProps.class"
 | 
				
			||||||
      />
 | 
					      />
 | 
				
			||||||
      {{ $t('general.delete') }}
 | 
					      {{ $t('general.delete') }}
 | 
				
			||||||
    </BaseDropdownItem>
 | 
					    </BaseDropdownItem>
 | 
				
			||||||
 | 
				
			|||||||
@ -10,11 +10,12 @@
 | 
				
			|||||||
    <!-- edit role  -->
 | 
					    <!-- edit role  -->
 | 
				
			||||||
    <BaseDropdownItem
 | 
					    <BaseDropdownItem
 | 
				
			||||||
      v-if="userStore.currentUser.is_owner"
 | 
					      v-if="userStore.currentUser.is_owner"
 | 
				
			||||||
 | 
					      v-slot="slotProps"
 | 
				
			||||||
      @click="editRole(row.id)"
 | 
					      @click="editRole(row.id)"
 | 
				
			||||||
    >
 | 
					    >
 | 
				
			||||||
      <BaseIcon
 | 
					      <BaseIcon
 | 
				
			||||||
        name="PencilIcon"
 | 
					        name="PencilIcon"
 | 
				
			||||||
        class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					        :class="slotProps.class"
 | 
				
			||||||
      />
 | 
					      />
 | 
				
			||||||
      {{ $t('general.edit') }}
 | 
					      {{ $t('general.edit') }}
 | 
				
			||||||
    </BaseDropdownItem>
 | 
					    </BaseDropdownItem>
 | 
				
			||||||
@ -22,11 +23,12 @@
 | 
				
			|||||||
    <!-- delete role  -->
 | 
					    <!-- delete role  -->
 | 
				
			||||||
    <BaseDropdownItem
 | 
					    <BaseDropdownItem
 | 
				
			||||||
      v-if="userStore.currentUser.is_owner"
 | 
					      v-if="userStore.currentUser.is_owner"
 | 
				
			||||||
 | 
					      v-slot="slotProps"
 | 
				
			||||||
      @click="removeRole(row.id)"
 | 
					      @click="removeRole(row.id)"
 | 
				
			||||||
    >
 | 
					    >
 | 
				
			||||||
      <BaseIcon
 | 
					      <BaseIcon
 | 
				
			||||||
        name="TrashIcon"
 | 
					        name="TrashIcon"
 | 
				
			||||||
        class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					        :class="slotProps.class"
 | 
				
			||||||
      />
 | 
					      />
 | 
				
			||||||
      {{ $t('general.delete') }}
 | 
					      {{ $t('general.delete') }}
 | 
				
			||||||
    </BaseDropdownItem>
 | 
					    </BaseDropdownItem>
 | 
				
			||||||
 | 
				
			|||||||
@ -10,11 +10,12 @@
 | 
				
			|||||||
    <!-- edit tax-type  -->
 | 
					    <!-- edit tax-type  -->
 | 
				
			||||||
    <BaseDropdownItem
 | 
					    <BaseDropdownItem
 | 
				
			||||||
      v-if="userStore.hasAbilities(abilities.EDIT_TAX_TYPE)"
 | 
					      v-if="userStore.hasAbilities(abilities.EDIT_TAX_TYPE)"
 | 
				
			||||||
 | 
					      v-slot="slotProps"
 | 
				
			||||||
      @click="editTaxType(row.id)"
 | 
					      @click="editTaxType(row.id)"
 | 
				
			||||||
    >
 | 
					    >
 | 
				
			||||||
      <BaseIcon
 | 
					      <BaseIcon
 | 
				
			||||||
        name="PencilIcon"
 | 
					        name="PencilIcon"
 | 
				
			||||||
        class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					        :class="slotProps.class"
 | 
				
			||||||
      />
 | 
					      />
 | 
				
			||||||
      {{ $t('general.edit') }}
 | 
					      {{ $t('general.edit') }}
 | 
				
			||||||
    </BaseDropdownItem>
 | 
					    </BaseDropdownItem>
 | 
				
			||||||
@ -22,11 +23,12 @@
 | 
				
			|||||||
    <!-- delete tax-type  -->
 | 
					    <!-- delete tax-type  -->
 | 
				
			||||||
    <BaseDropdownItem
 | 
					    <BaseDropdownItem
 | 
				
			||||||
      v-if="userStore.hasAbilities(abilities.DELETE_TAX_TYPE)"
 | 
					      v-if="userStore.hasAbilities(abilities.DELETE_TAX_TYPE)"
 | 
				
			||||||
 | 
					      v-slot="slotProps"
 | 
				
			||||||
      @click="removeTaxType(row.id)"
 | 
					      @click="removeTaxType(row.id)"
 | 
				
			||||||
    >
 | 
					    >
 | 
				
			||||||
      <BaseIcon
 | 
					      <BaseIcon
 | 
				
			||||||
        name="TrashIcon"
 | 
					        name="TrashIcon"
 | 
				
			||||||
        class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					        :class="slotProps.class"
 | 
				
			||||||
      />
 | 
					      />
 | 
				
			||||||
      {{ $t('general.delete') }}
 | 
					      {{ $t('general.delete') }}
 | 
				
			||||||
    </BaseDropdownItem>
 | 
					    </BaseDropdownItem>
 | 
				
			||||||
 | 
				
			|||||||
@ -9,20 +9,20 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
    <!-- edit user  -->
 | 
					    <!-- edit user  -->
 | 
				
			||||||
    <router-link :to="`/admin/users/${row.id}/edit`">
 | 
					    <router-link :to="`/admin/users/${row.id}/edit`">
 | 
				
			||||||
      <BaseDropdownItem>
 | 
					      <BaseDropdownItem v-slot="slotProps">
 | 
				
			||||||
        <BaseIcon
 | 
					        <BaseIcon
 | 
				
			||||||
          name="PencilIcon"
 | 
					          name="PencilIcon"
 | 
				
			||||||
          class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					          :class="slotProps.class"
 | 
				
			||||||
        />
 | 
					        />
 | 
				
			||||||
        {{ $t('general.edit') }}
 | 
					        {{ $t('general.edit') }}
 | 
				
			||||||
      </BaseDropdownItem>
 | 
					      </BaseDropdownItem>
 | 
				
			||||||
    </router-link>
 | 
					    </router-link>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    <!-- delete user  -->
 | 
					    <!-- delete user  -->
 | 
				
			||||||
    <BaseDropdownItem @click="removeUser(row.id)">
 | 
					    <BaseDropdownItem v-slot="slotProps" @click="removeUser(row.id)">
 | 
				
			||||||
      <BaseIcon
 | 
					      <BaseIcon
 | 
				
			||||||
        name="TrashIcon"
 | 
					        name="TrashIcon"
 | 
				
			||||||
        class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					        :class="slotProps.class"
 | 
				
			||||||
      />
 | 
					      />
 | 
				
			||||||
      {{ $t('general.delete') }}
 | 
					      {{ $t('general.delete') }}
 | 
				
			||||||
    </BaseDropdownItem>
 | 
					    </BaseDropdownItem>
 | 
				
			||||||
 | 
				
			|||||||
@ -1,5 +1,13 @@
 | 
				
			|||||||
<template>
 | 
					<template>
 | 
				
			||||||
  <tr class="box-border bg-white border border-gray-200 border-solid rounded-b">
 | 
					  <tr
 | 
				
			||||||
 | 
					    class="
 | 
				
			||||||
 | 
					      box-border
 | 
				
			||||||
 | 
					      bg-white
 | 
				
			||||||
 | 
					      border border-gray-200 border-solid
 | 
				
			||||||
 | 
					      rounded-b
 | 
				
			||||||
 | 
					      dark:shadow-glass dark:border dark:border-white/10 dark:bg-gray-800/70
 | 
				
			||||||
 | 
					      "
 | 
				
			||||||
 | 
					    >
 | 
				
			||||||
    <td colspan="5" class="p-0 text-left align-top">
 | 
					    <td colspan="5" class="p-0 text-left align-top">
 | 
				
			||||||
      <table class="w-full">
 | 
					      <table class="w-full">
 | 
				
			||||||
        <colgroup>
 | 
					        <colgroup>
 | 
				
			||||||
@ -130,7 +138,7 @@
 | 
				
			|||||||
                <div class="flex items-center justify-center w-6 h-10 mx-2">
 | 
					                <div class="flex items-center justify-center w-6 h-10 mx-2">
 | 
				
			||||||
                  <BaseIcon
 | 
					                  <BaseIcon
 | 
				
			||||||
                    v-if="showRemoveButton"
 | 
					                    v-if="showRemoveButton"
 | 
				
			||||||
                    class="h-5 text-gray-700 cursor-pointer"
 | 
					                    class="h-5 dark:text-red-400 cursor-pointer"
 | 
				
			||||||
                    name="TrashIcon"
 | 
					                    name="TrashIcon"
 | 
				
			||||||
                    @click="store.removeItem(index)"
 | 
					                    @click="store.removeItem(index)"
 | 
				
			||||||
                  />
 | 
					                  />
 | 
				
			||||||
 | 
				
			|||||||
@ -1,155 +1,113 @@
 | 
				
			|||||||
<template>
 | 
					<template>
 | 
				
			||||||
  <table class="text-center item-table min-w-full">
 | 
					  <div class="relative" >
 | 
				
			||||||
    <colgroup>
 | 
					    <BaseDarkHighlight class="z-[-1]" />
 | 
				
			||||||
      <col style="width: 40%; min-width: 280px" />
 | 
					    <table class="text-center item-table min-w-full">
 | 
				
			||||||
      <col style="width: 10%; min-width: 120px" />
 | 
					      <colgroup>
 | 
				
			||||||
      <col style="width: 15%; min-width: 120px" />
 | 
					        <col style="width: 40%; min-width: 280px" />
 | 
				
			||||||
      <col
 | 
					        <col style="width: 10%; min-width: 120px" />
 | 
				
			||||||
        v-if="store[storeProp].discount_per_item === 'YES'"
 | 
					        <col style="width: 15%; min-width: 120px" />
 | 
				
			||||||
        style="width: 15%; min-width: 160px"
 | 
					        <col
 | 
				
			||||||
      />
 | 
					 | 
				
			||||||
      <col style="width: 15%; min-width: 120px" />
 | 
					 | 
				
			||||||
    </colgroup>
 | 
					 | 
				
			||||||
    <thead class="bg-white border border-gray-200 border-solid">
 | 
					 | 
				
			||||||
      <tr>
 | 
					 | 
				
			||||||
        <th
 | 
					 | 
				
			||||||
          class="
 | 
					 | 
				
			||||||
            px-5
 | 
					 | 
				
			||||||
            py-3
 | 
					 | 
				
			||||||
            text-sm
 | 
					 | 
				
			||||||
            not-italic
 | 
					 | 
				
			||||||
            font-medium
 | 
					 | 
				
			||||||
            leading-5
 | 
					 | 
				
			||||||
            text-left text-gray-700
 | 
					 | 
				
			||||||
            border-t border-b border-gray-200 border-solid
 | 
					 | 
				
			||||||
          "
 | 
					 | 
				
			||||||
        >
 | 
					 | 
				
			||||||
          <BaseContentPlaceholders v-if="isLoading">
 | 
					 | 
				
			||||||
            <BaseContentPlaceholdersText :lines="1" class="w-16 h-5" />
 | 
					 | 
				
			||||||
          </BaseContentPlaceholders>
 | 
					 | 
				
			||||||
          <span v-else class="pl-7">
 | 
					 | 
				
			||||||
            {{ $tc('items.item', 2) }}
 | 
					 | 
				
			||||||
          </span>
 | 
					 | 
				
			||||||
        </th>
 | 
					 | 
				
			||||||
        <th
 | 
					 | 
				
			||||||
          class="
 | 
					 | 
				
			||||||
            px-5
 | 
					 | 
				
			||||||
            py-3
 | 
					 | 
				
			||||||
            text-sm
 | 
					 | 
				
			||||||
            not-italic
 | 
					 | 
				
			||||||
            font-medium
 | 
					 | 
				
			||||||
            leading-5
 | 
					 | 
				
			||||||
            text-right text-gray-700
 | 
					 | 
				
			||||||
            border-t border-b border-gray-200 border-solid
 | 
					 | 
				
			||||||
          "
 | 
					 | 
				
			||||||
        >
 | 
					 | 
				
			||||||
          <BaseContentPlaceholders v-if="isLoading">
 | 
					 | 
				
			||||||
            <BaseContentPlaceholdersText :lines="1" class="w-16 h-5" />
 | 
					 | 
				
			||||||
          </BaseContentPlaceholders>
 | 
					 | 
				
			||||||
          <span v-else>
 | 
					 | 
				
			||||||
            {{ $t('invoices.item.quantity') }}
 | 
					 | 
				
			||||||
          </span>
 | 
					 | 
				
			||||||
        </th>
 | 
					 | 
				
			||||||
        <th
 | 
					 | 
				
			||||||
          class="
 | 
					 | 
				
			||||||
            px-5
 | 
					 | 
				
			||||||
            py-3
 | 
					 | 
				
			||||||
            text-sm
 | 
					 | 
				
			||||||
            not-italic
 | 
					 | 
				
			||||||
            font-medium
 | 
					 | 
				
			||||||
            leading-5
 | 
					 | 
				
			||||||
            text-left text-gray-700
 | 
					 | 
				
			||||||
            border-t border-b border-gray-200 border-solid
 | 
					 | 
				
			||||||
          "
 | 
					 | 
				
			||||||
        >
 | 
					 | 
				
			||||||
          <BaseContentPlaceholders v-if="isLoading">
 | 
					 | 
				
			||||||
            <BaseContentPlaceholdersText :lines="1" class="w-16 h-5" />
 | 
					 | 
				
			||||||
          </BaseContentPlaceholders>
 | 
					 | 
				
			||||||
          <span v-else>
 | 
					 | 
				
			||||||
            {{ $t('invoices.item.price') }}
 | 
					 | 
				
			||||||
          </span>
 | 
					 | 
				
			||||||
        </th>
 | 
					 | 
				
			||||||
        <th
 | 
					 | 
				
			||||||
          v-if="store[storeProp].discount_per_item === 'YES'"
 | 
					          v-if="store[storeProp].discount_per_item === 'YES'"
 | 
				
			||||||
          class="
 | 
					          style="width: 15%; min-width: 160px"
 | 
				
			||||||
            px-5
 | 
					 | 
				
			||||||
            py-3
 | 
					 | 
				
			||||||
            text-sm
 | 
					 | 
				
			||||||
            not-italic
 | 
					 | 
				
			||||||
            font-medium
 | 
					 | 
				
			||||||
            leading-5
 | 
					 | 
				
			||||||
            text-left text-gray-700
 | 
					 | 
				
			||||||
            border-t border-b border-gray-200 border-solid
 | 
					 | 
				
			||||||
          "
 | 
					 | 
				
			||||||
        >
 | 
					 | 
				
			||||||
          <BaseContentPlaceholders v-if="isLoading">
 | 
					 | 
				
			||||||
            <BaseContentPlaceholdersText :lines="1" class="w-16 h-5" />
 | 
					 | 
				
			||||||
          </BaseContentPlaceholders>
 | 
					 | 
				
			||||||
          <span v-else>
 | 
					 | 
				
			||||||
            {{ $t('invoices.item.discount') }}
 | 
					 | 
				
			||||||
          </span>
 | 
					 | 
				
			||||||
        </th>
 | 
					 | 
				
			||||||
        <th
 | 
					 | 
				
			||||||
          class="
 | 
					 | 
				
			||||||
            px-5
 | 
					 | 
				
			||||||
            py-3
 | 
					 | 
				
			||||||
            text-sm
 | 
					 | 
				
			||||||
            not-italic
 | 
					 | 
				
			||||||
            font-medium
 | 
					 | 
				
			||||||
            leading-5
 | 
					 | 
				
			||||||
            text-right text-gray-700
 | 
					 | 
				
			||||||
            border-t border-b border-gray-200 border-solid
 | 
					 | 
				
			||||||
          "
 | 
					 | 
				
			||||||
        >
 | 
					 | 
				
			||||||
          <BaseContentPlaceholders v-if="isLoading">
 | 
					 | 
				
			||||||
            <BaseContentPlaceholdersText :lines="1" class="w-16 h-5" />
 | 
					 | 
				
			||||||
          </BaseContentPlaceholders>
 | 
					 | 
				
			||||||
          <span v-else class="pr-10 column-heading">
 | 
					 | 
				
			||||||
            {{ $t('invoices.item.amount') }}
 | 
					 | 
				
			||||||
          </span>
 | 
					 | 
				
			||||||
        </th>
 | 
					 | 
				
			||||||
      </tr>
 | 
					 | 
				
			||||||
    </thead>
 | 
					 | 
				
			||||||
    <draggable
 | 
					 | 
				
			||||||
      v-model="store[storeProp].items"
 | 
					 | 
				
			||||||
      item-key="id"
 | 
					 | 
				
			||||||
      tag="tbody"
 | 
					 | 
				
			||||||
      handle=".handle"
 | 
					 | 
				
			||||||
    >
 | 
					 | 
				
			||||||
      <template #item="{ element, index }">
 | 
					 | 
				
			||||||
        <Item
 | 
					 | 
				
			||||||
          :key="element.id"
 | 
					 | 
				
			||||||
          :index="index"
 | 
					 | 
				
			||||||
          :item-data="element"
 | 
					 | 
				
			||||||
          :loading="isLoading"
 | 
					 | 
				
			||||||
          :currency="defaultCurrency"
 | 
					 | 
				
			||||||
          :item-validation-scope="itemValidationScope"
 | 
					 | 
				
			||||||
          :invoice-items="store[storeProp].items"
 | 
					 | 
				
			||||||
          :store="store"
 | 
					 | 
				
			||||||
          :store-prop="storeProp"
 | 
					 | 
				
			||||||
        />
 | 
					        />
 | 
				
			||||||
      </template>
 | 
					        <col style="width: 15%; min-width: 120px" />
 | 
				
			||||||
    </draggable>
 | 
					      </colgroup>
 | 
				
			||||||
  </table>
 | 
					      <thead
 | 
				
			||||||
 | 
					        class="
 | 
				
			||||||
 | 
					          bg-white
 | 
				
			||||||
 | 
					          border border-gray-200 border-solid
 | 
				
			||||||
 | 
					          dark:shadow-glass dark:border dark:border-white/10 dark:bg-gray-800/70
 | 
				
			||||||
 | 
					          "
 | 
				
			||||||
 | 
					        >
 | 
				
			||||||
 | 
					        <tr>
 | 
				
			||||||
 | 
					          <th class="text-left" :class="theadClass">
 | 
				
			||||||
 | 
					            <BaseContentPlaceholders v-if="isLoading">
 | 
				
			||||||
 | 
					              <BaseContentPlaceholdersText :lines="1" class="w-16 h-5" />
 | 
				
			||||||
 | 
					            </BaseContentPlaceholders>
 | 
				
			||||||
 | 
					            <span v-else class="pl-7">
 | 
				
			||||||
 | 
					              {{ $tc('items.item', 2) }}
 | 
				
			||||||
 | 
					            </span>
 | 
				
			||||||
 | 
					          </th>
 | 
				
			||||||
 | 
					          <th class="text-right" :class="theadClass">
 | 
				
			||||||
 | 
					            <BaseContentPlaceholders v-if="isLoading">
 | 
				
			||||||
 | 
					              <BaseContentPlaceholdersText :lines="1" class="w-16 h-5" />
 | 
				
			||||||
 | 
					            </BaseContentPlaceholders>
 | 
				
			||||||
 | 
					            <span v-else>
 | 
				
			||||||
 | 
					              {{ $t('invoices.item.quantity') }}
 | 
				
			||||||
 | 
					            </span>
 | 
				
			||||||
 | 
					          </th>
 | 
				
			||||||
 | 
					          <th class="text-left" :class="theadClass">
 | 
				
			||||||
 | 
					            <BaseContentPlaceholders v-if="isLoading">
 | 
				
			||||||
 | 
					              <BaseContentPlaceholdersText :lines="1" class="w-16 h-5" />
 | 
				
			||||||
 | 
					            </BaseContentPlaceholders>
 | 
				
			||||||
 | 
					            <span v-else>
 | 
				
			||||||
 | 
					              {{ $t('invoices.item.price') }}
 | 
				
			||||||
 | 
					            </span>
 | 
				
			||||||
 | 
					          </th>
 | 
				
			||||||
 | 
					          <th
 | 
				
			||||||
 | 
					            v-if="store[storeProp].discount_per_item_enabled"
 | 
				
			||||||
 | 
					            class="text-left"
 | 
				
			||||||
 | 
					            :class="theadClass"
 | 
				
			||||||
 | 
					          >
 | 
				
			||||||
 | 
					            <BaseContentPlaceholders v-if="isLoading">
 | 
				
			||||||
 | 
					              <BaseContentPlaceholdersText :lines="1" class="w-16 h-5" />
 | 
				
			||||||
 | 
					            </BaseContentPlaceholders>
 | 
				
			||||||
 | 
					            <span v-else>
 | 
				
			||||||
 | 
					              {{ $t('invoices.item.discount') }}
 | 
				
			||||||
 | 
					            </span>
 | 
				
			||||||
 | 
					          </th>
 | 
				
			||||||
 | 
					          <th class="text-right" :class="theadClass">
 | 
				
			||||||
 | 
					            <BaseContentPlaceholders v-if="isLoading">
 | 
				
			||||||
 | 
					              <BaseContentPlaceholdersText :lines="1" class="w-16 h-5" />
 | 
				
			||||||
 | 
					            </BaseContentPlaceholders>
 | 
				
			||||||
 | 
					            <span v-else class="pr-10 column-heading">
 | 
				
			||||||
 | 
					              {{ $t('invoices.item.amount') }}
 | 
				
			||||||
 | 
					            </span>
 | 
				
			||||||
 | 
					          </th>
 | 
				
			||||||
 | 
					        </tr>
 | 
				
			||||||
 | 
					      </thead>
 | 
				
			||||||
 | 
					      <draggable
 | 
				
			||||||
 | 
					        v-model="store[storeProp].items"
 | 
				
			||||||
 | 
					        item-key="id"
 | 
				
			||||||
 | 
					        tag="tbody"
 | 
				
			||||||
 | 
					        handle=".handle"
 | 
				
			||||||
 | 
					      >
 | 
				
			||||||
 | 
					        <template #item="{ element, index }">
 | 
				
			||||||
 | 
					          <Item
 | 
				
			||||||
 | 
					            :key="element.id"
 | 
				
			||||||
 | 
					            :index="index"
 | 
				
			||||||
 | 
					            :item-data="element"
 | 
				
			||||||
 | 
					            :loading="isLoading"
 | 
				
			||||||
 | 
					            :currency="defaultCurrency"
 | 
				
			||||||
 | 
					            :item-validation-scope="itemValidationScope"
 | 
				
			||||||
 | 
					            :invoice-items="store[storeProp].items"
 | 
				
			||||||
 | 
					            :store="store"
 | 
				
			||||||
 | 
					            :store-prop="storeProp"
 | 
				
			||||||
 | 
					          />
 | 
				
			||||||
 | 
					        </template>
 | 
				
			||||||
 | 
					      </draggable>
 | 
				
			||||||
 | 
					    </table>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  <div
 | 
					    <div
 | 
				
			||||||
    class="
 | 
					      class="
 | 
				
			||||||
      flex
 | 
					        flex
 | 
				
			||||||
      items-center
 | 
					        items-center
 | 
				
			||||||
      justify-center
 | 
					        justify-center
 | 
				
			||||||
      w-full
 | 
					        w-full
 | 
				
			||||||
      px-6
 | 
					        px-6
 | 
				
			||||||
      py-3
 | 
					        py-3
 | 
				
			||||||
      text-base
 | 
					        text-base
 | 
				
			||||||
      border border-t-0 border-gray-200 border-solid
 | 
					        border border-t-0 border-gray-200 border-solid
 | 
				
			||||||
      cursor-pointer
 | 
					        cursor-pointer
 | 
				
			||||||
      text-primary-400
 | 
					        text-primary-400
 | 
				
			||||||
      hover:bg-primary-100
 | 
					        hover:bg-primary-100
 | 
				
			||||||
    "
 | 
					        dark:bg-gray-900/50 dark:border-white/10 dark:hover:bg-gray-900/80
 | 
				
			||||||
    @click="store.addItem"
 | 
					      "
 | 
				
			||||||
  >
 | 
					      @click="store.addItem"
 | 
				
			||||||
    <BaseIcon name="PlusCircleIcon" class="mr-2" />
 | 
					    >
 | 
				
			||||||
    {{ $t('general.add_new_item') }}
 | 
					      <BaseIcon name="PlusCircleIcon" class="mr-2" />
 | 
				
			||||||
 | 
					      {{ $t('general.add_new_item') }}
 | 
				
			||||||
 | 
					    </div>
 | 
				
			||||||
  </div>
 | 
					  </div>
 | 
				
			||||||
</template>
 | 
					</template>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@ -180,6 +138,11 @@ const props = defineProps({
 | 
				
			|||||||
    type: String,
 | 
					    type: String,
 | 
				
			||||||
    default: '',
 | 
					    default: '',
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
 | 
					  theadClass: {
 | 
				
			||||||
 | 
					    type: String,
 | 
				
			||||||
 | 
					    default: `px-5 py-3 text-sm not-italic font-medium leading-5
 | 
				
			||||||
 | 
					              text-gray-700 border-t border-b border-gray-200 border-solid dark:text-white dark:border-white/10`
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
})
 | 
					})
 | 
				
			||||||
 | 
					
 | 
				
			||||||
const companyStore = useCompanyStore()
 | 
					const companyStore = useCompanyStore()
 | 
				
			||||||
 | 
				
			|||||||
@ -5,7 +5,7 @@
 | 
				
			|||||||
    >
 | 
					    >
 | 
				
			||||||
      <SelectNotePopup :type="type" @select="onSelectNote" />
 | 
					      <SelectNotePopup :type="type" @select="onSelectNote" />
 | 
				
			||||||
    </div>
 | 
					    </div>
 | 
				
			||||||
    <label class="text-gray-800 font-medium mb-4 text-sm">
 | 
					    <label class="text-gray-800 font-medium mb-4 text-sm dark:text-gray-300">
 | 
				
			||||||
      {{ $t('invoices.notes') }}
 | 
					      {{ $t('invoices.notes') }}
 | 
				
			||||||
    </label>
 | 
					    </label>
 | 
				
			||||||
    <BaseCustomInput
 | 
					    <BaseCustomInput
 | 
				
			||||||
 | 
				
			|||||||
@ -6,6 +6,7 @@
 | 
				
			|||||||
      mt-6
 | 
					      mt-6
 | 
				
			||||||
      bg-white
 | 
					      bg-white
 | 
				
			||||||
      border border-gray-200 border-solid
 | 
					      border border-gray-200 border-solid
 | 
				
			||||||
 | 
					      dark:bg-gray-800/50 dark:border-white/10
 | 
				
			||||||
      rounded
 | 
					      rounded
 | 
				
			||||||
      md:min-w-[390px]
 | 
					      md:min-w-[390px]
 | 
				
			||||||
      min-w-[300px]
 | 
					      min-w-[300px]
 | 
				
			||||||
@ -29,7 +30,16 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
      <label
 | 
					      <label
 | 
				
			||||||
        v-else
 | 
					        v-else
 | 
				
			||||||
        class="flex items-center justify-center m-0 text-lg text-black uppercase "
 | 
					        class="
 | 
				
			||||||
 | 
					          flex
 | 
				
			||||||
 | 
					          items-center
 | 
				
			||||||
 | 
					          justify-center
 | 
				
			||||||
 | 
					          m-0
 | 
				
			||||||
 | 
					          text-lg
 | 
				
			||||||
 | 
					          text-black
 | 
				
			||||||
 | 
					          dark:text-white
 | 
				
			||||||
 | 
					          uppercase
 | 
				
			||||||
 | 
					        "
 | 
				
			||||||
      >
 | 
					      >
 | 
				
			||||||
        <BaseFormatMoney
 | 
					        <BaseFormatMoney
 | 
				
			||||||
          :amount="store.getSubTotal"
 | 
					          :amount="store.getSubTotal"
 | 
				
			||||||
@ -59,7 +69,16 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
      <label
 | 
					      <label
 | 
				
			||||||
        v-else-if="store[storeProp].tax_per_item === 'YES'"
 | 
					        v-else-if="store[storeProp].tax_per_item === 'YES'"
 | 
				
			||||||
        class="flex items-center justify-center m-0 text-lg text-black uppercase "
 | 
					        class="
 | 
				
			||||||
 | 
					          flex
 | 
				
			||||||
 | 
					          items-center
 | 
				
			||||||
 | 
					          justify-center
 | 
				
			||||||
 | 
					          m-0
 | 
				
			||||||
 | 
					          text-lg
 | 
				
			||||||
 | 
					          text-black
 | 
				
			||||||
 | 
					          dark:text-white
 | 
				
			||||||
 | 
					          uppercase
 | 
				
			||||||
 | 
					        "
 | 
				
			||||||
      >
 | 
					      >
 | 
				
			||||||
        <BaseFormatMoney :amount="tax.amount" :currency="defaultCurrency" />
 | 
					        <BaseFormatMoney :amount="tax.amount" :currency="defaultCurrency" />
 | 
				
			||||||
      </label>
 | 
					      </label>
 | 
				
			||||||
@ -166,14 +185,23 @@
 | 
				
			|||||||
    </div>
 | 
					    </div>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    <div
 | 
					    <div
 | 
				
			||||||
      class="flex items-center justify-between w-full pt-2 mt-5 border-t border-gray-200 border-solid "
 | 
					      class="
 | 
				
			||||||
 | 
					        flex
 | 
				
			||||||
 | 
					        items-center
 | 
				
			||||||
 | 
					        justify-between
 | 
				
			||||||
 | 
					        w-full
 | 
				
			||||||
 | 
					        pt-2
 | 
				
			||||||
 | 
					        mt-5
 | 
				
			||||||
 | 
					        border-t border-gray-200 border-solid
 | 
				
			||||||
 | 
					        dark:border-gray-600
 | 
				
			||||||
 | 
					      "
 | 
				
			||||||
    >
 | 
					    >
 | 
				
			||||||
      <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
 | 
					      <label
 | 
				
			||||||
        v-else
 | 
					        v-else
 | 
				
			||||||
        class="m-0 text-sm font-semibold leading-5 text-gray-400 uppercase"
 | 
					        class="m-0 text-sm font-semibold leading-5 text-gray-400 uppercase dark:text-gray-400"
 | 
				
			||||||
        >{{ $t('estimates.total') }} {{ $t('estimates.amount') }}:</label
 | 
					        >{{ $t('estimates.total') }} {{ $t('estimates.amount') }}:</label
 | 
				
			||||||
      >
 | 
					      >
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
				
			|||||||
@ -1,14 +1,23 @@
 | 
				
			|||||||
<template>
 | 
					<template>
 | 
				
			||||||
  <div class="flex items-center justify-between w-full mt-2 text-sm">
 | 
					  <div class="flex items-center justify-between w-full mt-2 text-sm">
 | 
				
			||||||
    <label class="font-semibold leading-5 text-gray-500 uppercase">
 | 
					    <label class="font-semibold leading-5 text-gray-500 uppercase dark:text-gray-300">
 | 
				
			||||||
      {{ tax.name }} ({{ tax.percent }} %)
 | 
					      {{ tax.name }} ({{ tax.percent }} %)
 | 
				
			||||||
    </label>
 | 
					    </label>
 | 
				
			||||||
    <label class="flex items-center justify-center text-lg text-black">
 | 
					    <label
 | 
				
			||||||
 | 
					      class="
 | 
				
			||||||
 | 
					        flex
 | 
				
			||||||
 | 
					        items-center
 | 
				
			||||||
 | 
					        justify-center
 | 
				
			||||||
 | 
					        text-lg
 | 
				
			||||||
 | 
					        text-black
 | 
				
			||||||
 | 
					        dark:text-white
 | 
				
			||||||
 | 
					      "
 | 
				
			||||||
 | 
					    >
 | 
				
			||||||
      <BaseFormatMoney :amount="tax.amount" :currency="currency" />
 | 
					      <BaseFormatMoney :amount="tax.amount" :currency="currency" />
 | 
				
			||||||
 | 
					
 | 
				
			||||||
      <BaseIcon
 | 
					      <BaseIcon
 | 
				
			||||||
        name="TrashIcon"
 | 
					        name="TrashIcon"
 | 
				
			||||||
        class="h-5 ml-2 cursor-pointer"
 | 
					        class="h-5 ml-2 cursor-pointer dark:text-red-400"
 | 
				
			||||||
        @click="$emit('remove', tax.id)"
 | 
					        @click="$emit('remove', tax.id)"
 | 
				
			||||||
      />
 | 
					      />
 | 
				
			||||||
    </label>
 | 
					    </label>
 | 
				
			||||||
 | 
				
			|||||||
@ -44,7 +44,7 @@
 | 
				
			|||||||
            >
 | 
					            >
 | 
				
			||||||
              <!-- Tax Search Input  -->
 | 
					              <!-- Tax Search Input  -->
 | 
				
			||||||
 | 
					
 | 
				
			||||||
              <div class="relative bg-white">
 | 
					              <div class="relative bg-white dark:bg-gray-800">
 | 
				
			||||||
                <div class="relative p-4">
 | 
					                <div class="relative p-4">
 | 
				
			||||||
                  <BaseInput
 | 
					                  <BaseInput
 | 
				
			||||||
                    v-model="textSearch"
 | 
					                    v-model="textSearch"
 | 
				
			||||||
@ -65,13 +65,14 @@
 | 
				
			|||||||
                    list
 | 
					                    list
 | 
				
			||||||
                    max-h-36
 | 
					                    max-h-36
 | 
				
			||||||
                    border-t border-gray-200
 | 
					                    border-t border-gray-200
 | 
				
			||||||
 | 
					                    dark:border-gray-600
 | 
				
			||||||
                  "
 | 
					                  "
 | 
				
			||||||
                >
 | 
					                >
 | 
				
			||||||
                  <div
 | 
					                  <div
 | 
				
			||||||
                    v-for="(taxType, index) in filteredTaxType"
 | 
					                    v-for="(taxType, index) in filteredTaxType"
 | 
				
			||||||
                    :key="index"
 | 
					                    :key="index"
 | 
				
			||||||
                    :class="{
 | 
					                    :class="{
 | 
				
			||||||
                      'bg-gray-100 cursor-not-allowed opacity-50 pointer-events-none':
 | 
					                      'bg-gray-100 cursor-not-allowed opacity-50 pointer-events-none dark:bg-gray-900':
 | 
				
			||||||
                        taxes.find((val) => {
 | 
					                        taxes.find((val) => {
 | 
				
			||||||
                          return val.tax_type_id === taxType.id
 | 
					                          return val.tax_type_id === taxType.id
 | 
				
			||||||
                        }),
 | 
					                        }),
 | 
				
			||||||
@ -84,6 +85,7 @@
 | 
				
			|||||||
                      cursor-pointer
 | 
					                      cursor-pointer
 | 
				
			||||||
                      hover:bg-gray-100 hover:cursor-pointer
 | 
					                      hover:bg-gray-100 hover:cursor-pointer
 | 
				
			||||||
                      last:border-b-0
 | 
					                      last:border-b-0
 | 
				
			||||||
 | 
					                      dark:border-gray-600 dark:hover:bg-gray-700/20
 | 
				
			||||||
                    "
 | 
					                    "
 | 
				
			||||||
                    @click="selectTaxType(taxType, close)"
 | 
					                    @click="selectTaxType(taxType, close)"
 | 
				
			||||||
                  >
 | 
					                  >
 | 
				
			||||||
@ -96,6 +98,7 @@
 | 
				
			|||||||
                          leading-tight
 | 
					                          leading-tight
 | 
				
			||||||
                          text-gray-700
 | 
					                          text-gray-700
 | 
				
			||||||
                          cursor-pointer
 | 
					                          cursor-pointer
 | 
				
			||||||
 | 
					                          dark:text-gray-300
 | 
				
			||||||
                        "
 | 
					                        "
 | 
				
			||||||
                      >
 | 
					                      >
 | 
				
			||||||
                        {{ taxType.name }}
 | 
					                        {{ taxType.name }}
 | 
				
			||||||
@ -108,6 +111,7 @@
 | 
				
			|||||||
                          font-semibold
 | 
					                          font-semibold
 | 
				
			||||||
                          text-gray-700
 | 
					                          text-gray-700
 | 
				
			||||||
                          cursor-pointer
 | 
					                          cursor-pointer
 | 
				
			||||||
 | 
					                          dark:text-gray-300
 | 
				
			||||||
                        "
 | 
					                        "
 | 
				
			||||||
                      >
 | 
					                      >
 | 
				
			||||||
                        {{ taxType.percent }} %
 | 
					                        {{ taxType.percent }} %
 | 
				
			||||||
@ -138,6 +142,10 @@
 | 
				
			|||||||
                  bg-gray-200
 | 
					                  bg-gray-200
 | 
				
			||||||
                  border-none
 | 
					                  border-none
 | 
				
			||||||
                  outline-none
 | 
					                  outline-none
 | 
				
			||||||
 | 
					                  dark:bg-gray-600/70
 | 
				
			||||||
 | 
					                  dark:backdrop-blur-xl
 | 
				
			||||||
 | 
					                  dark:shadow-glass
 | 
				
			||||||
 | 
					                  dark:hover:bg-gray-600/80
 | 
				
			||||||
                "
 | 
					                "
 | 
				
			||||||
                @click="openTaxTypeModal"
 | 
					                @click="openTaxTypeModal"
 | 
				
			||||||
              >
 | 
					              >
 | 
				
			||||||
 | 
				
			|||||||
@ -1,6 +1,6 @@
 | 
				
			|||||||
<template>
 | 
					<template>
 | 
				
			||||||
  <div>
 | 
					  <div>
 | 
				
			||||||
    <label class="flex text-gray-800 font-medium text-sm mb-2">
 | 
					    <label class="flex text-gray-800 font-medium text-sm mb-2 dark:text-gray-300">
 | 
				
			||||||
      {{ $t('general.select_template') }}
 | 
					      {{ $t('general.select_template') }}
 | 
				
			||||||
      <span class="text-sm text-red-500"> *</span>
 | 
					      <span class="text-sm text-red-500"> *</span>
 | 
				
			||||||
    </label>
 | 
					    </label>
 | 
				
			||||||
 | 
				
			|||||||
@ -57,9 +57,7 @@
 | 
				
			|||||||
          </BaseInputGroup>
 | 
					          </BaseInputGroup>
 | 
				
			||||||
        </BaseInputGrid>
 | 
					        </BaseInputGrid>
 | 
				
			||||||
      </div>
 | 
					      </div>
 | 
				
			||||||
      <div
 | 
					      <BaseModalFooter>
 | 
				
			||||||
        class="z-0 flex justify-end p-4 border-t border-gray-200 border-solid"
 | 
					 | 
				
			||||||
      >
 | 
					 | 
				
			||||||
        <BaseButton
 | 
					        <BaseButton
 | 
				
			||||||
          class="mr-3"
 | 
					          class="mr-3"
 | 
				
			||||||
          variant="primary-outline"
 | 
					          variant="primary-outline"
 | 
				
			||||||
@ -84,7 +82,7 @@
 | 
				
			|||||||
          </template>
 | 
					          </template>
 | 
				
			||||||
          {{ $t('general.create') }}
 | 
					          {{ $t('general.create') }}
 | 
				
			||||||
        </BaseButton>
 | 
					        </BaseButton>
 | 
				
			||||||
      </div>
 | 
					      </BaseModalFooter>
 | 
				
			||||||
    </form>
 | 
					    </form>
 | 
				
			||||||
  </BaseModal>
 | 
					  </BaseModal>
 | 
				
			||||||
</template>
 | 
					</template>
 | 
				
			||||||
 | 
				
			|||||||
@ -47,15 +47,7 @@
 | 
				
			|||||||
        </BaseInputGrid>
 | 
					        </BaseInputGrid>
 | 
				
			||||||
      </div>
 | 
					      </div>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
      <div
 | 
					      <BaseModalFooter>
 | 
				
			||||||
        class="
 | 
					 | 
				
			||||||
          z-0
 | 
					 | 
				
			||||||
          flex
 | 
					 | 
				
			||||||
          justify-end
 | 
					 | 
				
			||||||
          p-4
 | 
					 | 
				
			||||||
          border-t border-gray-200 border-solid border-modal-bg
 | 
					 | 
				
			||||||
        "
 | 
					 | 
				
			||||||
      >
 | 
					 | 
				
			||||||
        <BaseButton
 | 
					        <BaseButton
 | 
				
			||||||
          type="button"
 | 
					          type="button"
 | 
				
			||||||
          variant="primary-outline"
 | 
					          variant="primary-outline"
 | 
				
			||||||
@ -80,7 +72,7 @@
 | 
				
			|||||||
          </template>
 | 
					          </template>
 | 
				
			||||||
          {{ categoryStore.isEdit ? $t('general.update') : $t('general.save') }}
 | 
					          {{ categoryStore.isEdit ? $t('general.update') : $t('general.save') }}
 | 
				
			||||||
        </BaseButton>
 | 
					        </BaseButton>
 | 
				
			||||||
      </div>
 | 
					      </BaseModalFooter>
 | 
				
			||||||
    </form>
 | 
					    </form>
 | 
				
			||||||
  </BaseModal>
 | 
					  </BaseModal>
 | 
				
			||||||
</template>
 | 
					</template>
 | 
				
			||||||
 | 
				
			|||||||
@ -116,7 +116,7 @@
 | 
				
			|||||||
        </BaseInputGrid>
 | 
					        </BaseInputGrid>
 | 
				
			||||||
      </div>
 | 
					      </div>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
      <div class="z-0 flex justify-end p-4 bg-gray-50 border-modal-bg">
 | 
					       <BaseModalFooter>
 | 
				
			||||||
        <BaseButton
 | 
					        <BaseButton
 | 
				
			||||||
          class="mr-3 text-sm"
 | 
					          class="mr-3 text-sm"
 | 
				
			||||||
          variant="primary-outline"
 | 
					          variant="primary-outline"
 | 
				
			||||||
@ -141,7 +141,7 @@
 | 
				
			|||||||
          </template>
 | 
					          </template>
 | 
				
			||||||
          {{ $t('general.save') }}
 | 
					          {{ $t('general.save') }}
 | 
				
			||||||
        </BaseButton>
 | 
					        </BaseButton>
 | 
				
			||||||
      </div>
 | 
					      </BaseModalFooter>
 | 
				
			||||||
    </form>
 | 
					    </form>
 | 
				
			||||||
  </BaseModal>
 | 
					  </BaseModal>
 | 
				
			||||||
</template>
 | 
					</template>
 | 
				
			||||||
 | 
				
			|||||||
@ -122,7 +122,7 @@
 | 
				
			|||||||
          <BaseTab :title="$t('customers.portal_access')">
 | 
					          <BaseTab :title="$t('customers.portal_access')">
 | 
				
			||||||
            <BaseInputGrid class="col-span-5 lg:col-span-4">
 | 
					            <BaseInputGrid class="col-span-5 lg:col-span-4">
 | 
				
			||||||
              <div class="md:col-span-2">
 | 
					              <div class="md:col-span-2">
 | 
				
			||||||
                <p class="text-sm text-gray-500">
 | 
					                <p class="text-sm text-gray-500 dark:text-gray-300">
 | 
				
			||||||
                  {{ $t('customers.portal_access_text') }}
 | 
					                  {{ $t('customers.portal_access_text') }}
 | 
				
			||||||
                </p>
 | 
					                </p>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@ -425,9 +425,7 @@
 | 
				
			|||||||
        </BaseTabGroup>
 | 
					        </BaseTabGroup>
 | 
				
			||||||
      </div>
 | 
					      </div>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
      <div
 | 
					      <BaseModalFooter>
 | 
				
			||||||
        class="z-0 flex justify-end p-4 border-t border-gray-200 border-solid"
 | 
					 | 
				
			||||||
      >
 | 
					 | 
				
			||||||
        <BaseButton
 | 
					        <BaseButton
 | 
				
			||||||
          class="mr-3 text-sm"
 | 
					          class="mr-3 text-sm"
 | 
				
			||||||
          type="button"
 | 
					          type="button"
 | 
				
			||||||
@ -447,7 +445,7 @@
 | 
				
			|||||||
          </template>
 | 
					          </template>
 | 
				
			||||||
          {{ $t('general.save') }}
 | 
					          {{ $t('general.save') }}
 | 
				
			||||||
        </BaseButton>
 | 
					        </BaseButton>
 | 
				
			||||||
      </div>
 | 
					      </BaseModalFooter>
 | 
				
			||||||
    </form>
 | 
					    </form>
 | 
				
			||||||
  </BaseModal>
 | 
					  </BaseModal>
 | 
				
			||||||
</template>
 | 
					</template>
 | 
				
			||||||
 | 
				
			|||||||
@ -38,7 +38,7 @@
 | 
				
			|||||||
        </BaseInputGroup>
 | 
					        </BaseInputGroup>
 | 
				
			||||||
      </div>
 | 
					      </div>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
      <div class="z-0 flex justify-end p-4 bg-gray-50 border-modal-bg">
 | 
					      <BaseModalFooter>
 | 
				
			||||||
        <BaseButton
 | 
					        <BaseButton
 | 
				
			||||||
          class="mr-3 text-sm"
 | 
					          class="mr-3 text-sm"
 | 
				
			||||||
          variant="primary-outline"
 | 
					          variant="primary-outline"
 | 
				
			||||||
@ -63,7 +63,7 @@
 | 
				
			|||||||
          </template>
 | 
					          </template>
 | 
				
			||||||
          {{ $t('general.delete') }}
 | 
					          {{ $t('general.delete') }}
 | 
				
			||||||
        </BaseButton>
 | 
					        </BaseButton>
 | 
				
			||||||
      </div>
 | 
					      </BaseModalFooter>
 | 
				
			||||||
    </form>
 | 
					    </form>
 | 
				
			||||||
  </BaseModal>
 | 
					  </BaseModal>
 | 
				
			||||||
</template>
 | 
					</template>
 | 
				
			||||||
 | 
				
			|||||||
@ -150,9 +150,7 @@
 | 
				
			|||||||
          @Remove="removeUsedSelectedCurrencies"
 | 
					          @Remove="removeUsedSelectedCurrencies"
 | 
				
			||||||
        />
 | 
					        />
 | 
				
			||||||
      </div>
 | 
					      </div>
 | 
				
			||||||
      <div
 | 
					      <BaseModalFooter>
 | 
				
			||||||
        class="z-0 flex justify-end p-4 border-t border-gray-200 border-solid"
 | 
					 | 
				
			||||||
      >
 | 
					 | 
				
			||||||
        <BaseButton
 | 
					        <BaseButton
 | 
				
			||||||
          class="mr-3"
 | 
					          class="mr-3"
 | 
				
			||||||
          variant="primary-outline"
 | 
					          variant="primary-outline"
 | 
				
			||||||
@ -179,7 +177,7 @@
 | 
				
			|||||||
            exchangeRateStore.isEdit ? $t('general.update') : $t('general.save')
 | 
					            exchangeRateStore.isEdit ? $t('general.update') : $t('general.save')
 | 
				
			||||||
          }}
 | 
					          }}
 | 
				
			||||||
        </BaseButton>
 | 
					        </BaseButton>
 | 
				
			||||||
      </div>
 | 
					      </BaseModalFooter>
 | 
				
			||||||
    </form>
 | 
					    </form>
 | 
				
			||||||
  </BaseModal>
 | 
					  </BaseModal>
 | 
				
			||||||
</template>
 | 
					</template>
 | 
				
			||||||
 | 
				
			|||||||
@ -20,15 +20,7 @@
 | 
				
			|||||||
        @submit="createNewDisk"
 | 
					        @submit="createNewDisk"
 | 
				
			||||||
      >
 | 
					      >
 | 
				
			||||||
        <template #default="slotProps">
 | 
					        <template #default="slotProps">
 | 
				
			||||||
          <div
 | 
					          <BaseModalFooter>
 | 
				
			||||||
            class="
 | 
					 | 
				
			||||||
              z-0
 | 
					 | 
				
			||||||
              flex
 | 
					 | 
				
			||||||
              justify-end
 | 
					 | 
				
			||||||
              p-4
 | 
					 | 
				
			||||||
              border-t border-solid border-gray-light
 | 
					 | 
				
			||||||
            "
 | 
					 | 
				
			||||||
          >
 | 
					 | 
				
			||||||
            <BaseButton
 | 
					            <BaseButton
 | 
				
			||||||
              class="mr-3 text-sm"
 | 
					              class="mr-3 text-sm"
 | 
				
			||||||
              variant="primary-outline"
 | 
					              variant="primary-outline"
 | 
				
			||||||
@ -52,7 +44,7 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
              {{ $t('general.save') }}
 | 
					              {{ $t('general.save') }}
 | 
				
			||||||
            </BaseButton>
 | 
					            </BaseButton>
 | 
				
			||||||
          </div>
 | 
					          </BaseModalFooter>
 | 
				
			||||||
        </template>
 | 
					        </template>
 | 
				
			||||||
      </component>
 | 
					      </component>
 | 
				
			||||||
    </div>
 | 
					    </div>
 | 
				
			||||||
 | 
				
			|||||||
@ -89,9 +89,7 @@
 | 
				
			|||||||
            </BaseInputGroup>
 | 
					            </BaseInputGroup>
 | 
				
			||||||
          </BaseInputGrid>
 | 
					          </BaseInputGrid>
 | 
				
			||||||
        </div>
 | 
					        </div>
 | 
				
			||||||
        <div
 | 
					        <BaseModalFooter>
 | 
				
			||||||
          class="z-0 flex justify-end p-4 border-t border-gray-200 border-solid"
 | 
					 | 
				
			||||||
        >
 | 
					 | 
				
			||||||
          <BaseButton
 | 
					          <BaseButton
 | 
				
			||||||
            class="mr-3"
 | 
					            class="mr-3"
 | 
				
			||||||
            variant="primary-outline"
 | 
					            variant="primary-outline"
 | 
				
			||||||
@ -111,7 +109,7 @@
 | 
				
			|||||||
            </template>
 | 
					            </template>
 | 
				
			||||||
            {{ itemStore.isEdit ? $t('general.update') : $t('general.save') }}
 | 
					            {{ itemStore.isEdit ? $t('general.update') : $t('general.save') }}
 | 
				
			||||||
          </BaseButton>
 | 
					          </BaseButton>
 | 
				
			||||||
        </div>
 | 
					        </BaseModalFooter>
 | 
				
			||||||
      </form>
 | 
					      </form>
 | 
				
			||||||
    </div>
 | 
					    </div>
 | 
				
			||||||
  </BaseModal>
 | 
					  </BaseModal>
 | 
				
			||||||
 | 
				
			|||||||
@ -31,15 +31,7 @@
 | 
				
			|||||||
        </BaseInputGroup>
 | 
					        </BaseInputGroup>
 | 
				
			||||||
      </div>
 | 
					      </div>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
      <div
 | 
					      <BaseModalFooter>
 | 
				
			||||||
        class="
 | 
					 | 
				
			||||||
          z-0
 | 
					 | 
				
			||||||
          flex
 | 
					 | 
				
			||||||
          justify-end
 | 
					 | 
				
			||||||
          p-4
 | 
					 | 
				
			||||||
          border-t border-gray-200 border-solid border-modal-bg
 | 
					 | 
				
			||||||
        "
 | 
					 | 
				
			||||||
      >
 | 
					 | 
				
			||||||
        <BaseButton
 | 
					        <BaseButton
 | 
				
			||||||
          type="button"
 | 
					          type="button"
 | 
				
			||||||
          variant="primary-outline"
 | 
					          variant="primary-outline"
 | 
				
			||||||
@ -66,7 +58,7 @@
 | 
				
			|||||||
            itemStore.isItemUnitEdit ? $t('general.update') : $t('general.save')
 | 
					            itemStore.isItemUnitEdit ? $t('general.update') : $t('general.save')
 | 
				
			||||||
          }}
 | 
					          }}
 | 
				
			||||||
        </BaseButton>
 | 
					        </BaseButton>
 | 
				
			||||||
      </div>
 | 
					      </BaseModalFooter>
 | 
				
			||||||
    </form>
 | 
					    </form>
 | 
				
			||||||
  </BaseModal>
 | 
					  </BaseModal>
 | 
				
			||||||
</template>
 | 
					</template>
 | 
				
			||||||
 | 
				
			|||||||
@ -62,9 +62,7 @@
 | 
				
			|||||||
          </BaseInputGroup>
 | 
					          </BaseInputGroup>
 | 
				
			||||||
        </BaseInputGrid>
 | 
					        </BaseInputGrid>
 | 
				
			||||||
      </div>
 | 
					      </div>
 | 
				
			||||||
      <div
 | 
					     <BaseModalFooter>
 | 
				
			||||||
        class="z-0 flex justify-end p-4 border-t border-gray-200 border-solid"
 | 
					 | 
				
			||||||
      >
 | 
					 | 
				
			||||||
        <BaseButton
 | 
					        <BaseButton
 | 
				
			||||||
          variant="primary-outline"
 | 
					          variant="primary-outline"
 | 
				
			||||||
          type="button"
 | 
					          type="button"
 | 
				
			||||||
@ -84,7 +82,7 @@
 | 
				
			|||||||
          </template>
 | 
					          </template>
 | 
				
			||||||
          {{ $t('general.send') }}
 | 
					          {{ $t('general.send') }}
 | 
				
			||||||
        </BaseButton>
 | 
					        </BaseButton>
 | 
				
			||||||
      </div>
 | 
					      </BaseModalFooter>
 | 
				
			||||||
    </form>
 | 
					    </form>
 | 
				
			||||||
  </BaseModal>
 | 
					  </BaseModal>
 | 
				
			||||||
</template>
 | 
					</template>
 | 
				
			||||||
 | 
				
			|||||||
@ -63,16 +63,7 @@
 | 
				
			|||||||
          </BaseInputGroup>
 | 
					          </BaseInputGroup>
 | 
				
			||||||
        </BaseInputGrid>
 | 
					        </BaseInputGrid>
 | 
				
			||||||
      </div>
 | 
					      </div>
 | 
				
			||||||
      <div
 | 
					     <BaseModalFooter>
 | 
				
			||||||
        class="
 | 
					 | 
				
			||||||
          z-0
 | 
					 | 
				
			||||||
          flex
 | 
					 | 
				
			||||||
          justify-end
 | 
					 | 
				
			||||||
          px-4
 | 
					 | 
				
			||||||
          py-4
 | 
					 | 
				
			||||||
          border-t border-solid border-gray-light
 | 
					 | 
				
			||||||
        "
 | 
					 | 
				
			||||||
      >
 | 
					 | 
				
			||||||
        <BaseButton
 | 
					        <BaseButton
 | 
				
			||||||
          class="mr-2"
 | 
					          class="mr-2"
 | 
				
			||||||
          variant="primary-outline"
 | 
					          variant="primary-outline"
 | 
				
			||||||
@ -93,7 +84,7 @@
 | 
				
			|||||||
          </template>
 | 
					          </template>
 | 
				
			||||||
          {{ noteStore.isEdit ? $t('general.update') : $t('general.save') }}
 | 
					          {{ noteStore.isEdit ? $t('general.update') : $t('general.save') }}
 | 
				
			||||||
        </BaseButton>
 | 
					        </BaseButton>
 | 
				
			||||||
      </div>
 | 
					      </BaseModalFooter>
 | 
				
			||||||
    </form>
 | 
					    </form>
 | 
				
			||||||
  </BaseModal>
 | 
					  </BaseModal>
 | 
				
			||||||
</template>
 | 
					</template>
 | 
				
			||||||
 | 
				
			|||||||
@ -29,9 +29,7 @@
 | 
				
			|||||||
        </BaseInputGroup>
 | 
					        </BaseInputGroup>
 | 
				
			||||||
      </div>
 | 
					      </div>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
      <div
 | 
					      <BaseModalFooter>
 | 
				
			||||||
        class="z-0 flex justify-end p-4 border-t border-gray-200 border-solid"
 | 
					 | 
				
			||||||
      >
 | 
					 | 
				
			||||||
        <BaseButton
 | 
					        <BaseButton
 | 
				
			||||||
          variant="primary-outline"
 | 
					          variant="primary-outline"
 | 
				
			||||||
          class="mr-3"
 | 
					          class="mr-3"
 | 
				
			||||||
@ -56,7 +54,7 @@
 | 
				
			|||||||
              : $t('general.save')
 | 
					              : $t('general.save')
 | 
				
			||||||
          }}
 | 
					          }}
 | 
				
			||||||
        </BaseButton>
 | 
					        </BaseButton>
 | 
				
			||||||
      </div>
 | 
					      </BaseModalFooter>
 | 
				
			||||||
    </form>
 | 
					    </form>
 | 
				
			||||||
  </BaseModal>
 | 
					  </BaseModal>
 | 
				
			||||||
</template>
 | 
					</template>
 | 
				
			||||||
 | 
				
			|||||||
@ -72,7 +72,7 @@
 | 
				
			|||||||
        </div>
 | 
					        </div>
 | 
				
			||||||
      </div>
 | 
					      </div>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
      <div class="border-t border-gray-200 py-3">
 | 
					      <div class="border-t border-gray-200 dark:border-gray-600 py-3">
 | 
				
			||||||
        <div
 | 
					        <div
 | 
				
			||||||
          class="
 | 
					          class="
 | 
				
			||||||
            grid grid-cols-1
 | 
					            grid grid-cols-1
 | 
				
			||||||
@ -89,7 +89,7 @@
 | 
				
			|||||||
            :key="gIndex"
 | 
					            :key="gIndex"
 | 
				
			||||||
            class="flex flex-col space-y-1"
 | 
					            class="flex flex-col space-y-1"
 | 
				
			||||||
          >
 | 
					          >
 | 
				
			||||||
            <p class="text-sm text-gray-500 border-b border-gray-200 pb-1 mb-2">
 | 
					            <p class="text-sm text-gray-500 dark:text-gray-200 border-b dark:border-gray-600 pb-1 mb-2">
 | 
				
			||||||
              {{ gIndex }}
 | 
					              {{ gIndex }}
 | 
				
			||||||
            </p>
 | 
					            </p>
 | 
				
			||||||
            <div
 | 
					            <div
 | 
				
			||||||
@ -116,15 +116,7 @@
 | 
				
			|||||||
          </span>
 | 
					          </span>
 | 
				
			||||||
        </div>
 | 
					        </div>
 | 
				
			||||||
      </div>
 | 
					      </div>
 | 
				
			||||||
      <div
 | 
					      <BaseModalFooter>
 | 
				
			||||||
        class="
 | 
					 | 
				
			||||||
          z-0
 | 
					 | 
				
			||||||
          flex
 | 
					 | 
				
			||||||
          justify-end
 | 
					 | 
				
			||||||
          p-4
 | 
					 | 
				
			||||||
          border-t border-solid border--200 border-modal-bg
 | 
					 | 
				
			||||||
        "
 | 
					 | 
				
			||||||
      >
 | 
					 | 
				
			||||||
        <BaseButton
 | 
					        <BaseButton
 | 
				
			||||||
          class="mr-3 text-sm"
 | 
					          class="mr-3 text-sm"
 | 
				
			||||||
          variant="primary-outline"
 | 
					          variant="primary-outline"
 | 
				
			||||||
@ -144,7 +136,7 @@
 | 
				
			|||||||
          </template>
 | 
					          </template>
 | 
				
			||||||
          {{ !roleStore.isEdit ? $t('general.save') : $t('general.update') }}
 | 
					          {{ !roleStore.isEdit ? $t('general.save') : $t('general.update') }}
 | 
				
			||||||
        </BaseButton>
 | 
					        </BaseButton>
 | 
				
			||||||
      </div>
 | 
					      </BaseModalFooter>
 | 
				
			||||||
    </form>
 | 
					    </form>
 | 
				
			||||||
  </BaseModal>
 | 
					  </BaseModal>
 | 
				
			||||||
</template>
 | 
					</template>
 | 
				
			||||||
 | 
				
			|||||||
@ -70,7 +70,7 @@
 | 
				
			|||||||
      </div>
 | 
					      </div>
 | 
				
			||||||
    </div>
 | 
					    </div>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    <div class="z-0 flex justify-end p-4 border-t border-gray-200 border-solid">
 | 
					    <BaseModalFooter>
 | 
				
			||||||
      <BaseButton class="mr-3" variant="primary-outline" @click="closeModal">
 | 
					      <BaseButton class="mr-3" variant="primary-outline" @click="closeModal">
 | 
				
			||||||
        {{ $t('general.cancel') }}
 | 
					        {{ $t('general.cancel') }}
 | 
				
			||||||
      </BaseButton>
 | 
					      </BaseButton>
 | 
				
			||||||
@ -80,7 +80,7 @@
 | 
				
			|||||||
        </template>
 | 
					        </template>
 | 
				
			||||||
        {{ $t('general.choose') }}
 | 
					        {{ $t('general.choose') }}
 | 
				
			||||||
      </BaseButton>
 | 
					      </BaseButton>
 | 
				
			||||||
    </div>
 | 
					    </BaseModalFooter>
 | 
				
			||||||
  </BaseModal>
 | 
					  </BaseModal>
 | 
				
			||||||
</template>
 | 
					</template>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
				
			|||||||
@ -62,9 +62,7 @@
 | 
				
			|||||||
          </BaseInputGroup>
 | 
					          </BaseInputGroup>
 | 
				
			||||||
        </BaseInputGrid>
 | 
					        </BaseInputGrid>
 | 
				
			||||||
      </div>
 | 
					      </div>
 | 
				
			||||||
      <div
 | 
					      <BaseModalFooter>
 | 
				
			||||||
        class="z-0 flex justify-end p-4 border-t border-gray-200 border-solid"
 | 
					 | 
				
			||||||
      >
 | 
					 | 
				
			||||||
        <BaseButton
 | 
					        <BaseButton
 | 
				
			||||||
          class="mr-3"
 | 
					          class="mr-3"
 | 
				
			||||||
          variant="primary-outline"
 | 
					          variant="primary-outline"
 | 
				
			||||||
@ -85,7 +83,7 @@
 | 
				
			|||||||
          <BaseIcon v-if="!isLoading" name="PhotographIcon" class="h-5 mr-2" />
 | 
					          <BaseIcon v-if="!isLoading" name="PhotographIcon" class="h-5 mr-2" />
 | 
				
			||||||
          {{ $t('general.preview') }}
 | 
					          {{ $t('general.preview') }}
 | 
				
			||||||
        </BaseButton>
 | 
					        </BaseButton>
 | 
				
			||||||
      </div>
 | 
					      </BaseModalFooter>
 | 
				
			||||||
    </form>
 | 
					    </form>
 | 
				
			||||||
    <div v-else>
 | 
					    <div v-else>
 | 
				
			||||||
      <div class="my-6 mx-4 border border-gray-200 relative">
 | 
					      <div class="my-6 mx-4 border border-gray-200 relative">
 | 
				
			||||||
@ -106,9 +104,7 @@
 | 
				
			|||||||
        ></iframe>
 | 
					        ></iframe>
 | 
				
			||||||
      </div>
 | 
					      </div>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
      <div
 | 
					      <BaseModalFooter>
 | 
				
			||||||
        class="z-0 flex justify-end p-4 border-t border-gray-200 border-solid"
 | 
					 | 
				
			||||||
      >
 | 
					 | 
				
			||||||
        <BaseButton
 | 
					        <BaseButton
 | 
				
			||||||
          class="mr-3"
 | 
					          class="mr-3"
 | 
				
			||||||
          variant="primary-outline"
 | 
					          variant="primary-outline"
 | 
				
			||||||
@ -127,7 +123,7 @@
 | 
				
			|||||||
          <BaseIcon v-if="!isLoading" name="PaperAirplaneIcon" class="mr-2" />
 | 
					          <BaseIcon v-if="!isLoading" name="PaperAirplaneIcon" class="mr-2" />
 | 
				
			||||||
          {{ $t('general.send') }}
 | 
					          {{ $t('general.send') }}
 | 
				
			||||||
        </BaseButton>
 | 
					        </BaseButton>
 | 
				
			||||||
      </div>
 | 
					      </BaseModalFooter>
 | 
				
			||||||
    </div>
 | 
					    </div>
 | 
				
			||||||
  </BaseModal>
 | 
					  </BaseModal>
 | 
				
			||||||
</template>
 | 
					</template>
 | 
				
			||||||
 | 
				
			|||||||
@ -65,9 +65,7 @@
 | 
				
			|||||||
          </BaseInputGroup>
 | 
					          </BaseInputGroup>
 | 
				
			||||||
        </BaseInputGrid>
 | 
					        </BaseInputGrid>
 | 
				
			||||||
      </div>
 | 
					      </div>
 | 
				
			||||||
      <div
 | 
					      <BaseModalFooter>
 | 
				
			||||||
        class="z-0 flex justify-end p-4 border-t border-gray-200 border-solid"
 | 
					 | 
				
			||||||
      >
 | 
					 | 
				
			||||||
        <BaseButton
 | 
					        <BaseButton
 | 
				
			||||||
          class="mr-3"
 | 
					          class="mr-3"
 | 
				
			||||||
          variant="primary-outline"
 | 
					          variant="primary-outline"
 | 
				
			||||||
@ -93,7 +91,7 @@
 | 
				
			|||||||
          </template>
 | 
					          </template>
 | 
				
			||||||
          {{ $t('general.preview') }}
 | 
					          {{ $t('general.preview') }}
 | 
				
			||||||
        </BaseButton>
 | 
					        </BaseButton>
 | 
				
			||||||
      </div>
 | 
					      </BaseModalFooter>
 | 
				
			||||||
    </form>
 | 
					    </form>
 | 
				
			||||||
    <div v-else>
 | 
					    <div v-else>
 | 
				
			||||||
      <div class="my-6 mx-4 border border-gray-200 relative">
 | 
					      <div class="my-6 mx-4 border border-gray-200 relative">
 | 
				
			||||||
@ -114,9 +112,7 @@
 | 
				
			|||||||
          style="min-height: 500px"
 | 
					          style="min-height: 500px"
 | 
				
			||||||
        ></iframe>
 | 
					        ></iframe>
 | 
				
			||||||
      </div>
 | 
					      </div>
 | 
				
			||||||
      <div
 | 
					      <BaseModalFooter>
 | 
				
			||||||
        class="z-0 flex justify-end p-4 border-t border-gray-200 border-solid"
 | 
					 | 
				
			||||||
      >
 | 
					 | 
				
			||||||
        <BaseButton
 | 
					        <BaseButton
 | 
				
			||||||
          class="mr-3"
 | 
					          class="mr-3"
 | 
				
			||||||
          variant="primary-outline"
 | 
					          variant="primary-outline"
 | 
				
			||||||
@ -140,7 +136,7 @@
 | 
				
			|||||||
          />
 | 
					          />
 | 
				
			||||||
          {{ $t('general.send') }}
 | 
					          {{ $t('general.send') }}
 | 
				
			||||||
        </BaseButton>
 | 
					        </BaseButton>
 | 
				
			||||||
      </div>
 | 
					      </BaseModalFooter>
 | 
				
			||||||
    </div>
 | 
					    </div>
 | 
				
			||||||
  </BaseModal>
 | 
					  </BaseModal>
 | 
				
			||||||
</template>
 | 
					</template>
 | 
				
			||||||
 | 
				
			|||||||
@ -65,9 +65,7 @@
 | 
				
			|||||||
          </BaseInputGroup>
 | 
					          </BaseInputGroup>
 | 
				
			||||||
        </BaseInputGrid>
 | 
					        </BaseInputGrid>
 | 
				
			||||||
      </div>
 | 
					      </div>
 | 
				
			||||||
      <div
 | 
					      <BaseModalFooter>
 | 
				
			||||||
        class="z-0 flex justify-end p-4 border-t border-gray-200 border-solid"
 | 
					 | 
				
			||||||
      >
 | 
					 | 
				
			||||||
        <BaseButton
 | 
					        <BaseButton
 | 
				
			||||||
          class="mr-3"
 | 
					          class="mr-3"
 | 
				
			||||||
          variant="primary-outline"
 | 
					          variant="primary-outline"
 | 
				
			||||||
@ -93,7 +91,7 @@
 | 
				
			|||||||
          </template>
 | 
					          </template>
 | 
				
			||||||
          {{ $t('general.preview') }}
 | 
					          {{ $t('general.preview') }}
 | 
				
			||||||
        </BaseButton>
 | 
					        </BaseButton>
 | 
				
			||||||
      </div>
 | 
					      </BaseModalFooter>
 | 
				
			||||||
    </form>
 | 
					    </form>
 | 
				
			||||||
    <div v-else>
 | 
					    <div v-else>
 | 
				
			||||||
      <div class="my-6 mx-4 border border-gray-200 relative">
 | 
					      <div class="my-6 mx-4 border border-gray-200 relative">
 | 
				
			||||||
@ -114,9 +112,7 @@
 | 
				
			|||||||
          style="min-height: 500px"
 | 
					          style="min-height: 500px"
 | 
				
			||||||
        ></iframe>
 | 
					        ></iframe>
 | 
				
			||||||
      </div>
 | 
					      </div>
 | 
				
			||||||
      <div
 | 
					      <BaseModalFooter>
 | 
				
			||||||
        class="z-0 flex justify-end p-4 border-t border-gray-200 border-solid"
 | 
					 | 
				
			||||||
      >
 | 
					 | 
				
			||||||
        <BaseButton
 | 
					        <BaseButton
 | 
				
			||||||
          class="mr-3"
 | 
					          class="mr-3"
 | 
				
			||||||
          variant="primary-outline"
 | 
					          variant="primary-outline"
 | 
				
			||||||
@ -140,7 +136,7 @@
 | 
				
			|||||||
          />
 | 
					          />
 | 
				
			||||||
          {{ $t('general.send') }}
 | 
					          {{ $t('general.send') }}
 | 
				
			||||||
        </BaseButton>
 | 
					        </BaseButton>
 | 
				
			||||||
      </div>
 | 
					      </BaseModalFooter>
 | 
				
			||||||
    </div>
 | 
					    </div>
 | 
				
			||||||
  </BaseModal>
 | 
					  </BaseModal>
 | 
				
			||||||
</template>
 | 
					</template>
 | 
				
			||||||
 | 
				
			|||||||
@ -90,15 +90,7 @@
 | 
				
			|||||||
          </BaseInputGroup>
 | 
					          </BaseInputGroup>
 | 
				
			||||||
        </BaseInputGrid>
 | 
					        </BaseInputGrid>
 | 
				
			||||||
      </div>
 | 
					      </div>
 | 
				
			||||||
      <div
 | 
					      <BaseModalFooter>
 | 
				
			||||||
        class="
 | 
					 | 
				
			||||||
          z-0
 | 
					 | 
				
			||||||
          flex
 | 
					 | 
				
			||||||
          justify-end
 | 
					 | 
				
			||||||
          p-4
 | 
					 | 
				
			||||||
          border-t border-solid border--200 border-modal-bg
 | 
					 | 
				
			||||||
        "
 | 
					 | 
				
			||||||
      >
 | 
					 | 
				
			||||||
        <BaseButton
 | 
					        <BaseButton
 | 
				
			||||||
          class="mr-3 text-sm"
 | 
					          class="mr-3 text-sm"
 | 
				
			||||||
          variant="primary-outline"
 | 
					          variant="primary-outline"
 | 
				
			||||||
@ -122,7 +114,7 @@
 | 
				
			|||||||
          </template>
 | 
					          </template>
 | 
				
			||||||
          {{ taxTypeStore.isEdit ? $t('general.update') : $t('general.save') }}
 | 
					          {{ taxTypeStore.isEdit ? $t('general.update') : $t('general.save') }}
 | 
				
			||||||
        </BaseButton>
 | 
					        </BaseButton>
 | 
				
			||||||
      </div>
 | 
					      </BaseModalFooter>
 | 
				
			||||||
    </form>
 | 
					    </form>
 | 
				
			||||||
  </BaseModal>
 | 
					  </BaseModal>
 | 
				
			||||||
</template>
 | 
					</template>
 | 
				
			||||||
 | 
				
			|||||||
@ -87,9 +87,7 @@
 | 
				
			|||||||
        </BaseInputGrid>
 | 
					        </BaseInputGrid>
 | 
				
			||||||
      </div>
 | 
					      </div>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
      <div
 | 
					      <BaseModalFooter>
 | 
				
			||||||
        class="z-0 flex justify-end p-4 border-t border-gray-200 border-solid"
 | 
					 | 
				
			||||||
      >
 | 
					 | 
				
			||||||
        <BaseButton
 | 
					        <BaseButton
 | 
				
			||||||
          class="mr-3 text-sm"
 | 
					          class="mr-3 text-sm"
 | 
				
			||||||
          type="button"
 | 
					          type="button"
 | 
				
			||||||
@ -109,7 +107,7 @@
 | 
				
			|||||||
          </template>
 | 
					          </template>
 | 
				
			||||||
          {{ $t('general.save') }}
 | 
					          {{ $t('general.save') }}
 | 
				
			||||||
        </BaseButton>
 | 
					        </BaseButton>
 | 
				
			||||||
      </div>
 | 
					      </BaseModalFooter>
 | 
				
			||||||
    </form>
 | 
					    </form>
 | 
				
			||||||
  </BaseModal>
 | 
					  </BaseModal>
 | 
				
			||||||
</template>
 | 
					</template>
 | 
				
			||||||
 | 
				
			|||||||
@ -172,15 +172,7 @@
 | 
				
			|||||||
        </div>
 | 
					        </div>
 | 
				
			||||||
      </div>
 | 
					      </div>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
      <div
 | 
					      <BaseModalFooter>
 | 
				
			||||||
        class="
 | 
					 | 
				
			||||||
          z-0
 | 
					 | 
				
			||||||
          flex
 | 
					 | 
				
			||||||
          justify-end
 | 
					 | 
				
			||||||
          p-4
 | 
					 | 
				
			||||||
          border-t border-solid border-gray-light border-modal-bg
 | 
					 | 
				
			||||||
        "
 | 
					 | 
				
			||||||
      >
 | 
					 | 
				
			||||||
        <BaseButton
 | 
					        <BaseButton
 | 
				
			||||||
          class="mr-3"
 | 
					          class="mr-3"
 | 
				
			||||||
          type="button"
 | 
					          type="button"
 | 
				
			||||||
@ -207,7 +199,7 @@
 | 
				
			|||||||
            !customFieldStore.isEdit ? $t('general.save') : $t('general.update')
 | 
					            !customFieldStore.isEdit ? $t('general.save') : $t('general.update')
 | 
				
			||||||
          }}
 | 
					          }}
 | 
				
			||||||
        </BaseButton>
 | 
					        </BaseButton>
 | 
				
			||||||
      </div>
 | 
					      </BaseModalFooter>
 | 
				
			||||||
    </form>
 | 
					    </form>
 | 
				
			||||||
  </BaseModal>
 | 
					  </BaseModal>
 | 
				
			||||||
</template>
 | 
					</template>
 | 
				
			||||||
 | 
				
			|||||||
@ -153,7 +153,7 @@
 | 
				
			|||||||
          <BaseSwitch v-model="set_as_default" class="flex" />
 | 
					          <BaseSwitch v-model="set_as_default" class="flex" />
 | 
				
			||||||
        </div>
 | 
					        </div>
 | 
				
			||||||
        <div class="ml-4 right">
 | 
					        <div class="ml-4 right">
 | 
				
			||||||
          <p class="p-0 mb-1 text-base leading-snug text-black box-title">
 | 
					          <p class="p-0 mb-1 text-base leading-snug text-black dark:text-white box-title">
 | 
				
			||||||
            {{ $t('settings.disk.is_default') }}
 | 
					            {{ $t('settings.disk.is_default') }}
 | 
				
			||||||
          </p>
 | 
					          </p>
 | 
				
			||||||
        </div>
 | 
					        </div>
 | 
				
			||||||
 | 
				
			|||||||
@ -132,7 +132,7 @@
 | 
				
			|||||||
          <BaseSwitch v-model="set_as_default" class="flex" />
 | 
					          <BaseSwitch v-model="set_as_default" class="flex" />
 | 
				
			||||||
        </div>
 | 
					        </div>
 | 
				
			||||||
        <div class="ml-4 right">
 | 
					        <div class="ml-4 right">
 | 
				
			||||||
          <p class="p-0 mb-1 text-base leading-snug text-black box-title">
 | 
					          <p class="p-0 mb-1 text-base leading-snug text-black dark:text-white box-title">
 | 
				
			||||||
            {{ $t('settings.disk.is_default') }}
 | 
					            {{ $t('settings.disk.is_default') }}
 | 
				
			||||||
          </p>
 | 
					          </p>
 | 
				
			||||||
        </div>
 | 
					        </div>
 | 
				
			||||||
 | 
				
			|||||||
@ -63,7 +63,7 @@
 | 
				
			|||||||
        </div>
 | 
					        </div>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        <div class="ml-4 right">
 | 
					        <div class="ml-4 right">
 | 
				
			||||||
          <p class="p-0 mb-1 text-base leading-snug text-black box-title">
 | 
					          <p class="p-0 mb-1 text-base leading-snug text-black dark:text-white box-title">
 | 
				
			||||||
            {{ $t('settings.disk.is_default') }}
 | 
					            {{ $t('settings.disk.is_default') }}
 | 
				
			||||||
          </p>
 | 
					          </p>
 | 
				
			||||||
        </div>
 | 
					        </div>
 | 
				
			||||||
 | 
				
			|||||||
@ -134,7 +134,7 @@
 | 
				
			|||||||
          <BaseSwitch v-model="set_as_default" class="flex" />
 | 
					          <BaseSwitch v-model="set_as_default" class="flex" />
 | 
				
			||||||
        </div>
 | 
					        </div>
 | 
				
			||||||
        <div class="ml-4 right">
 | 
					        <div class="ml-4 right">
 | 
				
			||||||
          <p class="p-0 mb-1 text-base leading-snug text-black box-title">
 | 
					          <p class="p-0 mb-1 text-base leading-snug text-black dark:text-white box-title">
 | 
				
			||||||
            {{ $t('settings.disk.is_default') }}
 | 
					            {{ $t('settings.disk.is_default') }}
 | 
				
			||||||
          </p>
 | 
					          </p>
 | 
				
			||||||
        </div>
 | 
					        </div>
 | 
				
			||||||
 | 
				
			|||||||
@ -1,5 +1,5 @@
 | 
				
			|||||||
<template>
 | 
					<template>
 | 
				
			||||||
  <div class="grid h-screen grid-cols-12 overflow-y-hidden bg-gray-100">
 | 
					  <div class="grid h-screen grid-cols-12 overflow-y-hidden bg-gray-100 dark:bg-gray-900">
 | 
				
			||||||
    <NotificationRoot />
 | 
					    <NotificationRoot />
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    <div
 | 
					    <div
 | 
				
			||||||
 | 
				
			|||||||
@ -24,6 +24,8 @@
 | 
				
			|||||||
      dark:border-white/10
 | 
					      dark:border-white/10
 | 
				
			||||||
    "
 | 
					    "
 | 
				
			||||||
  >
 | 
					  >
 | 
				
			||||||
 | 
					    <BaseDarkHighlight />
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    <router-link
 | 
					    <router-link
 | 
				
			||||||
      to="/admin/dashboard"
 | 
					      to="/admin/dashboard"
 | 
				
			||||||
      class="
 | 
					      class="
 | 
				
			||||||
@ -72,7 +74,7 @@
 | 
				
			|||||||
        v-if="hasCreateAbilities"
 | 
					        v-if="hasCreateAbilities"
 | 
				
			||||||
        class="relative hidden float-left m-0 md:block"
 | 
					        class="relative hidden float-left m-0 md:block"
 | 
				
			||||||
      >
 | 
					      >
 | 
				
			||||||
        <BaseDropdown width-class="w-48">
 | 
					        <BaseDropdown width-class="w-48" >
 | 
				
			||||||
          <template #activator>
 | 
					          <template #activator>
 | 
				
			||||||
            <div
 | 
					            <div
 | 
				
			||||||
              class="
 | 
					              class="
 | 
				
			||||||
@ -86,19 +88,21 @@
 | 
				
			|||||||
                bg-white
 | 
					                bg-white
 | 
				
			||||||
                rounded
 | 
					                rounded
 | 
				
			||||||
                md:h-9 md:w-9
 | 
					                md:h-9 md:w-9
 | 
				
			||||||
 | 
					                dark:bg-gray-700 dark:border-gray-500 dark:border
 | 
				
			||||||
              "
 | 
					              "
 | 
				
			||||||
            >
 | 
					            >
 | 
				
			||||||
              <BaseIcon name="PlusIcon" class="w-5 h-5 text-gray-600" />
 | 
					              <BaseIcon name="PlusIcon" class="w-5 h-5 text-gray-600 dark:text-white" />
 | 
				
			||||||
            </div>
 | 
					            </div>
 | 
				
			||||||
          </template>
 | 
					          </template>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
          <router-link to="/admin/invoices/create">
 | 
					          <router-link to="/admin/invoices/create">
 | 
				
			||||||
            <BaseDropdownItem
 | 
					            <BaseDropdownItem
 | 
				
			||||||
              v-if="userStore.hasAbilities(abilities.CREATE_INVOICE)"
 | 
					              v-if="userStore.hasAbilities(abilities.CREATE_INVOICE)"
 | 
				
			||||||
 | 
					              v-slot="slotProps"
 | 
				
			||||||
            >
 | 
					            >
 | 
				
			||||||
              <BaseIcon
 | 
					              <BaseIcon
 | 
				
			||||||
                name="DocumentTextIcon"
 | 
					                name="DocumentTextIcon"
 | 
				
			||||||
                class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					                :class="slotProps.class"
 | 
				
			||||||
                aria-hidden="true"
 | 
					                aria-hidden="true"
 | 
				
			||||||
              />
 | 
					              />
 | 
				
			||||||
              {{ $t('invoices.new_invoice') }}
 | 
					              {{ $t('invoices.new_invoice') }}
 | 
				
			||||||
@ -107,10 +111,11 @@
 | 
				
			|||||||
          <router-link to="/admin/estimates/create">
 | 
					          <router-link to="/admin/estimates/create">
 | 
				
			||||||
            <BaseDropdownItem
 | 
					            <BaseDropdownItem
 | 
				
			||||||
              v-if="userStore.hasAbilities(abilities.CREATE_ESTIMATE)"
 | 
					              v-if="userStore.hasAbilities(abilities.CREATE_ESTIMATE)"
 | 
				
			||||||
 | 
					              v-slot="slotProps"
 | 
				
			||||||
            >
 | 
					            >
 | 
				
			||||||
              <BaseIcon
 | 
					              <BaseIcon
 | 
				
			||||||
                name="DocumentIcon"
 | 
					                name="DocumentIcon"
 | 
				
			||||||
                class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					                :class="slotProps.class"
 | 
				
			||||||
                aria-hidden="true"
 | 
					                aria-hidden="true"
 | 
				
			||||||
              />
 | 
					              />
 | 
				
			||||||
              {{ $t('estimates.new_estimate') }}
 | 
					              {{ $t('estimates.new_estimate') }}
 | 
				
			||||||
@ -120,10 +125,11 @@
 | 
				
			|||||||
          <router-link to="/admin/customers/create">
 | 
					          <router-link to="/admin/customers/create">
 | 
				
			||||||
            <BaseDropdownItem
 | 
					            <BaseDropdownItem
 | 
				
			||||||
              v-if="userStore.hasAbilities(abilities.CREATE_CUSTOMER)"
 | 
					              v-if="userStore.hasAbilities(abilities.CREATE_CUSTOMER)"
 | 
				
			||||||
 | 
					              v-slot="slotProps"
 | 
				
			||||||
            >
 | 
					            >
 | 
				
			||||||
              <BaseIcon
 | 
					              <BaseIcon
 | 
				
			||||||
                name="UserIcon"
 | 
					                name="UserIcon"
 | 
				
			||||||
                class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					                :class="slotProps.class"
 | 
				
			||||||
                aria-hidden="true"
 | 
					                aria-hidden="true"
 | 
				
			||||||
              />
 | 
					              />
 | 
				
			||||||
              {{ $t('customers.new_customer') }}
 | 
					              {{ $t('customers.new_customer') }}
 | 
				
			||||||
@ -156,20 +162,20 @@
 | 
				
			|||||||
          </template>
 | 
					          </template>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
          <router-link to="/admin/settings/account-settings">
 | 
					          <router-link to="/admin/settings/account-settings">
 | 
				
			||||||
            <BaseDropdownItem>
 | 
					            <BaseDropdownItem v-slot="slotProps">
 | 
				
			||||||
              <BaseIcon
 | 
					              <BaseIcon
 | 
				
			||||||
                name="CogIcon"
 | 
					                name="CogIcon"
 | 
				
			||||||
                class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					                :class="slotProps.class"
 | 
				
			||||||
                aria-hidden="true"
 | 
					                aria-hidden="true"
 | 
				
			||||||
              />
 | 
					              />
 | 
				
			||||||
              {{ $t('navigation.settings') }}
 | 
					              {{ $t('navigation.settings') }}
 | 
				
			||||||
            </BaseDropdownItem>
 | 
					            </BaseDropdownItem>
 | 
				
			||||||
          </router-link>
 | 
					          </router-link>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
          <BaseDropdownItem @click="logout">
 | 
					          <BaseDropdownItem v-slot="slotProps" @click="logout">
 | 
				
			||||||
            <BaseIcon
 | 
					            <BaseIcon
 | 
				
			||||||
              name="LogoutIcon"
 | 
					              name="LogoutIcon"
 | 
				
			||||||
              class="w-5 h-5 mr-3 text-gray-400 group-hover:text-gray-500"
 | 
					              :class="slotProps.class"
 | 
				
			||||||
              aria-hidden="true"
 | 
					              aria-hidden="true"
 | 
				
			||||||
            />
 | 
					            />
 | 
				
			||||||
            {{ $t('navigation.logout') }}
 | 
					            {{ $t('navigation.logout') }}
 | 
				
			||||||
 | 
				
			|||||||
@ -32,7 +32,7 @@
 | 
				
			|||||||
    <div class="mt-4 mb-4 text-sm">
 | 
					    <div class="mt-4 mb-4 text-sm">
 | 
				
			||||||
      <router-link
 | 
					      <router-link
 | 
				
			||||||
        to="/login"
 | 
					        to="/login"
 | 
				
			||||||
        class="text-sm text-primary-400 hover:text-gray-700"
 | 
					        class="text-sm text-primary-400 hover:text-gray-700 dark:hover:text-primary-500"
 | 
				
			||||||
      >
 | 
					      >
 | 
				
			||||||
        {{ $t('general.back_to_login') }}
 | 
					        {{ $t('general.back_to_login') }}
 | 
				
			||||||
      </router-link>
 | 
					      </router-link>
 | 
				
			||||||
 | 
				
			|||||||
@ -49,7 +49,7 @@
 | 
				
			|||||||
      <div class="mb-4">
 | 
					      <div class="mb-4">
 | 
				
			||||||
        <router-link
 | 
					        <router-link
 | 
				
			||||||
          to="forgot-password"
 | 
					          to="forgot-password"
 | 
				
			||||||
          class="text-sm text-primary-400 hover:text-gray-700"
 | 
					          class="text-sm text-primary-400 hover:text-gray-700 dark:hover:text-primary-500"
 | 
				
			||||||
        >
 | 
					        >
 | 
				
			||||||
          {{ $t('login.forgot_password') }}
 | 
					          {{ $t('login.forgot_password') }}
 | 
				
			||||||
        </router-link>
 | 
					        </router-link>
 | 
				
			||||||
 | 
				
			|||||||
@ -171,7 +171,7 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
          <BaseInputGrid class="col-span-5 lg:col-span-4">
 | 
					          <BaseInputGrid class="col-span-5 lg:col-span-4">
 | 
				
			||||||
            <div class="md:col-span-2">
 | 
					            <div class="md:col-span-2">
 | 
				
			||||||
              <p class="text-sm text-gray-500">
 | 
					              <p class="text-sm text-gray-500 dark:text-gray-300">
 | 
				
			||||||
                {{ $t('customers.portal_access_text') }}
 | 
					                {{ $t('customers.portal_access_text') }}
 | 
				
			||||||
              </p>
 | 
					              </p>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
				
			|||||||
@ -1,5 +1,5 @@
 | 
				
			|||||||
<template>
 | 
					<template>
 | 
				
			||||||
  <div class="pt-6 mt-5 border-t border-solid lg:pt-8 md:pt-4 border-gray-200">
 | 
					  <div class="pt-6 mt-5 border-t border-solid lg:pt-8 md:pt-4 border-gray-200 dark:border-gray-600">
 | 
				
			||||||
    <!-- Basic Info -->
 | 
					    <!-- Basic Info -->
 | 
				
			||||||
    <BaseHeading>
 | 
					    <BaseHeading>
 | 
				
			||||||
      {{ $t('customers.basic_info') }}
 | 
					      {{ $t('customers.basic_info') }}
 | 
				
			||||||
 | 
				
			|||||||
@ -2,8 +2,23 @@
 | 
				
			|||||||
  <div>
 | 
					  <div>
 | 
				
			||||||
    <div
 | 
					    <div
 | 
				
			||||||
      v-if="dashboardStore.isDashboardDataLoaded"
 | 
					      v-if="dashboardStore.isDashboardDataLoaded"
 | 
				
			||||||
      class="grid grid-cols-10 mt-8 bg-white rounded shadow"
 | 
					      class="
 | 
				
			||||||
 | 
					        grid
 | 
				
			||||||
 | 
					        grid-cols-10
 | 
				
			||||||
 | 
					        mt-8
 | 
				
			||||||
 | 
					        bg-white
 | 
				
			||||||
 | 
					        rounded shadow
 | 
				
			||||||
 | 
					        dark:text-white
 | 
				
			||||||
 | 
					        dark:backdrop-blur-xl
 | 
				
			||||||
 | 
					        dark:shadow-glass
 | 
				
			||||||
 | 
					        dark:border
 | 
				
			||||||
 | 
					        dark:bg-opacity-70
 | 
				
			||||||
 | 
					        dark:border-white/10
 | 
				
			||||||
 | 
					        dark:bg-gray-800
 | 
				
			||||||
 | 
					        relative
 | 
				
			||||||
 | 
					      "
 | 
				
			||||||
    >
 | 
					    >
 | 
				
			||||||
 | 
					      <BaseDarkHighlight />
 | 
				
			||||||
      <!-- Chart -->
 | 
					      <!-- Chart -->
 | 
				
			||||||
      <div
 | 
					      <div
 | 
				
			||||||
        class="
 | 
					        class="
 | 
				
			||||||
@ -54,6 +69,7 @@
 | 
				
			|||||||
          lg:border-t-0 lg:text-right lg:col-span-3
 | 
					          lg:border-t-0 lg:text-right lg:col-span-3
 | 
				
			||||||
          xl:col-span-2
 | 
					          xl:col-span-2
 | 
				
			||||||
          lg:grid-cols-1
 | 
					          lg:grid-cols-1
 | 
				
			||||||
 | 
					          dark:border-white/10
 | 
				
			||||||
        "
 | 
					        "
 | 
				
			||||||
      >
 | 
					      >
 | 
				
			||||||
        <div class="p-6">
 | 
					        <div class="p-6">
 | 
				
			||||||
@ -96,15 +112,7 @@
 | 
				
			|||||||
          </span>
 | 
					          </span>
 | 
				
			||||||
          <br />
 | 
					          <br />
 | 
				
			||||||
          <span
 | 
					          <span
 | 
				
			||||||
            class="
 | 
					            class="block mt-1 text-xl font-semibold leading-8 lg:text-2xl text-red-400"
 | 
				
			||||||
              block
 | 
					 | 
				
			||||||
              mt-1
 | 
					 | 
				
			||||||
              text-xl
 | 
					 | 
				
			||||||
              font-semibold
 | 
					 | 
				
			||||||
              leading-8
 | 
					 | 
				
			||||||
              lg:text-2xl
 | 
					 | 
				
			||||||
              text-red-400
 | 
					 | 
				
			||||||
            "
 | 
					 | 
				
			||||||
          >
 | 
					          >
 | 
				
			||||||
            <BaseFormatMoney
 | 
					            <BaseFormatMoney
 | 
				
			||||||
              :amount="dashboardStore.totalExpenses"
 | 
					              :amount="dashboardStore.totalExpenses"
 | 
				
			||||||
@ -116,8 +124,10 @@
 | 
				
			|||||||
          class="
 | 
					          class="
 | 
				
			||||||
            col-span-3
 | 
					            col-span-3
 | 
				
			||||||
            p-6
 | 
					            p-6
 | 
				
			||||||
            border-t border-gray-200 border-solid
 | 
					            border-t
 | 
				
			||||||
 | 
					            border-gray-200 border-solid
 | 
				
			||||||
            lg:col-span-1
 | 
					            lg:col-span-1
 | 
				
			||||||
 | 
					            dark:border-white/10
 | 
				
			||||||
          "
 | 
					          "
 | 
				
			||||||
        >
 | 
					        >
 | 
				
			||||||
          <span class="text-xs leading-5 lg:text-sm">
 | 
					          <span class="text-xs leading-5 lg:text-sm">
 | 
				
			||||||
@ -132,7 +142,7 @@
 | 
				
			|||||||
              font-semibold
 | 
					              font-semibold
 | 
				
			||||||
              leading-8
 | 
					              leading-8
 | 
				
			||||||
              lg:text-2xl
 | 
					              lg:text-2xl
 | 
				
			||||||
              text-primary-500
 | 
					              text-primary-500 dark:text-primary-400
 | 
				
			||||||
            "
 | 
					            "
 | 
				
			||||||
          >
 | 
					          >
 | 
				
			||||||
            <BaseFormatMoney
 | 
					            <BaseFormatMoney
 | 
				
			||||||
 | 
				
			|||||||
@ -1,6 +1,6 @@
 | 
				
			|||||||
<template>
 | 
					<template>
 | 
				
			||||||
  <BaseContentPlaceholders
 | 
					  <BaseContentPlaceholders
 | 
				
			||||||
    class="grid grid-cols-10 mt-8 bg-white rounded shadow"
 | 
					    class="grid grid-cols-10 mt-8 bg-white rounded shadow dark:bg-gray-800"
 | 
				
			||||||
  >
 | 
					  >
 | 
				
			||||||
    <!-- Chart -->
 | 
					    <!-- Chart -->
 | 
				
			||||||
    <div
 | 
					    <div
 | 
				
			||||||
@ -29,6 +29,7 @@
 | 
				
			|||||||
        text-center
 | 
					        text-center
 | 
				
			||||||
        border-t border-l border-gray-200 border-solid
 | 
					        border-t border-l border-gray-200 border-solid
 | 
				
			||||||
        lg:border-t-0 lg:text-right lg:col-span-3
 | 
					        lg:border-t-0 lg:text-right lg:col-span-3
 | 
				
			||||||
 | 
					        dark:border-gray-600
 | 
				
			||||||
        xl:col-span-2
 | 
					        xl:col-span-2
 | 
				
			||||||
        lg:grid-cols-1
 | 
					        lg:grid-cols-1
 | 
				
			||||||
      "
 | 
					      "
 | 
				
			||||||
@ -77,6 +78,7 @@
 | 
				
			|||||||
          col-span-3
 | 
					          col-span-3
 | 
				
			||||||
          p-6
 | 
					          p-6
 | 
				
			||||||
          border-t border-gray-200 border-solid
 | 
					          border-t border-gray-200 border-solid
 | 
				
			||||||
 | 
					          dark:border-gray-600
 | 
				
			||||||
          lg:justify-end lg:items-end lg:col-span-1
 | 
					          lg:justify-end lg:items-end lg:col-span-1
 | 
				
			||||||
        "
 | 
					        "
 | 
				
			||||||
      >
 | 
					      >
 | 
				
			||||||
 | 
				
			|||||||
@ -12,18 +12,24 @@
 | 
				
			|||||||
      hover:bg-gray-50
 | 
					      hover:bg-gray-50
 | 
				
			||||||
      xl:p-4
 | 
					      xl:p-4
 | 
				
			||||||
      lg:col-span-2
 | 
					      lg:col-span-2
 | 
				
			||||||
 | 
					      dark:backdrop-blur-xl
 | 
				
			||||||
 | 
					      dark:shadow-glass
 | 
				
			||||||
 | 
					      dark:border
 | 
				
			||||||
 | 
					      dark:border-white/10
 | 
				
			||||||
 | 
					      dark:bg-gray-800/70
 | 
				
			||||||
    "
 | 
					    "
 | 
				
			||||||
    :class="{ 'lg:!col-span-3': large }"
 | 
					    :class="{ 'lg:!col-span-3': large }"
 | 
				
			||||||
    :to="route"
 | 
					    :to="route"
 | 
				
			||||||
  >
 | 
					  >
 | 
				
			||||||
    <div>
 | 
					    <div>
 | 
				
			||||||
      <span class="text-xl font-semibold leading-tight text-black xl:text-3xl">
 | 
					      <span class="text-xl font-semibold leading-tight text-black xl:text-3xl dark:text-white">
 | 
				
			||||||
        <slot />
 | 
					        <slot />
 | 
				
			||||||
      </span>
 | 
					      </span>
 | 
				
			||||||
      <span class="block mt-1 text-sm leading-tight text-gray-500 xl:text-lg">
 | 
					      <span class="block mt-1 text-sm leading-tight text-gray-500 xl:text-lg dark:text-gray-300">
 | 
				
			||||||
        {{ label }}
 | 
					        {{ label }}
 | 
				
			||||||
      </span>
 | 
					      </span>
 | 
				
			||||||
    </div>
 | 
					    </div>
 | 
				
			||||||
 | 
					    <BaseDarkHighlight class="!bg-highlight/[.17] !top-5" />
 | 
				
			||||||
    <div class="flex items-center">
 | 
					    <div class="flex items-center">
 | 
				
			||||||
      <component :is="iconComponent" class="w-10 h-10 xl:w-12 xl:h-12" />
 | 
					      <component :is="iconComponent" class="w-10 h-10 xl:w-12 xl:h-12" />
 | 
				
			||||||
    </div>
 | 
					    </div>
 | 
				
			||||||
 | 
				
			|||||||
@ -1,7 +1,7 @@
 | 
				
			|||||||
<template>
 | 
					<template>
 | 
				
			||||||
  <BaseContentPlaceholders
 | 
					  <BaseContentPlaceholders
 | 
				
			||||||
    :rounded="true"
 | 
					    :rounded="true"
 | 
				
			||||||
    class="relative flex justify-between w-full p-3 bg-white rounded shadow lg:col-span-3 xl:p-4"
 | 
					    class="relative flex justify-between w-full p-3 bg-white rounded shadow lg:col-span-3 xl:p-4 dark:bg-gray-800"
 | 
				
			||||||
  >
 | 
					  >
 | 
				
			||||||
    <div>
 | 
					    <div>
 | 
				
			||||||
      <BaseContentPlaceholdersText
 | 
					      <BaseContentPlaceholdersText
 | 
				
			||||||
 | 
				
			|||||||
@ -12,6 +12,7 @@
 | 
				
			|||||||
      shadow
 | 
					      shadow
 | 
				
			||||||
      lg:col-span-2
 | 
					      lg:col-span-2
 | 
				
			||||||
      xl:p-4
 | 
					      xl:p-4
 | 
				
			||||||
 | 
					      dark:bg-gray-800
 | 
				
			||||||
    "
 | 
					    "
 | 
				
			||||||
  >
 | 
					  >
 | 
				
			||||||
    <div>
 | 
					    <div>
 | 
				
			||||||
 | 
				
			|||||||
@ -130,6 +130,7 @@
 | 
				
			|||||||
          mt-5
 | 
					          mt-5
 | 
				
			||||||
          list-none
 | 
					          list-none
 | 
				
			||||||
          border-b-2 border-gray-200 border-solid
 | 
					          border-b-2 border-gray-200 border-solid
 | 
				
			||||||
 | 
					          dark:border-gray-600
 | 
				
			||||||
        "
 | 
					        "
 | 
				
			||||||
      >
 | 
					      >
 | 
				
			||||||
        <!-- Tabs -->
 | 
					        <!-- Tabs -->
 | 
				
			||||||
 | 
				
			|||||||
@ -50,6 +50,7 @@
 | 
				
			|||||||
        xl:ml-64
 | 
					        xl:ml-64
 | 
				
			||||||
        w-88
 | 
					        w-88
 | 
				
			||||||
        xl:block
 | 
					        xl:block
 | 
				
			||||||
 | 
					        dark:bg-gray-800
 | 
				
			||||||
      "
 | 
					      "
 | 
				
			||||||
    >
 | 
					    >
 | 
				
			||||||
      <div
 | 
					      <div
 | 
				
			||||||
@ -62,6 +63,7 @@
 | 
				
			|||||||
          pb-2
 | 
					          pb-2
 | 
				
			||||||
          border border-gray-200 border-solid
 | 
					          border border-gray-200 border-solid
 | 
				
			||||||
          height-full
 | 
					          height-full
 | 
				
			||||||
 | 
					          dark:border-gray-600
 | 
				
			||||||
        "
 | 
					        "
 | 
				
			||||||
      >
 | 
					      >
 | 
				
			||||||
        <div class="mb-6">
 | 
					        <div class="mb-6">
 | 
				
			||||||
@ -96,9 +98,10 @@
 | 
				
			|||||||
                px-4
 | 
					                px-4
 | 
				
			||||||
                py-1
 | 
					                py-1
 | 
				
			||||||
                pb-2
 | 
					                pb-2
 | 
				
			||||||
                mb-1 mb-2
 | 
					                mb-2
 | 
				
			||||||
                text-sm
 | 
					                text-sm
 | 
				
			||||||
                border-b border-gray-200 border-solid
 | 
					                border-b border-gray-200 border-solid
 | 
				
			||||||
 | 
					                dark:border-gray-600
 | 
				
			||||||
              "
 | 
					              "
 | 
				
			||||||
            >
 | 
					            >
 | 
				
			||||||
              {{ $t('general.sort_by') }}
 | 
					              {{ $t('general.sort_by') }}
 | 
				
			||||||
@ -161,6 +164,7 @@
 | 
				
			|||||||
          overflow-y-scroll
 | 
					          overflow-y-scroll
 | 
				
			||||||
          border-l border-gray-200 border-solid
 | 
					          border-l border-gray-200 border-solid
 | 
				
			||||||
          base-scroll
 | 
					          base-scroll
 | 
				
			||||||
 | 
					          dark:border-gray-600
 | 
				
			||||||
        "
 | 
					        "
 | 
				
			||||||
      >
 | 
					      >
 | 
				
			||||||
        <div v-for="(estimate, index) in estimateList" :key="index">
 | 
					        <div v-for="(estimate, index) in estimateList" :key="index">
 | 
				
			||||||
@ -169,9 +173,9 @@
 | 
				
			|||||||
            :id="'estimate-' + estimate.id"
 | 
					            :id="'estimate-' + estimate.id"
 | 
				
			||||||
            :to="`/admin/estimates/${estimate.id}/view`"
 | 
					            :to="`/admin/estimates/${estimate.id}/view`"
 | 
				
			||||||
            :class="[
 | 
					            :class="[
 | 
				
			||||||
              'flex justify-between side-estimate p-4 cursor-pointer hover:bg-gray-100 items-center border-l-4 border-transparent',
 | 
					              'flex justify-between side-estimate p-4 cursor-pointer hover:bg-gray-100 items-center border-l-4 border-transparent dark:hover:bg-gray-700',
 | 
				
			||||||
              {
 | 
					              {
 | 
				
			||||||
                'bg-gray-100 border-l-4 border-primary-500 border-solid':
 | 
					                'bg-gray-100 border-l-4 border-primary-500 border-solid dark:border-primary-400 dark:bg-gray-700':
 | 
				
			||||||
                  hasActiveUrl(estimate.id),
 | 
					                  hasActiveUrl(estimate.id),
 | 
				
			||||||
              },
 | 
					              },
 | 
				
			||||||
            ]"
 | 
					            ]"
 | 
				
			||||||
@ -191,6 +195,7 @@
 | 
				
			|||||||
                  text-black
 | 
					                  text-black
 | 
				
			||||||
                  capitalize
 | 
					                  capitalize
 | 
				
			||||||
                  truncate
 | 
					                  truncate
 | 
				
			||||||
 | 
					                  dark:text-white
 | 
				
			||||||
                "
 | 
					                "
 | 
				
			||||||
              />
 | 
					              />
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@ -203,6 +208,7 @@
 | 
				
			|||||||
                  font-medium
 | 
					                  font-medium
 | 
				
			||||||
                  leading-5
 | 
					                  leading-5
 | 
				
			||||||
                  text-gray-600
 | 
					                  text-gray-600
 | 
				
			||||||
 | 
					                  dark:text-gray-400
 | 
				
			||||||
                "
 | 
					                "
 | 
				
			||||||
              >
 | 
					              >
 | 
				
			||||||
                {{ estimate.estimate_number }}
 | 
					                {{ estimate.estimate_number }}
 | 
				
			||||||
@ -228,6 +234,7 @@
 | 
				
			|||||||
                  font-semibold
 | 
					                  font-semibold
 | 
				
			||||||
                  leading-8
 | 
					                  leading-8
 | 
				
			||||||
                  text-right text-gray-900
 | 
					                  text-right text-gray-900
 | 
				
			||||||
 | 
					                  dark:text-white
 | 
				
			||||||
                "
 | 
					                "
 | 
				
			||||||
              />
 | 
					              />
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@ -239,6 +246,7 @@
 | 
				
			|||||||
                  leading-5
 | 
					                  leading-5
 | 
				
			||||||
                  text-right text-gray-600
 | 
					                  text-right text-gray-600
 | 
				
			||||||
                  est-date
 | 
					                  est-date
 | 
				
			||||||
 | 
					                  dark:text-gray-400
 | 
				
			||||||
                "
 | 
					                "
 | 
				
			||||||
              >
 | 
					              >
 | 
				
			||||||
                {{ estimate.formatted_estimate_date }}
 | 
					                {{ estimate.formatted_estimate_date }}
 | 
				
			||||||
@ -251,7 +259,7 @@
 | 
				
			|||||||
        </div>
 | 
					        </div>
 | 
				
			||||||
        <p
 | 
					        <p
 | 
				
			||||||
          v-if="!estimateList?.length && !isLoading"
 | 
					          v-if="!estimateList?.length && !isLoading"
 | 
				
			||||||
          class="flex justify-center px-4 mt-5 text-sm text-gray-600"
 | 
					          class="flex justify-center px-4 mt-5 text-sm text-gray-600 dark:text-gray-300"
 | 
				
			||||||
        >
 | 
					        >
 | 
				
			||||||
          {{ $t('estimates.no_matching_estimates') }}
 | 
					          {{ $t('estimates.no_matching_estimates') }}
 | 
				
			||||||
        </p>
 | 
					        </p>
 | 
				
			||||||
 | 
				
			|||||||
@ -127,6 +127,7 @@
 | 
				
			|||||||
          mt-5
 | 
					          mt-5
 | 
				
			||||||
          list-none
 | 
					          list-none
 | 
				
			||||||
          border-b-2 border-gray-200 border-solid
 | 
					          border-b-2 border-gray-200 border-solid
 | 
				
			||||||
 | 
					          dark:border-gray-600
 | 
				
			||||||
        "
 | 
					        "
 | 
				
			||||||
      >
 | 
					      >
 | 
				
			||||||
        <!-- Tabs -->
 | 
					        <!-- Tabs -->
 | 
				
			||||||
 | 
				
			|||||||
@ -299,6 +299,7 @@ onSearched = debounce(onSearched, 500)
 | 
				
			|||||||
        xl:ml-64
 | 
					        xl:ml-64
 | 
				
			||||||
        w-88
 | 
					        w-88
 | 
				
			||||||
        xl:block
 | 
					        xl:block
 | 
				
			||||||
 | 
					        dark:bg-gray-800
 | 
				
			||||||
      "
 | 
					      "
 | 
				
			||||||
    >
 | 
					    >
 | 
				
			||||||
      <div
 | 
					      <div
 | 
				
			||||||
@ -311,6 +312,7 @@ onSearched = debounce(onSearched, 500)
 | 
				
			|||||||
          pb-2
 | 
					          pb-2
 | 
				
			||||||
          border border-gray-200 border-solid
 | 
					          border border-gray-200 border-solid
 | 
				
			||||||
          height-full
 | 
					          height-full
 | 
				
			||||||
 | 
					          dark:border-gray-600
 | 
				
			||||||
        "
 | 
					        "
 | 
				
			||||||
      >
 | 
					      >
 | 
				
			||||||
        <div class="mb-6">
 | 
					        <div class="mb-6">
 | 
				
			||||||
@ -339,9 +341,10 @@ onSearched = debounce(onSearched, 500)
 | 
				
			|||||||
                px-2
 | 
					                px-2
 | 
				
			||||||
                py-1
 | 
					                py-1
 | 
				
			||||||
                pb-2
 | 
					                pb-2
 | 
				
			||||||
                mb-1 mb-2
 | 
					                mb-2
 | 
				
			||||||
                text-sm
 | 
					                text-sm
 | 
				
			||||||
                border-b border-gray-200 border-solid
 | 
					                border-b border-gray-200 border-solid
 | 
				
			||||||
 | 
					                dark:border-gray-600
 | 
				
			||||||
              "
 | 
					              "
 | 
				
			||||||
            >
 | 
					            >
 | 
				
			||||||
              {{ $t('general.sort_by') }}
 | 
					              {{ $t('general.sort_by') }}
 | 
				
			||||||
@ -404,6 +407,7 @@ onSearched = debounce(onSearched, 500)
 | 
				
			|||||||
          overflow-y-scroll
 | 
					          overflow-y-scroll
 | 
				
			||||||
          border-l border-gray-200 border-solid
 | 
					          border-l border-gray-200 border-solid
 | 
				
			||||||
          base-scroll
 | 
					          base-scroll
 | 
				
			||||||
 | 
					          dark:border-gray-600
 | 
				
			||||||
        "
 | 
					        "
 | 
				
			||||||
      >
 | 
					      >
 | 
				
			||||||
        <div v-for="(invoice, index) in invoiceList" :key="index">
 | 
					        <div v-for="(invoice, index) in invoiceList" :key="index">
 | 
				
			||||||
@ -412,9 +416,9 @@ onSearched = debounce(onSearched, 500)
 | 
				
			|||||||
            :id="'invoice-' + invoice.id"
 | 
					            :id="'invoice-' + invoice.id"
 | 
				
			||||||
            :to="`/admin/invoices/${invoice.id}/view`"
 | 
					            :to="`/admin/invoices/${invoice.id}/view`"
 | 
				
			||||||
            :class="[
 | 
					            :class="[
 | 
				
			||||||
              'flex justify-between side-invoice p-4 cursor-pointer hover:bg-gray-100 items-center border-l-4 border-transparent',
 | 
					              'flex justify-between side-invoice p-4 cursor-pointer hover:bg-gray-100 items-center border-l-4 border-transparent dark:hover:bg-gray-700',
 | 
				
			||||||
              {
 | 
					              {
 | 
				
			||||||
                'bg-gray-100 border-l-4 border-primary-500 border-solid':
 | 
					                'bg-gray-100 border-l-4 border-primary-500 border-solid dark:bg-gray-700':
 | 
				
			||||||
                  hasActiveUrl(invoice.id),
 | 
					                  hasActiveUrl(invoice.id),
 | 
				
			||||||
              },
 | 
					              },
 | 
				
			||||||
            ]"
 | 
					            ]"
 | 
				
			||||||
@ -434,6 +438,7 @@ onSearched = debounce(onSearched, 500)
 | 
				
			|||||||
                  text-black
 | 
					                  text-black
 | 
				
			||||||
                  capitalize
 | 
					                  capitalize
 | 
				
			||||||
                  truncate
 | 
					                  truncate
 | 
				
			||||||
 | 
					                  dark:text-white
 | 
				
			||||||
                "
 | 
					                "
 | 
				
			||||||
              />
 | 
					              />
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@ -446,16 +451,17 @@ onSearched = debounce(onSearched, 500)
 | 
				
			|||||||
                  font-medium
 | 
					                  font-medium
 | 
				
			||||||
                  leading-5
 | 
					                  leading-5
 | 
				
			||||||
                  text-gray-600
 | 
					                  text-gray-600
 | 
				
			||||||
 | 
					                  dark:text-gray-400
 | 
				
			||||||
                "
 | 
					                "
 | 
				
			||||||
              >
 | 
					              >
 | 
				
			||||||
                {{ invoice.invoice_number }}
 | 
					                {{ invoice.invoice_number }}
 | 
				
			||||||
              </div>
 | 
					              </div>
 | 
				
			||||||
              <BaseEstimateStatusBadge
 | 
					              <BaseInvoiceStatusBadge
 | 
				
			||||||
                :status="invoice.status"
 | 
					                :status="invoice.status"
 | 
				
			||||||
                class="px-1 text-xs"
 | 
					                class="px-1 text-xs"
 | 
				
			||||||
              >
 | 
					              >
 | 
				
			||||||
                {{ invoice.status }}
 | 
					                {{ invoice.status }}
 | 
				
			||||||
              </BaseEstimateStatusBadge>
 | 
					              </BaseInvoiceStatusBadge>
 | 
				
			||||||
            </div>
 | 
					            </div>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
            <div class="flex-1 whitespace-nowrap right">
 | 
					            <div class="flex-1 whitespace-nowrap right">
 | 
				
			||||||
@ -468,6 +474,7 @@ onSearched = debounce(onSearched, 500)
 | 
				
			|||||||
                  leading-8
 | 
					                  leading-8
 | 
				
			||||||
                  text-right text-gray-900
 | 
					                  text-right text-gray-900
 | 
				
			||||||
                  block
 | 
					                  block
 | 
				
			||||||
 | 
					                  dark:text-white
 | 
				
			||||||
                "
 | 
					                "
 | 
				
			||||||
                :amount="invoice.total"
 | 
					                :amount="invoice.total"
 | 
				
			||||||
                :currency="invoice.customer.currency"
 | 
					                :currency="invoice.customer.currency"
 | 
				
			||||||
@ -480,6 +487,7 @@ onSearched = debounce(onSearched, 500)
 | 
				
			|||||||
                  leading-5
 | 
					                  leading-5
 | 
				
			||||||
                  text-right text-gray-600
 | 
					                  text-right text-gray-600
 | 
				
			||||||
                  est-date
 | 
					                  est-date
 | 
				
			||||||
 | 
					                  dark:text-gray-400
 | 
				
			||||||
                "
 | 
					                "
 | 
				
			||||||
              >
 | 
					              >
 | 
				
			||||||
                {{ invoice.formatted_invoice_date }}
 | 
					                {{ invoice.formatted_invoice_date }}
 | 
				
			||||||
@ -492,7 +500,7 @@ onSearched = debounce(onSearched, 500)
 | 
				
			|||||||
        </div>
 | 
					        </div>
 | 
				
			||||||
        <p
 | 
					        <p
 | 
				
			||||||
          v-if="!invoiceList?.length && !isLoading"
 | 
					          v-if="!invoiceList?.length && !isLoading"
 | 
				
			||||||
          class="flex justify-center px-4 mt-5 text-sm text-gray-600"
 | 
					          class="flex justify-center px-4 mt-5 text-sm text-gray-600 dark:text-gray-300"
 | 
				
			||||||
        >
 | 
					        >
 | 
				
			||||||
          {{ $t('invoices.no_matching_invoices') }}
 | 
					          {{ $t('invoices.no_matching_invoices') }}
 | 
				
			||||||
        </p>
 | 
					        </p>
 | 
				
			||||||
 | 
				
			|||||||
@ -53,7 +53,7 @@
 | 
				
			|||||||
          </div>
 | 
					          </div>
 | 
				
			||||||
        </div>
 | 
					        </div>
 | 
				
			||||||
        <div v-else class="mt-24">
 | 
					        <div v-else class="mt-24">
 | 
				
			||||||
          <label class="flex items-center justify-center text-gray-500">
 | 
					          <label class="flex items-center justify-center text-gray-500 dark:text-gray-300">
 | 
				
			||||||
            {{ $t('modules.no_modules_installed') }}
 | 
					            {{ $t('modules.no_modules_installed') }}
 | 
				
			||||||
          </label>
 | 
					          </label>
 | 
				
			||||||
        </div>
 | 
					        </div>
 | 
				
			||||||
@ -61,10 +61,10 @@
 | 
				
			|||||||
    </div>
 | 
					    </div>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    <BaseCard v-else class="mt-6">
 | 
					    <BaseCard v-else class="mt-6">
 | 
				
			||||||
      <h6 class="text-gray-900 text-lg font-medium">
 | 
					      <h6 class="text-gray-900 text-lg font-medium dark:text-white">
 | 
				
			||||||
        {{ $t('modules.connect_installation') }}
 | 
					        {{ $t('modules.connect_installation') }}
 | 
				
			||||||
      </h6>
 | 
					      </h6>
 | 
				
			||||||
      <p class="mt-1 text-sm text-gray-500">
 | 
					      <p class="mt-1 text-sm text-gray-500 dark:text-gray-400">
 | 
				
			||||||
        {{
 | 
					        {{
 | 
				
			||||||
          $t('modules.api_token_description', {
 | 
					          $t('modules.api_token_description', {
 | 
				
			||||||
            url: globalStore.config.base_url.replace(/^http:\/\//, ''),
 | 
					            url: globalStore.config.base_url.replace(/^http:\/\//, ''),
 | 
				
			||||||
 | 
				
			|||||||
@ -215,7 +215,7 @@
 | 
				
			|||||||
            <SelectNotePopup type="Payment" @select="onSelectNote" />
 | 
					            <SelectNotePopup type="Payment" @select="onSelectNote" />
 | 
				
			||||||
          </div>
 | 
					          </div>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
          <label class="mb-4 text-sm font-medium text-gray-800">
 | 
					          <label class="mb-4 text-sm font-medium text-gray-800 dark:text-gray-300">
 | 
				
			||||||
            {{ $t('estimates.notes') }}
 | 
					            {{ $t('estimates.notes') }}
 | 
				
			||||||
          </label>
 | 
					          </label>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
				
			|||||||
@ -35,6 +35,7 @@
 | 
				
			|||||||
        xl:ml-64
 | 
					        xl:ml-64
 | 
				
			||||||
        w-88
 | 
					        w-88
 | 
				
			||||||
        xl:block
 | 
					        xl:block
 | 
				
			||||||
 | 
					        dark:bg-gray-800
 | 
				
			||||||
      "
 | 
					      "
 | 
				
			||||||
    >
 | 
					    >
 | 
				
			||||||
      <div
 | 
					      <div
 | 
				
			||||||
@ -46,6 +47,7 @@
 | 
				
			|||||||
          pt-8
 | 
					          pt-8
 | 
				
			||||||
          pb-6
 | 
					          pb-6
 | 
				
			||||||
          border border-gray-200 border-solid
 | 
					          border border-gray-200 border-solid
 | 
				
			||||||
 | 
					          dark:border-gray-600
 | 
				
			||||||
        "
 | 
					        "
 | 
				
			||||||
      >
 | 
					      >
 | 
				
			||||||
        <BaseInput
 | 
					        <BaseInput
 | 
				
			||||||
@ -77,6 +79,7 @@
 | 
				
			|||||||
                mb-2
 | 
					                mb-2
 | 
				
			||||||
                text-sm
 | 
					                text-sm
 | 
				
			||||||
                border-b border-gray-200 border-solid
 | 
					                border-b border-gray-200 border-solid
 | 
				
			||||||
 | 
					                dark:border-gray-600
 | 
				
			||||||
              "
 | 
					              "
 | 
				
			||||||
            >
 | 
					            >
 | 
				
			||||||
              {{ $t('general.sort_by') }}
 | 
					              {{ $t('general.sort_by') }}
 | 
				
			||||||
@ -139,7 +142,7 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
      <div
 | 
					      <div
 | 
				
			||||||
        ref="paymentListSection"
 | 
					        ref="paymentListSection"
 | 
				
			||||||
        class="h-full overflow-y-scroll border-l border-gray-200 border-solid"
 | 
					        class="h-full overflow-y-scroll border-l border-gray-200 border-solid dark:border-gray-600"
 | 
				
			||||||
      >
 | 
					      >
 | 
				
			||||||
        <div v-for="(payment, index) in paymentList" :key="index">
 | 
					        <div v-for="(payment, index) in paymentList" :key="index">
 | 
				
			||||||
          <router-link
 | 
					          <router-link
 | 
				
			||||||
@ -147,9 +150,9 @@
 | 
				
			|||||||
            :id="'payment-' + payment.id"
 | 
					            :id="'payment-' + payment.id"
 | 
				
			||||||
            :to="`/admin/payments/${payment.id}/view`"
 | 
					            :to="`/admin/payments/${payment.id}/view`"
 | 
				
			||||||
            :class="[
 | 
					            :class="[
 | 
				
			||||||
              'flex justify-between p-4 items-center cursor-pointer hover:bg-gray-100 border-l-4 border-transparent',
 | 
					              'flex justify-between p-4 items-center cursor-pointer hover:bg-gray-100 border-l-4 border-transparent dark:hover:bg-gray-700',
 | 
				
			||||||
              {
 | 
					              {
 | 
				
			||||||
                'bg-gray-100 border-l-4 border-primary-500 border-solid':
 | 
					                'bg-gray-100 border-l-4 border-primary-500 border-solid dark:bg-gray-700':
 | 
				
			||||||
                  hasActiveUrl(payment.id),
 | 
					                  hasActiveUrl(payment.id),
 | 
				
			||||||
              },
 | 
					              },
 | 
				
			||||||
            ]"
 | 
					            ]"
 | 
				
			||||||
@ -169,6 +172,7 @@
 | 
				
			|||||||
                  text-black
 | 
					                  text-black
 | 
				
			||||||
                  capitalize
 | 
					                  capitalize
 | 
				
			||||||
                  truncate
 | 
					                  truncate
 | 
				
			||||||
 | 
					                  dark:text-white
 | 
				
			||||||
                "
 | 
					                "
 | 
				
			||||||
              />
 | 
					              />
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@ -181,6 +185,7 @@
 | 
				
			|||||||
                  leading-5
 | 
					                  leading-5
 | 
				
			||||||
                  text-gray-500
 | 
					                  text-gray-500
 | 
				
			||||||
                  capitalize
 | 
					                  capitalize
 | 
				
			||||||
 | 
					                  dark:text-gray-400
 | 
				
			||||||
                "
 | 
					                "
 | 
				
			||||||
              >
 | 
					              >
 | 
				
			||||||
                {{ payment?.payment_number }}
 | 
					                {{ payment?.payment_number }}
 | 
				
			||||||
@ -211,12 +216,13 @@
 | 
				
			|||||||
                  font-semibold
 | 
					                  font-semibold
 | 
				
			||||||
                  leading-8
 | 
					                  leading-8
 | 
				
			||||||
                  text-right text-gray-900
 | 
					                  text-right text-gray-900
 | 
				
			||||||
 | 
					                  dark:text-white
 | 
				
			||||||
                "
 | 
					                "
 | 
				
			||||||
                :amount="payment?.amount"
 | 
					                :amount="payment?.amount"
 | 
				
			||||||
                :currency="payment.customer?.currency"
 | 
					                :currency="payment.customer?.currency"
 | 
				
			||||||
              />
 | 
					              />
 | 
				
			||||||
 | 
					
 | 
				
			||||||
              <div class="text-sm text-right text-gray-500 non-italic">
 | 
					              <div class="text-sm text-right text-gray-500 non-italic dark:text-gray-400">
 | 
				
			||||||
                {{ payment.formatted_payment_date }}
 | 
					                {{ payment.formatted_payment_date }}
 | 
				
			||||||
              </div>
 | 
					              </div>
 | 
				
			||||||
            </div>
 | 
					            </div>
 | 
				
			||||||
@ -227,7 +233,7 @@
 | 
				
			|||||||
        </div>
 | 
					        </div>
 | 
				
			||||||
        <p
 | 
					        <p
 | 
				
			||||||
          v-if="!paymentList?.length && !isLoading"
 | 
					          v-if="!paymentList?.length && !isLoading"
 | 
				
			||||||
          class="flex justify-center px-4 mt-5 text-sm text-gray-600"
 | 
					          class="flex justify-center px-4 mt-5 text-sm text-gray-600 dark:text-gray-300"
 | 
				
			||||||
        >
 | 
					        >
 | 
				
			||||||
          {{ $t('payments.no_matching_payments') }}
 | 
					          {{ $t('payments.no_matching_payments') }}
 | 
				
			||||||
        </p>
 | 
					        </p>
 | 
				
			||||||
 | 
				
			|||||||
@ -121,6 +121,7 @@
 | 
				
			|||||||
          mt-5
 | 
					          mt-5
 | 
				
			||||||
          list-none
 | 
					          list-none
 | 
				
			||||||
          border-b-2 border-gray-200 border-solid
 | 
					          border-b-2 border-gray-200 border-solid
 | 
				
			||||||
 | 
					          dark:border-gray-600
 | 
				
			||||||
        "
 | 
					        "
 | 
				
			||||||
      >
 | 
					      >
 | 
				
			||||||
        <!-- Tabs -->
 | 
					        <!-- Tabs -->
 | 
				
			||||||
 | 
				
			|||||||
@ -16,11 +16,11 @@
 | 
				
			|||||||
      </div>
 | 
					      </div>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
      <div class="ml-2">
 | 
					      <div class="ml-2">
 | 
				
			||||||
        <p class="p-0 mb-1 leading-snug text-left text-black">
 | 
					        <p class="p-0 mb-1 leading-snug text-left text-black dark:text-white">
 | 
				
			||||||
          {{ $t('recurring_invoices.send_automatically') }}
 | 
					          {{ $t('recurring_invoices.send_automatically') }}
 | 
				
			||||||
        </p>
 | 
					        </p>
 | 
				
			||||||
        <p
 | 
					        <p
 | 
				
			||||||
          class="p-0 m-0 text-xs leading-tight text-left text-gray-500"
 | 
					          class="p-0 m-0 text-xs leading-tight text-left text-gray-500 dark:text-gray-400"
 | 
				
			||||||
          style="max-width: 480px"
 | 
					          style="max-width: 480px"
 | 
				
			||||||
        >
 | 
					        >
 | 
				
			||||||
          {{ $t('recurring_invoices.send_automatically_desc') }}
 | 
					          {{ $t('recurring_invoices.send_automatically_desc') }}
 | 
				
			||||||
 | 
				
			|||||||
@ -152,6 +152,7 @@ onSearched = debounce(onSearched, 500)
 | 
				
			|||||||
      xl:ml-64
 | 
					      xl:ml-64
 | 
				
			||||||
      w-88
 | 
					      w-88
 | 
				
			||||||
      xl:block
 | 
					      xl:block
 | 
				
			||||||
 | 
					      dark:bg-gray-800
 | 
				
			||||||
    "
 | 
					    "
 | 
				
			||||||
  >
 | 
					  >
 | 
				
			||||||
    <div
 | 
					    <div
 | 
				
			||||||
@ -164,6 +165,7 @@ onSearched = debounce(onSearched, 500)
 | 
				
			|||||||
        pb-2
 | 
					        pb-2
 | 
				
			||||||
        border border-gray-200 border-solid
 | 
					        border border-gray-200 border-solid
 | 
				
			||||||
        height-full
 | 
					        height-full
 | 
				
			||||||
 | 
					        dark:border-gray-600
 | 
				
			||||||
      "
 | 
					      "
 | 
				
			||||||
    >
 | 
					    >
 | 
				
			||||||
      <div class="mb-6">
 | 
					      <div class="mb-6">
 | 
				
			||||||
@ -192,9 +194,10 @@ onSearched = debounce(onSearched, 500)
 | 
				
			|||||||
              px-2
 | 
					              px-2
 | 
				
			||||||
              py-1
 | 
					              py-1
 | 
				
			||||||
              pb-2
 | 
					              pb-2
 | 
				
			||||||
              mb-1 mb-2
 | 
					              mb-2
 | 
				
			||||||
              text-sm
 | 
					              text-sm
 | 
				
			||||||
              border-b border-gray-200 border-solid
 | 
					              border-b border-gray-200 border-solid
 | 
				
			||||||
 | 
					              dark:border-gray-600
 | 
				
			||||||
            "
 | 
					            "
 | 
				
			||||||
          >
 | 
					          >
 | 
				
			||||||
            {{ $t('general.sort_by') }}
 | 
					            {{ $t('general.sort_by') }}
 | 
				
			||||||
@ -243,6 +246,7 @@ onSearched = debounce(onSearched, 500)
 | 
				
			|||||||
        overflow-y-scroll
 | 
					        overflow-y-scroll
 | 
				
			||||||
        border-l border-gray-200 border-solid
 | 
					        border-l border-gray-200 border-solid
 | 
				
			||||||
        base-scroll
 | 
					        base-scroll
 | 
				
			||||||
 | 
					        dark:border-gray-600
 | 
				
			||||||
      "
 | 
					      "
 | 
				
			||||||
    >
 | 
					    >
 | 
				
			||||||
      <div v-for="(invoice, index) in invoiceList" :key="index">
 | 
					      <div v-for="(invoice, index) in invoiceList" :key="index">
 | 
				
			||||||
@ -251,9 +255,9 @@ onSearched = debounce(onSearched, 500)
 | 
				
			|||||||
          :id="'recurring-invoice-' + invoice.id"
 | 
					          :id="'recurring-invoice-' + invoice.id"
 | 
				
			||||||
          :to="`/admin/recurring-invoices/${invoice.id}/view`"
 | 
					          :to="`/admin/recurring-invoices/${invoice.id}/view`"
 | 
				
			||||||
          :class="[
 | 
					          :class="[
 | 
				
			||||||
            'flex justify-between side-invoice p-4 cursor-pointer hover:bg-gray-100 items-center border-l-4 border-transparent',
 | 
					            'flex justify-between side-invoice p-4 cursor-pointer hover:bg-gray-100 items-center border-l-4 border-transparent dark:hover:bg-gray-700',
 | 
				
			||||||
            {
 | 
					            {
 | 
				
			||||||
              'bg-gray-100 border-l-4 border-primary-500 border-solid':
 | 
					              'bg-gray-100 border-l-4 border-primary-500 border-solid dark:bg-gray-700':
 | 
				
			||||||
                hasActiveUrl(invoice.id),
 | 
					                hasActiveUrl(invoice.id),
 | 
				
			||||||
            },
 | 
					            },
 | 
				
			||||||
          ]"
 | 
					          ]"
 | 
				
			||||||
@ -273,6 +277,7 @@ onSearched = debounce(onSearched, 500)
 | 
				
			|||||||
                text-black
 | 
					                text-black
 | 
				
			||||||
                capitalize
 | 
					                capitalize
 | 
				
			||||||
                truncate
 | 
					                truncate
 | 
				
			||||||
 | 
					                dark:text-white
 | 
				
			||||||
              "
 | 
					              "
 | 
				
			||||||
            />
 | 
					            />
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@ -285,6 +290,7 @@ onSearched = debounce(onSearched, 500)
 | 
				
			|||||||
                font-medium
 | 
					                font-medium
 | 
				
			||||||
                leading-5
 | 
					                leading-5
 | 
				
			||||||
                text-gray-600
 | 
					                text-gray-600
 | 
				
			||||||
 | 
					                dark:text-gray-400
 | 
				
			||||||
              "
 | 
					              "
 | 
				
			||||||
            >
 | 
					            >
 | 
				
			||||||
              {{ invoice.invoice_number }}
 | 
					              {{ invoice.invoice_number }}
 | 
				
			||||||
@ -307,6 +313,7 @@ onSearched = debounce(onSearched, 500)
 | 
				
			|||||||
                font-semibold
 | 
					                font-semibold
 | 
				
			||||||
                leading-8
 | 
					                leading-8
 | 
				
			||||||
                text-right text-gray-900
 | 
					                text-right text-gray-900
 | 
				
			||||||
 | 
					                dark:text-white
 | 
				
			||||||
              "
 | 
					              "
 | 
				
			||||||
              :amount="invoice.total"
 | 
					              :amount="invoice.total"
 | 
				
			||||||
              :currency="invoice.customer.currency"
 | 
					              :currency="invoice.customer.currency"
 | 
				
			||||||
@ -320,6 +327,7 @@ onSearched = debounce(onSearched, 500)
 | 
				
			|||||||
                leading-5
 | 
					                leading-5
 | 
				
			||||||
                text-right text-gray-600
 | 
					                text-right text-gray-600
 | 
				
			||||||
                est-date
 | 
					                est-date
 | 
				
			||||||
 | 
					                dark:text-gray-400
 | 
				
			||||||
              "
 | 
					              "
 | 
				
			||||||
            >
 | 
					            >
 | 
				
			||||||
              {{ invoice.formatted_starts_at }}
 | 
					              {{ invoice.formatted_starts_at }}
 | 
				
			||||||
@ -332,7 +340,7 @@ onSearched = debounce(onSearched, 500)
 | 
				
			|||||||
      </div>
 | 
					      </div>
 | 
				
			||||||
      <p
 | 
					      <p
 | 
				
			||||||
        v-if="!invoiceList?.length && !isLoading"
 | 
					        v-if="!invoiceList?.length && !isLoading"
 | 
				
			||||||
        class="flex justify-center px-4 mt-5 text-sm text-gray-600"
 | 
					        class="flex justify-center px-4 mt-5 text-sm text-gray-600 dark:text-gray-300"
 | 
				
			||||||
      >
 | 
					      >
 | 
				
			||||||
        {{ $t('invoices.no_matching_invoices') }}
 | 
					        {{ $t('invoices.no_matching_invoices') }}
 | 
				
			||||||
      </p>
 | 
					      </p>
 | 
				
			||||||
 | 
				
			|||||||
@ -51,14 +51,14 @@
 | 
				
			|||||||
            </div>
 | 
					            </div>
 | 
				
			||||||
          </template>
 | 
					          </template>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
          <BaseDropdownItem @click="onDownloadBckup(row.data)">
 | 
					          <BaseDropdownItem v-slot="slotProps" @click="onDownloadBckup(row.data)">
 | 
				
			||||||
            <BaseIcon name="CloudDownloadIcon" class="mr-3 text-gray-600" />
 | 
					            <BaseIcon name="CloudDownloadIcon" :class="slotProps.class" />
 | 
				
			||||||
 | 
					
 | 
				
			||||||
            {{ $t('general.download') }}
 | 
					            {{ $t('general.download') }}
 | 
				
			||||||
          </BaseDropdownItem>
 | 
					          </BaseDropdownItem>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
          <BaseDropdownItem @click="onRemoveBackup(row.data)">
 | 
					          <BaseDropdownItem v-slot="slotProps" @click="onRemoveBackup(row.data)">
 | 
				
			||||||
            <BaseIcon name="TrashIcon" class="mr-3 text-gray-600" />
 | 
					            <BaseIcon name="TrashIcon" :class="slotProps.class" />
 | 
				
			||||||
            {{ $t('general.delete') }}
 | 
					            {{ $t('general.delete') }}
 | 
				
			||||||
          </BaseDropdownItem>
 | 
					          </BaseDropdownItem>
 | 
				
			||||||
        </BaseDropdown>
 | 
					        </BaseDropdown>
 | 
				
			||||||
 | 
				
			|||||||
@ -113,10 +113,10 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
      <div v-if="companyStore.companies.length !== 1" class="py-5">
 | 
					      <div v-if="companyStore.companies.length !== 1" class="py-5">
 | 
				
			||||||
        <BaseDivider class="my-4" />
 | 
					        <BaseDivider class="my-4" />
 | 
				
			||||||
        <h3 class="text-lg leading-6 font-medium text-gray-900">
 | 
					        <h3 class="text-lg leading-6 font-medium text-gray-900 dark:text-white">
 | 
				
			||||||
          {{ $tc('settings.company_info.delete_company') }}
 | 
					          {{ $tc('settings.company_info.delete_company') }}
 | 
				
			||||||
        </h3>
 | 
					        </h3>
 | 
				
			||||||
        <div class="mt-2 max-w-xl text-sm text-gray-500">
 | 
					        <div class="mt-2 max-w-xl text-sm text-gray-500 dark:text-gray-400">
 | 
				
			||||||
          <p>
 | 
					          <p>
 | 
				
			||||||
            {{ $tc('settings.company_info.delete_company_description') }}
 | 
					            {{ $tc('settings.company_info.delete_company_description') }}
 | 
				
			||||||
          </p>
 | 
					          </p>
 | 
				
			||||||
 | 
				
			|||||||
@ -27,7 +27,7 @@
 | 
				
			|||||||
    >
 | 
					    >
 | 
				
			||||||
      <template #cell-name="{ row }">
 | 
					      <template #cell-name="{ row }">
 | 
				
			||||||
        {{ row.data.name }}
 | 
					        {{ row.data.name }}
 | 
				
			||||||
        <span class="text-xs text-gray-500"> ({{ row.data.slug }})</span>
 | 
					        <span class="text-xs text-gray-500 dark:text-gray-400"> ({{ row.data.slug }})</span>
 | 
				
			||||||
      </template>
 | 
					      </template>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
      <template #cell-is_required="{ row }">
 | 
					      <template #cell-is_required="{ row }">
 | 
				
			||||||
 | 
				
			|||||||
@ -7,7 +7,7 @@
 | 
				
			|||||||
          {{ $t('settings.menu_title.exchange_rate') }}
 | 
					          {{ $t('settings.menu_title.exchange_rate') }}
 | 
				
			||||||
        </h6>
 | 
					        </h6>
 | 
				
			||||||
        <p
 | 
					        <p
 | 
				
			||||||
          class="mt-2 text-sm leading-snug text-left text-gray-500"
 | 
					          class="mt-2 text-sm leading-snug text-left text-gray-500 dark:text-gray-400"
 | 
				
			||||||
          style="max-width: 680px"
 | 
					          style="max-width: 680px"
 | 
				
			||||||
        >
 | 
					        >
 | 
				
			||||||
          {{ $t('settings.exchange_rate.providers_description') }}
 | 
					          {{ $t('settings.exchange_rate.providers_description') }}
 | 
				
			||||||
 | 
				
			|||||||
@ -45,27 +45,30 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
          <BaseDropdownItem
 | 
					          <BaseDropdownItem
 | 
				
			||||||
            v-if="!row.data.set_as_default"
 | 
					            v-if="!row.data.set_as_default"
 | 
				
			||||||
 | 
					            v-slot="slotProps"
 | 
				
			||||||
            @click="setDefaultDiskData(row.data.id)"
 | 
					            @click="setDefaultDiskData(row.data.id)"
 | 
				
			||||||
          >
 | 
					          >
 | 
				
			||||||
            <BaseIcon class="mr-3 tetx-gray-600" name="CheckCircleIcon" />
 | 
					            <BaseIcon :class="slotProps.class" name="CheckCircleIcon" />
 | 
				
			||||||
 | 
					
 | 
				
			||||||
            {{ $t('settings.disk.set_default_disk') }}
 | 
					            {{ $t('settings.disk.set_default_disk') }}
 | 
				
			||||||
          </BaseDropdownItem>
 | 
					          </BaseDropdownItem>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
          <BaseDropdownItem
 | 
					          <BaseDropdownItem
 | 
				
			||||||
            v-if="row.data.type !== 'SYSTEM'"
 | 
					            v-if="row.data.type !== 'SYSTEM'"
 | 
				
			||||||
 | 
					            v-slot="slotProps"
 | 
				
			||||||
            @click="openEditDiskModal(row.data)"
 | 
					            @click="openEditDiskModal(row.data)"
 | 
				
			||||||
          >
 | 
					          >
 | 
				
			||||||
            <BaseIcon name="PencilIcon" class="mr-3 text-gray-600" />
 | 
					            <BaseIcon name="PencilIcon" :class="slotProps.class" />
 | 
				
			||||||
 | 
					
 | 
				
			||||||
            {{ $t('general.edit') }}
 | 
					            {{ $t('general.edit') }}
 | 
				
			||||||
          </BaseDropdownItem>
 | 
					          </BaseDropdownItem>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
          <BaseDropdownItem
 | 
					          <BaseDropdownItem
 | 
				
			||||||
            v-if="row.data.type !== 'SYSTEM' && !row.data.set_as_default"
 | 
					            v-if="row.data.type !== 'SYSTEM' && !row.data.set_as_default"
 | 
				
			||||||
 | 
					            v-slot="slotProps"
 | 
				
			||||||
            @click="removeDisk(row.data.id)"
 | 
					            @click="removeDisk(row.data.id)"
 | 
				
			||||||
          >
 | 
					          >
 | 
				
			||||||
            <BaseIcon name="TrashIcon" class="mr-3 text-gray-600" />
 | 
					            <BaseIcon name="TrashIcon" :class="slotProps.class" />
 | 
				
			||||||
            {{ $t('general.delete') }}
 | 
					            {{ $t('general.delete') }}
 | 
				
			||||||
          </BaseDropdownItem>
 | 
					          </BaseDropdownItem>
 | 
				
			||||||
        </BaseDropdown>
 | 
					        </BaseDropdown>
 | 
				
			||||||
 | 
				
			|||||||
@ -4,23 +4,14 @@
 | 
				
			|||||||
    :description="$t('settings.update_app.description')"
 | 
					    :description="$t('settings.update_app.description')"
 | 
				
			||||||
  >
 | 
					  >
 | 
				
			||||||
    <div class="pb-8 ml-0">
 | 
					    <div class="pb-8 ml-0">
 | 
				
			||||||
      <label class="text-sm not-italic font-medium input-label">
 | 
					      <label
 | 
				
			||||||
 | 
					        class="text-sm not-italic font-medium input-label dark:text-gray-300"
 | 
				
			||||||
 | 
					      >
 | 
				
			||||||
        {{ $t('settings.update_app.current_version') }}
 | 
					        {{ $t('settings.update_app.current_version') }}
 | 
				
			||||||
      </label>
 | 
					      </label>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
      <div
 | 
					      <div
 | 
				
			||||||
        class="
 | 
					        class="box-border flex w-16 p-3 my-2 text-sm text-gray-600 bg-gray-200 border border-gray-200 border-solid dark:bg-gray-600 dark:text-gray-200 dark:border-gray-500 rounded-md version"
 | 
				
			||||||
          box-border
 | 
					 | 
				
			||||||
          flex
 | 
					 | 
				
			||||||
          w-16
 | 
					 | 
				
			||||||
          p-3
 | 
					 | 
				
			||||||
          my-2
 | 
					 | 
				
			||||||
          text-sm text-gray-600
 | 
					 | 
				
			||||||
          bg-gray-200
 | 
					 | 
				
			||||||
          border border-gray-200 border-solid
 | 
					 | 
				
			||||||
          rounded-md
 | 
					 | 
				
			||||||
          version
 | 
					 | 
				
			||||||
        "
 | 
					 | 
				
			||||||
      >
 | 
					      >
 | 
				
			||||||
        {{ currentVersion }}
 | 
					        {{ currentVersion }}
 | 
				
			||||||
      </div>
 | 
					      </div>
 | 
				
			||||||
@ -42,20 +33,20 @@
 | 
				
			|||||||
          {{ $t('settings.update_app.avail_update') }}
 | 
					          {{ $t('settings.update_app.avail_update') }}
 | 
				
			||||||
        </BaseHeading>
 | 
					        </BaseHeading>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        <div class="rounded-md bg-primary-50 p-4 mb-3">
 | 
					        <div class="rounded-md bg-primary-50 p-4 mb-3 dark:bg-gray-600">
 | 
				
			||||||
          <div class="flex">
 | 
					          <div class="flex">
 | 
				
			||||||
            <div class="shrink-0">
 | 
					            <div class="shrink-0">
 | 
				
			||||||
              <BaseIcon
 | 
					              <BaseIcon
 | 
				
			||||||
                name="InformationCircleIcon"
 | 
					                name="InformationCircleIcon"
 | 
				
			||||||
                class="h-5 w-5 text-primary-400"
 | 
					                class="h-5 w-5 text-primary-400 dark:text-primary-300"
 | 
				
			||||||
                aria-hidden="true"
 | 
					                aria-hidden="true"
 | 
				
			||||||
              />
 | 
					              />
 | 
				
			||||||
            </div>
 | 
					            </div>
 | 
				
			||||||
            <div class="ml-3">
 | 
					            <div class="ml-3">
 | 
				
			||||||
              <h3 class="text-sm font-medium text-primary-800">
 | 
					              <h3 class="text-sm font-medium text-primary-800 dark:text-primary-300">
 | 
				
			||||||
                {{ $t('general.note') }}
 | 
					                {{ $t('general.note') }}
 | 
				
			||||||
              </h3>
 | 
					              </h3>
 | 
				
			||||||
              <div class="mt-2 text-sm text-primary-700">
 | 
					              <div class="mt-2 text-sm text-primary-700 dark:text-primary-400">
 | 
				
			||||||
                <p>
 | 
					                <p>
 | 
				
			||||||
                  {{ $t('settings.update_app.update_warning') }}
 | 
					                  {{ $t('settings.update_app.update_warning') }}
 | 
				
			||||||
                </p>
 | 
					                </p>
 | 
				
			||||||
@ -75,26 +66,20 @@
 | 
				
			|||||||
            w-16
 | 
					            w-16
 | 
				
			||||||
            p-3
 | 
					            p-3
 | 
				
			||||||
            my-2
 | 
					            my-2
 | 
				
			||||||
            text-sm text-gray-600
 | 
					            text-sm
 | 
				
			||||||
            bg-gray-200
 | 
					            text-gray-600 bg-gray-200
 | 
				
			||||||
            border border-gray-200 border-solid
 | 
					            border border-gray-200 border-solid
 | 
				
			||||||
            rounded-md
 | 
					            rounded-md
 | 
				
			||||||
            version
 | 
					            version
 | 
				
			||||||
 | 
					            dark:bg-gray-600 dark:text-gray-200
 | 
				
			||||||
 | 
					            dark:border-gray-500
 | 
				
			||||||
          "
 | 
					          "
 | 
				
			||||||
        >
 | 
					        >
 | 
				
			||||||
          {{ updateData.version }}
 | 
					          {{ updateData.version }}
 | 
				
			||||||
        </div>
 | 
					        </div>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        <div
 | 
					        <div
 | 
				
			||||||
          class="
 | 
					          class="pl-5 mt-4 mb-8 text-sm leading-snug text-gray-500 update-description"
 | 
				
			||||||
            pl-5
 | 
					 | 
				
			||||||
            mt-4
 | 
					 | 
				
			||||||
            mb-8
 | 
					 | 
				
			||||||
            text-sm
 | 
					 | 
				
			||||||
            leading-snug
 | 
					 | 
				
			||||||
            text-gray-500
 | 
					 | 
				
			||||||
            update-description
 | 
					 | 
				
			||||||
          "
 | 
					 | 
				
			||||||
          style="white-space: pre-wrap; max-width: 480px"
 | 
					          style="white-space: pre-wrap; max-width: 480px"
 | 
				
			||||||
          v-html="description"
 | 
					          v-html="description"
 | 
				
			||||||
        ></div>
 | 
					        ></div>
 | 
				
			||||||
@ -150,14 +135,7 @@
 | 
				
			|||||||
        <li
 | 
					        <li
 | 
				
			||||||
          v-for="step in updateSteps"
 | 
					          v-for="step in updateSteps"
 | 
				
			||||||
          :key="step.stepUrl"
 | 
					          :key="step.stepUrl"
 | 
				
			||||||
          class="
 | 
					          class="flex justify-between w-full py-3 border-b border-gray-200 border-solid last:border-b-0"
 | 
				
			||||||
            flex
 | 
					 | 
				
			||||||
            justify-between
 | 
					 | 
				
			||||||
            w-full
 | 
					 | 
				
			||||||
            py-3
 | 
					 | 
				
			||||||
            border-b border-gray-200 border-solid
 | 
					 | 
				
			||||||
            last:border-b-0
 | 
					 | 
				
			||||||
          "
 | 
					 | 
				
			||||||
        >
 | 
					        >
 | 
				
			||||||
          <p class="m-0 text-sm leading-8">{{ $t(step.translationKey) }}</p>
 | 
					          <p class="m-0 text-sm leading-8">{{ $t(step.translationKey) }}</p>
 | 
				
			||||||
          <div class="flex flex-row items-center">
 | 
					          <div class="flex flex-row items-center">
 | 
				
			||||||
 | 
				
			|||||||
@ -1,12 +1,12 @@
 | 
				
			|||||||
<template>
 | 
					<template>
 | 
				
			||||||
  <h6 class="text-gray-900 text-lg font-medium">
 | 
					  <BaseHeading
 | 
				
			||||||
    {{ $t(`settings.customization.${type}s.${type}_number_format`) }}
 | 
					    type="heading-title"
 | 
				
			||||||
  </h6>
 | 
					    :subtitle="
 | 
				
			||||||
  <p class="mt-1 text-sm text-gray-500">
 | 
					 | 
				
			||||||
    {{
 | 
					 | 
				
			||||||
      $t(`settings.customization.${type}s.${type}_number_format_description`)
 | 
					      $t(`settings.customization.${type}s.${type}_number_format_description`)
 | 
				
			||||||
    }}
 | 
					    "
 | 
				
			||||||
  </p>
 | 
					  >
 | 
				
			||||||
 | 
					    {{ $t(`settings.customization.${type}s.${type}_number_format`) }}
 | 
				
			||||||
 | 
					  </BaseHeading>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  <div class="overflow-x-auto">
 | 
					  <div class="overflow-x-auto">
 | 
				
			||||||
    <table class="w-full mt-6 table-fixed">
 | 
					    <table class="w-full mt-6 table-fixed">
 | 
				
			||||||
@ -29,6 +29,7 @@
 | 
				
			|||||||
              leading-5
 | 
					              leading-5
 | 
				
			||||||
              text-left text-gray-700
 | 
					              text-left text-gray-700
 | 
				
			||||||
              border-t border-b border-gray-200 border-solid
 | 
					              border-t border-b border-gray-200 border-solid
 | 
				
			||||||
 | 
					              dark:border-gray-600
 | 
				
			||||||
            "
 | 
					            "
 | 
				
			||||||
          ></th>
 | 
					          ></th>
 | 
				
			||||||
          <th
 | 
					          <th
 | 
				
			||||||
@ -41,6 +42,7 @@
 | 
				
			|||||||
              leading-5
 | 
					              leading-5
 | 
				
			||||||
              text-left text-gray-700
 | 
					              text-left text-gray-700
 | 
				
			||||||
              border-t border-b border-gray-200 border-solid
 | 
					              border-t border-b border-gray-200 border-solid
 | 
				
			||||||
 | 
					              dark:text-gray-300 dark:border-gray-600
 | 
				
			||||||
            "
 | 
					            "
 | 
				
			||||||
          >
 | 
					          >
 | 
				
			||||||
            Component
 | 
					            Component
 | 
				
			||||||
@ -55,6 +57,7 @@
 | 
				
			|||||||
              leading-5
 | 
					              leading-5
 | 
				
			||||||
              text-left text-gray-700
 | 
					              text-left text-gray-700
 | 
				
			||||||
              border-t border-b border-gray-200 border-solid
 | 
					              border-t border-b border-gray-200 border-solid
 | 
				
			||||||
 | 
					              dark:text-gray-300 dark:border-gray-600
 | 
				
			||||||
            "
 | 
					            "
 | 
				
			||||||
          >
 | 
					          >
 | 
				
			||||||
            Parameter
 | 
					            Parameter
 | 
				
			||||||
@ -69,13 +72,14 @@
 | 
				
			|||||||
              leading-5
 | 
					              leading-5
 | 
				
			||||||
              text-left text-gray-700
 | 
					              text-left text-gray-700
 | 
				
			||||||
              border-t border-b border-gray-200 border-solid
 | 
					              border-t border-b border-gray-200 border-solid
 | 
				
			||||||
 | 
					              dark:border-gray-600
 | 
				
			||||||
            "
 | 
					            "
 | 
				
			||||||
          ></th>
 | 
					          ></th>
 | 
				
			||||||
        </tr>
 | 
					        </tr>
 | 
				
			||||||
      </thead>
 | 
					      </thead>
 | 
				
			||||||
      <draggable
 | 
					      <draggable
 | 
				
			||||||
        v-model="selectedFields"
 | 
					        v-model="selectedFields"
 | 
				
			||||||
        class="divide-y divide-gray-200"
 | 
					        class="divide-y divide-gray-200 dark:divide-gray-600"
 | 
				
			||||||
        item-key="id"
 | 
					        item-key="id"
 | 
				
			||||||
        tag="tbody"
 | 
					        tag="tbody"
 | 
				
			||||||
        handle=".handle"
 | 
					        handle=".handle"
 | 
				
			||||||
@ -97,12 +101,13 @@
 | 
				
			|||||||
                  whitespace-nowrap
 | 
					                  whitespace-nowrap
 | 
				
			||||||
                  mr-2
 | 
					                  mr-2
 | 
				
			||||||
                  min-w-[200px]
 | 
					                  min-w-[200px]
 | 
				
			||||||
 | 
					                  dark:text-primary-400
 | 
				
			||||||
                "
 | 
					                "
 | 
				
			||||||
              >
 | 
					              >
 | 
				
			||||||
                {{ element.label }}
 | 
					                {{ element.label }}
 | 
				
			||||||
              </label>
 | 
					              </label>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
              <p class="text-xs text-gray-500 mt-1">
 | 
					              <p class="text-xs text-gray-500 dark:text-gray-400 mt-1">
 | 
				
			||||||
                {{ element.description }}
 | 
					                {{ element.description }}
 | 
				
			||||||
              </p>
 | 
					              </p>
 | 
				
			||||||
            </td>
 | 
					            </td>
 | 
				
			||||||
 | 
				
			|||||||
@ -1,10 +1,12 @@
 | 
				
			|||||||
<template>
 | 
					<template>
 | 
				
			||||||
  <h6 class="text-gray-900 text-lg font-medium">
 | 
					  <BaseHeading
 | 
				
			||||||
 | 
					    type="heading-title"
 | 
				
			||||||
 | 
					    :subtitle="
 | 
				
			||||||
 | 
					      $t('settings.customization.estimates.convert_estimate_description')
 | 
				
			||||||
 | 
					    "
 | 
				
			||||||
 | 
					    >
 | 
				
			||||||
    {{ $tc('settings.customization.estimates.convert_estimate_options') }}
 | 
					    {{ $tc('settings.customization.estimates.convert_estimate_options') }}
 | 
				
			||||||
  </h6>
 | 
					  </BaseHeading>
 | 
				
			||||||
  <p class="mt-1 text-sm text-gray-500">
 | 
					 | 
				
			||||||
    {{ $t('settings.customization.estimates.convert_estimate_description') }}
 | 
					 | 
				
			||||||
  </p>
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
  <BaseInputGroup required>
 | 
					  <BaseInputGroup required>
 | 
				
			||||||
    <BaseRadio
 | 
					    <BaseRadio
 | 
				
			||||||
 | 
				
			|||||||
@ -1,11 +1,13 @@
 | 
				
			|||||||
<template>
 | 
					<template>
 | 
				
			||||||
  <form @submit.prevent="submitForm">
 | 
					  <form @submit.prevent="submitForm">
 | 
				
			||||||
    <h6 class="text-gray-900 text-lg font-medium">
 | 
					    <BaseHeading
 | 
				
			||||||
 | 
					      type="heading-title"
 | 
				
			||||||
 | 
					      :subtitle="
 | 
				
			||||||
 | 
					        $t('settings.customization.estimates.default_formats_description')
 | 
				
			||||||
 | 
					      "
 | 
				
			||||||
 | 
					    >
 | 
				
			||||||
      {{ $t('settings.customization.estimates.default_formats') }}
 | 
					      {{ $t('settings.customization.estimates.default_formats') }}
 | 
				
			||||||
    </h6>
 | 
					    </BaseHeading>
 | 
				
			||||||
    <p class="mt-1 text-sm text-gray-500 mb-2">
 | 
					 | 
				
			||||||
      {{ $t('settings.customization.estimates.default_formats_description') }}
 | 
					 | 
				
			||||||
    </p>
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
    <BaseInputGroup
 | 
					    <BaseInputGroup
 | 
				
			||||||
      :label="
 | 
					      :label="
 | 
				
			||||||
 | 
				
			|||||||
@ -1,11 +1,13 @@
 | 
				
			|||||||
<template>
 | 
					<template>
 | 
				
			||||||
  <form @submit.prevent="submitForm">
 | 
					  <form @submit.prevent="submitForm">
 | 
				
			||||||
    <h6 class="text-gray-900 text-lg font-medium">
 | 
					    <BaseHeading
 | 
				
			||||||
 | 
					      type="heading-title"
 | 
				
			||||||
 | 
					      :subtitle="
 | 
				
			||||||
 | 
					        $t('settings.customization.estimates.expiry_date_description')
 | 
				
			||||||
 | 
					      "
 | 
				
			||||||
 | 
					    >
 | 
				
			||||||
      {{ $t('settings.customization.estimates.expiry_date') }}
 | 
					      {{ $t('settings.customization.estimates.expiry_date') }}
 | 
				
			||||||
    </h6>
 | 
					    </BaseHeading>
 | 
				
			||||||
    <p class="mt-1 text-sm text-gray-500 mb-2">
 | 
					 | 
				
			||||||
      {{ $t('settings.customization.estimates.expiry_date_description') }}
 | 
					 | 
				
			||||||
    </p>
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
    <BaseSwitchSection
 | 
					    <BaseSwitchSection
 | 
				
			||||||
      v-model="expiryDateAutoField"
 | 
					      v-model="expiryDateAutoField"
 | 
				
			||||||
 | 
				
			|||||||
@ -1,11 +1,13 @@
 | 
				
			|||||||
<template>
 | 
					<template>
 | 
				
			||||||
  <form @submit.prevent="submitForm">
 | 
					  <form @submit.prevent="submitForm">
 | 
				
			||||||
    <h6 class="text-gray-900 text-lg font-medium">
 | 
					    <BaseHeading
 | 
				
			||||||
 | 
					      type="heading-title"
 | 
				
			||||||
 | 
					      :subtitle="
 | 
				
			||||||
 | 
					        $t('settings.customization.invoices.default_formats_description')
 | 
				
			||||||
 | 
					      "
 | 
				
			||||||
 | 
					    >
 | 
				
			||||||
      {{ $t('settings.customization.invoices.default_formats') }}
 | 
					      {{ $t('settings.customization.invoices.default_formats') }}
 | 
				
			||||||
    </h6>
 | 
					    </BaseHeading>
 | 
				
			||||||
    <p class="mt-1 text-sm text-gray-500 mb-2">
 | 
					 | 
				
			||||||
      {{ $t('settings.customization.invoices.default_formats_description') }}
 | 
					 | 
				
			||||||
    </p>
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
    <BaseInputGroup
 | 
					    <BaseInputGroup
 | 
				
			||||||
      :label="$t('settings.customization.invoices.default_invoice_email_body')"
 | 
					      :label="$t('settings.customization.invoices.default_invoice_email_body')"
 | 
				
			||||||
 | 
				
			|||||||
@ -1,11 +1,13 @@
 | 
				
			|||||||
<template>
 | 
					<template>
 | 
				
			||||||
  <form @submit.prevent="submitForm">
 | 
					  <form @submit.prevent="submitForm">
 | 
				
			||||||
    <h6 class="text-gray-900 text-lg font-medium">
 | 
					    <BaseHeading
 | 
				
			||||||
      {{ $t('settings.customization.invoices.due_date') }}
 | 
					    type="heading-title"
 | 
				
			||||||
    </h6>
 | 
					    :subtitle="
 | 
				
			||||||
    <p class="mt-1 text-sm text-gray-500 mb-2">
 | 
					      $t('settings.customization.invoices.due_date_description')
 | 
				
			||||||
      {{ $t('settings.customization.invoices.due_date_description') }}
 | 
					    "
 | 
				
			||||||
    </p>
 | 
					  >
 | 
				
			||||||
 | 
					    {{ $t('settings.customization.invoices.due_date') }}
 | 
				
			||||||
 | 
					  </BaseHeading>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    <BaseSwitchSection
 | 
					    <BaseSwitchSection
 | 
				
			||||||
      v-model="dueDateAutoField"
 | 
					      v-model="dueDateAutoField"
 | 
				
			||||||
 | 
				
			|||||||
@ -1,10 +1,12 @@
 | 
				
			|||||||
<template>
 | 
					<template>
 | 
				
			||||||
  <h6 class="text-gray-900 text-lg font-medium">
 | 
					  <BaseHeading
 | 
				
			||||||
 | 
					    type="heading-title"
 | 
				
			||||||
 | 
					    :subtitle="
 | 
				
			||||||
 | 
					      $t('settings.customization.invoices.retrospective_edits_description')
 | 
				
			||||||
 | 
					    "
 | 
				
			||||||
 | 
					  >
 | 
				
			||||||
    {{ $tc('settings.customization.invoices.retrospective_edits') }}
 | 
					    {{ $tc('settings.customization.invoices.retrospective_edits') }}
 | 
				
			||||||
  </h6>
 | 
					  </BaseHeading>
 | 
				
			||||||
  <p class="mt-1 text-sm text-gray-500">
 | 
					 | 
				
			||||||
    {{ $t('settings.customization.invoices.retrospective_edits_description') }}
 | 
					 | 
				
			||||||
  </p>
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
  <BaseInputGroup required>
 | 
					  <BaseInputGroup required>
 | 
				
			||||||
    <BaseRadio
 | 
					    <BaseRadio
 | 
				
			||||||
 | 
				
			|||||||
@ -1,11 +1,13 @@
 | 
				
			|||||||
<template>
 | 
					<template>
 | 
				
			||||||
  <form @submit.prevent="submitForm">
 | 
					  <form @submit.prevent="submitForm">
 | 
				
			||||||
    <h6 class="text-gray-900 text-lg font-medium">
 | 
					     <BaseHeading
 | 
				
			||||||
 | 
					      type="heading-title"
 | 
				
			||||||
 | 
					      :subtitle="
 | 
				
			||||||
 | 
					        $t('settings.customization.payments.default_formats_description')
 | 
				
			||||||
 | 
					      "
 | 
				
			||||||
 | 
					    >
 | 
				
			||||||
      {{ $t('settings.customization.payments.default_formats') }}
 | 
					      {{ $t('settings.customization.payments.default_formats') }}
 | 
				
			||||||
    </h6>
 | 
					    </BaseHeading>
 | 
				
			||||||
    <p class="mt-1 text-sm text-gray-500 mb-2">
 | 
					 | 
				
			||||||
      {{ $t('settings.customization.payments.default_formats_description') }}
 | 
					 | 
				
			||||||
    </p>
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
    <BaseInputGroup
 | 
					    <BaseInputGroup
 | 
				
			||||||
      :label="$t('settings.customization.payments.default_payment_email_body')"
 | 
					      :label="$t('settings.customization.payments.default_payment_email_body')"
 | 
				
			||||||
 | 
				
			|||||||
@ -1,21 +1,23 @@
 | 
				
			|||||||
<template>
 | 
					<template>
 | 
				
			||||||
  <div ref="companySwitchBar" class="relative rounded">
 | 
					  <div ref="companySwitchBar" class="relative rounded dark:text-white">
 | 
				
			||||||
    <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-white
 | 
					      text-sm
 | 
				
			||||||
        bg-white
 | 
					      text-white
 | 
				
			||||||
        rounded
 | 
					      bg-white
 | 
				
			||||||
        cursor-pointer
 | 
					      rounded
 | 
				
			||||||
        bg-opacity-20
 | 
					      cursor-pointer
 | 
				
			||||||
 | 
					      bg-opacity-20
 | 
				
			||||||
 | 
					      dark:bg-gray-700
 | 
				
			||||||
      "
 | 
					      "
 | 
				
			||||||
      @click="isShow = !isShow"
 | 
					      @click="isShow = !isShow"
 | 
				
			||||||
    >
 | 
					    >
 | 
				
			||||||
@ -38,28 +40,42 @@
 | 
				
			|||||||
    >
 | 
					    >
 | 
				
			||||||
      <div
 | 
					      <div
 | 
				
			||||||
        v-if="isShow"
 | 
					        v-if="isShow"
 | 
				
			||||||
        class="absolute right-0 mt-2 bg-white rounded-md shadow-lg"
 | 
					        class="
 | 
				
			||||||
 | 
					        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-thumb-rounded-full
 | 
					          scrollbar-thin
 | 
				
			||||||
            w-[250px]
 | 
					          scrollbar-thumb-rounded-full
 | 
				
			||||||
            max-h-[350px]
 | 
					          w-[250px] max-h-[350px]
 | 
				
			||||||
            scrollbar-thumb-gray-300 scrollbar-track-gray-10
 | 
					          scrollbar-thumb-gray-300
 | 
				
			||||||
            pb-4
 | 
					          scrollbar-track-gray-10
 | 
				
			||||||
 | 
					          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
 | 
					            block uppercase
 | 
				
			||||||
              uppercase
 | 
					 | 
				
			||||||
            "
 | 
					            "
 | 
				
			||||||
          >
 | 
					          >
 | 
				
			||||||
            {{ $t('company_switcher.label') }}
 | 
					            {{ $t('company_switcher.label') }}
 | 
				
			||||||
@ -68,13 +84,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" />
 | 
				
			||||||
@ -86,14 +102,17 @@
 | 
				
			|||||||
                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':
 | 
					                  'bg-gray-100 text-primary-500 dark:bg-gray-700':
 | 
				
			||||||
                    companyStore.selectedCompany.id === company.id,
 | 
					                    companyStore.selectedCompany.id === company.id,
 | 
				
			||||||
                }"
 | 
					                }"
 | 
				
			||||||
                @click="changeCompany(company)"
 | 
					                @click="changeCompany(company)"
 | 
				
			||||||
@ -101,18 +120,19 @@
 | 
				
			|||||||
                <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-base
 | 
					                    text-sm
 | 
				
			||||||
                      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">
 | 
				
			||||||
@ -136,15 +156,17 @@
 | 
				
			|||||||
        <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-gray-100
 | 
					          border-t-2
 | 
				
			||||||
            cursor-pointer
 | 
					          border-gray-100
 | 
				
			||||||
            text-primary-400
 | 
					          cursor-pointer
 | 
				
			||||||
            hover:text-primary-500
 | 
					          text-primary-400
 | 
				
			||||||
 | 
					          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">
 | 
					  <div ref="searchBar" class="hidden rounded md:block relative dark:text-white">
 | 
				
			||||||
    <div>
 | 
					    <div>
 | 
				
			||||||
      <BaseInput
 | 
					      <BaseInput
 | 
				
			||||||
        v-model="name"
 | 
					        v-model="name"
 | 
				
			||||||
@ -41,6 +41,11 @@
 | 
				
			|||||||
          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
 | 
				
			||||||
@ -68,7 +73,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"
 | 
					              class="p-2 hover:bg-gray-100 cursor-pointer rounded-md dark:hover:bg-gray-700/40"
 | 
				
			||||||
            >
 | 
					            >
 | 
				
			||||||
              <router-link
 | 
					              <router-link
 | 
				
			||||||
                :to="{ path: `/admin/customers/${customer.id}/view` }"
 | 
					                :to="{ path: `/admin/customers/${customer.id}/view` }"
 | 
				
			||||||
@ -87,6 +92,7 @@
 | 
				
			|||||||
                    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) }}
 | 
				
			||||||
@ -116,7 +122,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"
 | 
					              class="p-2 hover:bg-gray-100 cursor-pointer rounded-md dark:hover:bg-gray-700/40"
 | 
				
			||||||
            >
 | 
					            >
 | 
				
			||||||
              <router-link
 | 
					              <router-link
 | 
				
			||||||
                :to="{ path: `/admin/users/${user.id}/edit` }"
 | 
					                :to="{ path: `/admin/users/${user.id}/edit` }"
 | 
				
			||||||
@ -135,6 +141,7 @@
 | 
				
			|||||||
                    bg-gray-200
 | 
					                    bg-gray-200
 | 
				
			||||||
                    rounded-full
 | 
					                    rounded-full
 | 
				
			||||||
                    text-primary-500
 | 
					                    text-primary-500
 | 
				
			||||||
 | 
					                    dark:bg-gray-600
 | 
				
			||||||
                  "
 | 
					                  "
 | 
				
			||||||
                >
 | 
					                >
 | 
				
			||||||
                  {{ initGenerator(user.name) }}
 | 
					                  {{ initGenerator(user.name) }}
 | 
				
			||||||
 | 
				
			|||||||
@ -1,33 +1,40 @@
 | 
				
			|||||||
<template>
 | 
					<template>
 | 
				
			||||||
  <div class="bg-white shadow overflow-hidden rounded-lg mt-6">
 | 
					  <div class="bg-white shadow overflow-hidden rounded-lg mt-6 dark:bg-gray-800">
 | 
				
			||||||
    <div class="px-4 py-5 sm:px-6">
 | 
					    <div class="px-4 py-5 sm:px-6">
 | 
				
			||||||
      <h3 class="text-lg leading-6 font-medium text-gray-900">
 | 
					      <h3 class="text-lg leading-6 font-medium text-gray-900 dark:text-gray-100">
 | 
				
			||||||
        {{ $t('invoices.invoice_information') }}
 | 
					        {{ $t('invoices.invoice_information') }}
 | 
				
			||||||
      </h3>
 | 
					      </h3>
 | 
				
			||||||
    </div>
 | 
					    </div>
 | 
				
			||||||
    <div v-if="invoice" class="border-t border-gray-200 px-4 py-5 sm:p-0">
 | 
					    <div v-if="invoice"
 | 
				
			||||||
      <dl class="sm:divide-y sm:divide-gray-200">
 | 
					      class="
 | 
				
			||||||
 | 
					        border-t
 | 
				
			||||||
 | 
					        border-gray-200
 | 
				
			||||||
 | 
					        px-4 py-5 sm:p-0
 | 
				
			||||||
 | 
					        dark:border-gray-600
 | 
				
			||||||
 | 
					      "
 | 
				
			||||||
 | 
					    >
 | 
				
			||||||
 | 
					      <dl class="sm:divide-y sm:divide-gray-200 sm:dark:divide-gray-500">
 | 
				
			||||||
        <div class="py-4 sm:py-5 sm:grid sm:grid-cols-3 sm:gap-4 sm:px-6">
 | 
					        <div class="py-4 sm:py-5 sm:grid sm:grid-cols-3 sm:gap-4 sm:px-6">
 | 
				
			||||||
          <dt class="text-sm font-medium text-gray-500">
 | 
					          <dt class="text-sm font-medium text-gray-500 dark:dark:text-gray-400">
 | 
				
			||||||
            {{ $t('general.from') }}
 | 
					            {{ $t('general.from') }}
 | 
				
			||||||
          </dt>
 | 
					          </dt>
 | 
				
			||||||
          <dd class="mt-1 text-sm text-gray-900 sm:mt-0 sm:col-span-2">
 | 
					          <dd class="mt-1 text-sm text-gray-900 sm:mt-0 sm:col-span-2 dark:text-gray-100">
 | 
				
			||||||
            {{ invoice.company.name }}
 | 
					            {{ invoice.company.name }}
 | 
				
			||||||
          </dd>
 | 
					          </dd>
 | 
				
			||||||
        </div>
 | 
					        </div>
 | 
				
			||||||
        <div class="py-4 sm:py-5 sm:grid sm:grid-cols-3 sm:gap-4 sm:px-6">
 | 
					        <div class="py-4 sm:py-5 sm:grid sm:grid-cols-3 sm:gap-4 sm:px-6">
 | 
				
			||||||
          <dt class="text-sm font-medium text-gray-500">
 | 
					          <dt class="text-sm font-medium text-gray-500 dark:dark:text-gray-400">
 | 
				
			||||||
            {{ $t('general.to') }}
 | 
					            {{ $t('general.to') }}
 | 
				
			||||||
          </dt>
 | 
					          </dt>
 | 
				
			||||||
          <dd class="mt-1 text-sm text-gray-900 sm:mt-0 sm:col-span-2">
 | 
					          <dd class="mt-1 text-sm text-gray-900 sm:mt-0 sm:col-span-2 dark:text-gray-100">
 | 
				
			||||||
            {{ invoice.customer.name }}
 | 
					            {{ invoice.customer.name }}
 | 
				
			||||||
          </dd>
 | 
					          </dd>
 | 
				
			||||||
        </div>
 | 
					        </div>
 | 
				
			||||||
        <div class="py-4 sm:py-5 sm:grid sm:grid-cols-3 sm:gap-4 sm:px-6">
 | 
					        <div class="py-4 sm:py-5 sm:grid sm:grid-cols-3 sm:gap-4 sm:px-6">
 | 
				
			||||||
          <dt class="text-sm font-medium text-gray-500 capitalize">
 | 
					          <dt class="text-sm font-medium text-gray-500 capitalize dark:dark:text-gray-400">
 | 
				
			||||||
            {{ $t('invoices.paid_status').toLowerCase() }}
 | 
					            {{ $t('invoices.paid_status').toLowerCase() }}
 | 
				
			||||||
          </dt>
 | 
					          </dt>
 | 
				
			||||||
          <dd class="mt-1 text-sm text-gray-900 sm:mt-0 sm:col-span-2">
 | 
					          <dd class="mt-1 text-sm text-gray-900 sm:mt-0 sm:col-span-2 dark:text-gray-100">
 | 
				
			||||||
            <BaseInvoiceStatusBadge
 | 
					            <BaseInvoiceStatusBadge
 | 
				
			||||||
              :status="invoice.paid_status"
 | 
					              :status="invoice.paid_status"
 | 
				
			||||||
              class="px-3 py-1"
 | 
					              class="px-3 py-1"
 | 
				
			||||||
@ -37,10 +44,10 @@
 | 
				
			|||||||
          </dd>
 | 
					          </dd>
 | 
				
			||||||
        </div>
 | 
					        </div>
 | 
				
			||||||
        <div class="py-4 sm:py-5 sm:grid sm:grid-cols-3 sm:gap-4 sm:px-6">
 | 
					        <div class="py-4 sm:py-5 sm:grid sm:grid-cols-3 sm:gap-4 sm:px-6">
 | 
				
			||||||
          <dt class="text-sm font-medium text-gray-500">
 | 
					          <dt class="text-sm font-medium text-gray-500 dark:dark:text-gray-400">
 | 
				
			||||||
            {{ $t('invoices.total') }}
 | 
					            {{ $t('invoices.total') }}
 | 
				
			||||||
          </dt>
 | 
					          </dt>
 | 
				
			||||||
          <dd class="mt-1 text-sm text-gray-900 sm:mt-0 sm:col-span-2">
 | 
					          <dd class="mt-1 text-sm text-gray-900 sm:mt-0 sm:col-span-2 dark:text-gray-100">
 | 
				
			||||||
            <BaseFormatMoney
 | 
					            <BaseFormatMoney
 | 
				
			||||||
              :currency="invoice.currency"
 | 
					              :currency="invoice.currency"
 | 
				
			||||||
              :amount="invoice.total"
 | 
					              :amount="invoice.total"
 | 
				
			||||||
 | 
				
			|||||||
@ -439,7 +439,7 @@ export default {
 | 
				
			|||||||
        container:
 | 
					        container:
 | 
				
			||||||
          'p-0 relative mx-auto w-full flex items-center justify-end box-border cursor-pointer border border-gray-200 dark:border-gray-600 rounded-md bg-white dark:bg-gray-700 text-sm leading-snug outline-none max-h-10',
 | 
					          'p-0 relative mx-auto w-full flex items-center justify-end box-border cursor-pointer border border-gray-200 dark:border-gray-600 rounded-md bg-white dark:bg-gray-700 text-sm leading-snug outline-none max-h-10',
 | 
				
			||||||
        containerDisabled:
 | 
					        containerDisabled:
 | 
				
			||||||
          'bg-gray-200 bg-opacity-50 !text-gray-400 dark:!text-gray-800 !dark:text-gray-500 !cursor-default dark:opacity-25',
 | 
					          'bg-gray-200 !text-gray-800 dark:!text-gray-800 !dark:text-gray-500 !cursor-not-allowed dark:opacity-50',
 | 
				
			||||||
        containerOpen: '',
 | 
					        containerOpen: '',
 | 
				
			||||||
        containerOpenTop: '',
 | 
					        containerOpenTop: '',
 | 
				
			||||||
        containerActive: 'ring-1 ring-primary-400 border-primary-400',
 | 
					        containerActive: 'ring-1 ring-primary-400 border-primary-400',
 | 
				
			||||||
 | 
				
			|||||||
@ -15,12 +15,12 @@
 | 
				
			|||||||
        v-if="label"
 | 
					        v-if="label"
 | 
				
			||||||
        :for="id"
 | 
					        :for="id"
 | 
				
			||||||
        :class="`font-medium ${
 | 
					        :class="`font-medium ${
 | 
				
			||||||
          disabled ? 'text-gray-400 cursor-not-allowed' : 'text-gray-600'
 | 
					          disabled ? 'text-gray-400 cursor-not-allowed' : 'text-gray-600 dark:text-white'
 | 
				
			||||||
        } cursor-pointer `"
 | 
					        } cursor-pointer `"
 | 
				
			||||||
      >
 | 
					      >
 | 
				
			||||||
        {{ label }}
 | 
					        {{ label }}
 | 
				
			||||||
      </label>
 | 
					      </label>
 | 
				
			||||||
      <p v-if="description" class="text-gray-500">{{ description }}</p>
 | 
					      <p v-if="description" class="text-gray-500 dark:text-gray-400">{{ description }}</p>
 | 
				
			||||||
    </div>
 | 
					    </div>
 | 
				
			||||||
  </div>
 | 
					  </div>
 | 
				
			||||||
</template>
 | 
					</template>
 | 
				
			||||||
@ -51,7 +51,7 @@ const props = defineProps({
 | 
				
			|||||||
  },
 | 
					  },
 | 
				
			||||||
  checkboxClass: {
 | 
					  checkboxClass: {
 | 
				
			||||||
    type: String,
 | 
					    type: String,
 | 
				
			||||||
    default: 'w-4 h-4 border-gray-300 rounded cursor-pointer',
 | 
					    default: 'w-4 h-4 border-gray-300 rounded cursor-pointer dark:bg-gray-600 dark:border-gray-500',
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
  setInitialValue: {
 | 
					  setInitialValue: {
 | 
				
			||||||
    type: Boolean,
 | 
					    type: Boolean,
 | 
				
			||||||
 | 
				
			|||||||
@ -39,6 +39,8 @@ $base-content-placeholders-border-radius: 6px !default;
 | 
				
			|||||||
$base-content-placeholders-line-height: 15px !default;
 | 
					$base-content-placeholders-line-height: 15px !default;
 | 
				
			||||||
$base-content-placeholders-spacing: 10px !default;
 | 
					$base-content-placeholders-spacing: 10px !default;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					$base-content-placeholders-primary-color-dark: rgb(71, 85, 105) !default;
 | 
				
			||||||
 | 
					$base-content-placeholders-secondary-color-dark: rgb(71, 85, 105) !default;
 | 
				
			||||||
// Animations
 | 
					// Animations
 | 
				
			||||||
@keyframes vueContentPlaceholdersAnimation {
 | 
					@keyframes vueContentPlaceholdersAnimation {
 | 
				
			||||||
  0% {
 | 
					  0% {
 | 
				
			||||||
@ -57,6 +59,10 @@ $base-content-placeholders-spacing: 10px !default;
 | 
				
			|||||||
  min-height: $base-content-placeholders-line-height;
 | 
					  min-height: $base-content-placeholders-line-height;
 | 
				
			||||||
  background: $base-content-placeholders-secondary-color;
 | 
					  background: $base-content-placeholders-secondary-color;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  .dark & {
 | 
				
			||||||
 | 
					    background: $base-content-placeholders-secondary-color-dark;
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
  .base-content-placeholders-is-rounded & {
 | 
					  .base-content-placeholders-is-rounded & {
 | 
				
			||||||
    border-radius: $base-content-placeholders-border-radius;
 | 
					    border-radius: $base-content-placeholders-border-radius;
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
@ -86,6 +92,15 @@ $base-content-placeholders-spacing: 10px !default;
 | 
				
			|||||||
    animation-name: vueContentPlaceholdersAnimation;
 | 
					    animation-name: vueContentPlaceholdersAnimation;
 | 
				
			||||||
    animation-timing-function: linear;
 | 
					    animation-timing-function: linear;
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  .dark .base-content-placeholders-is-animated &::before {
 | 
				
			||||||
 | 
					    background: linear-gradient(
 | 
				
			||||||
 | 
					      to right,
 | 
				
			||||||
 | 
					      transparent 0%,
 | 
				
			||||||
 | 
					      darken($base-content-placeholders-secondary-color-dark, 5%) 15%,
 | 
				
			||||||
 | 
					      transparent 30%
 | 
				
			||||||
 | 
					    );
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@mixin base-content-placeholders-spacing {
 | 
					@mixin base-content-placeholders-spacing {
 | 
				
			||||||
@ -156,6 +171,10 @@ $base-content-placeholders-spacing: 10px !default;
 | 
				
			|||||||
  min-height: $base-content-placeholders-line-height;
 | 
					  min-height: $base-content-placeholders-line-height;
 | 
				
			||||||
  background: $base-content-placeholders-secondary-color;
 | 
					  background: $base-content-placeholders-secondary-color;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					  .dark & {
 | 
				
			||||||
 | 
					    background: $base-content-placeholders-secondary-color-dark;
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
 | 
					  
 | 
				
			||||||
  .base-content-placeholders-is-animated &::before {
 | 
					  .base-content-placeholders-is-animated &::before {
 | 
				
			||||||
    content: '';
 | 
					    content: '';
 | 
				
			||||||
    position: absolute;
 | 
					    position: absolute;
 | 
				
			||||||
@ -177,6 +196,14 @@ $base-content-placeholders-spacing: 10px !default;
 | 
				
			|||||||
    animation-timing-function: linear;
 | 
					    animation-timing-function: linear;
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    .dark .base-content-placeholders-is-animated &::before {
 | 
				
			||||||
 | 
					      background: linear-gradient(
 | 
				
			||||||
 | 
					      to right,
 | 
				
			||||||
 | 
					      transparent 0%,
 | 
				
			||||||
 | 
					      darken($base-content-placeholders-secondary-color-dark, 5%) 15%,
 | 
				
			||||||
 | 
					      transparent 30%
 | 
				
			||||||
 | 
					    );
 | 
				
			||||||
 | 
					  }
 | 
				
			||||||
  // @include base-content-placeholders-spacing;
 | 
					  // @include base-content-placeholders-spacing;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
				
			|||||||
@ -40,6 +40,7 @@
 | 
				
			|||||||
                font-normal
 | 
					                font-normal
 | 
				
			||||||
                cursor-pointer
 | 
					                cursor-pointer
 | 
				
			||||||
                hover:bg-gray-100
 | 
					                hover:bg-gray-100
 | 
				
			||||||
 | 
					                dark:hover:bg-gray-700/60
 | 
				
			||||||
                rounded
 | 
					                rounded
 | 
				
			||||||
                ml-1
 | 
					                ml-1
 | 
				
			||||||
                py-0.5
 | 
					                py-0.5
 | 
				
			||||||
 | 
				
			|||||||
@ -1,7 +1,7 @@
 | 
				
			|||||||
<template>
 | 
					<template>
 | 
				
			||||||
  <div
 | 
					  <div
 | 
				
			||||||
    v-if="address"
 | 
					    v-if="address"
 | 
				
			||||||
    class="text-sm font-bold leading-5 text-black non-italic space-y-1"
 | 
					    class="text-sm font-bold leading-5 text-black non-italic space-y-1 dark:text-white"
 | 
				
			||||||
  >
 | 
					  >
 | 
				
			||||||
    <p v-if="address?.address_street_1">{{ address?.address_street_1 }},</p>
 | 
					    <p v-if="address?.address_street_1">{{ address?.address_street_1 }},</p>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
				
			|||||||
@ -20,6 +20,7 @@
 | 
				
			|||||||
        border border-gray-200 border-solid
 | 
					        border border-gray-200 border-solid
 | 
				
			||||||
        min-h-[170px]
 | 
					        min-h-[170px]
 | 
				
			||||||
        rounded-md
 | 
					        rounded-md
 | 
				
			||||||
 | 
					        dark:border-white/10 dark:bg-gray-800/50
 | 
				
			||||||
      "
 | 
					      "
 | 
				
			||||||
      @click.stop
 | 
					      @click.stop
 | 
				
			||||||
    >
 | 
					    >
 | 
				
			||||||
@ -27,7 +28,7 @@
 | 
				
			|||||||
        <BaseText
 | 
					        <BaseText
 | 
				
			||||||
          :text="selectedCustomer.name"
 | 
					          :text="selectedCustomer.name"
 | 
				
			||||||
          :length="30"
 | 
					          :length="30"
 | 
				
			||||||
          class="flex-1 text-base font-medium text-left text-gray-900"
 | 
					          class="flex-1 text-base font-medium text-left text-gray-900 dark:text-white"
 | 
				
			||||||
        />
 | 
					        />
 | 
				
			||||||
        <div class="flex">
 | 
					        <div class="flex">
 | 
				
			||||||
          <a
 | 
					          <a
 | 
				
			||||||
@ -192,6 +193,7 @@
 | 
				
			|||||||
            border border-gray-200 border-solid
 | 
					            border border-gray-200 border-solid
 | 
				
			||||||
            rounded-md
 | 
					            rounded-md
 | 
				
			||||||
            min-h-[170px]
 | 
					            min-h-[170px]
 | 
				
			||||||
 | 
					            dark:border-white/10 dark:bg-gray-700/60 dark:text-white
 | 
				
			||||||
          "
 | 
					          "
 | 
				
			||||||
        >
 | 
					        >
 | 
				
			||||||
          <BaseIcon
 | 
					          <BaseIcon
 | 
				
			||||||
@ -207,11 +209,12 @@
 | 
				
			|||||||
              bg-gray-200
 | 
					              bg-gray-200
 | 
				
			||||||
              rounded-full
 | 
					              rounded-full
 | 
				
			||||||
              font-base
 | 
					              font-base
 | 
				
			||||||
 | 
					              dark:bg-gray-700
 | 
				
			||||||
            "
 | 
					            "
 | 
				
			||||||
          />
 | 
					          />
 | 
				
			||||||
 | 
					
 | 
				
			||||||
          <div class="mt-1">
 | 
					          <div class="mt-1">
 | 
				
			||||||
            <label class="text-lg font-medium text-gray-900">
 | 
					            <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>
 | 
				
			||||||
@ -246,6 +249,11 @@
 | 
				
			|||||||
              shadow-lg
 | 
					              shadow-lg
 | 
				
			||||||
              ring-1 ring-black ring-opacity-5
 | 
					              ring-1 ring-black ring-opacity-5
 | 
				
			||||||
              bg-white
 | 
					              bg-white
 | 
				
			||||||
 | 
					               dark:border
 | 
				
			||||||
 | 
					              dark:border-white/10
 | 
				
			||||||
 | 
					              dark:bg-gray-800
 | 
				
			||||||
 | 
					              dark:text-white
 | 
				
			||||||
 | 
					              dark:shadow-glass
 | 
				
			||||||
            "
 | 
					            "
 | 
				
			||||||
          >
 | 
					          >
 | 
				
			||||||
            <div class="relative">
 | 
					            <div class="relative">
 | 
				
			||||||
@ -265,6 +273,7 @@
 | 
				
			|||||||
                  overflow-auto
 | 
					                  overflow-auto
 | 
				
			||||||
                  list
 | 
					                  list
 | 
				
			||||||
                  border-t border-gray-200
 | 
					                  border-t border-gray-200
 | 
				
			||||||
 | 
					                  dark:border-white/10
 | 
				
			||||||
                "
 | 
					                "
 | 
				
			||||||
              >
 | 
					              >
 | 
				
			||||||
                <li
 | 
					                <li
 | 
				
			||||||
@ -280,6 +289,7 @@
 | 
				
			|||||||
                    hover:cursor-pointer hover:bg-gray-100
 | 
					                    hover:cursor-pointer hover:bg-gray-100
 | 
				
			||||||
                    focus:outline-none focus:bg-gray-100
 | 
					                    focus:outline-none focus:bg-gray-100
 | 
				
			||||||
                    last:border-b-0
 | 
					                    last:border-b-0
 | 
				
			||||||
 | 
					                    dark:border-white/10 dark:hover:bg-gray-700/30
 | 
				
			||||||
                  "
 | 
					                  "
 | 
				
			||||||
                  @click="selectNewCustomer(customer.id, close)"
 | 
					                  @click="selectNewCustomer(customer.id, close)"
 | 
				
			||||||
                >
 | 
					                >
 | 
				
			||||||
@ -299,6 +309,7 @@
 | 
				
			|||||||
                      bg-gray-300
 | 
					                      bg-gray-300
 | 
				
			||||||
                      rounded-full
 | 
					                      rounded-full
 | 
				
			||||||
                      avatar
 | 
					                      avatar
 | 
				
			||||||
 | 
					                      dark:bg-gray-600
 | 
				
			||||||
                    "
 | 
					                    "
 | 
				
			||||||
                  >
 | 
					                  >
 | 
				
			||||||
                    {{ initGenerator(customer.name) }}
 | 
					                    {{ initGenerator(customer.name) }}
 | 
				
			||||||
@ -333,9 +344,9 @@
 | 
				
			|||||||
                </li>
 | 
					                </li>
 | 
				
			||||||
                <div
 | 
					                <div
 | 
				
			||||||
                  v-if="customerStore.customers.length === 0"
 | 
					                  v-if="customerStore.customers.length === 0"
 | 
				
			||||||
                  class="flex justify-center p-5 text-gray-400"
 | 
					                  class="flex justify-center p-5 text-gray-400 dark:text-gray-300"
 | 
				
			||||||
                >
 | 
					                >
 | 
				
			||||||
                  <label class="text-base text-gray-500 cursor-pointer">
 | 
					                  <label class="text-base text-gray-500 cursor-pointer dark:text-gray-300">
 | 
				
			||||||
                    {{ $t('customers.no_customers_found') }}
 | 
					                    {{ $t('customers.no_customers_found') }}
 | 
				
			||||||
                  </label>
 | 
					                  </label>
 | 
				
			||||||
                </div>
 | 
					                </div>
 | 
				
			||||||
@ -357,6 +368,10 @@
 | 
				
			|||||||
                border-none
 | 
					                border-none
 | 
				
			||||||
                outline-none
 | 
					                outline-none
 | 
				
			||||||
                focus:bg-gray-300
 | 
					                focus:bg-gray-300
 | 
				
			||||||
 | 
					                dark:bg-gray-600/70
 | 
				
			||||||
 | 
					                dark:shadow-glass
 | 
				
			||||||
 | 
					                dark:backdrop-blur-xl
 | 
				
			||||||
 | 
					                dark:hover:bg-gray-600/80
 | 
				
			||||||
              "
 | 
					              "
 | 
				
			||||||
              @click="openCustomerModal"
 | 
					              @click="openCustomerModal"
 | 
				
			||||||
            >
 | 
					            >
 | 
				
			||||||
 | 
				
			|||||||
@ -28,6 +28,7 @@
 | 
				
			|||||||
      :attributes="attrs"
 | 
					      :attributes="attrs"
 | 
				
			||||||
      :model-config="config"
 | 
					      :model-config="config"
 | 
				
			||||||
      :masks="masks"
 | 
					      :masks="masks"
 | 
				
			||||||
 | 
					      :is-dark="isDarkModeOn"
 | 
				
			||||||
      :locale="global.locale"
 | 
					      :locale="global.locale"
 | 
				
			||||||
    >
 | 
					    >
 | 
				
			||||||
      <template
 | 
					      <template
 | 
				
			||||||
@ -72,7 +73,7 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
      <template v-if="showExtraOptions" #footer>
 | 
					      <template v-if="showExtraOptions" #footer>
 | 
				
			||||||
        <div
 | 
					        <div
 | 
				
			||||||
          class="bg-gray-100 grid grid-cols-3 gap-2 p-2 border-t rounded-b-lg"
 | 
					          class="bg-gray-100 dark:bg-gray-800 grid grid-cols-3 gap-2 p-2 border-t dark:border-gray-500 rounded-b-lg"
 | 
				
			||||||
        >
 | 
					        >
 | 
				
			||||||
          <button type="button" class="extra-button" @click="moveToDate(sourceDate)">
 | 
					          <button type="button" class="extra-button" @click="moveToDate(sourceDate)">
 | 
				
			||||||
            {{ global.t('date_picker.same_day') }}
 | 
					            {{ global.t('date_picker.same_day') }}
 | 
				
			||||||
@ -146,7 +147,7 @@ const props = defineProps({
 | 
				
			|||||||
  defaultInputClass: {
 | 
					  defaultInputClass: {
 | 
				
			||||||
    type: String,
 | 
					    type: String,
 | 
				
			||||||
    default:
 | 
					    default:
 | 
				
			||||||
      'border-2 font-base pl-8 py-2 outline-none focus:ring-primary-400 focus:outline-none focus:border-primary-400 block w-full sm:text-sm border-gray-200 rounded-md text-black',
 | 
					      'border-2 dark:bg-gray-700 dark:border-gray-600 dark:text-white font-base pl-8 py-2 outline-none focus:ring-primary-400 focus:outline-none focus:border-primary-400 block w-full sm:text-sm border-gray-200 rounded-md text-black',
 | 
				
			||||||
  },
 | 
					  },
 | 
				
			||||||
  time24hr: {
 | 
					  time24hr: {
 | 
				
			||||||
    type: Boolean,
 | 
					    type: Boolean,
 | 
				
			||||||
@ -163,7 +164,7 @@ const props = defineProps({
 | 
				
			|||||||
  sourceDate: {
 | 
					  sourceDate: {
 | 
				
			||||||
    type: [String, Date],
 | 
					    type: [String, Date],
 | 
				
			||||||
    default: () => new Date(),
 | 
					    default: () => new Date(),
 | 
				
			||||||
  }
 | 
					  },
 | 
				
			||||||
})
 | 
					})
 | 
				
			||||||
 | 
					
 | 
				
			||||||
const emit = defineEmits(['update:modelValue'])
 | 
					const emit = defineEmits(['update:modelValue'])
 | 
				
			||||||
@ -175,6 +176,9 @@ const vCalendar = ref(null)
 | 
				
			|||||||
const hasIconSlot = computed(() => {
 | 
					const hasIconSlot = computed(() => {
 | 
				
			||||||
  return !!slots.icon
 | 
					  return !!slots.icon
 | 
				
			||||||
})
 | 
					})
 | 
				
			||||||
 | 
					const isDarkModeOn = computed(() =>
 | 
				
			||||||
 | 
					  document.documentElement.classList.contains('dark')
 | 
				
			||||||
 | 
					)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
const computedContainerClass = computed(() => {
 | 
					const computedContainerClass = computed(() => {
 | 
				
			||||||
  let containerClass = `${props.containerClass} `
 | 
					  let containerClass = `${props.containerClass} `
 | 
				
			||||||
 | 
				
			|||||||
@ -10,7 +10,7 @@
 | 
				
			|||||||
        {{ label }}
 | 
					        {{ label }}
 | 
				
			||||||
      </BaseLabel>
 | 
					      </BaseLabel>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
      <p class="text-sm font-bold leading-5 text-black non-italic">
 | 
					      <p class="text-sm font-bold leading-5 text-black non-italic dark:text-white">
 | 
				
			||||||
        {{ value }}
 | 
					        {{ value }}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        <slot />
 | 
					        <slot />
 | 
				
			||||||
 | 
				
			|||||||
@ -30,8 +30,13 @@
 | 
				
			|||||||
          leave-to="opacity-0"
 | 
					          leave-to="opacity-0"
 | 
				
			||||||
        >
 | 
					        >
 | 
				
			||||||
          <DialogOverlay
 | 
					          <DialogOverlay
 | 
				
			||||||
            class="fixed inset-0 transition-opacity bg-gray-500 bg-opacity-75"
 | 
					            class="fixed inset-0 transition-opacity bg-gray-500 bg-opacity-75 dark:backdrop-blur-xl dark:bg-gray-900/80"
 | 
				
			||||||
 | 
					          >
 | 
				
			||||||
 | 
					           <BaseDarkHighlight
 | 
				
			||||||
 | 
					            class="!bg-highlight/[.17] !top-1/2 h-60 -translate-y-1/2 mt-5"
 | 
				
			||||||
 | 
					            :class="dialogSizeClasses"
 | 
				
			||||||
          />
 | 
					          />
 | 
				
			||||||
 | 
					          </DialogOverlay>
 | 
				
			||||||
        </TransitionChild>
 | 
					        </TransitionChild>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        <!-- This element is to trick the browser into centering the modal contents. -->
 | 
					        <!-- This element is to trick the browser into centering the modal contents. -->
 | 
				
			||||||
@ -64,6 +69,11 @@
 | 
				
			|||||||
              shadow-xl
 | 
					              shadow-xl
 | 
				
			||||||
              sm:my-8 sm:align-middle sm:w-full sm:p-6
 | 
					              sm:my-8 sm:align-middle sm:w-full sm:p-6
 | 
				
			||||||
              relative
 | 
					              relative
 | 
				
			||||||
 | 
					              dark:backdrop-blur-xl
 | 
				
			||||||
 | 
					              dark:shadow-glass
 | 
				
			||||||
 | 
					              dark:border
 | 
				
			||||||
 | 
					              dark:border-white/10
 | 
				
			||||||
 | 
					              dark:bg-gray-800
 | 
				
			||||||
            "
 | 
					            "
 | 
				
			||||||
            :class="dialogSizeClasses"
 | 
					            :class="dialogSizeClasses"
 | 
				
			||||||
          >
 | 
					          >
 | 
				
			||||||
@ -80,31 +90,31 @@
 | 
				
			|||||||
                  rounded-full
 | 
					                  rounded-full
 | 
				
			||||||
                "
 | 
					                "
 | 
				
			||||||
                :class="{
 | 
					                :class="{
 | 
				
			||||||
                  'bg-green-100': dialogStore.variant === 'primary',
 | 
					                  'bg-green-100 dark:bg-primary-500': dialogStore.variant === 'primary',
 | 
				
			||||||
                  'bg-red-100': dialogStore.variant === 'danger',
 | 
					                  'bg-red-100 dark:bg-red-500': dialogStore.variant === 'danger',
 | 
				
			||||||
                }"
 | 
					                }"
 | 
				
			||||||
              >
 | 
					              >
 | 
				
			||||||
                <BaseIcon
 | 
					                <BaseIcon
 | 
				
			||||||
                  v-if="dialogStore.variant === 'primary'"
 | 
					                  v-if="dialogStore.variant === 'primary'"
 | 
				
			||||||
                  name="CheckIcon"
 | 
					                  name="CheckIcon"
 | 
				
			||||||
                  class="w-6 h-6 text-green-600"
 | 
					                  class="w-6 h-6 text-green-600 dark:text-white"
 | 
				
			||||||
                />
 | 
					                />
 | 
				
			||||||
                <BaseIcon
 | 
					                <BaseIcon
 | 
				
			||||||
                  v-else
 | 
					                  v-else
 | 
				
			||||||
                  name="ExclamationIcon"
 | 
					                  name="ExclamationIcon"
 | 
				
			||||||
                  class="w-6 h-6 text-red-600"
 | 
					                  class="w-6 h-6 text-red-600 dark:text-white"
 | 
				
			||||||
                  aria-hidden="true"
 | 
					                  aria-hidden="true"
 | 
				
			||||||
                />
 | 
					                />
 | 
				
			||||||
              </div>
 | 
					              </div>
 | 
				
			||||||
              <div class="mt-3 text-center sm:mt-5">
 | 
					              <div class="mt-3 text-center sm:mt-5">
 | 
				
			||||||
                <DialogTitle
 | 
					                <DialogTitle
 | 
				
			||||||
                  as="h3"
 | 
					                  as="h3"
 | 
				
			||||||
                  class="text-lg font-medium leading-6 text-gray-900"
 | 
					                  class="text-lg font-medium leading-6 text-gray-900 dark:text-white"
 | 
				
			||||||
                >
 | 
					                >
 | 
				
			||||||
                  {{ dialogStore.title }}
 | 
					                  {{ dialogStore.title }}
 | 
				
			||||||
                </DialogTitle>
 | 
					                </DialogTitle>
 | 
				
			||||||
                <div class="mt-2">
 | 
					                <div class="mt-2">
 | 
				
			||||||
                  <p class="text-sm text-gray-500">
 | 
					                  <p class="text-sm text-gray-500 dark:text-gray-400">
 | 
				
			||||||
                    {{ dialogStore.message }}
 | 
					                    {{ dialogStore.message }}
 | 
				
			||||||
                  </p>
 | 
					                  </p>
 | 
				
			||||||
                </div>
 | 
					                </div>
 | 
				
			||||||
 | 
				
			|||||||
@ -1,3 +1,3 @@
 | 
				
			|||||||
<template>
 | 
					<template>
 | 
				
			||||||
  <hr class="w-full text-gray-300" />
 | 
					  <div class="w-full h-px bg-gray-300 dark:bg-gray-600" />
 | 
				
			||||||
</template>
 | 
					</template>
 | 
				
			||||||
 | 
				
			|||||||
@ -69,7 +69,8 @@ const props = defineProps({
 | 
				
			|||||||
})
 | 
					})
 | 
				
			||||||
 | 
					
 | 
				
			||||||
const containerClasses = computed(() => {
 | 
					const containerClasses = computed(() => {
 | 
				
			||||||
  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`
 | 
					  const baseClass = `dark:border dark:border-white/10 dark:text-white dark:bg-gray-800 dark:shadow-glass
 | 
				
			||||||
 | 
					  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,16 +2,20 @@
 | 
				
			|||||||
  <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 ? 'bg-gray-100 text-gray-900' : 'text-gray-700',
 | 
					        active
 | 
				
			||||||
        'group flex items-center px-4 py-2 text-sm font-normal',
 | 
					          ? 'bg-gray-100 text-gray-900 dark:text-white dark:bg-gray-700'
 | 
				
			||||||
 | 
					          : 'text-gray-700 dark:text-gray-200',
 | 
				
			||||||
      ]"
 | 
					      ]"
 | 
				
			||||||
    >
 | 
					    >
 | 
				
			||||||
      <slot :active="active" />
 | 
					      <slot :active="active" :class="defaultIconClass" />
 | 
				
			||||||
    </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>
 | 
				
			||||||
 | 
				
			|||||||
@ -1,18 +1,24 @@
 | 
				
			|||||||
<template>
 | 
					<template>
 | 
				
			||||||
  <div class="flex flex-col items-center justify-center mt-16">
 | 
					  <div class="flex flex-col items-center justify-center mt-16">
 | 
				
			||||||
    <div class="flex flex-col items-center justify-center">
 | 
					    <div class="relative">
 | 
				
			||||||
      <slot></slot>
 | 
					      <BaseDarkHighlight class="bg-highlight/[.07] top-2" />
 | 
				
			||||||
    </div>
 | 
					
 | 
				
			||||||
    <div class="mt-2">
 | 
					      <div class="relative z-5 flex flex-col items-center">
 | 
				
			||||||
      <label class="font-medium">{{ title }}</label>
 | 
					        <div class="flex flex-col items-center justify-center">
 | 
				
			||||||
    </div>
 | 
					          <slot />
 | 
				
			||||||
    <div class="mt-2">
 | 
					        </div>
 | 
				
			||||||
      <label class="text-gray-500">
 | 
					        <div class="mt-2">
 | 
				
			||||||
        {{ description }}
 | 
					          <label class="font-medium">{{ title }}</label>
 | 
				
			||||||
      </label>
 | 
					        </div>
 | 
				
			||||||
    </div>
 | 
					        <div class="mt-2 text-center md:text-left">
 | 
				
			||||||
    <div class="mt-6">
 | 
					          <label class="text-gray-500 dark:text-gray-400">
 | 
				
			||||||
      <slot name="actions" />
 | 
					            {{ description }}
 | 
				
			||||||
 | 
					          </label>
 | 
				
			||||||
 | 
					        </div>
 | 
				
			||||||
 | 
					        <div class="mt-6">
 | 
				
			||||||
 | 
					          <slot name="actions" />
 | 
				
			||||||
 | 
					        </div>
 | 
				
			||||||
 | 
					      </div>
 | 
				
			||||||
    </div>
 | 
					    </div>
 | 
				
			||||||
  </div>
 | 
					  </div>
 | 
				
			||||||
</template>
 | 
					</template>
 | 
				
			||||||
 | 
				
			|||||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user