| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278 |
- <template>
- <q-dialog ref="dialogRef" @hide="onDialogHide">
- <q-card
- class="q-dialog-plugin overflow-hidden"
- style="width: 100%; max-width: 1100px"
- >
- <DefaultDialogHeader
- :title="() => 'Criar novo contrato'"
- @close="onDialogCancel"
- />
- <q-card-section>
- <div class="text-body2 q-mb-sm">Dados da Unidade</div>
- <div class="row q-col-gutter-x-sm">
- <DefaultInput
- :model-value="unitData.id"
- label="ID"
- color="secondary"
- label-color="secondary"
- class="col-md-3 col-12"
- disable
- />
- <DefaultInput
- :model-value="unitData.franchisee_name"
- label="Nome do Franqueado"
- color="secondary"
- label-color="secondary"
- class="col-md-3 col-12"
- disable
- />
- <DefaultInput
- :model-value="unitData.franchisee_document"
- label="CPF/CNH"
- color="secondary"
- label-color="secondary"
- class="col-md-3 col-12"
- disable
- />
- <DefaultInput
- :model-value="unitData.franchisee_birthday"
- label="Data de Nascimento"
- color="secondary"
- label-color="secondary"
- class="col-md-3 col-12"
- disable
- />
- </div>
- </q-card-section>
- <q-card-section>
- <div class="text-body2 q-mb-sm">Definir Valores e TBR</div>
- <div class="row q-col-gutter-sm">
- <DefaultInputDatePicker
- v-model:untreated-date="contractForm.start_date"
- label="Data de Início"
- color="secondary"
- label-color="secondary"
- class="col-md-3 col-12"
- />
- <DefaultInputDatePicker
- v-model:untreated-date="contractForm.end_date"
- label="Data de Fim"
- color="secondary"
- label-color="secondary"
- class="col-md-3 col-12"
- />
- <DefaultCurrencyInput
- v-model="contractForm.tbr_fixed_value"
- label="TBR $"
- color="secondary"
- label-color="secondary"
- class="col-md-3 col-12"
- />
- <DefaultInputDatePicker
- v-model:untreated-date="contractForm.invoice_due_date"
- label="Vencimento Boleto"
- color="secondary"
- label-color="secondary"
- class="col-md-3 col-12"
- />
- <DefaultSelect
- v-model="contractForm.inhabitant_classification_id"
- label="Faixa de Habitante"
- color="secondary"
- label-color="secondary"
- :options="inhabitantOptions"
- emit-value
- map-options
- use-input
- fill-input
- input-debounce="0"
- class="col-md-3 col-12"
- />
- <DefaultInput
- v-model="contractForm.tax_base_royalts"
- label="Taxa Base Royalties"
- color="secondary"
- label-color="secondary"
- type="number"
- class="col-md-3 col-12"
- >
- <template #append>
- <span class="text-secondary">%</span>
- </template>
- </DefaultInput>
- <DefaultInput
- v-model="contractForm.tax_base_fnm"
- label="Taxa Base FMN"
- color="secondary"
- label-color="secondary"
- type="number"
- class="col-md-3 col-12"
- >
- <template #append>
- <span class="text-secondary">%</span>
- </template>
- </DefaultInput>
- <DefaultInput
- v-model="contractForm.tax_base_maintenance"
- label="Taxa Base Manutenção"
- color="secondary"
- label-color="secondary"
- type="number"
- class="col-md-3 col-12"
- >
- <template #append>
- <span class="text-secondary">%</span>
- </template>
- </DefaultInput>
- </div>
- </q-card-section>
- <q-card-actions align="right">
- <q-btn
- outline
- color="primary"
- label="Cancelar"
- @click="onDialogCancel"
- />
- <q-btn
- color="primary"
- label="Salvar"
- :loading="saving"
- @click="save"
- />
- </q-card-actions>
- </q-card>
- </q-dialog>
- </template>
- <script setup>
- import { ref, reactive, onMounted } from "vue";
- import { useDialogPluginComponent } from "quasar";
- import DefaultDialogHeader from "src/components/defaults/DefaultDialogHeader.vue";
- import DefaultInput from "src/components/defaults/DefaultInput.vue";
- import DefaultInputDatePicker from "src/components/defaults/DefaultInputDatePicker.vue";
- import DefaultCurrencyInput from "src/components/defaults/DefaultCurrencyInput.vue";
- import DefaultSelect from "src/components/defaults/DefaultSelect.vue";
- import { getUnit } from "src/api/unit";
- import { getLatestTbr } from "src/api/tbr";
- import { getInhabitantClassificationsForSelect } from "src/api/inhabitant_classification";
- import { createFranchiseeContract } from "src/api/franchisee_contract";
- defineEmits([...useDialogPluginComponent.emits]);
- const props = defineProps({
- unitId: {
- type: Number,
- required: true,
- },
- });
- const { dialogRef, onDialogHide, onDialogCancel, onDialogOK } =
- useDialogPluginComponent();
- const saving = ref(false);
- const inhabitantOptions = ref([]);
- const unitData = reactive({
- id: null,
- franchisee_name: null,
- franchisee_document: null,
- franchisee_birthday: null,
- });
- const contractForm = reactive({
- start_date: null,
- end_date: null,
- tbr_fixed_value: null,
- invoice_due_date: null,
- inhabitant_classification_id: null,
- tax_base_royalts: null,
- tax_base_fnm: null,
- tax_base_maintenance: null,
- });
- async function loadData() {
- const [unit, latestTbr, classifications] = await Promise.all([
- getUnit(props.unitId),
- getLatestTbr(),
- getInhabitantClassificationsForSelect(),
- ]);
- unitData.id = unit.id;
- unitData.franchisee_name = unit.name_responsible;
- const firstPartner = unit.partners?.[0];
- if (firstPartner) {
- unitData.franchisee_document = firstPartner.cpf;
- unitData.franchisee_birthday = firstPartner.birth_date;
- }
- if (latestTbr) {
- contractForm.tbr_fixed_value = parseFloat(latestTbr.tbr_value);
- contractForm.tax_base_royalts = parseFloat(
- (latestTbr.royalties_percentage * 100).toFixed(4),
- );
- contractForm.tax_base_fnm = parseFloat(
- (latestTbr.fnm_percentage * 100).toFixed(4),
- );
- contractForm.tax_base_maintenance = parseFloat(
- (latestTbr.maintenance_percentage * 100).toFixed(4),
- );
- }
- inhabitantOptions.value = classifications.map((c) => ({
- label: `${c.description} (${c.acronym})`,
- value: c.id,
- }));
- }
- async function save() {
- saving.value = true;
- try {
- await createFranchiseeContract({
- unit_id: props.unitId,
- start_date: contractForm.start_date,
- end_date: contractForm.end_date,
- tbr_fixed_value: contractForm.tbr_fixed_value,
- invoice_due_date: contractForm.invoice_due_date,
- inhabitant_classification_id: contractForm.inhabitant_classification_id,
- tbr_fixed_value_percentage:
- contractForm.tax_base_royalts != null
- ? contractForm.tax_base_royalts / 100
- : null,
- marketing_fund_percentage:
- contractForm.tax_base_fnm != null
- ? contractForm.tax_base_fnm / 100
- : null,
- maintance_tax_percentage:
- contractForm.tax_base_maintenance != null
- ? contractForm.tax_base_maintenance / 100
- : null,
- });
- onDialogOK();
- } catch (error) {
- console.error(error);
- } finally {
- saving.value = false;
- }
- }
- onMounted(loadData);
- </script>
|