|
@@ -2,26 +2,80 @@
|
|
|
<div class="data-query">
|
|
|
<div class="data-query-header">
|
|
|
<div class="manageTitle">{{ title }}</div>
|
|
|
- <el-form ref="formRef" :model="formData" class="data-query-form" :rules="rules" @submit.native.prevent>
|
|
|
+ <el-form
|
|
|
+ ref="formRef"
|
|
|
+ :model="formData"
|
|
|
+ class="data-query-form"
|
|
|
+ :rules="rules"
|
|
|
+ @submit.native.prevent
|
|
|
+ >
|
|
|
<div v-if="name === 'freight'" class="form-left">
|
|
|
<el-form-item prop="startDate">
|
|
|
- <el-date-picker v-model="formData.startDate" format="YYYY-MM-DD" value-format="YYYY-MM-DD" size="default" type="date" placeholder="开始日期" :prefix-icon="datePreTitle('开始')" :clearable="false" class="pre-text" />
|
|
|
+ <el-date-picker
|
|
|
+ v-model="formData.startDate"
|
|
|
+ format="YYYY-MM-DD"
|
|
|
+ value-format="YYYY-MM-DD"
|
|
|
+ size="default"
|
|
|
+ type="date"
|
|
|
+ placeholder="开始日期"
|
|
|
+ :prefix-icon="datePreTitle('开始')"
|
|
|
+ :clearable="false"
|
|
|
+ class="pre-text"
|
|
|
+ />
|
|
|
</el-form-item>
|
|
|
<el-form-item prop="endDate">
|
|
|
- <el-date-picker v-model="formData.endDate" format="YYYY-MM-DD" value-format="YYYY-MM-DD" :disabled-date="disabledEndDate" size="default" type="date" placeholder="结束日期" :prefix-icon="datePreTitle('结束')" :clearable="false" class="pre-text" />
|
|
|
+ <el-date-picker
|
|
|
+ v-model="formData.endDate"
|
|
|
+ format="YYYY-MM-DD"
|
|
|
+ value-format="YYYY-MM-DD"
|
|
|
+ :disabled-date="disabledEndDate"
|
|
|
+ size="default"
|
|
|
+ type="date"
|
|
|
+ placeholder="结束日期"
|
|
|
+ :prefix-icon="datePreTitle('结束')"
|
|
|
+ :clearable="false"
|
|
|
+ class="pre-text"
|
|
|
+ />
|
|
|
</el-form-item>
|
|
|
</div>
|
|
|
<div v-if="name === 'waybill'" class="form-left">
|
|
|
<el-form-item>
|
|
|
- <el-date-picker v-model="formData.startDate" format="YYYY-MM-DD" value-format="YYYY-MM-DD" size="default" type="date" placeholder="开始日期" :prefix-icon="datePreTitle('开始')" class="pre-text" />
|
|
|
+ <el-date-picker
|
|
|
+ v-model="formData.startDate"
|
|
|
+ format="YYYY-MM-DD"
|
|
|
+ value-format="YYYY-MM-DD"
|
|
|
+ size="default"
|
|
|
+ type="date"
|
|
|
+ placeholder="开始日期"
|
|
|
+ :prefix-icon="datePreTitle('开始')"
|
|
|
+ class="pre-text"
|
|
|
+ />
|
|
|
</el-form-item>
|
|
|
<el-form-item>
|
|
|
- <el-date-picker v-model="formData.endDate" format="YYYY-MM-DD" value-format="YYYY-MM-DD" :disabled-date="disabledEndDate" size="default" type="date" placeholder="结束日期" :prefix-icon="datePreTitle('结束')" class="pre-text" />
|
|
|
+ <el-date-picker
|
|
|
+ v-model="formData.endDate"
|
|
|
+ format="YYYY-MM-DD"
|
|
|
+ value-format="YYYY-MM-DD"
|
|
|
+ :disabled-date="disabledEndDate"
|
|
|
+ size="default"
|
|
|
+ type="date"
|
|
|
+ placeholder="结束日期"
|
|
|
+ :prefix-icon="datePreTitle('结束')"
|
|
|
+ class="pre-text"
|
|
|
+ />
|
|
|
</el-form-item>
|
|
|
</div>
|
|
|
<div v-if="name === 'flight'" class="form-left">
|
|
|
<el-form-item prop="flightDate" style="width: 148px">
|
|
|
- <el-date-picker v-model="formData.flightDate" format="YYYY-MM-DD" value-format="YYYY-MM-DD" size="default" type="date" placeholder="请选择航班日期" :clearable="false" />
|
|
|
+ <el-date-picker
|
|
|
+ v-model="formData.flightDate"
|
|
|
+ format="YYYY-MM-DD"
|
|
|
+ value-format="YYYY-MM-DD"
|
|
|
+ size="default"
|
|
|
+ type="date"
|
|
|
+ placeholder="请选择航班日期"
|
|
|
+ :clearable="false"
|
|
|
+ />
|
|
|
</el-form-item>
|
|
|
<el-form-item prop="inOrOut" style="width: 108px">
|
|
|
<el-select v-model="formData.inOrOut" size="default">
|
|
@@ -30,68 +84,165 @@
|
|
|
</el-select>
|
|
|
</el-form-item>
|
|
|
<el-form-item prop="flightType" style="width: 108px">
|
|
|
- <el-select v-model="formData.flightType" size="default" placeholder="航班类型" clearable>
|
|
|
+ <el-select
|
|
|
+ v-model="formData.flightType"
|
|
|
+ size="default"
|
|
|
+ placeholder="航班类型"
|
|
|
+ clearable
|
|
|
+ >
|
|
|
<el-option :value="0" label="货机" />
|
|
|
<el-option :value="1" label="客机" />
|
|
|
<el-option :value="2" label="其他" />
|
|
|
</el-select>
|
|
|
</el-form-item>
|
|
|
<el-form-item prop="sAirport" style="width: 108px">
|
|
|
- <el-select v-model="formData.sAirport" :disabled="formData.inOrOut === 'out'" size="default" placeholder="始发站" filterable clearable>
|
|
|
- <el-option v-for="{ value, label } in airportOptions" :key="value" :value="value" :label="label" />
|
|
|
+ <el-select
|
|
|
+ v-model="formData.sAirport"
|
|
|
+ :disabled="formData.inOrOut === 'out'"
|
|
|
+ size="default"
|
|
|
+ placeholder="始发站"
|
|
|
+ filterable
|
|
|
+ clearable
|
|
|
+ >
|
|
|
+ <el-option
|
|
|
+ v-for="{ value, label } in airportOptions"
|
|
|
+ :key="value"
|
|
|
+ :value="value"
|
|
|
+ :label="label"
|
|
|
+ />
|
|
|
</el-select>
|
|
|
</el-form-item>
|
|
|
<el-form-item prop="eAirport" style="width: 108px">
|
|
|
- <el-select v-model="formData.eAirport" :disabled="formData.inOrOut === 'in'" size="default" placeholder="目的站" filterable clearable>
|
|
|
- <el-option v-for="{ value, label } in airportOptions" :key="value" :value="value" :label="label" />
|
|
|
+ <el-select
|
|
|
+ v-model="formData.eAirport"
|
|
|
+ :disabled="formData.inOrOut === 'in'"
|
|
|
+ size="default"
|
|
|
+ placeholder="目的站"
|
|
|
+ filterable
|
|
|
+ clearable
|
|
|
+ >
|
|
|
+ <el-option
|
|
|
+ v-for="{ value, label } in airportOptions"
|
|
|
+ :key="value"
|
|
|
+ :value="value"
|
|
|
+ :label="label"
|
|
|
+ />
|
|
|
</el-select>
|
|
|
</el-form-item>
|
|
|
<el-form-item prop="planeType" style="width: 108px">
|
|
|
- <el-select v-model="formData.planeType" size="default" placeholder="属性" clearable>
|
|
|
+ <el-select
|
|
|
+ v-model="formData.planeType"
|
|
|
+ size="default"
|
|
|
+ placeholder="属性"
|
|
|
+ clearable
|
|
|
+ >
|
|
|
<el-option value="DOM" label="国内" />
|
|
|
<el-option value="INT" label="国际" />
|
|
|
</el-select>
|
|
|
</el-form-item>
|
|
|
<el-form-item prop="sFlightDate" style="width: 148px">
|
|
|
- <el-date-picker v-model="formData.sFlightDate" format="YYYY-MM-DD" value-format="YYYY-MM-DD" size="default" type="date" placeholder="请选择实飞时间" />
|
|
|
+ <el-date-picker
|
|
|
+ v-model="formData.sFlightDate"
|
|
|
+ format="YYYY-MM-DD"
|
|
|
+ value-format="YYYY-MM-DD"
|
|
|
+ size="default"
|
|
|
+ type="date"
|
|
|
+ placeholder="请选择实飞时间"
|
|
|
+ />
|
|
|
</el-form-item>
|
|
|
</div>
|
|
|
<div class="form-right">
|
|
|
- <el-form-item v-if="name === 'flight'" prop="company" style="width: 180px">
|
|
|
- <el-input v-model.trim="formData.company" size="default" placeholder="请输入航司进行搜索" :prefix-icon="Search" clearable @keyup.enter.prevent="dataQuery" />
|
|
|
+ <el-form-item
|
|
|
+ v-if="name === 'flight'"
|
|
|
+ prop="company"
|
|
|
+ style="width: 180px"
|
|
|
+ >
|
|
|
+ <el-input
|
|
|
+ v-model.trim="formData.company"
|
|
|
+ size="default"
|
|
|
+ placeholder="请输入航司进行搜索"
|
|
|
+ :prefix-icon="Search"
|
|
|
+ clearable
|
|
|
+ @keyup.enter.prevent="dataQuery"
|
|
|
+ />
|
|
|
</el-form-item>
|
|
|
- <el-form-item v-if="name === 'waybill'" prop="flightNO" style="width: 180px">
|
|
|
- <el-input v-model.trim="formData.flightNO" size="default" placeholder="请输入航班号" clearable />
|
|
|
+ <el-form-item
|
|
|
+ v-if="name === 'waybill'"
|
|
|
+ prop="flightNO"
|
|
|
+ style="width: 180px"
|
|
|
+ >
|
|
|
+ <el-input
|
|
|
+ v-model.trim="formData.flightNO"
|
|
|
+ size="default"
|
|
|
+ placeholder="请输入航班号"
|
|
|
+ clearable
|
|
|
+ />
|
|
|
</el-form-item>
|
|
|
- <el-form-item prop="keyWords" :style="name === 'flight' ? { width: '190px' } : {}">
|
|
|
- <el-input v-model.trim="formData.keyWords" size="default" :placeholder="keyWordsPlaceHolder" :prefix-icon="Search" clearable @keyup.enter.prevent="dataQuery" />
|
|
|
+ <el-form-item
|
|
|
+ prop="keyWords"
|
|
|
+ :style="name === 'flight' ? { width: '190px' } : {}"
|
|
|
+ >
|
|
|
+ <el-input
|
|
|
+ v-model.trim="formData.keyWords"
|
|
|
+ size="default"
|
|
|
+ :placeholder="keyWordsPlaceHolder"
|
|
|
+ :prefix-icon="Search"
|
|
|
+ clearable
|
|
|
+ @keyup.enter.prevent="dataQuery"
|
|
|
+ />
|
|
|
</el-form-item>
|
|
|
</div>
|
|
|
</el-form>
|
|
|
- <el-button size="default" color="#ac014d" @click="dataQuery">搜索</el-button>
|
|
|
+ <el-button size="default" color="#ac014d" @click="dataQuery"
|
|
|
+ >搜索</el-button
|
|
|
+ >
|
|
|
<el-button size="default" plain @click="resetForm">重置</el-button>
|
|
|
- <ColumnSet :table-columns="tableColumns" @checked-submit="columnChecked" />
|
|
|
+ <ColumnSet :table-columns="tableCols" @checked-submit="columnChecked" />
|
|
|
</div>
|
|
|
- <div v-loading="loading" element-loading-text="拼命加载中" element-loading-background="rgba(0, 0, 0, 0.8)" class="data-query-table">
|
|
|
- <SimpleTable :header-cell-style="() => ({ background: '#F9FAFC' })" ref="tableRef" :data="
|
|
|
+ <div
|
|
|
+ v-loading="loading"
|
|
|
+ element-loading-text="拼命加载中"
|
|
|
+ element-loading-background="rgba(0, 0, 0, 0.8)"
|
|
|
+ class="data-query-table"
|
|
|
+ >
|
|
|
+ <SimpleTable
|
|
|
+ :header-cell-style="() => ({ background: '#F9FAFC' })"
|
|
|
+ ref="tableRef"
|
|
|
+ :data="
|
|
|
tableData.slice((currentPage - 1) * pageSize, currentPage * pageSize)
|
|
|
- " :columns="tableColumns" :cell-class-name="cellClass" :column-props="{ formatter }" height="calc(100vh - 220px)" custom-sequence @cell-click="cellClickHandler" />
|
|
|
- <el-pagination v-if="tableData.length > 0" background layout="total, prev, pager, next, jumper" :total="tableData.length" :page-size="pageSize" style="position: absolute; right: 19px; bottom: 10px" @size-change="handleSizeChange" @current-change="handleCurrentChange">
|
|
|
+ "
|
|
|
+ :columns="tableCols"
|
|
|
+ :cell-class-name="cellClass"
|
|
|
+ :column-props="{ formatter }"
|
|
|
+ height="calc(100vh - 220px)"
|
|
|
+ custom-sequence
|
|
|
+ @cell-click="cellClickHandler"
|
|
|
+ />
|
|
|
+ <el-pagination
|
|
|
+ v-if="tableData.length > 0"
|
|
|
+ background
|
|
|
+ layout="total, prev, pager, next, jumper"
|
|
|
+ :total="tableData.length"
|
|
|
+ :page-size="pageSize"
|
|
|
+ style="position: absolute; right: 19px; bottom: 10px"
|
|
|
+ @size-change="handleSizeChange"
|
|
|
+ @current-change="handleCurrentChange"
|
|
|
+ >
|
|
|
</el-pagination>
|
|
|
</div>
|
|
|
</div>
|
|
|
</template>
|
|
|
|
|
|
<script setup lang="tsx">
|
|
|
-import { Search } from '@element-plus/icons-vue'
|
|
|
-import ColumnSet from '@/components/ColumnSet/index.vue'
|
|
|
-import SimpleTable from '@/components/SimpleTable/index.vue'
|
|
|
-import { ElMessage, FormInstance } from 'element-plus'
|
|
|
-import { parseTime } from '@/utils/validate'
|
|
|
-import { useTable } from './useTable'
|
|
|
-import { useTableColumnSet } from '@/hooks/useTableColumnSet'
|
|
|
-import { CommonTableFormatter } from '~/common'
|
|
|
-import { Query } from '@/api/webApi'
|
|
|
+import { Search } from "@element-plus/icons-vue";
|
|
|
+import ColumnSet from "@/components/ColumnSet/index.vue";
|
|
|
+import SimpleTable from "@/components/SimpleTable/index.vue";
|
|
|
+import { ElMessage, FormInstance } from "element-plus";
|
|
|
+import { parseTime } from "@/utils/validate";
|
|
|
+import { useTable } from "./useTable";
|
|
|
+import { useTableColumnSet } from "@/hooks/useTableColumnSet";
|
|
|
+import { CommonTableFormatter } from "~/common";
|
|
|
+import { Query } from "@/api/webApi";
|
|
|
|
|
|
const props = defineProps({
|
|
|
name: {
|
|
@@ -102,66 +253,69 @@ const props = defineProps({
|
|
|
type: String,
|
|
|
required: true,
|
|
|
},
|
|
|
-})
|
|
|
-const currentPage = ref(1)
|
|
|
-const pageSize = ref(50)
|
|
|
-const today = parseTime(new Date(), '{y}-{m}-{d}') as string
|
|
|
+});
|
|
|
+const tableCols = ref<any[]>([]); //表头数据
|
|
|
+const conditon = ref("");
|
|
|
+const dataContent = ref({});
|
|
|
+const currentPage = ref(1);
|
|
|
+const pageSize = ref(50);
|
|
|
+const today = parseTime(new Date(), "{y}-{m}-{d}") as string;
|
|
|
const formData = reactive({
|
|
|
flightDate: today,
|
|
|
- inOrOut: 'out',
|
|
|
- flightType: '',
|
|
|
- sAirport: '',
|
|
|
- eAirport: '',
|
|
|
- planeType: '',
|
|
|
- sFlightDate: '',
|
|
|
- company: '',
|
|
|
+ inOrOut: "out",
|
|
|
+ flightType: "",
|
|
|
+ sAirport: "",
|
|
|
+ eAirport: "",
|
|
|
+ planeType: "",
|
|
|
+ sFlightDate: "",
|
|
|
+ company: "",
|
|
|
startDate: today,
|
|
|
endDate: today,
|
|
|
- keyWords: '',
|
|
|
- flightNO:''
|
|
|
-})
|
|
|
+ keyWords: "",
|
|
|
+ flightNO: "",
|
|
|
+});
|
|
|
watchEffect(() => {
|
|
|
- if (formData.inOrOut === 'in') {
|
|
|
- formData.sAirport = ''
|
|
|
- formData.eAirport = 'SZX'
|
|
|
+ if (formData.inOrOut === "in") {
|
|
|
+ formData.sAirport = "";
|
|
|
+ formData.eAirport = "SZX";
|
|
|
} else {
|
|
|
- formData.sAirport = 'SZX'
|
|
|
- formData.eAirport = ''
|
|
|
+ formData.sAirport = "SZX";
|
|
|
+ formData.eAirport = "";
|
|
|
}
|
|
|
if (!formData.startDate || !formData.endDate) {
|
|
|
- return
|
|
|
+ return;
|
|
|
}
|
|
|
- const start = new Date(formData.startDate).getTime()
|
|
|
- const end = new Date(formData.endDate).getTime()
|
|
|
+ const start = new Date(formData.startDate).getTime();
|
|
|
+ const end = new Date(formData.endDate).getTime();
|
|
|
if (start > end) {
|
|
|
- ElMessage.warning('开始时间不能晚于结束时间')
|
|
|
- formData.endDate = ''
|
|
|
+ ElMessage.warning("开始时间不能晚于结束时间");
|
|
|
+ formData.endDate = "";
|
|
|
}
|
|
|
if (start <= end - 2 * 24 * 60 * 60 * 1000) {
|
|
|
- ElMessage.warning('间隔不能超过2天')
|
|
|
- formData.endDate = ''
|
|
|
+ ElMessage.warning("间隔不能超过2天");
|
|
|
+ formData.endDate = "";
|
|
|
}
|
|
|
-})
|
|
|
+});
|
|
|
const disabledEndDate = (endDate: Date) => {
|
|
|
- const start = new Date(formData.startDate + ' 00:00:00').getTime()
|
|
|
- const end = endDate.getTime()
|
|
|
- return start > end || start <= end - 2 * 24 * 60 * 60 * 1000
|
|
|
-}
|
|
|
+ const start = new Date(formData.startDate + " 00:00:00").getTime();
|
|
|
+ const end = endDate.getTime();
|
|
|
+ return start > end || start <= end - 2 * 24 * 60 * 60 * 1000;
|
|
|
+};
|
|
|
const datePreTitle = (title: string) => {
|
|
|
- return <div class="date-pre-title">{title}:</div>
|
|
|
-}
|
|
|
+ return <div class="date-pre-title">{title}:</div>;
|
|
|
+};
|
|
|
|
|
|
const searchTitleMap = {
|
|
|
- flight: '航班号',
|
|
|
- waybill: '运单号',
|
|
|
- freight: '货物编码',
|
|
|
-}
|
|
|
+ flight: "航班号",
|
|
|
+ waybill: "运单号",
|
|
|
+ freight: "货物编码",
|
|
|
+};
|
|
|
|
|
|
const keyWordsPlaceHolder = computed(
|
|
|
- () => `请输入${searchTitleMap[props.name] ?? '内容'}进行搜索`
|
|
|
-)
|
|
|
+ () => `请输入${searchTitleMap[props.name] ?? "内容"}进行搜索`
|
|
|
+);
|
|
|
|
|
|
-const airportOptions = ref<{ value: string; label: string }[]>([])
|
|
|
+const airportOptions = ref<{ value: string; label: string }[]>([]);
|
|
|
const getAirports = async () => {
|
|
|
try {
|
|
|
const {
|
|
@@ -171,35 +325,35 @@ const getAirports = async () => {
|
|
|
} = await Query<{ [x: string]: string }>({
|
|
|
id: DATACONTENT_ID.airportCode,
|
|
|
dataContent: [],
|
|
|
- })
|
|
|
+ });
|
|
|
if (Number(code) !== 0) {
|
|
|
- throw new Error(message || '失败')
|
|
|
+ throw new Error(message || "失败");
|
|
|
}
|
|
|
airportOptions.value = listValues.map(({ code3 }) => ({
|
|
|
value: code3,
|
|
|
label: code3,
|
|
|
- }))
|
|
|
+ }));
|
|
|
} catch (error) {
|
|
|
- console.error(error)
|
|
|
+ console.error(error);
|
|
|
}
|
|
|
-}
|
|
|
+};
|
|
|
onMounted(() => {
|
|
|
- if (props.name === 'flight') {
|
|
|
- getAirports()
|
|
|
- dataQuery()
|
|
|
+ if (props.name === "flight") {
|
|
|
+ getAirports();
|
|
|
+ dataQuery();
|
|
|
}
|
|
|
-})
|
|
|
+});
|
|
|
|
|
|
const keyWordsValidator = (rule: any, value: any, callback: any) => {
|
|
|
- if (props.name == 'waybill') {
|
|
|
- return true
|
|
|
+ if (props.name == "waybill") {
|
|
|
+ return true;
|
|
|
}
|
|
|
- const searchTitle = searchTitleMap[props.name] ?? '关键词'
|
|
|
+ const searchTitle = searchTitleMap[props.name] ?? "关键词";
|
|
|
if (!value) {
|
|
|
- if (['flight'].includes(props.name)) {
|
|
|
- return callback()
|
|
|
+ if (["flight"].includes(props.name)) {
|
|
|
+ return callback();
|
|
|
} else {
|
|
|
- return callback(new Error(`请输入${searchTitle}`))
|
|
|
+ return callback(new Error(`请输入${searchTitle}`));
|
|
|
}
|
|
|
}
|
|
|
const regsMap: { [x: string]: RegExp[] } = {
|
|
@@ -207,51 +361,72 @@ const keyWordsValidator = (rule: any, value: any, callback: any) => {
|
|
|
flight: [/^[0-9]{1,4}$/],
|
|
|
waybill: [/^[0-9]{8}$/, /^[0-9]{11}$/, /^[0-9]{3}\-[0-9]{8}$/],
|
|
|
freight: [/^[0-9]{5}$/, /^[0-9]{3}\-[0-9]{8}\-[0-9]{5}$/],
|
|
|
- }
|
|
|
- const regs = regsMap[props.name] ?? []
|
|
|
- const notMatched = regs.length && regs.every(reg => !reg.test(value))
|
|
|
+ };
|
|
|
+ const regs = regsMap[props.name] ?? [];
|
|
|
+ const notMatched = regs.length && regs.every((reg) => !reg.test(value));
|
|
|
if (notMatched) {
|
|
|
- return callback(new Error(`请输入正确的${searchTitle}`))
|
|
|
+ return callback(new Error(`请输入正确的${searchTitle}`));
|
|
|
}
|
|
|
- return callback()
|
|
|
-}
|
|
|
+ return callback();
|
|
|
+};
|
|
|
const rules = {
|
|
|
- startDate: [{ required: true, message: '请选择开始日期', trigger: 'blur' }],
|
|
|
- endDate: [{ required: true, message: '请选择结束日期', trigger: 'blur' }],
|
|
|
- keyWords: [{ validator: keyWordsValidator, trigger: 'blur' }],
|
|
|
- flightDate: [{ required: true, message: '请选择航班日期', trigger: 'blur' }],
|
|
|
+ startDate: [{ required: true, message: "请选择开始日期", trigger: "blur" }],
|
|
|
+ endDate: [{ required: true, message: "请选择结束日期", trigger: "blur" }],
|
|
|
+ keyWords: [{ validator: keyWordsValidator, trigger: "blur" }],
|
|
|
+ flightDate: [{ required: true, message: "请选择航班日期", trigger: "blur" }],
|
|
|
company: [
|
|
|
{
|
|
|
pattern: /^[A-Za-z0-9][A-Za-z0-9]$/,
|
|
|
- message: '请输入正确的航司',
|
|
|
- trigger: 'blur',
|
|
|
+ message: "请输入正确的航司",
|
|
|
+ trigger: "blur",
|
|
|
},
|
|
|
],
|
|
|
-}
|
|
|
-const formRef = ref<FormInstance | null>()
|
|
|
+};
|
|
|
+const formRef = ref<FormInstance | null>();
|
|
|
const dataQuery = () => {
|
|
|
- formRef.value?.validate(valid => {
|
|
|
+ formRef.value?.validate((valid) => {
|
|
|
if (valid) {
|
|
|
- tableInit()
|
|
|
- getTableData()
|
|
|
+ tableInit();
|
|
|
+ getTableData();
|
|
|
// load();
|
|
|
}
|
|
|
- })
|
|
|
-}
|
|
|
+ });
|
|
|
+};
|
|
|
const resetForm = () => {
|
|
|
- formRef.value?.resetFields()
|
|
|
-}
|
|
|
+ formRef.value?.resetFields();
|
|
|
+};
|
|
|
|
|
|
-const loading = ref(false)
|
|
|
-const page = ref(1)
|
|
|
-const noMore = ref(false)
|
|
|
+const loading = ref(false);
|
|
|
+const page = ref(1);
|
|
|
+const noMore = ref(false);
|
|
|
const { tableColumns, tableData, getTableData } = useTable(
|
|
|
props.name,
|
|
|
formData,
|
|
|
page,
|
|
|
noMore,
|
|
|
loading
|
|
|
-)
|
|
|
+);
|
|
|
+const gueryRoles = async () => {
|
|
|
+ const { code, returnData } = await Query({
|
|
|
+ id: DATACONTENT_ID.allId,
|
|
|
+ needPage: ++page.value,
|
|
|
+ dataContent: Object.values(dataContent.value),
|
|
|
+ });
|
|
|
+ conditon.value = returnData.listValues[0].query_col_conditon;
|
|
|
+ tableCols.value = [];
|
|
|
+ if (conditon.value == null) {
|
|
|
+ tableCols.value = tableColumns.value;
|
|
|
+ } else {
|
|
|
+ conditon.value.split(",").forEach((element) => {
|
|
|
+ tableColumns.value.forEach((res) => {
|
|
|
+ if (element === res.columnName) {
|
|
|
+ tableCols.value.push(res);
|
|
|
+ }
|
|
|
+ });
|
|
|
+ });
|
|
|
+ }
|
|
|
+};
|
|
|
+gueryRoles();
|
|
|
// const load = () => {
|
|
|
// if (loading.value || noMore.value) {
|
|
|
// return
|
|
@@ -259,137 +434,136 @@ const { tableColumns, tableData, getTableData } = useTable(
|
|
|
// page.value++
|
|
|
// getTableData()
|
|
|
// }
|
|
|
-const handleSizeChange = val => {
|
|
|
- pageSize.value = val
|
|
|
-}
|
|
|
-const handleCurrentChange = val => {
|
|
|
- currentPage.value = val
|
|
|
-}
|
|
|
+const handleSizeChange = (val) => {
|
|
|
+ pageSize.value = val;
|
|
|
+};
|
|
|
+const handleCurrentChange = (val) => {
|
|
|
+ currentPage.value = val;
|
|
|
+};
|
|
|
const tableInit = () => {
|
|
|
- page.value = 0
|
|
|
- noMore.value = false
|
|
|
- tableData.value = []
|
|
|
-}
|
|
|
-
|
|
|
-const { columnChecked } = useTableColumnSet(tableColumns)
|
|
|
+ page.value = 0;
|
|
|
+ noMore.value = false;
|
|
|
+ tableData.value = [];
|
|
|
+};
|
|
|
+const { columnChecked } = useTableColumnSet(tableColumns);
|
|
|
|
|
|
const flightStateMap = {
|
|
|
- CAN: '取消',
|
|
|
- DLY: '延误',
|
|
|
-}
|
|
|
-const flightTypeMap = ['货机', '客机', '其他']
|
|
|
+ CAN: "取消",
|
|
|
+ DLY: "延误",
|
|
|
+};
|
|
|
+const flightTypeMap = ["货机", "客机", "其他"];
|
|
|
const DITypeMap = {
|
|
|
- DOM: '国内',
|
|
|
- INT: '国际'
|
|
|
-}
|
|
|
+ DOM: "国内",
|
|
|
+ INT: "国际",
|
|
|
+};
|
|
|
const formatter: CommonTableFormatter = (row, column, cellValue, index) => {
|
|
|
- const value = String(cellValue ?? '').trim()
|
|
|
- if (column.property.includes('Time')) {
|
|
|
- return value.replace(/[T|\s]+/, '\n')
|
|
|
+ const value = String(cellValue ?? "").trim();
|
|
|
+ if (column.property.includes("Time")) {
|
|
|
+ return value.replace(/[T|\s]+/, "\n");
|
|
|
}
|
|
|
- if (column.property === 'DIType' && value) {
|
|
|
- return DITypeMap[value] ?? value
|
|
|
+ if (column.property === "DIType" && value) {
|
|
|
+ return DITypeMap[value] ?? value;
|
|
|
}
|
|
|
- if (column.property === 'flightState') {
|
|
|
- return value ? flightStateMap[value] ?? '正常' : '正常'
|
|
|
+ if (column.property === "flightState") {
|
|
|
+ return value ? flightStateMap[value] ?? "正常" : "正常";
|
|
|
}
|
|
|
- if (column.property === 'flightType') {
|
|
|
- return cellValue ? flightTypeMap[cellValue] ?? '其他' : '其他'
|
|
|
+ if (column.property === "flightType") {
|
|
|
+ return cellValue ? flightTypeMap[cellValue] ?? "其他" : "其他";
|
|
|
}
|
|
|
- return value
|
|
|
-}
|
|
|
+ return value;
|
|
|
+};
|
|
|
|
|
|
const cellClass = ({ row, column, rowIndex, columnIndex }) => {
|
|
|
- const classes: string[] = []
|
|
|
+ const classes: string[] = [];
|
|
|
switch (props.name) {
|
|
|
- case 'flight':
|
|
|
- if (['flightNO'].includes(column.property) && row[column.property]) {
|
|
|
- classes.push('cell-click')
|
|
|
+ case "flight":
|
|
|
+ if (["flightNO"].includes(column.property) && row[column.property]) {
|
|
|
+ classes.push("cell-click");
|
|
|
}
|
|
|
- break
|
|
|
- case 'waybill':
|
|
|
- if (['stockCode'].includes(column.property) && row[column.property]) {
|
|
|
- classes.push('cell-click')
|
|
|
+ break;
|
|
|
+ case "waybill":
|
|
|
+ if (["stockCode"].includes(column.property) && row[column.property]) {
|
|
|
+ classes.push("cell-click");
|
|
|
}
|
|
|
- break
|
|
|
- case 'freight':
|
|
|
- break
|
|
|
+ break;
|
|
|
+ case "freight":
|
|
|
+ break;
|
|
|
default:
|
|
|
- break
|
|
|
+ break;
|
|
|
}
|
|
|
- return classes.join(' ')
|
|
|
-}
|
|
|
+ return classes.join(" ");
|
|
|
+};
|
|
|
|
|
|
-const router = useRouter()
|
|
|
+const router = useRouter();
|
|
|
|
|
|
const cellClickHandler = (row, column, cell, event) => {
|
|
|
switch (props.name) {
|
|
|
- case 'flight': {
|
|
|
+ case "flight": {
|
|
|
switch (column.property) {
|
|
|
- case 'flightNO': {
|
|
|
+ case "flightNO": {
|
|
|
if (!row.flightAllNO || !row.flightDate) {
|
|
|
- ElMessage.error('航班信息缺失!')
|
|
|
- return
|
|
|
+ ElMessage.error("航班信息缺失!");
|
|
|
+ return;
|
|
|
}
|
|
|
- if (!['INT', 'DOM'].includes(row.DIType)) {
|
|
|
- ElMessage.error('国内/国际无法识别!')
|
|
|
- return
|
|
|
+ if (!["INT", "DOM"].includes(row.DIType)) {
|
|
|
+ ElMessage.error("国内/国际无法识别!");
|
|
|
+ return;
|
|
|
}
|
|
|
- const viewName = `${row.DIType === 'DOM' ? '' : 'International'}${
|
|
|
- row.departureAirport === 'SZX' ||
|
|
|
- (!row.departureAirport && row.arriveAirport !== 'SZX')
|
|
|
- ? 'Departure'
|
|
|
- : 'Arrival'
|
|
|
- }Flight`
|
|
|
+ const viewName = `${row.DIType === "DOM" ? "" : "International"}${
|
|
|
+ row.departureAirport === "SZX" ||
|
|
|
+ (!row.departureAirport && row.arriveAirport !== "SZX")
|
|
|
+ ? "Departure"
|
|
|
+ : "Arrival"
|
|
|
+ }Flight`;
|
|
|
router.push({
|
|
|
path: `/dataQuery/flightQuery/${viewName}`,
|
|
|
query: {
|
|
|
flightNO: row.flightAllNO,
|
|
|
flightDate: row.flightDate,
|
|
|
},
|
|
|
- })
|
|
|
- break
|
|
|
+ });
|
|
|
+ break;
|
|
|
}
|
|
|
default:
|
|
|
- break
|
|
|
+ break;
|
|
|
}
|
|
|
- break
|
|
|
+ break;
|
|
|
}
|
|
|
- case 'waybill': {
|
|
|
+ case "waybill": {
|
|
|
switch (column.property) {
|
|
|
- case 'stockCode': {
|
|
|
+ case "stockCode": {
|
|
|
if (
|
|
|
!row.stockCode ||
|
|
|
!row.flightDate ||
|
|
|
- !['INT', 'DOM'].includes(row.DIType)
|
|
|
+ !["INT", "DOM"].includes(row.DIType)
|
|
|
) {
|
|
|
- ElMessage.error('运单信息缺失!')
|
|
|
- return
|
|
|
+ ElMessage.error("运单信息缺失!");
|
|
|
+ return;
|
|
|
}
|
|
|
- const viewName = `${row.DIType === 'DOM' ? '' : 'International'}${
|
|
|
- row.departureAirport === 'SZX' ||
|
|
|
- (!row.departureAirport && row.arriveAirport !== 'SZX')
|
|
|
- ? 'Departure'
|
|
|
- : 'Arrival'
|
|
|
- }Waybill`
|
|
|
+ const viewName = `${row.DIType === "DOM" ? "" : "International"}${
|
|
|
+ row.departureAirport === "SZX" ||
|
|
|
+ (!row.departureAirport && row.arriveAirport !== "SZX")
|
|
|
+ ? "Departure"
|
|
|
+ : "Arrival"
|
|
|
+ }Waybill`;
|
|
|
router.push({
|
|
|
path: `/dataQuery/waybillQuery/${viewName}`,
|
|
|
query: {
|
|
|
waybillNO: row.stockCode,
|
|
|
flightDate: row.flightDate,
|
|
|
},
|
|
|
- })
|
|
|
- break
|
|
|
+ });
|
|
|
+ break;
|
|
|
}
|
|
|
}
|
|
|
- break
|
|
|
+ break;
|
|
|
}
|
|
|
- case 'freight':
|
|
|
- break
|
|
|
+ case "freight":
|
|
|
+ break;
|
|
|
default:
|
|
|
- break
|
|
|
+ break;
|
|
|
}
|
|
|
-}
|
|
|
+};
|
|
|
</script>
|
|
|
|
|
|
<style lang="scss" scoped>
|