mirror of
				https://github.com/crater-invoice/crater.git
				synced 2025-11-04 06:23:17 -05:00 
			
		
		
		
	
		
			
				
	
	
		
			135 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
			
		
		
	
	
			135 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
<template>
 | 
						|
  <form @submit.prevent="submitForm">
 | 
						|
    <h6 class="text-gray-900 text-lg font-medium">
 | 
						|
      {{ $t('settings.customization.invoices.due_date') }}
 | 
						|
    </h6>
 | 
						|
    <p class="mt-1 text-sm text-gray-500 mb-2">
 | 
						|
      {{ $t('settings.customization.invoices.due_date_description') }}
 | 
						|
    </p>
 | 
						|
 | 
						|
    <BaseSwitchSection
 | 
						|
      v-model="dueDateAutoField"
 | 
						|
      :title="$t('settings.customization.invoices.set_due_date_automatically')"
 | 
						|
      :description="
 | 
						|
        $t(
 | 
						|
          'settings.customization.invoices.set_due_date_automatically_description'
 | 
						|
        )
 | 
						|
      "
 | 
						|
    />
 | 
						|
 | 
						|
    <BaseInputGroup
 | 
						|
      v-if="dueDateAutoField"
 | 
						|
      :label="$t('settings.customization.invoices.due_date_days')"
 | 
						|
      :error="
 | 
						|
        v$.dueDateSettings.invoice_due_date_days.$error &&
 | 
						|
        v$.dueDateSettings.invoice_due_date_days.$errors[0].$message
 | 
						|
      "
 | 
						|
      class="mt-2 mb-4"
 | 
						|
    >
 | 
						|
      <div class="w-full sm:w-1/2 md:w-1/4 lg:w-1/5">
 | 
						|
        <BaseInput
 | 
						|
          v-model="dueDateSettings.invoice_due_date_days"
 | 
						|
          :invalid="v$.dueDateSettings.invoice_due_date_days.$error"
 | 
						|
          type="number"
 | 
						|
          @input="v$.dueDateSettings.invoice_due_date_days.$touch()"
 | 
						|
        />
 | 
						|
      </div>
 | 
						|
    </BaseInputGroup>
 | 
						|
 | 
						|
    <BaseButton
 | 
						|
      :loading="isSaving"
 | 
						|
      :disabled="isSaving"
 | 
						|
      variant="primary"
 | 
						|
      type="submit"
 | 
						|
      class="mt-4"
 | 
						|
    >
 | 
						|
      <template #left="slotProps">
 | 
						|
        <BaseIcon v-if="!isSaving" :class="slotProps.class" name="SaveIcon" />
 | 
						|
      </template>
 | 
						|
      {{ $t('settings.customization.save') }}
 | 
						|
    </BaseButton>
 | 
						|
  </form>
 | 
						|
</template>
 | 
						|
 | 
						|
<script setup>
 | 
						|
import { ref, computed, onMounted, reactive, inject } from 'vue'
 | 
						|
import { useI18n } from 'vue-i18n'
 | 
						|
import { useCompanyStore } from '@/scripts/admin/stores/company'
 | 
						|
import { numeric, helpers, requiredIf } from '@vuelidate/validators'
 | 
						|
 | 
						|
import useVuelidate from '@vuelidate/core'
 | 
						|
 | 
						|
const { t } = useI18n()
 | 
						|
const companyStore = useCompanyStore()
 | 
						|
 | 
						|
const utils = inject('utils')
 | 
						|
 | 
						|
let isSaving = ref(false)
 | 
						|
 | 
						|
const dueDateSettings = reactive({
 | 
						|
  invoice_set_due_date_automatically: null,
 | 
						|
  invoice_due_date_days: null,
 | 
						|
})
 | 
						|
 | 
						|
utils.mergeSettings(dueDateSettings, {
 | 
						|
  ...companyStore.selectedCompanySettings,
 | 
						|
})
 | 
						|
 | 
						|
const dueDateAutoField = computed({
 | 
						|
  get: () => {
 | 
						|
    return dueDateSettings.invoice_set_due_date_automatically === 'YES'
 | 
						|
  },
 | 
						|
  set: async (newValue) => {
 | 
						|
    const value = newValue ? 'YES' : 'NO'
 | 
						|
 | 
						|
    dueDateSettings.invoice_set_due_date_automatically = value
 | 
						|
  },
 | 
						|
})
 | 
						|
 | 
						|
const rules = computed(() => {
 | 
						|
  return {
 | 
						|
    dueDateSettings: {
 | 
						|
      invoice_due_date_days: {
 | 
						|
        required: helpers.withMessage(
 | 
						|
          t('validation.required'),
 | 
						|
          requiredIf(dueDateAutoField.value)
 | 
						|
        ),
 | 
						|
        numeric: helpers.withMessage(t('validation.numbers_only'), numeric),
 | 
						|
      },
 | 
						|
    },
 | 
						|
  }
 | 
						|
})
 | 
						|
 | 
						|
const v$ = useVuelidate(rules, { dueDateSettings })
 | 
						|
 | 
						|
async function submitForm() {
 | 
						|
  v$.value.dueDateSettings.$touch()
 | 
						|
 | 
						|
  if (v$.value.dueDateSettings.$invalid) {
 | 
						|
    return false
 | 
						|
  }
 | 
						|
 | 
						|
  isSaving.value = true
 | 
						|
 | 
						|
  let data = {
 | 
						|
    settings: {
 | 
						|
      ...dueDateSettings,
 | 
						|
    },
 | 
						|
  }
 | 
						|
  // Don't pass due_date_days if setting is not enabled
 | 
						|
 | 
						|
  if (!dueDateAutoField.value) {
 | 
						|
    delete data.settings.invoice_due_date_days
 | 
						|
  }
 | 
						|
 | 
						|
  await companyStore.updateCompanySettings({
 | 
						|
    data,
 | 
						|
    message: 'settings.customization.invoices.invoice_settings_updated',
 | 
						|
  })
 | 
						|
 | 
						|
  isSaving.value = false
 | 
						|
 | 
						|
  return true
 | 
						|
}
 | 
						|
</script>
 |