123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203 |
- <script setup lang="ts">
- import { shallowRef, computed, onMounted ,ref } from "vue";
- import { useRoute, useRouter } from "vue-router";
- import { useAsync, useResponseHandle } from "/@/hooks";
- import Invoice from "/@/components/Invoice";
- import { approvalProcess } from "./components/approval-process";
- import InvoiceDetailVue from "./components/invoice-detail/index.vue";
- import AddEditForm from "./components/add-edit-form/add-edit-form.vue";
- import { useUserInfo } from "/@/hooks/core/useUser";
- import { usePermission } from "/@/hooks/core/usePermission";
- import CurrentcyForm from "./components/currentcy-form/add-edit-form.vue";
- import CurrentcyFormWanyu from "./components/currentcy-form-wanyu/add-edit-form.vue";
- import {
- httpCompanyList,
- httpSetPost,
- httpStatus,
- httpDetail,
- httpList
- } from "/@/api/InvoiceSales/invoiceApply";
- const { query } = useRoute();
- const responseHandle = useResponseHandle();
- const { isSuperUser } = useUserInfo();
- const radioValue = shallowRef("销售订单");
- const isOtherOrder = computed(() => radioValue.value === "销售订单")
- const isWanyu = computed(() => radioValue.value === "通用订单")
- const PageName = "invoiceApplyDetail";
- // { code: "025", name: "财务审核" },
- const { hasPermissionWithCode } = usePermission(PageName);
- //是否支持金税
- const isSupport = shallowRef(false);
- const examCode = shallowRef("");
- const activeName = computed(() => (isCreate.value ? "0" : "1"));
- const collapseItem = ref(["0", "1", "2", "3", "4"]);
- const id = computed(() => query.id);
- const isCreate = computed(() => !id.value);
- const { push } = useRouter();
- const {
- loading,
- data: invoiceDetail,
- run: invoiceDetailRun
- } = useAsync<Record<string, string>>({
- initalData: {},
- success: () =>
- invoiceDetail.value &&
- companyRun(httpCompanyList({ companyNo: invoiceDetail.value.inv_out }))
- });
- const { data: list, run: listRun } = useAsync<Array<Record<string, string>>>({
- isList: true,
- initalData: []
- });
- const { data: companylist, run: companyRun } = useAsync<
- Array<Record<string, string>>
- >({
- isList: true,
- initalData: [],
- success: () => {
- const [company] = companylist.value || [];
- if (!company) return;
- const { input_ticket } = company;
- isSupport.value = input_ticket === "1";
- }
- });
- const showApproval = computed(() => {
- return (
- (
- String(invoiceDetail.value.status) === "1" && hasPermissionWithCode("025")) ||
- String(invoiceDetail.value.status) === "2" && hasPermissionWithCode("058")
- );
- });
- //最大开票金额
- const showInvStatus = computed(() => {
- const { status } = invoiceDetail.value;
- return ["4", "6"].includes(String(status));
- });
- //是否电子票
- const isElectronic = computed(() => {
- const { inv_type } = invoiceDetail.value;
- return inv_type === "3" || inv_type === "4";
- });
- //是否电子专票
- const isSpecialTicket = computed(() => {
- const { inv_type } = invoiceDetail.value;
- return inv_type === "4";
- });
- //是否普票
- const isPlain = computed(() => {
- const { inv_type } = invoiceDetail.value;
- return inv_type === "2" || inv_type === "3";
- });
- //当前的审批流程 ->
- const currentProcess = computed(() => {
- const { status } = invoiceDetail.value;
- return approvalProcess[String(status)] || {};
- });
- //设置状态/物流
- async function handleChangeStatus({ status, ...otherParmas }) {
- let response: any;
- if (!status) {
- //设置物流
- response = await httpSetPost({ invNo: id.value, ...otherParmas });
- } else {
- //设置状态
- response = await httpStatus({ invNo: id.value, status, ...otherParmas });
- }
- const { code, message } = response;
- responseHandle({
- code,
- message,
- handler: () => push("/InvoiceSales/invoiceApply")
- });
- }
- const requesetlist = () => {
- listRun(httpList({ invNo: id.value }));
- };
- const requesetInvoiceDetail = () => {
- invoiceDetailRun(httpDetail({ invNo: id.value }));
- };
- onMounted(() => {
- if (!isCreate.value) {
- requesetInvoiceDetail();
- requesetlist();
- }
- });
- </script>
- <template>
- <div class="main bg-white" v-loading="loading">
- <el-tabs v-model="activeName" type="border-card">
- <el-tab-pane label="新建发票申请" name="0" v-if="isCreate">
- <ElRadioGroup v-model="radioValue">
- <ElRadio label="销售订单"/>
- <ElRadio label="通用订单(元隆定制)" />
- <ElRadio label="通用订单" />
- </ElRadioGroup>
- <AddEditForm v-if="isOtherOrder" />
- <CurrentcyFormWanyu v-else-if="isWanyu" />
- <CurrentcyForm v-else />
- </el-tab-pane>
- <el-tab-pane label="业务详情" name="1" v-if="!isCreate">
- <el-collapse v-model="collapseItem">
- <el-collapse-item title="发票申请详情" name="2">
- <InvoiceDetailVue v-loading="loading" :detail="invoiceDetail" />
- </el-collapse-item>
- <el-collapse-item
- name="3"
- title="发票详情"
- v-if="list.length > 0 && list[0].inv_number && showInvStatus"
- >
- <Invoice :inv-number="list[0].inv_number" type="sale" />
- </el-collapse-item>
- <!-- <template v-if="!isSuperUser"> -->
- <el-collapse-item
- name="4"
- :title="currentProcess.title"
- v-if="Object.keys(currentProcess).length && showApproval"
- >
- <component
- :is="currentProcess.component"
- :is-electronic="isElectronic"
- :is-support="isSupport"
- :is-special-ticket="isSpecialTicket"
- :is-plain="isPlain"
- :inv-type="invoiceDetail.inv_type"
- @change-status="handleChangeStatus"
- />
- </el-collapse-item>
- <!-- </template> -->
- </el-collapse>
- </el-tab-pane>
- </el-tabs>
- </div>
- </template>
- <style scoped lang="scss">
- :deep(.el-dropdown-menu__item i) {
- margin: 0;
- }
- </style>
|