|
@@ -0,0 +1,157 @@
|
|
|
|
+<template>
|
|
|
|
+ <a-card :bordered="false" style="margin-bottom: 10px" class="mb-2">
|
|
|
|
+ <a-form ref="searchFormRef" name="advanced_search" :model="searchFormState" class="ant-advanced-search-form">
|
|
|
|
+ <a-row :gutter="24">
|
|
|
|
+ <a-col :span="6">
|
|
|
|
+ <a-form-item label="点位名称" name="loadPoint">
|
|
|
|
+ <a-input v-model:value="searchFormState.loadPoint" placeholder="查询点位名称" allow-clear />
|
|
|
|
+ </a-form-item>
|
|
|
|
+ </a-col>
|
|
|
|
+ <a-col :span="6">
|
|
|
|
+ <a-button type="primary" @click="tableRef.refresh()">查询</a-button>
|
|
|
|
+ <a-button style="margin: 0 8px" @click="reset">重置</a-button>
|
|
|
|
+
|
|
|
|
+ <a-button type="primary" @click="formRef.onOpen()" v-if="hasPerm('bizLoadPointAdd')">
|
|
|
|
+ <template #icon><plus-outlined /></template>
|
|
|
|
+ 新增
|
|
|
|
+ </a-button>
|
|
|
|
+ </a-col>
|
|
|
|
+ </a-row>
|
|
|
|
+ </a-form>
|
|
|
|
+ </a-card>
|
|
|
|
+ <a-card :bordered="false" style="margin-bottom: 10px" class="mb-2">
|
|
|
|
+ <s-table
|
|
|
|
+ ref="tableRef"
|
|
|
|
+ :columns="columns"
|
|
|
|
+ :data="loadData"
|
|
|
|
+ bordered
|
|
|
|
+ :row-key="(record) => record.id"
|
|
|
|
+ >
|
|
|
|
+ <template #bodyCell="{ column, record, index }">
|
|
|
|
+ <template v-if="column.dataIndex === 'serial'">
|
|
|
|
+ {{ index + 1 }}
|
|
|
|
+ </template>
|
|
|
|
+ <template v-if="column.dataIndex === 'action'">
|
|
|
|
+ <a-space>
|
|
|
|
+ <a @click="formRef.onOpen(record)" v-if="hasPerm('bizLoadPointEdit')">编辑</a>
|
|
|
|
+ <a-divider type="vertical" v-if="hasPerm(['bizLoadPointEdit', 'bizLoadPointDelete'], 'and')" />
|
|
|
|
+ <a-button type="link" danger size="small" v-if="hasPerm('bizLoadPointDelete')" @click="deleteConfig(record)">删除</a-button>
|
|
|
|
+
|
|
|
|
+ <a-divider type="vertical" v-if="hasPerm(['bizLoadPointEdit', 'bizLoadPointDelete'], 'or') && hasPerm('bizLoadUser')" />
|
|
|
|
+ <a @click="userIndexRef.onOpen(record)" v-if="hasPerm('bizLoadUser')">起卸员</a>
|
|
|
|
+
|
|
|
|
+ <a-divider type="vertical" v-if="hasPerm(['bizLoadPointEdit', 'bizLoadPointDelete', 'bizLoadUser'], 'or') && hasPerm('bizLoadTime')" />
|
|
|
|
+ <a @click="timeIndexRef.onOpen(record)" v-if="hasPerm('bizLoadTime')">起卸时间</a>
|
|
|
|
+ </a-space>
|
|
|
|
+ </template>
|
|
|
|
+ </template>
|
|
|
|
+ </s-table>
|
|
|
|
+ </a-card>
|
|
|
|
+
|
|
|
|
+ <Form ref="formRef" @successful="tableRef.refresh()" />
|
|
|
|
+ <UserIndex ref="userIndexRef" @successful="tableRef.refresh()" />
|
|
|
|
+ <TimeIndex ref="timeIndexRef" @successful="tableRef.refresh()" />
|
|
|
|
+</template>
|
|
|
|
+
|
|
|
|
+<script setup name="bizloadpoint">
|
|
|
|
+ import { cloneDeep } from 'lodash-es'
|
|
|
|
+ import Form from './form.vue'
|
|
|
|
+ import UserIndex from './userIndex.vue'
|
|
|
|
+ import TimeIndex from './timeIndex.vue'
|
|
|
|
+ import bizLoadPointApi from '@/api/biz/bizLoadPointApi'
|
|
|
|
+ import {ExclamationCircleOutlined} from '@ant-design/icons-vue';
|
|
|
|
+ import {Modal} from 'ant-design-vue';
|
|
|
|
+ import {createVNode} from 'vue';
|
|
|
|
+
|
|
|
|
+ const submitLoading = ref(false)
|
|
|
|
+ const searchFormState = ref({})
|
|
|
|
+ const searchFormRef = ref()
|
|
|
|
+ const toolConfig = { refresh: true, height: true, columnSetting: true, striped: false }
|
|
|
|
+
|
|
|
|
+ const tableRef = ref()
|
|
|
|
+ const formRef = ref()
|
|
|
|
+ const userIndexRef = ref()
|
|
|
|
+ const timeIndexRef = ref()
|
|
|
|
+
|
|
|
|
+ const columns = [
|
|
|
|
+ {
|
|
|
|
+ title: '序号',
|
|
|
|
+ width: 50,
|
|
|
|
+ dataIndex: 'serial',
|
|
|
|
+ align:'center'
|
|
|
|
+ },
|
|
|
|
+ {
|
|
|
|
+ title: '起卸点位',
|
|
|
|
+ dataIndex: 'loadPoint',
|
|
|
|
+ align: 'center'
|
|
|
|
+ },
|
|
|
|
+ {
|
|
|
|
+ title: '创建时间',
|
|
|
|
+ dataIndex: 'createTime',
|
|
|
|
+ align: 'center'
|
|
|
|
+ },
|
|
|
|
+ ]
|
|
|
|
+ // 操作栏通过权限判断是否显示
|
|
|
|
+ if (hasPerm(['bizLoadPointEdit', 'bizLoadPointDelete', 'bizLoadUser', 'bizLoadTime'], 'or')) {
|
|
|
|
+ columns.push({
|
|
|
|
+ title: '操作',
|
|
|
|
+ dataIndex: 'action',
|
|
|
|
+ align: 'center',
|
|
|
|
+ width: 320
|
|
|
|
+ })
|
|
|
|
+ }
|
|
|
|
+ const selectedRowKeys = ref([])
|
|
|
|
+ // 列表选择配置
|
|
|
|
+ const options = {
|
|
|
|
+ // columns数字类型字段加入 needTotal: true 可以勾选自动算账
|
|
|
|
+ alert: {
|
|
|
|
+ show: true,
|
|
|
|
+ clear: () => {
|
|
|
|
+ selectedRowKeys.value = ref([])
|
|
|
|
+ }
|
|
|
|
+ },
|
|
|
|
+ rowSelection: {
|
|
|
|
+ onChange: (selectedRowKey, selectedRows) => {
|
|
|
|
+ selectedRowKeys.value = selectedRowKey
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ const loadData = (parameter) => {
|
|
|
|
+ const searchFormParam = cloneDeep(searchFormState.value)
|
|
|
|
+ searchFormParam.loadType = '1'
|
|
|
|
+ return bizLoadPointApi.bizLoadPointPage(Object.assign(parameter, searchFormParam)).then((data) => {
|
|
|
|
+ return data
|
|
|
|
+ })
|
|
|
|
+ }
|
|
|
|
+ // 重置
|
|
|
|
+ const reset = () => {
|
|
|
|
+ searchFormRef.value.resetFields()
|
|
|
|
+ tableRef.value.refresh(true)
|
|
|
|
+ }
|
|
|
|
+ // 删除
|
|
|
|
+ const deleteConfig = (record) => {
|
|
|
|
+ Modal.confirm({
|
|
|
|
+ title: '确定删除该数据吗?',
|
|
|
|
+ icon: createVNode(ExclamationCircleOutlined),
|
|
|
|
+ content: '',
|
|
|
|
+ onOk() {
|
|
|
|
+ submitLoading.value = true
|
|
|
|
+ let params = [
|
|
|
|
+ {
|
|
|
|
+ id: record.id
|
|
|
|
+ }
|
|
|
|
+ ]
|
|
|
|
+
|
|
|
|
+ bizLoadPointApi
|
|
|
|
+ .bizLoadPointDelete(params)
|
|
|
|
+ .then(() => {
|
|
|
|
+ tableRef.value.refresh(true)
|
|
|
|
+ })
|
|
|
|
+ .finally(() => {
|
|
|
|
+ submitLoading.value = false
|
|
|
|
+ })
|
|
|
|
+ },
|
|
|
|
+ onCancel() {}
|
|
|
|
+ })
|
|
|
|
+ }
|
|
|
|
+</script>
|