feat(contracttemp): 新增合同模版详情与表单组件

- 创建合同模版详情组件Detail.vue,呈现合同模版编码、名称、备注等信息
- 详情页使用BasicModal弹窗及多标签页展示合同框架、合同参数、打印模版
- 实现RelationDetail作为关联表单详情展示模块
- 新增合同模版表单组件Form.vue,支持合同模版的新增与编辑
- 表单包含合同基础信息及启用各类清单开关切换
- 合同参数中支持合同类型及签约类型的选择
- 打印模版部分实现打印模版列表展示及增删复制操作
- 使用Yunzhupaas系列组件构建输入框、开关、选择器等表单元素
- 表单支持操作后的提交与记录切换(上一条、下一条)
- 完善表单权限、数据加载、数据变更监听等逻辑处理
- 为表格列增加复杂表头处理的预留支持
- 掩码配置及多语言国际化支持已集成
This commit is contained in:
2026-05-21 00:28:16 +08:00
parent fccdf57954
commit 301c0199d2
8 changed files with 4281 additions and 0 deletions

View File

@@ -0,0 +1,423 @@
<template>
<BasicModal v-bind="$attrs" @register="registerModal" :title="title" width="1000px" :minHeight="100"
:showOkBtn="false">
<template #insertFooter>
</template>
<!-- 表单 -->
<a-row class="dynamic-form ">
<a-form :colon="false" size="middle" layout="horizontal" labelAlign="right"
:labelCol="{ style: { width: '100px' } }" :model="dataForm" ref="formRef">
<a-row :gutter="15">
<!-- 具体表单 -->
<a-col :span="12" class="ant-col-item">
<a-form-item name="contract_temp_code">
<template #label>合同模版编码
</template>
<YunzhupaasInput v-model:value="dataForm.contract_temp_code" placeholder="请输入" disabled
detailed allowClear :style='{ "width": "100%" }'
:maskConfig="maskConfig.contract_temp_code">
</YunzhupaasInput>
</a-form-item>
</a-col>
<a-col :span="12" class="ant-col-item">
<a-form-item name="contract_temp_name">
<template #label>合同模版名称
</template>
<YunzhupaasInput v-model:value="dataForm.contract_temp_name" placeholder="请输入" disabled
detailed allowClear :style='{ "width": "100%" }'
:maskConfig="maskConfig.contract_temp_name">
</YunzhupaasInput>
</a-form-item>
</a-col>
<a-col :span="24" class="ant-col-item">
<a-form-item name="remark">
<template #label>备注
</template>
<p>{{ dataForm.remark }}</p>
</a-form-item>
</a-col>
<a-col :span="24" class="ant-col-item">
<a-tabs v-model:activeKey="state.activetabformItem45e7a2" tabPosition="left" class="mb-20">
<a-tab-pane tab="合同框架" key="1" forceRender>
<a-row :gutter="15">
<table class="table-grid-box"
:style='{ "--borderType": "solid", "--borderColor": "#E2E0E0", "--borderWidth": "1px" }'>
<tbody>
<tr>
<td colspan="1" rowspan="1">
<a-col :span="24" class="ant-col-item">
<a-form-item name="is_framework">
<template #label>框架合同
<BasicHelp text="是:只有合同基本信息和合同主体,无合同清单、金额、付款计划。否:反之" />
</template>
<p>{{ dataForm.is_framework }}</p>
</a-form-item>
</a-col>
</td>
<td colspan="1" rowspan="1">
<a-col :span="24" class="ant-col-item">
<a-form-item name="is_detail_list">
<template #label>清单合同
<BasicHelp
text="是:显示合同清单,合同金额根据清单金额汇总生成;否:不显示清单,只显示合同金额与付款计划,合同金额手工录入" />
</template>
<p>{{ dataForm.is_detail_list }}</p>
</a-form-item>
</a-col>
</td>
</tr>
<tr>
<td colspan="1" rowspan="1">
<a-col :span="24" class="ant-col-item">
<a-form-item name="enable_tableProductList">
<template #label>启用产品清单
</template>
<p>{{ dataForm.enable_tableProductList }}</p>
</a-form-item>
</a-col>
</td>
<td colspan="1" rowspan="1">
<a-col :span="24" class="ant-col-item">
<a-form-item name="enable_tableMaterialList">
<template #label>启用材料清单
</template>
<p>{{ dataForm.enable_tableMaterialList }}</p>
</a-form-item>
</a-col>
</td>
</tr>
<tr>
<td colspan="1" rowspan="1">
<a-col :span="24" class="ant-col-item">
<a-form-item name="enable_tableWorktypeList">
<template #label>启用人力清单
</template>
<p>{{ dataForm.enable_tableWorktypeList }}</p>
</a-form-item>
</a-col>
</td>
<td colspan="1" rowspan="1">
<a-col :span="24" class="ant-col-item">
<a-form-item name="enable_tableAssetList">
<template #label>启用资产清单
</template>
<p>{{ dataForm.enable_tableAssetList }}</p>
</a-form-item>
</a-col>
</td>
</tr>
<tr>
<td colspan="1" rowspan="1">
<a-col :span="24" class="ant-col-item">
<a-form-item name="enable_tableTaskList">
<template #label>启用任务清单
</template>
<p>{{ dataForm.enable_tableTaskList }}</p>
</a-form-item>
</a-col>
</td>
<td colspan="1" rowspan="1">
</td>
</tr>
<tr>
<td colspan="1" rowspan="1">
</td>
<td colspan="1" rowspan="1">
</td>
</tr>
</tbody>
</table>
</a-row>
</a-tab-pane>
<a-tab-pane tab="合同参数" key="2" forceRender>
<a-row :gutter="15">
<table class="table-grid-box"
:style='{ "--borderType": "solid", "--borderColor": "#E2E0E0", "--borderWidth": "1px" }'>
<tbody>
<tr>
<td colspan="1" rowspan="1">
<a-col :span="24" class="ant-col-item">
<a-form-item name="contract_type">
<template #label>合同类型
</template>
<p>{{ dataForm.contract_type }}</p>
</a-form-item>
</a-col>
</td>
<td colspan="1" rowspan="1">
<a-col :span="24" class="ant-col-item">
<a-form-item name="enable_printing">
<template #label>启用在线打印
</template>
<p>{{ dataForm.enable_printing }}</p>
</a-form-item>
</a-col>
</td>
</tr>
<tr>
<td colspan="1" rowspan="1">
<a-col :span="24" class="ant-col-item">
<a-form-item name="our_company_type">
<template #label>我方签约类型
</template>
<p>{{ dataForm.our_company_type }}</p>
</a-form-item>
</a-col>
</td>
<td colspan="1" rowspan="1">
<a-col :span="24" class="ant-col-item">
<a-form-item name="second_party_type">
<template #label>乙方签约类型
</template>
<p>{{ dataForm.second_party_type }}</p>
</a-form-item>
</a-col>
</td>
</tr>
<tr>
<td colspan="1" rowspan="1">
<a-col :span="24" class="ant-col-item">
<a-form-item name="third_party_type">
<template #label>丙方签约类型
</template>
<p>{{ dataForm.third_party_type }}</p>
</a-form-item>
</a-col>
</td>
<td colspan="1" rowspan="1">
</td>
</tr>
</tbody>
</table>
</a-row>
</a-tab-pane>
<a-tab-pane tab="打印模版" key="fbb4be" forceRender>
<a-row :gutter="15">
<a-col :span="24" class="ant-col-item mb-20px">
<a-form-item>
<a-table :data-source="dataForm.tablePrintingTemp"
:columns="contractPrintingTempColumns" size="small" :pagination="false"
:scroll="{ x: 'max-content' }">
<template #headerCell="{ column }">
<span class="required-sign" v-if="column.required">*</span>
{{ column.title }}
<BasicHelp :text="column.tipLabel"
v-if="column.tipLabel && column.title" />
</template>
<template #bodyCell="{ column, index, record }">
<template v-if="column.key === 'index'">{{ index + 1 }}</template>
<template v-if="column.key === 'printing_temp_id'">
<p>{{ record.printing_temp_id }}</p>
</template>
<template v-if="column.key === 'is_enabled'">
<p>{{ record.is_enabled }}</p>
</template>
</template>
</a-table>
</a-form-item>
</a-col>
</a-row>
</a-tab-pane>
</a-tabs>
</a-col>
<!-- 表单结束 -->
</a-row>
</a-form>
</a-row>
</BasicModal>
<!-- 有关联表单详情开始 -->
<RelationDetail ref="relationDetailRef" />
<!-- 有关联表单详情结束 -->
</template>
<script lang="ts" setup>
import { getDetailInfo } from './helper/api';
import { getConfigData } from '@/api/onlineDev/visualDev';
import { reactive, toRefs, nextTick, ref, computed, unref, toRaw } from 'vue';
import { BasicModal, useModal } from '@/components/Modal';
// 有关联表单详情
import RelationDetail from '@/views/common/dynamicModel/list/detail/index.vue';
// 表单权限
import { usePermission } from '@/hooks/web/usePermission';
import { useMessage } from '@/hooks/web/useMessage';
import { CaretRightOutlined } from '@ant-design/icons-vue';
import { buildUUID } from '@/utils/uuid';
import { useI18n } from '@/hooks/web/useI18n';
import { getDataChange } from '@/api/onlineDev/visualDev';
import { getDataInterfaceDataInfoByIds } from '@/api/systemData/dataInterface';
import ExtraRelationInfo from '@/components/yunzhupaas/RelationForm/src/ExtraRelationInfo.vue';
interface State {
dataForm: any;
title: string;
maskConfig: any;
interfaceRes: any;
locationScope: any;
extraOptions: any;
extraData: any;
activetabformItem45e7a2: any;
}
defineOptions({ name: 'Detail' });
const { createMessage, createConfirm } = useMessage();
const [registerModal, { openModal, setModalProps, closeModal }] = useModal();
const contractPrintingTempColumns: any[] = computed(() => {
let list = [
{
title: '打印模版ID',
dataIndex: 'printing_temp_id',
key: 'printing_temp_id',
width: 350,
labelWidth: '',
span: '24',
tipLabel: '',
required: false,
style: { "width": "100%" },
align: 'left',
fixed: false,
formP: 'printing_temp_id',
},
{
title: '是否启用',
dataIndex: 'is_enabled',
key: 'is_enabled',
labelWidth: '',
span: '24',
tipLabel: '',
required: false,
style: '',
align: 'left',
fixed: false,
formP: 'is_enabled',
},
];
const indexColumn = { title: '序号', showLabel: true, dataIndex: 'index', key: 'index', align: 'center', fixed: 'left', width: 50 };
//子表复杂表头-处理
let columnList = list;
let complexHeaderList: any[] = [];
if (complexHeaderList.length) {
let childColumns: any[] = [];
let firstChildColumns: string[] = [];
for (let i = 0; i < complexHeaderList.length; i++) {
const e = complexHeaderList[i];
e.title = e.fullNameI18nCode ? t(e.fullNameI18nCode, e.fullName) : e.fullName;
e.align = e.align;
e.children = [];
e.yunzhupaasKey = 'complexHeader';
if (e.childColumns?.length) {
childColumns.push(...e.childColumns);
for (let k = 0; k < e.childColumns.length; k++) {
const item = e.childColumns[k];
for (let j = 0; j < list.length; j++) {
const o = list[j];
if (o.key == item && o.fixed !== 'left' && o.fixed !== 'right') e.children.push({ ...o });
}
}
}
if (e.children.length) firstChildColumns.push(e.children[0].key);
}
complexHeaderList = complexHeaderList.filter(o => o.children.length);
let newList: any[] = [];
for (let i = 0; i < list.length; i++) {
const e = list[i];
if (!childColumns.includes(e.key) || e.fixed === 'left' || e.fixed === 'right') {
newList.push(e);
} else {
if (firstChildColumns.includes(e.key)) {
const item = complexHeaderList.find(o => o.childColumns.includes(e.key));
newList.push(item);
}
}
}
columnList = newList;
}
let columns = [indexColumn, ...columnList]
const leftFixedList = columns.filter(o => o.fixed === 'left');
const rightFixedList = columns.filter(o => o.fixed === 'right');
const noFixedList = columns.filter(o => o.fixed !== 'left' && o.fixed !== 'right');
return [...leftFixedList, ...noFixedList, ...rightFixedList];
});
const { t } = useI18n();
const relationDetailRef = ref<any>(null);
const state = reactive<State>({
dataForm: {},
title: t('common.detailText', '详情'),
maskConfig: {
contract_temp_code: { "prefixType": 1, "useUnrealMask": false, "maskType": 1, "unrealMaskLength": 1, "prefixLimit": 0, "suffixLimit": 0, "filler": "*", "prefixSpecifyChar": "", "suffixType": 1, "ignoreChar": "", "suffixSpecifyChar": "" },
contract_temp_name: { "prefixType": 1, "useUnrealMask": false, "maskType": 1, "unrealMaskLength": 1, "prefixLimit": 0, "suffixLimit": 0, "filler": "*", "prefixSpecifyChar": "", "suffixType": 1, "ignoreChar": "", "suffixSpecifyChar": "" },
}
,
interfaceRes: { "enable_tableAssetList": [], "is_framework": [], "enable_tableMaterialList": [], "enable_printing": [], "our_company_type": [], "third_party_type": [], "remark": [], "contractPrintingTempprinting_temp_id": [], "enable_tableWorktypeList": [], "contract_type": [], "enable_tableTaskList": [], "contractPrintingTempis_enabled": [], "contract_temp_code": [], "enable_tableProductList": [], "is_detail_list": [], "second_party_type": [], "contract_temp_name": [] },
locationScope: {
}
,
extraOptions: {
}
,
extraData: {
}
,
activetabformItem45e7a2: 'fbb4be',
});
const { title, dataForm, maskConfig } = toRefs(state);
// 表单权限
const { hasFormP } = usePermission();
defineExpose({ init });
function init(data) {
state.dataForm.id = data.id;
openModal();
nextTick(() => {
setTimeout(initData, 0);
});
}
function initData() {
changeLoading(true);
state.activetabformItem45e7a2 = 'fbb4be';
if (state.dataForm.id) {
getData(state.dataForm.id);
} else {
closeModal();
}
}
function getData(id) {
getDetailInfo(id).then((res) => {
state.dataForm = res.data || {};
nextTick(() => {
changeLoading(false);
});
});
}
function toDetail(modelId, id, propsValue) {
if (!id) return;
getConfigData(modelId).then((res) => {
if (!res.data || !res.data.formData) return;
const formConf = JSON.parse(res.data.formData);
formConf.popupType = 'general';
formConf.hasPrintBtn = false;
formConf.customBtns = [];
const data = { id, formConf, modelId, propsValue };
relationDetailRef.value?.init(data);
});
}
function setFormProps(data) {
setModalProps(data);
}
function changeLoading(loading) {
setFormProps({ loading });
}
function getParamList(key) {
let templateJson: any[] = state.interfaceRes[key];
if (!templateJson || !templateJson.length || !state.dataForm) return templateJson;
for (let i = 0; i < templateJson.length; i++) {
if (templateJson[i].relationField && templateJson[i].sourceType == 1) {
templateJson[i].defaultValue = state.dataForm[templateJson[i].relationField + '_id'] || '';
}
}
return templateJson;
}
</script>

View File

@@ -0,0 +1,873 @@
<template>
<BasicModal v-bind="$attrs" @register="registerModal" width="1000px"
:minHeight="100"
:cancelText="t('common.cancelText','取消')"
:okText="t('common.okText','确定')"
@ok="handleSubmit" :closeFunc="onClose">
<template #title>
<a-space :size="10">
<div class="text-16px font-medium">{{ title }}</div>
<a-space-compact size="small" block v-if="dataForm.id">
<a-tooltip :title="t('common.prevRecord')">
<a-button size="small" :disabled="getPrevDisabled" @click="handlePrev">
<i class="icon-ym icon-ym-caret-left text-10px"></i>
</a-button>
</a-tooltip>
<a-tooltip :title="t('common.nextRecord')">
<a-button size="small" :disabled="getNextDisabled" @click="handleNext">
<i class="icon-ym icon-ym-caret-right text-10px"></i>
</a-button>
</a-tooltip>
</a-space-compact>
</a-space>
</template>
<template #insertFooter>
<div class="float-left mt-5px">
<yunzhupaasCheckboxSingle v-model:value="submitType" :label="continueText" />
</div>
</template>
<a-row class="dynamic-form ">
<a-form :colon="false" size="middle" layout= "horizontal"
labelAlign= "right"
:labelCol="{ style: { width: '100px' } }" :model="dataForm" :rules="dataRule" ref="formRef">
<a-row :gutter="15">
<!-- 具体表单 -->
<a-col :span="12" class="ant-col-item" >
<a-form-item
name="contract_temp_code" >
<template #label>合同模版编码
</template> <YunzhupaasInput v-model:value="dataForm.contract_temp_code" @change="changeData('contract_temp_code',-1)"
placeholder="请输入" :allowClear='true' :style='{"width":"100%"}' :maskConfig = "maskConfig.contract_temp_code" :showCount = "false" >
</YunzhupaasInput>
</a-form-item>
</a-col>
<a-col :span="12" class="ant-col-item" >
<a-form-item
name="contract_temp_name" >
<template #label>合同模版名称
</template> <YunzhupaasInput v-model:value="dataForm.contract_temp_name" @change="changeData('contract_temp_name',-1)"
placeholder="请输入" :allowClear='true' :style='{"width":"100%"}' :maskConfig = "maskConfig.contract_temp_name" :showCount = "false" >
</YunzhupaasInput>
</a-form-item>
</a-col>
<a-col :span="24" class="ant-col-item" >
<a-form-item
name="remark" >
<template #label>备注
</template> <YunzhupaasTextarea v-model:value="dataForm.remark" @change="changeData('remark',-1)"
placeholder="请输入" :allowClear='true' :style='{"width":"100%"}' :autoSize='{"minRows":3,"maxRows":3}' :showCount = "false" >
</YunzhupaasTextarea>
</a-form-item>
</a-col>
<a-col :span="24" class="ant-col-item">
<a-tabs v-model:activeKey="state.activetabformItem45e7a2" tabPosition="left" class="mb-20" >
<a-tab-pane tab="合同框架" key="1" forceRender>
<a-row :gutter="15">
<table class="table-grid-box" :style='{"--borderType":"solid","--borderColor":"#E2E0E0","--borderWidth":"1px"}'>
<tbody
>
<tr
>
<td colspan="1" rowspan="1"
>
<a-row :gutter="15">
<a-col :span="24" class="ant-col-item" >
<a-form-item
name="is_framework" >
<template #label>框架合同
<BasicHelp text="是:只有合同基本信息和合同主体,无合同清单、金额、付款计划。否:反之" /></template> <YunzhupaasSwitch v-model:value="dataForm.is_framework" @change="changeData('is_framework',-1)"
>
</YunzhupaasSwitch>
</a-form-item>
</a-col>
</a-row>
</td>
<td colspan="1" rowspan="1"
>
<a-row :gutter="15">
<a-col :span="24" class="ant-col-item" >
<a-form-item
name="is_detail_list" >
<template #label>清单合同
<BasicHelp text="是:显示合同清单,合同金额根据清单金额汇总生成;否:不显示清单,只显示合同金额与付款计划,合同金额手工录入" /></template> <YunzhupaasSwitch v-model:value="dataForm.is_detail_list" @change="changeData('is_detail_list',-1)"
>
</YunzhupaasSwitch>
</a-form-item>
</a-col>
</a-row>
</td>
</tr>
<tr
>
<td colspan="1" rowspan="1"
>
<a-row :gutter="15">
<a-col :span="24" class="ant-col-item" >
<a-form-item
name="enable_tableProductList" >
<template #label>启用产品清单
</template> <YunzhupaasSwitch v-model:value="dataForm.enable_tableProductList" @change="changeData('enable_tableProductList',-1)"
>
</YunzhupaasSwitch>
</a-form-item>
</a-col>
</a-row>
</td>
<td colspan="1" rowspan="1"
>
<a-row :gutter="15">
<a-col :span="24" class="ant-col-item" >
<a-form-item
name="enable_tableMaterialList" >
<template #label>启用材料清单
</template> <YunzhupaasSwitch v-model:value="dataForm.enable_tableMaterialList" @change="changeData('enable_tableMaterialList',-1)"
>
</YunzhupaasSwitch>
</a-form-item>
</a-col>
</a-row>
</td>
</tr>
<tr
>
<td colspan="1" rowspan="1"
>
<a-row :gutter="15">
<a-col :span="24" class="ant-col-item" >
<a-form-item
name="enable_tableWorktypeList" >
<template #label>启用人力清单
</template> <YunzhupaasSwitch v-model:value="dataForm.enable_tableWorktypeList" @change="changeData('enable_tableWorktypeList',-1)"
>
</YunzhupaasSwitch>
</a-form-item>
</a-col>
</a-row>
</td>
<td colspan="1" rowspan="1"
>
<a-row :gutter="15">
<a-col :span="24" class="ant-col-item" >
<a-form-item
name="enable_tableAssetList" >
<template #label>启用资产清单
</template> <YunzhupaasSwitch v-model:value="dataForm.enable_tableAssetList" @change="changeData('enable_tableAssetList',-1)"
>
</YunzhupaasSwitch>
</a-form-item>
</a-col>
</a-row>
</td>
</tr>
<tr
>
<td colspan="1" rowspan="1"
>
<a-row :gutter="15">
<a-col :span="24" class="ant-col-item" >
<a-form-item
name="enable_tableTaskList" >
<template #label>启用任务清单
</template> <YunzhupaasSwitch v-model:value="dataForm.enable_tableTaskList" @change="changeData('enable_tableTaskList',-1)"
>
</YunzhupaasSwitch>
</a-form-item>
</a-col>
</a-row>
</td>
<td colspan="1" rowspan="1"
>
<a-row :gutter="15">
</a-row>
</td>
</tr>
<tr
>
<td colspan="1" rowspan="1"
>
<a-row :gutter="15">
</a-row>
</td>
<td colspan="1" rowspan="1"
>
<a-row :gutter="15">
</a-row>
</td>
</tr>
</tbody>
</table>
</a-row>
</a-tab-pane >
<a-tab-pane tab="合同参数" key="2" forceRender>
<a-row :gutter="15">
<table class="table-grid-box" :style='{"--borderType":"solid","--borderColor":"#E2E0E0","--borderWidth":"1px"}'>
<tbody
>
<tr
>
<td colspan="1" rowspan="1"
>
<a-row :gutter="15">
<a-col :span="24" class="ant-col-item" >
<a-form-item
name="contract_type" >
<template #label>合同类型
</template> <YunzhupaasSelect v-model:value="dataForm.contract_type" @change="changeData('contract_type',-1)"
placeholder="请选择" :templateJson="state.interfaceRes.contract_type" :allowClear='true' :style='{"width":"100%"}' :showSearch='false' :options="optionsObj.contract_typeOptions" :fieldNames="optionsObj.contract_typeProps"
>
</YunzhupaasSelect>
</a-form-item>
</a-col>
</a-row>
</td>
<td colspan="1" rowspan="1"
>
<a-row :gutter="15">
<a-col :span="24" class="ant-col-item" >
<a-form-item
name="enable_printing" >
<template #label>启用在线打印
</template> <YunzhupaasSwitch v-model:value="dataForm.enable_printing" @change="changeData('enable_printing',-1)"
>
</YunzhupaasSwitch>
</a-form-item>
</a-col>
</a-row>
</td>
</tr>
<tr
>
<td colspan="1" rowspan="1"
>
<a-row :gutter="15">
<a-col :span="24" class="ant-col-item" >
<a-form-item
name="our_company_type" >
<template #label>我方签约类型
</template> <YunzhupaasSelect v-model:value="dataForm.our_company_type" @change="changeData('our_company_type',-1)"
placeholder="请选择" :templateJson="state.interfaceRes.our_company_type" :allowClear='true' :style='{"width":"100%"}' :showSearch='false' :options="optionsObj.our_company_typeOptions" :fieldNames="optionsObj.our_company_typeProps"
>
</YunzhupaasSelect>
</a-form-item>
</a-col>
</a-row>
</td>
<td colspan="1" rowspan="1"
>
<a-row :gutter="15">
<a-col :span="24" class="ant-col-item" >
<a-form-item
name="second_party_type" >
<template #label>乙方签约类型
</template> <YunzhupaasSelect v-model:value="dataForm.second_party_type" @change="changeData('second_party_type',-1)"
placeholder="请选择" :templateJson="state.interfaceRes.second_party_type" :allowClear='true' :style='{"width":"100%"}' :showSearch='false' :options="optionsObj.second_party_typeOptions" :fieldNames="optionsObj.second_party_typeProps"
>
</YunzhupaasSelect>
</a-form-item>
</a-col>
</a-row>
</td>
</tr>
<tr
>
<td colspan="1" rowspan="1"
>
<a-row :gutter="15">
<a-col :span="24" class="ant-col-item" >
<a-form-item
name="third_party_type" >
<template #label>丙方签约类型
</template> <YunzhupaasSelect v-model:value="dataForm.third_party_type" @change="changeData('third_party_type',-1)"
placeholder="请选择" :templateJson="state.interfaceRes.third_party_type" :allowClear='true' :style='{"width":"100%"}' :showSearch='false' :options="optionsObj.third_party_typeOptions" :fieldNames="optionsObj.third_party_typeProps"
>
</YunzhupaasSelect>
</a-form-item>
</a-col>
</a-row>
</td>
<td colspan="1" rowspan="1"
>
<a-row :gutter="15">
</a-row>
</td>
</tr>
</tbody>
</table>
</a-row>
</a-tab-pane >
<a-tab-pane tab="打印模版" key="fbb4be" forceRender>
<a-row :gutter="15">
<a-col :span="24" class="ant-col-item mb-20px" >
<a-form-item>
<yunzhupaasGroupTitle content="设计子表" :bordered="false"
helpMessage="" />
<a-table :data-source="dataForm.contractPrintingTempList"
:columns="contractPrintingTempColumns" size="small" :pagination="false" :scroll="{ x: 'max-content' }"
:rowSelection="getcontractPrintingTempRowSelection" rowKey="yunzhupaasId">
<template #headerCell="{ column }">
<span class="required-sign" v-if="column.required">*</span>
{{ column.title }}
<BasicHelp :text="column.tipLabel" v-if="column.tipLabel && column.title" />
</template>
<template #bodyCell="{ column, index, record }">
<template v-if="column.key === 'index'">{{ index + 1 }}</template>
<template v-if="column.key === 'printing_temp_id' ">
<YunzhupaasPopupTableSelect v-model:value="record.printing_temp_id" @change="changeData('contractPrintingTempprinting_temp_id',index)"
placeholder="请选择" :rowIndex="index" :formData="dataForm"
:templateJson="state.interfaceRes.contractPrintingTempprinting_temp_id" :allowClear='true' :style='{"width":"100%"}' :showSearch='true' :field="'printing_temp_id'+index" interfaceId="826713957526931333"
:columnOptions="optionsObj.contractPrintingTempprinting_temp_idcolumnOptions" propsValue="f_id" relationField="f_full_name" popupType="popover"
popupTitle="选择数据" popupWidth="800px" >
</YunzhupaasPopupTableSelect>
</template>
<template v-if="column.key === 'is_enabled' ">
<YunzhupaasSwitch v-model:value="record.is_enabled" @change="changeData('contractPrintingTempis_enabled',index)"
>
</YunzhupaasSwitch>
</template>
<template v-if="column.key === 'action'">
<a-space>
<a-button class="action-btn" type="link" @click="copyContractPrintingTempRow(index)" size="small"> {{t('common.copyText', '复制')}} </a-button>
<a-button class="action-btn" type="link" color="error" @click="removeContractPrintingTempRow(index,true)" size="small"> {{t('common.delText', '删除')}} </a-button>
</a-space>
</template>
</template>
</a-table>
<a-space class="input-table-footer-btn" >
<a-button type ='primary' preIcon="icon-ym icon-ym-btn-add"
@click="addContractPrintingTempRow"> {{t('common.add1Text','添加')}} </a-button>
<a-button type ='danger' preIcon="icon-ym icon-ym-btn-clearn"
@click="batchRemoveContractPrintingTempRow(true)"> {{t('common.batchDelText','批量删除')}} </a-button>
</a-space>
</a-form-item>
</a-col>
</a-row>
</a-tab-pane >
</a-tabs>
</a-col>
<!-- 表单结束 -->
</a-row>
</a-form>
</a-row>
</BasicModal>
</template>
<script lang="ts" setup>
import { create, update, getInfo } from './helper/api';
import { reactive, toRefs, nextTick, ref, unref, computed,toRaw, inject } from 'vue';
import { BasicModal, useModal } from '@/components/Modal';
import { yunzhupaasRelationForm } from '@/components/yunzhupaas';
import { useMessage } from '@/hooks/web/useMessage';
import { useI18n } from '@/hooks/web/useI18n';
import { useUserStore } from '@/store/modules/user';
import type { FormInstance } from 'ant-design-vue';
import { thousandsFormat , getDateTimeUnit, getTimeUnit} from '@/utils/yunzhupaas';
import { getDictionaryDataSelector } from '@/api/systemData/dictionary';
import { getDataInterfaceRes } from '@/api/systemData/dataInterface';
import dayjs from 'dayjs';
// 表单权限
import { usePermission } from '@/hooks/web/usePermission';
import { cloneDeep } from 'lodash-es';
import { buildUUID } from '@/utils/uuid';
import { CaretRightOutlined } from '@ant-design/icons-vue';
interface State {
dataForm: any;
tableRows: any;
dataRule: any;
optionsObj: any;
childIndex: any;
isEdit: any;
interfaceRes: any;
//可选范围默认值
ableAll: any;
//掩码配置
maskConfig:any;
//定位属性
locationScope:any;
activetabformItem45e7a2:any;
selectedcontractPrintingTempRowKeys : any;
extraOptions: any;
title: string;
continueText: string; allList: any[];
currIndex: number;
isContinue: boolean;
submitType: number;
showContinueBtn: boolean;
}
const emit = defineEmits(['reload']);
const getLeftTreeActiveInfo: (() => any) | null = inject('getLeftTreeActiveInfo', null);
const userStore = useUserStore();
const userInfo = userStore.getUserInfo;
const { createMessage, createConfirm } = useMessage();
const { t } = useI18n();
const [registerModal, { openModal, setModalProps }] = useModal();
const formRef = ref<FormInstance>();
const contractPrintingTempColumns: any[] = computed(() => {
let list = [
{
title: '打印模版ID' ,
dataIndex: 'printing_temp_id' ,
key: 'printing_temp_id' ,
width: 350,
labelWidth: '' ,
span:'24',
tipLabel: '' ,
required: false,
style: {"width":"100%"} ,
align: 'left' ,
fixed: false ,
formP: 'printing_temp_id' ,
},
{
title: '是否启用' ,
dataIndex: 'is_enabled' ,
key: 'is_enabled' ,
labelWidth: '' ,
span:'24',
tipLabel: '' ,
required: false,
style: '',
align: 'left' ,
fixed: false ,
formP: 'is_enabled' ,
},
];
list.push({ title: t('component.table.action'), showLabel: true, dataIndex: 'action', key: 'action', align: 'center', fixed: 'right', width: 100 }); const indexColumn = { title: t('component.table.index'), showLabel: true, dataIndex: 'index', key: 'index', align: 'center', fixed: 'left', width: 50 };
//子表复杂表头-处理
let columnList = list;
let complexHeaderList: any[] = [];
if (complexHeaderList.length) {
let childColumns: any[] = [];
let firstChildColumns: string[] = [];
for (let i = 0; i < complexHeaderList.length; i++) {
const e = complexHeaderList[i];
e.title = e.fullNameI18nCode ? t(e.fullNameI18nCode,e.fullName) : e.fullName;
e.align = e.align;
e.children = [];
e.yunzhupaasKey = 'complexHeader';
if (e.childColumns?.length) {
childColumns.push(...e.childColumns);
for (let k = 0; k < e.childColumns.length; k++) {
const item = e.childColumns[k];
for (let j = 0; j < list.length; j++) {
const o = list[j];
if (o.key == item && o.fixed !== 'left' && o.fixed !== 'right') e.children.push({ ...o });
}
}
}
if (e.children.length) firstChildColumns.push(e.children[0].key);
}
complexHeaderList = complexHeaderList.filter(o => o.children.length);
let newList: any[] = [];
for (let i = 0; i < list.length; i++) {
const e = list[i];
if (!childColumns.includes(e.key) || e.fixed === 'left' || e.fixed === 'right') {
newList.push(e);
} else {
if (firstChildColumns.includes(e.key)) {
const item = complexHeaderList.find(o => o.childColumns.includes(e.key));
newList.push(item);
}
}
}
columnList = newList;
}
let columns = [indexColumn, ...columnList]
const leftFixedList = columns.filter(o => o.fixed === 'left');
const rightFixedList = columns.filter(o => o.fixed === 'right');
const noFixedList = columns.filter(o => o.fixed !== 'left' && o.fixed !== 'right');
return [...leftFixedList, ...noFixedList, ...rightFixedList];
});
const getcontractPrintingTempHasBatchBtn = computed(() =>{
let flist:any[] = [{"btnIcon":"icon-ym icon-ym-btn-add","show":true,"label":"添加","btnType":"primary","value":"add","labelI18nCode":"common.add1Text"},{"btnIcon":"icon-ym icon-ym-btn-clearn","showConfirm":"true","show":true,"label":"批量删除","btnType":"danger","value":"batchRemove","labelI18nCode":"common.batchDelText"}]
return flist?.length && flist.some(o => o.value == 'batchRemove' && !!o.show)
});
const getcontractPrintingTempRowSelection = computed(() => {
if (!unref(getcontractPrintingTempHasBatchBtn )) return undefined;
const rowSelection = {
selectedRowKeys: state.selectedcontractPrintingTempRowKeys,
onChange: (selectedRowKeys: string[]) => {
state.selectedcontractPrintingTempRowKeys = selectedRowKeys;
},
};
return rowSelection;
});
const state = reactive<State>({
dataForm: {
contract_temp_code:undefined,
contract_temp_name:undefined,
remark:undefined,
is_framework:0,
is_detail_list:1,
enable_tableProductList:0,
enable_tableMaterialList:0,
enable_tableWorktypeList:0,
enable_tableAssetList:0,
enable_tableTaskList:0,
contract_type:'',
enable_printing:1,
our_company_type:'PartA',
second_party_type:'PartB',
third_party_type:'PartC',
contractPrintingTempList:[],
},
tableRows:{
contractPrintingTempList:{
printing_temp_id : '',
is_enabled : 0,
enabledmark:undefined
},
},
dataRule: {
},
optionsObj:{
contract_typeOptions:[{"fullName":"收入合同","id":"REV"},{"fullName":"支出合同","id":"COS"}],
contract_typeProps:{"label":"fullName","value":"id" },
our_company_typeOptions:[{"fullName":"甲方","id":"PartA"},{"fullName":"乙方","id":"PartB"},{"fullName":"丙方","id":"PartC"}],
our_company_typeProps:{"label":"fullName","value":"id" },
second_party_typeOptions:[{"fullName":"甲方","id":"PartA"},{"fullName":"乙方","id":"PartB"},{"fullName":"丙方","id":"PartC"}],
second_party_typeProps:{"label":"fullName","value":"id" },
third_party_typeOptions:[{"fullName":"甲方","id":"PartA"},{"fullName":"乙方","id":"PartB"},{"fullName":"丙方","id":"PartC"}],
third_party_typeProps:{"label":"fullName","value":"id" },
contractPrintingTempprinting_temp_idcolumnOptions:[ {"label":"打印模版名称","value":"f_full_name"}, {"label":"打印模版描述","value":"f_description"},],
},
childIndex: -1,
isEdit: false,
interfaceRes: {"enable_tableAssetList":[],"is_framework":[],"enable_tableMaterialList":[],"enable_printing":[],"our_company_type":[],"third_party_type":[],"remark":[],"contractPrintingTempprinting_temp_id":[],"enable_tableWorktypeList":[],"contract_type":[],"enable_tableTaskList":[],"contractPrintingTempis_enabled":[],"contract_temp_code":[],"enable_tableProductList":[],"is_detail_list":[],"second_party_type":[],"contract_temp_name":[]},
//可选范围默认值
ableAll:{
},
//掩码配置
maskConfig:{
contract_temp_code: {"prefixType":1,"useUnrealMask":false,"maskType":1,"unrealMaskLength":1,"prefixLimit":0,"suffixLimit":0,"filler":"*","prefixSpecifyChar":"","suffixType":1,"ignoreChar":"","suffixSpecifyChar":""} ,
contract_temp_name: {"prefixType":1,"useUnrealMask":false,"maskType":1,"unrealMaskLength":1,"prefixLimit":0,"suffixLimit":0,"filler":"*","prefixSpecifyChar":"","suffixType":1,"ignoreChar":"","suffixSpecifyChar":""} ,
},
//定位属性
locationScope:{
},
activetabformItem45e7a2:'fbb4be',
selectedcontractPrintingTempRowKeys : [],
extraOptions:{
},
title: "",
continueText: "", allList: [],
currIndex: 0,
isContinue: false,
submitType: 0,
showContinueBtn: true ,
});
const { title, continueText, showContinueBtn, dataRule, dataForm, optionsObj, ableAll, maskConfig,submitType } = toRefs(state);
const getPrevDisabled = computed(() => state.currIndex === 0);
const getNextDisabled = computed(() => state.currIndex === state.allList.length - 1);
// 表单权限
const { hasFormP } = usePermission();
defineExpose({ init });
function init(data) {
state.submitType = 0;
state.isContinue = false;
state.title = !data.id ? t('common.add2Text','新增') : t('common.editText','编辑');
state.continueText = !data.id ? t('common.continueAndAddText','确定并新增') : t('common.continueText','确定并继续'); setFormProps({ continueLoading: false });
state.dataForm.id = data.id;
openModal();
state.allList = data.allList;
state.currIndex = state.allList.length && data.id ? state.allList.findIndex((item) => item.id === data.id) : 0;
nextTick(() => {
getForm().resetFields();
state.dataForm.contractPrintingTempList = [];
setTimeout(initData, 0);
});
}
function initData() {
changeLoading(true);
state.activetabformItem45e7a2='fbb4be';
if (state.dataForm.id) {
getData(state.dataForm.id);
} else {
//初始化options
if (state.dataForm.contractPrintingTempList) {
for (let i = 0; i < state.dataForm.contractPrintingTempList.length; i++) {
state.childIndex = i;
state.dataForm.contractPrintingTempList[i].yunzhupaasId = buildUUID();
}
}
// 设置默认值
state.dataForm={
contract_temp_code:undefined,
contract_temp_name:undefined,
remark:undefined,
is_framework:0,
is_detail_list:1,
enable_tableProductList:0,
enable_tableMaterialList:0,
enable_tableWorktypeList:0,
enable_tableAssetList:0,
enable_tableTaskList:0,
contract_type:'',
enable_printing:1,
our_company_type:'PartA',
second_party_type:'PartB',
third_party_type:'PartC',
contractPrintingTempList:[],
};
if (getLeftTreeActiveInfo) state.dataForm = {...state.dataForm, ...(getLeftTreeActiveInfo() || {}) };
state.childIndex = -1;
changeLoading(false);
}
}
function getForm() {
const form = unref(formRef);
if (!form) {
throw new Error('form is null!');
}
return form;
}
function getData(id) {
getInfo(id).then((res) => {
state.dataForm = res.data || {};
if (state.dataForm.contractPrintingTempList) {
for (let i = 0; i < state.dataForm.contractPrintingTempList.length; i++) {
state.childIndex = i;
state.dataForm.contractPrintingTempList[i].yunzhupaasId = buildUUID();
}
}
state.childIndex = -1;
changeLoading(false);
});
}
async function handleSubmit(type) {
try {
const values = await getForm()?.validate();
if (!values) return;
if(!contractPrintingTempExist()) return;
setFormProps({ confirmLoading: true });
const formMethod = state.dataForm.id ? update : create;
formMethod(state.dataForm)
.then((res) => {
createMessage.success(res.msg);
setFormProps({ confirmLoading: false });
if (state.submitType == 1) {
initData();
state.isContinue = true;
} else {
setFormProps({ open: false });
emit('reload');
}
})
.catch(() => {
setFormProps({ confirmLoading: false });
});
} catch (_) {}
}
function handlePrev() {
state.currIndex--;
handleGetNewInfo();
}
function handleNext() {
state.currIndex++;
handleGetNewInfo();
}
function handleGetNewInfo() {
changeLoading(true);
getForm().resetFields();
const id = state.allList[state.currIndex].id;
getData(id);
}
function setFormProps(data) {
setModalProps(data);
}
function changeLoading(loading) {
setModalProps({ loading });
}
async function onClose() {
if (state.isContinue) emit('reload');
return true;
}
function changeData(model, index) {
state.isEdit = false
state.childIndex = index
for (let key in state.interfaceRes) {
if (key != model) {
let faceReList = state.interfaceRes[key]
for (let i = 0; i < faceReList.length; i++) {
let relationField = faceReList[i].relationField;
if(relationField){
let modelAll = relationField.split('-');
let faceMode = '';
let faceMode2 = modelAll.length == 2?modelAll[0].substring(0, modelAll[0].length-4) +modelAll[1]:""
for (let i = 0; i < modelAll.length; i++) {
faceMode += modelAll[i];
}
if (faceMode == model || faceMode2 == model ) {
let options = 'get' + key + 'Options';
eval(options)(true);
changeData(key, index)
}
}
}
}
}
}
function changeDataFormData(type, data, model,index,defaultValue) {
if(!state.isEdit) {
if (type == 2) {
for (let i = 0; i < state.dataForm[data].length; i++) {
if (index == -1) {
state.dataForm[data][i][model] = defaultValue
} else if (index == i) {
state.dataForm[data][i][model] = defaultValue
}
}
} else {
state.dataForm[data] = defaultValue
}
}
}
function addContractPrintingTempRow(){
let item = {
printing_temp_id:'',
is_enabled:0,
yunzhupaasId: buildUUID(),
}
state.dataForm.contractPrintingTempList.push(item)
state.childIndex=state.dataForm.contractPrintingTempList.length-1
state.childIndex = -1
}
function removeContractPrintingTempRow(index,showConfirm=false){
if(showConfirm){
createConfirm({
iconType: 'warning',
title: '提示',
content: '此操作将永久删除该数据, 是否继续?',
onOk: () => {
state.dataForm.contractPrintingTempList.splice(index, 1);
},
});
}else{
state.dataForm.contractPrintingTempList.splice(index, 1);
}
}
function copyContractPrintingTempRow(index){
let item = cloneDeep(state.dataForm.contractPrintingTempList[index]);
let copyData = {};
for (let i = 0; i < unref(contractPrintingTempColumns).length; i++) {
const cur = unref(contractPrintingTempColumns)[i];
if (cur.key != 'index' && cur.key != 'action') {
if (cur.children?.length && cur.yunzhupaasKey == 'complexHeader') {
for (let j = 0; j < cur.children.length; j++) {
copyData[cur.children[j].key] = item[cur.children[j].key];
}
} else {
copyData[cur.key] = item[cur.key];
}
}
}
const copyItem = { ...copyData, yunzhupaasId: buildUUID() };
state.dataForm.contractPrintingTempList.push(copyItem);
state.childIndex=state.dataForm.contractPrintingTempList.length-1
state.childIndex = -1
}
function batchRemoveContractPrintingTempRow(showConfirm=false){
if (!state.selectedcontractPrintingTempRowKeys.length) return createMessage.error('请选择一条数据');
const handleRemove = ()=>{
state.dataForm.contractPrintingTempList = state.dataForm.contractPrintingTempList.filter(
o => !state.selectedcontractPrintingTempRowKeys.includes(o.yunzhupaasId),
);
nextTick(() => {
state.selectedcontractPrintingTempRowKeys = [];
});
}
if(showConfirm){
createConfirm({
iconType: 'warning',
title: '提示',
content: '此操作将永久删除该数据, 是否继续?',
onOk: ()=>{
handleRemove()
},
});
}else{
handleRemove()
}
}
function contractPrintingTempExist(){
let isOk = true;
for(let i=0;i<state.dataForm.contractPrintingTempList.length;i++){
const e = state.dataForm.contractPrintingTempList[i];
}
return isOk;
}
function getcontractPrintingTempprinting_temp_idOptions() {
const index = state.childIndex
changeDataFormData(2,'contractPrintingTempList','contractPrintingTempprinting_temp_id',index,'')
}
function getRelationDate(timeRule, timeType, timeTarget, timeValueData, dataValue) {
let timeDataValue: any = null;
let timeValue = Number(timeValueData);
if (timeRule) {
if (timeType == 1) {
timeDataValue = timeValue;
} else if (timeType == 2) {
timeDataValue = dataValue;
} else if (timeType == 3) {
timeDataValue = new Date().getTime();
} else if (timeType == 4 || timeType == 5) {
const type = getTimeUnit(timeTarget);
const method = timeType == 4 ? 'subtract' : 'add';
timeDataValue = dayjs()[method](timeValue, type).valueOf();
}
}
return timeDataValue;
}
function getRelationTime(timeRule, timeType, timeTarget, timeValue, formatType, dataValue) {
let format = formatType == 'HH:mm' ? 'HH:mm:00' : formatType;
let timeDataValue: any = null;
if (timeRule) {
if (timeType == 1) {
timeDataValue = timeValue || '00:00:00';
if (timeDataValue.split(':').length == 3) {
timeDataValue = timeDataValue;
} else {
timeDataValue = timeDataValue + ':00';
}
} else if (timeType == 2) {
timeDataValue = dataValue;
} else if (timeType == 3) {
timeDataValue = dayjs().format(format);
} else if (timeType == 4 || timeType == 5) {
const type = getTimeUnit(timeTarget + 3);
const method = timeType == 4 ? 'subtract' : 'add';
timeDataValue = dayjs()[method](timeValue, type).format(format);
}
}
return timeDataValue;
}
</script>

View File

@@ -0,0 +1,34 @@
import { defHttp } from '@/utils/http/axios';
// 获取列表
export function getList(data) {
return defHttp.post({ url: '/api/cm/ContractTemp/getList', data });
}
// 新建
export function create(data) {
return defHttp.post({ url:'/api/cm/ContractTemp', data });
}
// 修改
export function update(data) {
return defHttp.put({ url: '/api/cm/ContractTemp/'+ data.id, data });
}
// 详情(无转换数据)
export function getInfo(id) {
return defHttp.get({ url: '/api/cm/ContractTemp/' + id });
}
// 获取(转换数据)
export function getDetailInfo(id) {
return defHttp.get({ url: '/api/cm/ContractTemp/detail/' + id });
}
// 删除
export function del(id) {
return defHttp.delete({ url: '/api/cm/ContractTemp/' + id });
}
// 批量删除数据
export function batchDelete(data) {
return defHttp.delete({ url: '/api/cm/ContractTemp/batchRemove', data });
}
// 导出
export function exportData(data) {
return defHttp.post({ url: '/api/cm/ContractTemp/Actions/Export', data });
}

View File

@@ -0,0 +1,213 @@
const columnList = [
{
"yunzhupaasKey":"input",
"useScan":false,
"suffixIcon":"",
"fullNameI18nCode":[
""
],
"align":"left",
"showCount":false,
"__config__":{
"formId":"formItemb3758f",
"yunzhupaasKey":"input",
"visibility":[
"pc",
"app"
],
"noShow":false,
"tipLabel":"",
"tableFixed":"none",
"dragDisabled":false,
"className":[],
"label":"合同模版编码",
"trigger":"blur",
"showLabel":true,
"required":false,
"tableName":"cm_contract_temp",
"renderKey":1779197093361,
"layout":"colFormItem",
"tagIcon":"icon-ym icon-ym-generator-input",
"tag":"YunzhupaasInput",
"regList":[],
"tableAlign":"left",
"span":12,
"labelI18nCode":""
},
"readonly":false,
"prop":"contract_temp_code",
"__vModel__":"contract_temp_code",
"disabled":false,
"id":"contract_temp_code",
"placeholder":"请输入",
"addonBefore":"",
"on":{
"change":"({ data, rowIndex, formData, setFormData, setShowOrHide, setRequired, setDisabled, onlineUtils }) => {\n // 在此编写代码\n \n}",
"blur":"({ data, rowIndex, formData, setFormData, setShowOrHide, setRequired, setDisabled, onlineUtils }) => {\n // 在此编写代码\n \n}"
},
"clearable":true,
"resizable":true,
"maxlength":null,
"fullName":"合同模版编码",
"label":"合同模版编码",
"sortable":false,
"addonAfter":"",
"maskConfig":{
"prefixType":1,
"useUnrealMask":false,
"maskType":1,
"unrealMaskLength":1,
"prefixLimit":0,
"suffixLimit":0,
"filler":"*",
"prefixSpecifyChar":"",
"suffixType":1,
"ignoreChar":"",
"suffixSpecifyChar":""
},
"width":200,
"useMask":false,
"showPassword":false,
"fixed":"none",
"style":{
"width":"100%"
},
"prefixIcon":"",
"labelI18nCode":""
},
{
"yunzhupaasKey":"input",
"useScan":false,
"suffixIcon":"",
"fullNameI18nCode":[
""
],
"align":"left",
"showCount":false,
"__config__":{
"formId":"formItem7c816a",
"yunzhupaasKey":"input",
"visibility":[
"pc",
"app"
],
"noShow":false,
"tipLabel":"",
"tableFixed":"none",
"dragDisabled":false,
"className":[],
"label":"合同模版名称",
"trigger":"blur",
"showLabel":true,
"required":false,
"tableName":"cm_contract_temp",
"renderKey":1779197096173,
"layout":"colFormItem",
"tagIcon":"icon-ym icon-ym-generator-input",
"tag":"YunzhupaasInput",
"regList":[],
"tableAlign":"left",
"span":12
},
"readonly":false,
"prop":"contract_temp_name",
"__vModel__":"contract_temp_name",
"disabled":false,
"id":"contract_temp_name",
"placeholder":"请输入",
"addonBefore":"",
"on":{
"change":"({ data, rowIndex, formData, setFormData, setShowOrHide, setRequired, setDisabled, onlineUtils }) => {\n // 在此编写代码\n \n}",
"blur":"({ data, rowIndex, formData, setFormData, setShowOrHide, setRequired, setDisabled, onlineUtils }) => {\n // 在此编写代码\n \n}"
},
"clearable":true,
"resizable":true,
"maxlength":null,
"fullName":"合同模版名称",
"label":"合同模版名称",
"sortable":false,
"addonAfter":"",
"maskConfig":{
"prefixType":1,
"useUnrealMask":false,
"maskType":1,
"unrealMaskLength":1,
"prefixLimit":0,
"suffixLimit":0,
"filler":"*",
"prefixSpecifyChar":"",
"suffixType":1,
"ignoreChar":"",
"suffixSpecifyChar":""
},
"width":350,
"useMask":false,
"showPassword":false,
"fixed":"none",
"style":{
"width":"100%"
},
"prefixIcon":"",
"labelI18nCode":""
},
{
"yunzhupaasKey":"textarea",
"clearable":true,
"resizable":true,
"maxlength":null,
"fullName":"备注",
"fullNameI18nCode":[
""
],
"label":"备注",
"sortable":false,
"align":"left",
"autoSize":{
"minRows":3,
"maxRows":3
},
"showCount":false,
"__config__":{
"formId":"formItem4ef0df",
"yunzhupaasKey":"textarea",
"visibility":[
"pc",
"app"
],
"noShow":false,
"tipLabel":"",
"tableFixed":"none",
"dragDisabled":false,
"className":[],
"label":"备注",
"trigger":"blur",
"showLabel":true,
"required":false,
"tableName":"cm_contract_temp",
"renderKey":1779197120754,
"layout":"colFormItem",
"tagIcon":"icon-ym icon-ym-generator-textarea",
"tag":"YunzhupaasTextarea",
"regList":[],
"tableAlign":"left",
"span":24
},
"readonly":false,
"prop":"remark",
"width":null,
"__vModel__":"remark",
"fixed":"none",
"style":{
"width":"100%"
},
"disabled":false,
"id":"remark",
"placeholder":"请输入",
"labelI18nCode":"",
"on":{
"change":"({ data, rowIndex, formData, setFormData, setShowOrHide, setRequired, setDisabled, onlineUtils }) => {\n // 在此编写代码\n \n}",
"blur":"({ data, rowIndex, formData, setFormData, setShowOrHide, setRequired, setDisabled, onlineUtils }) => {\n // 在此编写代码\n \n}"
}
}
]
export default columnList

View File

@@ -0,0 +1,2 @@
const searchList = []
export default searchList

View File

@@ -0,0 +1,914 @@
const superQueryJson = [
{
"clearable":true,
"maxlength":null,
"useScan":false,
"suffixIcon":"",
"fullName":"合同模版编码",
"fullNameI18nCode":[
""
],
"addonAfter":"",
"showCount":false,
"__config__":{
"formId":"formItemb3758f",
"yunzhupaasKey":"input",
"visibility":[
"pc",
"app"
],
"noShow":false,
"tipLabel":"",
"tableFixed":"none",
"dragDisabled":false,
"className":[],
"label":"合同模版编码",
"trigger":"blur",
"showLabel":true,
"required":false,
"tableName":"cm_contract_temp",
"renderKey":1779197093361,
"layout":"colFormItem",
"tagIcon":"icon-ym icon-ym-generator-input",
"tag":"YunzhupaasInput",
"regList":[],
"tableAlign":"left",
"span":12,
"labelI18nCode":""
},
"readonly":false,
"maskConfig":{
"prefixType":1,
"useUnrealMask":false,
"maskType":1,
"unrealMaskLength":1,
"prefixLimit":0,
"suffixLimit":0,
"filler":"*",
"prefixSpecifyChar":"",
"suffixType":1,
"ignoreChar":"",
"suffixSpecifyChar":""
},
"__vModel__":"contract_temp_code",
"useMask":false,
"showPassword":false,
"style":{
"width":"100%"
},
"disabled":false,
"id":"contract_temp_code",
"placeholder":"请输入",
"prefixIcon":"",
"addonBefore":"",
"on":{
"change":"({ data, rowIndex, formData, setFormData, setShowOrHide, setRequired, setDisabled, onlineUtils }) => {\n // 在此编写代码\n \n}",
"blur":"({ data, rowIndex, formData, setFormData, setShowOrHide, setRequired, setDisabled, onlineUtils }) => {\n // 在此编写代码\n \n}"
}
},
{
"clearable":true,
"maxlength":null,
"useScan":false,
"suffixIcon":"",
"fullName":"合同模版名称",
"fullNameI18nCode":[
""
],
"addonAfter":"",
"showCount":false,
"__config__":{
"formId":"formItem7c816a",
"yunzhupaasKey":"input",
"visibility":[
"pc",
"app"
],
"noShow":false,
"tipLabel":"",
"tableFixed":"none",
"dragDisabled":false,
"className":[],
"label":"合同模版名称",
"trigger":"blur",
"showLabel":true,
"required":false,
"tableName":"cm_contract_temp",
"renderKey":1779197096173,
"layout":"colFormItem",
"tagIcon":"icon-ym icon-ym-generator-input",
"tag":"YunzhupaasInput",
"regList":[],
"tableAlign":"left",
"span":12
},
"readonly":false,
"maskConfig":{
"prefixType":1,
"useUnrealMask":false,
"maskType":1,
"unrealMaskLength":1,
"prefixLimit":0,
"suffixLimit":0,
"filler":"*",
"prefixSpecifyChar":"",
"suffixType":1,
"ignoreChar":"",
"suffixSpecifyChar":""
},
"__vModel__":"contract_temp_name",
"useMask":false,
"showPassword":false,
"style":{
"width":"100%"
},
"disabled":false,
"id":"contract_temp_name",
"placeholder":"请输入",
"prefixIcon":"",
"addonBefore":"",
"on":{
"change":"({ data, rowIndex, formData, setFormData, setShowOrHide, setRequired, setDisabled, onlineUtils }) => {\n // 在此编写代码\n \n}",
"blur":"({ data, rowIndex, formData, setFormData, setShowOrHide, setRequired, setDisabled, onlineUtils }) => {\n // 在此编写代码\n \n}"
}
},
{
"clearable":true,
"maxlength":null,
"fullName":"备注",
"fullNameI18nCode":[
""
],
"autoSize":{
"minRows":3,
"maxRows":3
},
"showCount":false,
"__config__":{
"formId":"formItem4ef0df",
"yunzhupaasKey":"textarea",
"visibility":[
"pc",
"app"
],
"noShow":false,
"tipLabel":"",
"tableFixed":"none",
"dragDisabled":false,
"className":[],
"label":"备注",
"trigger":"blur",
"showLabel":true,
"required":false,
"tableName":"cm_contract_temp",
"renderKey":1779197120754,
"layout":"colFormItem",
"tagIcon":"icon-ym icon-ym-generator-textarea",
"tag":"YunzhupaasTextarea",
"regList":[],
"tableAlign":"left",
"span":24
},
"readonly":false,
"__vModel__":"remark",
"style":{
"width":"100%"
},
"disabled":false,
"id":"remark",
"placeholder":"请输入",
"on":{
"change":"({ data, rowIndex, formData, setFormData, setShowOrHide, setRequired, setDisabled, onlineUtils }) => {\n // 在此编写代码\n \n}",
"blur":"({ data, rowIndex, formData, setFormData, setShowOrHide, setRequired, setDisabled, onlineUtils }) => {\n // 在此编写代码\n \n}"
}
},
{
"__config__":{
"formId":"formItemfdc810",
"yunzhupaasKey":"switch",
"visibility":[
"pc",
"app"
],
"defaultValue":0,
"noShow":false,
"tipLabel":"是:只有合同基本信息和合同主体,无合同清单和金额。否:反之",
"tableFixed":"none",
"dragDisabled":false,
"className":[],
"label":"框架合同",
"trigger":"change",
"showLabel":true,
"required":false,
"tableName":"cm_contract_temp",
"renderKey":1779204216891,
"layout":"colFormItem",
"tagIcon":"icon-ym icon-ym-generator-switch",
"tag":"YunzhupaasSwitch",
"regList":[],
"tableAlign":"left",
"span":24
},
"activeValue":1,
"inactiveValue":0,
"__vModel__":"is_framework",
"fullName":"框架合同",
"inactiveTxt":"N",
"fullNameI18nCode":[
""
],
"disabled":false,
"activeTxt":"Y",
"id":"is_framework",
"on":{
"change":"({ data, rowIndex, formData, setFormData, setShowOrHide, setRequired, setDisabled, onlineUtils }) => {\n // 在此编写代码\n \n}"
}
},
{
"__config__":{
"formId":"formItemda36db",
"yunzhupaasKey":"switch",
"visibility":[
"pc",
"app"
],
"defaultValue":1,
"noShow":false,
"tipLabel":"是:显示合同清单,合同金额根据清单金额汇总生成;否:不显示清单,合同金额手工录入",
"tableFixed":"none",
"dragDisabled":false,
"className":[],
"label":"清单合同",
"trigger":"change",
"showLabel":true,
"required":false,
"tableName":"cm_contract_temp",
"renderKey":1779197789072,
"layout":"colFormItem",
"tagIcon":"icon-ym icon-ym-generator-switch",
"tag":"YunzhupaasSwitch",
"regList":[],
"tableAlign":"left",
"span":24
},
"activeValue":1,
"inactiveValue":0,
"__vModel__":"is_detail_list",
"fullName":"清单合同",
"inactiveTxt":"N",
"fullNameI18nCode":[
""
],
"disabled":false,
"activeTxt":"Y",
"id":"is_detail_list",
"on":{
"change":"({ data, rowIndex, formData, setFormData, setShowOrHide, setRequired, setDisabled, onlineUtils }) => {\n // 在此编写代码\n \n}"
}
},
{
"__config__":{
"formId":"formItemcdd9ba",
"yunzhupaasKey":"switch",
"visibility":[
"pc",
"app"
],
"defaultValue":0,
"noShow":false,
"tipLabel":"",
"tableFixed":"none",
"dragDisabled":false,
"className":[],
"label":"启用产品清单",
"trigger":"change",
"showLabel":true,
"required":false,
"tableName":"cm_contract_temp",
"renderKey":1779204672306,
"layout":"colFormItem",
"tagIcon":"icon-ym icon-ym-generator-switch",
"tag":"YunzhupaasSwitch",
"regList":[],
"tableAlign":"left",
"span":24
},
"activeValue":1,
"inactiveValue":0,
"__vModel__":"enable_tableProductList",
"fullName":"启用产品清单",
"inactiveTxt":"N",
"fullNameI18nCode":[
""
],
"disabled":false,
"activeTxt":"Y",
"id":"enable_tableProductList",
"on":{
"change":"({ data, rowIndex, formData, setFormData, setShowOrHide, setRequired, setDisabled, onlineUtils }) => {\n // 在此编写代码\n \n}"
}
},
{
"__config__":{
"formId":"formItem2787d4",
"yunzhupaasKey":"switch",
"visibility":[
"pc",
"app"
],
"defaultValue":0,
"noShow":false,
"tipLabel":"",
"tableFixed":"none",
"dragDisabled":false,
"className":[],
"label":"启用材料清单",
"trigger":"change",
"showLabel":true,
"required":false,
"tableName":"cm_contract_temp",
"renderKey":1779204756615,
"layout":"colFormItem",
"tagIcon":"icon-ym icon-ym-generator-switch",
"tag":"YunzhupaasSwitch",
"regList":[],
"tableAlign":"left",
"span":24
},
"activeValue":1,
"inactiveValue":0,
"__vModel__":"enable_tableMaterialList",
"fullName":"启用材料清单",
"inactiveTxt":"N",
"fullNameI18nCode":[
""
],
"disabled":false,
"activeTxt":"Y",
"id":"enable_tableMaterialList",
"on":{
"change":"({ data, rowIndex, formData, setFormData, setShowOrHide, setRequired, setDisabled, onlineUtils }) => {\n // 在此编写代码\n \n}"
}
},
{
"__config__":{
"formId":"formItem62a424",
"yunzhupaasKey":"switch",
"visibility":[
"pc",
"app"
],
"defaultValue":0,
"noShow":false,
"tipLabel":"",
"tableFixed":"none",
"dragDisabled":false,
"className":[],
"label":"启用人力清单",
"trigger":"change",
"showLabel":true,
"required":false,
"tableName":"cm_contract_temp",
"renderKey":1779204777094,
"layout":"colFormItem",
"tagIcon":"icon-ym icon-ym-generator-switch",
"tag":"YunzhupaasSwitch",
"regList":[],
"tableAlign":"left",
"span":24
},
"activeValue":1,
"inactiveValue":0,
"__vModel__":"enable_tableWorktypeList",
"fullName":"启用人力清单",
"inactiveTxt":"N",
"fullNameI18nCode":[
""
],
"disabled":false,
"activeTxt":"Y",
"id":"enable_tableWorktypeList",
"on":{
"change":"({ data, rowIndex, formData, setFormData, setShowOrHide, setRequired, setDisabled, onlineUtils }) => {\n // 在此编写代码\n \n}"
}
},
{
"__config__":{
"formId":"formItemc956e5",
"yunzhupaasKey":"switch",
"visibility":[
"pc",
"app"
],
"defaultValue":0,
"noShow":false,
"tipLabel":"",
"tableFixed":"none",
"dragDisabled":false,
"className":[],
"label":"启用资产清单",
"trigger":"change",
"showLabel":true,
"required":false,
"tableName":"cm_contract_temp",
"renderKey":1779204823252,
"layout":"colFormItem",
"tagIcon":"icon-ym icon-ym-generator-switch",
"tag":"YunzhupaasSwitch",
"regList":[],
"tableAlign":"left",
"span":24
},
"activeValue":1,
"inactiveValue":0,
"__vModel__":"enable_tableAssetList",
"fullName":"启用资产清单",
"inactiveTxt":"N",
"fullNameI18nCode":[
""
],
"disabled":false,
"activeTxt":"Y",
"id":"enable_tableAssetList",
"on":{
"change":"({ data, rowIndex, formData, setFormData, setShowOrHide, setRequired, setDisabled, onlineUtils }) => {\n // 在此编写代码\n \n}"
}
},
{
"__config__":{
"formId":"formItem1dceff",
"yunzhupaasKey":"switch",
"visibility":[
"pc",
"app"
],
"defaultValue":0,
"noShow":false,
"tipLabel":"",
"tableFixed":"none",
"dragDisabled":false,
"className":[],
"label":"启用任务清单",
"trigger":"change",
"showLabel":true,
"required":false,
"tableName":"cm_contract_temp",
"renderKey":1779205615044,
"layout":"colFormItem",
"tagIcon":"icon-ym icon-ym-generator-switch",
"tag":"YunzhupaasSwitch",
"regList":[],
"tableAlign":"left",
"span":24
},
"activeValue":1,
"inactiveValue":0,
"__vModel__":"enable_tableTaskList",
"fullName":"启用任务清单",
"inactiveTxt":"N",
"fullNameI18nCode":[
""
],
"disabled":false,
"activeTxt":"Y",
"id":"enable_tableTaskList",
"on":{
"change":"({ data, rowIndex, formData, setFormData, setShowOrHide, setRequired, setDisabled, onlineUtils }) => {\n // 在此编写代码\n \n}"
}
},
{
"filterable":false,
"clearable":true,
"multiple":false,
"fullName":"合同类型",
"fullNameI18nCode":[
""
],
"props":{
"label":"fullName",
"value":"id"
},
"__config__":{
"yunzhupaasKey":"select",
"defaultValue":"",
"dragDisabled":false,
"className":[],
"propsUrl":"",
"templateJson":[],
"showLabel":true,
"required":false,
"tableName":"cm_contract_temp",
"renderKey":1779206776300,
"tagIcon":"icon-ym icon-ym-generator-select",
"tag":"YunzhupaasSelect",
"formId":"formItem4917e5",
"visibility":[
"pc",
"app"
],
"noShow":false,
"dataType":"static",
"dictionaryType":"",
"tipLabel":"",
"tableFixed":"none",
"label":"合同类型",
"trigger":"change",
"layout":"colFormItem",
"useCache":true,
"propsName":"",
"regList":[],
"tableAlign":"left",
"span":24
},
"options":[
{
"fullName":"收入合同",
"id":"REV"
},
{
"fullName":"支出合同",
"id":"COS"
}
],
"__vModel__":"contract_type",
"style":{
"width":"100%"
},
"disabled":false,
"id":"contract_type",
"placeholder":"请选择",
"on":{
"change":"({ data, rowIndex, formData, setFormData, setShowOrHide, setRequired, setDisabled, onlineUtils }) => {\n // 在此编写代码\n \n}"
}
},
{
"__config__":{
"formId":"formItem046684",
"yunzhupaasKey":"switch",
"visibility":[
"pc",
"app"
],
"defaultValue":1,
"noShow":false,
"tipLabel":"",
"tableFixed":"none",
"dragDisabled":false,
"className":[],
"label":"启用在线打印",
"trigger":"change",
"showLabel":true,
"required":false,
"tableName":"cm_contract_temp",
"renderKey":1779238994341,
"layout":"colFormItem",
"tagIcon":"icon-ym icon-ym-generator-switch",
"tag":"YunzhupaasSwitch",
"regList":[],
"tableAlign":"left",
"span":24
},
"activeValue":1,
"inactiveValue":0,
"__vModel__":"enable_printing",
"fullName":"启用在线打印",
"inactiveTxt":"N",
"fullNameI18nCode":[
""
],
"disabled":false,
"activeTxt":"Y",
"id":"enable_printing",
"on":{
"change":"({ data, rowIndex, formData, setFormData, setShowOrHide, setRequired, setDisabled, onlineUtils }) => {\n // 在此编写代码\n \n}"
}
},
{
"filterable":false,
"clearable":true,
"multiple":false,
"fullName":"我方签约类型",
"fullNameI18nCode":[
""
],
"props":{
"label":"fullName",
"value":"id"
},
"__config__":{
"yunzhupaasKey":"select",
"defaultValue":"PartA",
"dragDisabled":false,
"className":[],
"propsUrl":"",
"templateJson":[],
"showLabel":true,
"required":false,
"tableName":"cm_contract_temp",
"renderKey":1779239106349,
"tagIcon":"icon-ym icon-ym-generator-select",
"tag":"YunzhupaasSelect",
"formId":"formItem709985",
"visibility":[
"pc",
"app"
],
"noShow":false,
"dataType":"static",
"dictionaryType":"",
"tipLabel":"",
"tableFixed":"none",
"label":"我方签约类型",
"trigger":"change",
"layout":"colFormItem",
"useCache":true,
"propsName":"",
"regList":[],
"tableAlign":"left",
"span":24
},
"options":[
{
"fullName":"甲方",
"id":"PartA"
},
{
"fullName":"乙方",
"id":"PartB"
},
{
"fullName":"丙方",
"id":"PartC"
}
],
"__vModel__":"our_company_type",
"style":{
"width":"100%"
},
"disabled":false,
"id":"our_company_type",
"placeholder":"请选择",
"on":{
"change":"({ data, rowIndex, formData, setFormData, setShowOrHide, setRequired, setDisabled, onlineUtils }) => {\n // 在此编写代码\n \n}"
}
},
{
"filterable":false,
"clearable":true,
"multiple":false,
"fullName":"乙方签约类型",
"fullNameI18nCode":[
""
],
"props":{
"label":"fullName",
"value":"id"
},
"__config__":{
"yunzhupaasKey":"select",
"defaultValue":"PartB",
"dragDisabled":false,
"className":[],
"propsUrl":"",
"templateJson":[],
"showLabel":true,
"required":false,
"tableName":"cm_contract_temp",
"renderKey":1779239278811,
"tagIcon":"icon-ym icon-ym-generator-select",
"tag":"YunzhupaasSelect",
"formId":"formItem3495e6",
"visibility":[
"pc",
"app"
],
"noShow":false,
"dataType":"static",
"dictionaryType":"",
"tipLabel":"",
"tableFixed":"none",
"label":"乙方签约类型",
"trigger":"change",
"layout":"colFormItem",
"useCache":true,
"propsName":"",
"regList":[],
"tableAlign":"left",
"span":24
},
"options":[
{
"fullName":"甲方",
"id":"PartA"
},
{
"fullName":"乙方",
"id":"PartB"
},
{
"fullName":"丙方",
"id":"PartC"
}
],
"__vModel__":"second_party_type",
"style":{
"width":"100%"
},
"disabled":false,
"id":"second_party_type",
"placeholder":"请选择",
"on":{
"change":"({ data, rowIndex, formData, setFormData, setShowOrHide, setRequired, setDisabled, onlineUtils }) => {\n // 在此编写代码\n \n}"
}
},
{
"filterable":false,
"clearable":true,
"multiple":false,
"fullName":"丙方签约类型",
"fullNameI18nCode":[
""
],
"props":{
"label":"fullName",
"value":"id"
},
"__config__":{
"yunzhupaasKey":"select",
"defaultValue":"PartC",
"dragDisabled":false,
"className":[],
"propsUrl":"",
"templateJson":[],
"showLabel":true,
"required":false,
"tableName":"cm_contract_temp",
"renderKey":1779239279825,
"tagIcon":"icon-ym icon-ym-generator-select",
"tag":"YunzhupaasSelect",
"formId":"formItem242830",
"visibility":[
"pc",
"app"
],
"noShow":false,
"dataType":"static",
"dictionaryType":"",
"tipLabel":"",
"tableFixed":"none",
"label":"丙方签约类型",
"trigger":"change",
"layout":"colFormItem",
"useCache":true,
"propsName":"",
"regList":[],
"tableAlign":"left",
"span":24
},
"options":[
{
"fullName":"甲方",
"id":"PartA"
},
{
"fullName":"乙方",
"id":"PartB"
},
{
"fullName":"丙方",
"id":"PartC"
}
],
"__vModel__":"third_party_type",
"style":{
"width":"100%"
},
"disabled":false,
"id":"third_party_type",
"placeholder":"请选择",
"on":{
"change":"({ data, rowIndex, formData, setFormData, setShowOrHide, setRequired, setDisabled, onlineUtils }) => {\n // 在此编写代码\n \n}"
}
},
{
"popupType":"popover",
"hasPage":false,
"pageSize":20,
"columnOptions":[
{
"label":"打印模版名称",
"value":"f_full_name"
},
{
"label":"打印模版描述",
"value":"f_description"
}
],
"fullNameI18nCode":[
"",
""
],
"templateJson":[],
"__config__":{
"relationTable":"cm_contract_pringing_temp",
"yunzhupaasKey":"popupTableSelect",
"defaultValue":"",
"parentVModel":"tablePrintingTemp",
"dragDisabled":false,
"className":[],
"showLabel":true,
"required":false,
"tableName":"cm_contract_temp",
"renderKey":1779240109576,
"transferList":[],
"tagIcon":"icon-ym icon-ym-generator-popupTableSelect",
"isSubTable":true,
"columnWidth":350,
"tag":"YunzhupaasPopupTableSelect",
"formId":"formItemb39d07",
"visibility":[
"pc",
"app"
],
"noShow":false,
"tipLabel":"",
"tableFixed":"none",
"label":"打印模版ID",
"trigger":"change",
"layout":"colFormItem",
"useCache":true,
"regList":[],
"tableAlign":"left",
"span":24
},
"__vModel__":"printing_temp_id",
"disabled":false,
"id":"tablePrintingTemp-printing_temp_id",
"placeholder":"请选择",
"interfaceName":"获取系统打印模版列表",
"popupWidth":"800px",
"on":{
"change":"({ data, rowIndex, formData, setFormData, setShowOrHide, setRequired, setDisabled, onlineUtils }) => {\n // 在此编写代码\n \n}"
},
"filterable":true,
"clearable":true,
"multiple":false,
"fullName":"设计子表-打印模版ID",
"relationField":"f_full_name",
"extraOptions":[],
"popupTitle":"选择数据",
"style":{
"width":"100%"
},
"interfaceHasPage":0,
"interfaceId":"826713957526931333",
"propsValue":"f_id"
},
{
"__config__":{
"formId":"formItemd53b4e",
"relationTable":"cm_contract_pringing_temp",
"yunzhupaasKey":"switch",
"visibility":[
"pc",
"app"
],
"defaultValue":0,
"noShow":false,
"parentVModel":"tablePrintingTemp",
"tipLabel":"",
"tableFixed":"none",
"dragDisabled":false,
"className":[],
"label":"是否启用",
"trigger":"change",
"showLabel":true,
"required":false,
"tableName":"cm_contract_temp",
"renderKey":1779240149420,
"layout":"colFormItem",
"tagIcon":"icon-ym icon-ym-generator-switch",
"isSubTable":true,
"tag":"YunzhupaasSwitch",
"regList":[],
"tableAlign":"left",
"span":24
},
"activeValue":1,
"inactiveValue":0,
"__vModel__":"is_enabled",
"fullName":"设计子表-是否启用",
"inactiveTxt":"N",
"fullNameI18nCode":[
"",
""
],
"disabled":false,
"activeTxt":"Y",
"id":"tablePrintingTemp-is_enabled",
"on":{
"change":"({ data, rowIndex, formData, setFormData, setShowOrHide, setRequired, setDisabled, onlineUtils }) => {\n // 在此编写代码\n \n}"
}
}
]
export default superQueryJson

View File

@@ -0,0 +1,652 @@
<template>
<div class="yunzhupaas-content-wrapper">
<div class="yunzhupaas-content-wrapper-center">
<div class="yunzhupaas-content-wrapper-search-box" v-if="getSearchList.length">
<BasicForm @register="registerSearchForm" :schemas="getSearchList"
@advanced-change="redoHeight" @submit="handleSearchSubmit" @reset="handleSearchReset"
class="search-form">
</BasicForm>
</div>
<div class="yunzhupaas-content-wrapper-content bg-white">
<BasicTable @register="registerTable" v-bind="getTableBindValue" ref="tableRef"
@columns-change="handleColumnChange">
<template #tableTitle>
<a-button type="primary" preIcon="icon-ym icon-ym-btn-add"
@click="addHandle()"> {{t('common.add2Text','新增')}}</a-button>
</template>
<template #toolbar>
<a-tooltip placement="top">
<template #title>
<span>{{ t('common.superQuery') }}</span>
</template>
<filter-outlined @click="openSuperQuery(true, { columnOptions: superQueryJson })" />
</a-tooltip>
</template>
<template #toolbarAfter>
<ViewList :menuId="route.meta.modelId" :viewList="viewList" @itemClick="handleViewClick" @reload="initViewList" />
<ViewSetting :menuId="route.meta.modelId" :viewList="viewList" :currentView="currentView" @reload="initViewList" />
</template>
<template #bodyCell="{ column, record, index }">
<template v-for="(item, index) in childColumnList" v-if="childColumnList.length">
<template
v-if="column?.id?.includes('-') && item.children && item.children[0] && column.key === item.children[0]?.dataIndex">
<ChildTableColumn :data="record[item.prop]" :head="item.children"
@toggleExpand="toggleExpand(record, item.prop+`Expand`)" @toDetail="toDetail"
:expand="record[item.prop+`Expand`]" :key="index" :showOverflow="true "/>
</template>
</template>
<template v-if="!(record.top || column.id?.includes('-'))">
<template v-if="column.yunzhupaasKey === 'relationForm'">
<p class="link-text"
@click="toDetail(column.modelId, record[column.dataIndex+`_id`], column.propsValue)">
{{ record[column.dataIndex] }}</p>
</template>
<template v-if="column.yunzhupaasKey === 'inputNumber'">
<yunzhupaas-input-number v-model:value="record[column.prop]" :precision="column.precision" :thousands="column.thousands" disabled detailed />
</template>
<template v-if="column.yunzhupaasKey === 'calculate'">
<yunzhupaas-calculate
v-model:value="record[column.prop]"
:isStorage="column.isStorage"
:precision="column.precision"
:thousands="column.thousands"
detailed />
</template>
<template v-if="column.yunzhupaasKey === 'sign'">
<yunzhupaas-sign v-model:value="record[column.prop]" detailed />
</template>
<template v-if="column.yunzhupaasKey === 'signature'">
<yunzhupaas-signature v-model:value="record[column.prop]" detailed />
</template>
<template v-if="column.yunzhupaasKey === 'rate'">
<yunzhupaas-rate v-model:value="record[column.prop]" :count="column.count" :allowHalf="column.allowHalf" disabled />
</template>
<template v-if="column.yunzhupaasKey === 'slider'">
<yunzhupaas-slider v-model:value="record[column.prop]" :min="column.min" :max="column.max" :step="column.step" disabled />
</template>
<template v-if="column.yunzhupaasKey === 'uploadImg'">
<yunzhupaas-upload-img v-model:value="record[column.prop]" disabled detailed simple v-if="record[column.prop]?.length" />
</template>
<template v-if="column.yunzhupaasKey === 'uploadFile'">
<yunzhupaas-upload-file v-model:value="record[column.prop]" disabled detailed simple v-if="record[column.prop]?.length" />
</template>
<template v-if="column.yunzhupaasKey === 'input'">
<yunzhupaas-input
v-model:value="record[column.prop]"
:useMask="column.useMask"
:maskConfig="column.maskConfig"
:showOverflow="true"
detailed />
</template>
</template>
<template v-if="column.key === 'action' && !record.top">
<TableAction :actions="getTableActions(record)" />
</template>
</template>
</BasicTable>
</div>
</div>
<Form ref="formRef" @reload="reload" />
<Detail ref="detailRef" />
<ExportModal @register="registerExportModal" @download="handleDownload" />
<ImportModal @register="registerImportModal" @reload="reload" />
<PrintSelect @register="registerPrintSelect" @change="handleShowBrowse" />
<PrintBrowse @register="registerPrintBrowse" />
<RelationDetail ref="relationDetailRef" />
<SuperQueryModal @register="registerSuperQueryModal" @superQuery="handleSuperQuery" />
</div>
</template>
<script lang="ts" setup>
import { getList, del, exportData, batchDelete } from './helper/api';
import { getConfigData,getViewList } from '@/api/onlineDev/visualDev';
import { getDictionaryDataSelector } from '@/api/systemData/dictionary';
import { getDataInterfaceRes } from '@/api/systemData/dataInterface';
import { getOrgByOrganizeCondition,getDepartmentSelectAsyncList } from '@/api/permission/organize';
import { ref, reactive, onMounted, toRefs, computed, unref, nextTick, toRaw, provide } from 'vue';
import { useMessage } from '@/hooks/web/useMessage';
import { useI18n } from '@/hooks/web/useI18n';
import { useOrganizeStore } from '@/store/modules/organize';
import { useUserStore } from '@/store/modules/user';
import { BasicModal, useModal } from '@/components/Modal';
import { usePopup } from '@/components/Popup';
import { ScrollContainer } from '@/components/Container';
import { BasicLeftTree, TreeActionType } from '@/components/Tree';
import { BasicForm, useForm } from '@/components/Form';
import { BasicTable, useTable, TableAction, ActionItem, TableActionType, SorterResult } from '@/components/Table';
import { SuperQueryModal } from '@/components/CommonModal';
import Form from './Form.vue';
import Detail from './Detail.vue';
// 有关联表单详情:开始
import RelationDetail from '@/views/common/dynamicModel/list/detail/index.vue';
// 有关联表单详情:结束
import ChildTableColumn from '@/views/common/dynamicModel/list/ChildTableColumn.vue';
import { ExportModal } from '@/components/CommonModal';
import { downloadByUrl } from '@/utils/file/download';
import { ImportModal} from '@/components/CommonModal';
// 打印模板多条生成PrintSelect
import PrintSelect from '@/components/PrintDesign/printSelect/index.vue';
import PrintBrowse from '@/components/PrintDesign/printBrowse/index.vue';
import { useRoute,useRouter } from 'vue-router';
import { FilterOutlined } from '@ant-design/icons-vue';
import { getSearchFormSchemas } from '@/components/FormGenerator/src/helper/transform';
import { cloneDeep } from 'lodash-es';
import columnList from './helper/columnList';
import searchList from './helper/searchList';
import superQueryJson from './helper/superQueryJson';
import { dyOptionsList, systemComponentsList } from '@/components/FormGenerator/src/helper/config';
import { thousandsFormat, getParamList} from '@/utils/yunzhupaas';
import { usePermission } from '@/hooks/web/usePermission';
import ViewSetting from '@/views/common/dynamicModel/list/components/ViewSetting.vue';
import ViewList from '@/views/common/dynamicModel/list/components/ViewList.vue';
interface State {
config: any;
columnList: any[];
printListOptions: any[];
columnBtnsList: any[];
customBtnsList: any[];
treeFieldNames: any;
leftTreeData: any[];
leftTreeLoading: boolean;
treeActiveId: string;
treeActiveNodePath: any;
columns: any[];
complexColumns: any[];
childColumnList: any[];
exportList: any[];
cacheList: any[];
currFlow: any;
isCustomCopy: boolean;
candidateType: number;
currRow: any;
workFlowFormData: any;
expandObj: any;
columnSettingList: any[];
searchSchemas: any[];
treeRelationObj: any;
treeQueryJson: any;
leftTreeActiveInfo: any;
keyword: string;
viewList: any[];
currentView: any;
}
const route = useRoute();
const { hasBtnP } = usePermission();
const { createMessage, createConfirm } = useMessage();
const { t } = useI18n();
const organizeStore = useOrganizeStore();
const userStore = useUserStore();
const userInfo = userStore.getUserInfo;
const [registerExportModal, { openModal: openExportModal, closeModal: closeExportModal, setModalProps: setExportModalProps }] = useModal();
const [registerImportModal, { openModal: openImportModal }] = useModal();
const [registerSuperQueryModal, { openModal: openSuperQuery }] = useModal();
const formRef = ref<any>(null);
const tableRef = ref<Nullable<TableActionType>>(null);
const detailRef = ref<any>(null);
const relationDetailRef = ref<any>(null);
const state = reactive<State>({
config: {},
columnList: [],
printListOptions: [],
columnBtnsList: [],
customBtnsList: [],
treeFieldNames: {
children: 'children' ,
title: 'fullName' ,
key: 'id' ,
isLeaf: 'isLeaf',
},
leftTreeData: [],
leftTreeLoading: false,
treeActiveId: '',
treeActiveNodePath: [],
columns: [],
complexColumns: [], // 复杂表头
childColumnList: [],
exportList: [],
cacheList: [],
currFlow: {},
isCustomCopy: false,
candidateType: 1,
currRow: {},
workFlowFormData: {},
expandObj: {},
columnSettingList: [],
searchSchemas: [],
treeRelationObj: null,
treeQueryJson: {},
leftTreeActiveInfo: {},
keyword: '',
viewList: [],
currentView: {},
});
const defaultSearchInfo = {
menuId: route.meta.modelId as string,
moduleId:'826534292984170373',
superQueryJson: '',
dataType:0,
};
const searchInfo = reactive({
...cloneDeep(defaultSearchInfo),
});
const { childColumnList, searchSchemas, viewList, currentView} = toRefs(state);
const [registerSearchForm, { updateSchema, resetFields, submit: searchFormSubmit, setFieldsValue}] = useForm({
baseColProps: { span: 6 },
showActionButtonGroup: true,
showAdvancedButton: true,
compact: true,
});
const [registerTable, { reload, setLoading, getFetchParams, getSelectRows, getSelectRowKeys, redoHeight,clearSelectedRowKeys }] = useTable({
api: getList,
immediate: false,
clickToRowSelect: false,
tableSetting: { setting: false },
afterFetch: (data) => {
const list = data.map((o) => ({
...o,
...state.expandObj,
}));
state.cacheList = cloneDeep(list);
return list;
},
});
const [registerChildTable] = useTable({
pagination: false,
canResize: false,
showTableSetting: false,
});
provide('getLeftTreeActiveInfo', () => state.leftTreeActiveInfo);
const getHasBatchBtn = computed(() => {
let btnsList =[]
return !!btnsList.length
});
const getColumns = computed(() => {
const columns = state.complexColumns;
return setListValue(state.currentView?.columnList, columns, 'prop');
});
const getSearchList = computed(() => {
const searchSchemas = cloneDeep(state.searchSchemas).map(o => ({ ...o, show: true }));
return setListValue(state.currentView?.searchList, searchSchemas, 'field');
});
const getTableBindValue = computed(() => {
let columns = unref(getColumns);
const defaultSortConfig= [];
const sortField = defaultSortConfig.map(o => (o.sort === 'desc' ? '-' : '') + o.field);
const data: any = {
pagination: { pageSize: 20 }, //有分页
searchInfo: unref(searchInfo),
defSort: { sidx: sortField.join(',') },
sortFn: (sortInfo: SorterResult | SorterResult[]) => {
if (Array.isArray(sortInfo)) {
const sortList = sortInfo.map(o => (o.order === 'descend' ? '-' : '') + o.field);
return { sidx: sortList.join(',') };
} else {
const { field, order } = sortInfo;
if (field && order) {
// 排序字段
return { sidx: (order === 'descend' ? '-' : '') + field };
} else {
return {};
}
}
},
ellipsis:true ,
columns,
bordered: true,
actionColumn: {
width: 150,
title: t('component.table.action'),
dataIndex: 'action',
},
};
if (unref(getHasBatchBtn)) {
const rowSelection: any = { type: 'checkbox' };
data.rowSelection = rowSelection;
}
return data;
});
function init() {
state.config = {};
searchInfo.menuId = route.meta.modelId as string;
state.columnList = columnList;
setLoading(true);
getSearchSchemas();
getColumnList();
initViewList();
nextTick(() => {
unref(getSearchList)?.length ? searchFormSubmit() : reload({ page: 1 });
});
}
function getSearchSchemas() {
const schemas = getSearchFormSchemas(searchList);
state.searchSchemas = schemas;
schemas.forEach((cur) => {
const config = cur.__config__;
if (dyOptionsList.includes(config.yunzhupaasKey)) {
if (config.dataType === 'dictionary') {
if (!config.dictionaryType) return;
getDictionaryDataSelector(config.dictionaryType).then((res) => {
updateSchema([{ field: cur.field, componentProps: { options: res.data.list } }]);
});
}
if (config.dataType === 'dynamic') {
if (!config.propsUrl) return;
const query = { paramList: getParamList(config.templateJson) };
getDataInterfaceRes(config.propsUrl, query).then((res) => {
const data = Array.isArray(res.data) ? res.data : [];
updateSchema([{ field: cur.field, componentProps: { options: data } }]);
});
}
}
cur.defaultValue = cur.value;
});
}
function getColumnList() {
// 没有开启列表权限
let columnList = state.columnList;
state.exportList = columnList;
let columns = columnList.map((o) => ({
...o,
title: o.labelI18nCode ? t(o.labelI18nCode, o.label) : o.label,
dataIndex: o.prop,
align: o.align,
fixed: o.fixed == 'none' ? false : o.fixed,
sorter: o.sortable ? { multiple: 1 } : o.sortable,
width: o.width || 100,
}));
//添加复杂表头
columns = getComplexColumns(columns);
state.columns = columns.filter((o) => o.prop.indexOf('-') < 0);
//子表表头
getChildComplexColumns(columns);
}
//复杂表头
function getComplexColumns(columns) {
//这里生成复杂表头的配置
let complexHeaderList: any[] = [];
if (!complexHeaderList.length) return columns;
let childColumns: any[] = [];
let firstChildColumns: string[] = [];
for (let i = 0; i < complexHeaderList.length; i++) {
const e = complexHeaderList[i];
e.label = e.fullName;
e.labelI18nCode = e.fullNameI18nCode;
e.title = e.fullNameI18nCode ? t(e.fullNameI18nCode, e.fullName) : e.fullName;
e.align = e.align;
e.dataIndex = e.id;
e.prop = e.id;
e.children = [];
e.yunzhupaasKey = 'complexHeader';
if (e.childColumns?.length) {
childColumns.push(...e.childColumns);
for (let k = 0; k < e.childColumns.length; k++) {
const item = e.childColumns[k];
for (let j = 0; j < columns.length; j++) {
const o = columns[j];
if (o.prop == item && o.fixed !== 'left' && o.fixed !== 'right') e.children.push({ ...o });
}
}
}
if (e.children.length) firstChildColumns.push(e.children[0].prop);
}
complexHeaderList = complexHeaderList.filter(o => o.children.length);
let list: any[] = [];
for (let i = 0; i < columns.length; i++) {
const e = columns[i];
if (!childColumns.includes(e.prop)) {
list.push(e);
} else {
if (firstChildColumns.includes(e.prop)) {
const item = complexHeaderList.find(o => o.childColumns.includes(e.prop));
list.push(item);
}
}
}
return list;
}
//子表表头
function getChildComplexColumns(columnList) {
let list: any[] = [];
for (let i = 0; i < columnList.length; i++) {
const e = columnList[i];
if (!e.prop.includes('-')) {
list.push(e);
} else {
let prop = e.prop.split('-')[0];
let vModel = e.prop.split('-')[1];
let label = e.label.split('-')[0];
let childLabel = e.label.replace(label + '-', '');
if (e.fullNameI18nCode && Array.isArray(e.fullNameI18nCode) && e.fullNameI18nCode[0]) label = t(e.fullNameI18nCode[0], label);
let newItem = {
align: 'center',
yunzhupaasKey: 'table',
prop,
label,
title: label,
dataIndex: prop,
children: [],
};
e.dataIndex = vModel;
e.title = e.labelI18nCode ? t(e.labelI18nCode, childLabel) : childLabel;
if (!state.expandObj.hasOwnProperty(prop+`Expand`)) state.expandObj[prop+`Expand`] = false;
if (!list.some((o) => o.prop === prop)) list.push(newItem);
for (let i = 0; i < list.length; i++) {
if (list[i].prop === prop) {
list[i].children.push(e);
break;
}
}
}
}
// 行内分组展示
getMergeList(list);
state.complexColumns = list;
state.childColumnList = list.filter((o) => o.yunzhupaasKey === 'table');
// 子表分组展示宽度取100
for (let i = 0; i < state.childColumnList.length; i++) {
const e = state.childColumnList[i];
if (e.children?.length) e.children = e.children.map(o => ({ ...o, width: 100 }));
}
}
function getMergeList(list) {
list.forEach((item) => {
if (item.yunzhupaasKey === 'table' && item.children && item.children.length) {
item.children.forEach((child, index) => {
if (index == 0) {
child.customCell = () => ({
rowspan: 1,
colspan: item.children.length,
class: 'child-table-box',
});
} else {
child.customCell = () => ({
rowspan: 0,
colspan: 0,
});
}
});
}
});
}
function toggleExpand(row, field) {
row[field] = !row[field];
}
// 关联表单查看详情
function toDetail(modelId, id, propsValue) {
if (!id) return;
getConfigData(modelId).then((res) => {
if (!res.data || !res.data.formData) return;
const formConf = JSON.parse(res.data.formData);
formConf.popupType = 'general';
formConf.hasPrintBtn = false;
formConf.customBtns = [];
const data = { id, formConf, modelId, propsValue};
relationDetailRef.value?.init(data);
});
}
function handleColumnChange(data) {
state.columnSettingList = data;
}
function getTableActions(record): ActionItem[] {
return [
{
label: t('common.editText','编辑') ,
onClick: updateHandle.bind(null, record),
},
{
label: t('common.delText','删除') ,
color: 'error',
modelConfirm: {
onOk: handleDelete.bind(null, record.id),
},
},
{
label: t('common.detailText','详情') ,
onClick: goDetail.bind(null, record),
},
];
}
// 编辑
function updateHandle(record) {
// 不带工作流
const data = {
id: record.id,
menuId: searchInfo.menuId,
allList: state.cacheList,
};
formRef.value?.init(data);
}
// 删除
function handleDelete(id) {
const query={ids:[id] }
batchDelete(query).then((res) => {
createMessage.success(res.msg);
clearSelectedRowKeys();
reload();
});
}
// 查看详情
function goDetail(record) {
// 不带流程
const data = {
id: record.id,
};
detailRef.value?.init(data);
}
// 新增
function addHandle() {
// 不带流程新增
const data = {
id: '',
menuId: searchInfo.menuId,
allList: state.cacheList,
};
formRef.value?.init(data);
}
// 高级查询
function handleSuperQuery(superQueryJson) {
searchInfo.superQueryJson = superQueryJson;
reload({ page: 1 });
}
function handleSearchReset() {
clearSelectedRowKeys();
if (!state.resetFromTree) updateSearchFormValue();
if (state.resetFromTree) state.resetFromTree = false;
}
function handleSearchSubmit(data) {
clearSelectedRowKeys();
let obj = {
...defaultSearchInfo,
superQueryJson: searchInfo.superQueryJson,
...data,
};
Object.keys(searchInfo).map(key => {
delete searchInfo[key];
});
for (let [key, value] of Object.entries(obj)) {
searchInfo[key.replaceAll('-', '_')] = value;
}
console.log(searchInfo);
reload({ page: 1 });
}
function updateSearchFormValue() {
if (!state.treeActiveId) return searchFormSubmit();
let queryJson: any = {};
let leftTreeActiveInfo: any = {};
const isMultiple = !state.treeRelationObj ? false : state.treeRelationObj.searchMultiple;
//多级左侧树,需要拼父级->转为查询参数
if (state.treeRelationObj && state.treeRelationObj.yunzhupaasKey && ['organizeSelect', 'cascader', 'areaSelect'].includes(state.treeRelationObj.yunzhupaasKey)) {
let currValue = [];
currValue = state.treeActiveNodePath.map(o => o[state.treeFieldNames.key]);
queryJson = { '': isMultiple ? [currValue] : currValue };
leftTreeActiveInfo = { '': state.treeRelationObj.multiple ? [currValue] : currValue };
} else {
queryJson = { '': isMultiple ? [state.treeActiveId] : state.treeActiveId };
leftTreeActiveInfo = { '': state.treeRelationObj.multiple ? [state.treeActiveId] : state.treeActiveId };
}
state.leftTreeActiveInfo = leftTreeActiveInfo;
if(unref(getSearchList)?.length){
// 有搜索列表
setFieldsValue(queryJson);
searchFormSubmit();
}else{
// 无搜索列表
handleSearchSubmit(queryJson);
}
}
function initViewList(currentId = '') {
const query = {
menuId: route.meta.modelId,
};
getViewList(query).then(res => {
const columns : any[]= state.complexColumns;
const searchList: any[] = state.searchSchemas.map(o => ({ label: o.label, id: o.field, show: o.show, labelI18nCode: o.labelI18nCode }));
const columnList: any[] = columns.map(o => ({ label: o.label, id: o.prop, show: true, fixed: o.fixed || 'none', labelI18nCode: o.labelI18nCode }));
state.viewList = (res.data || []).map(o => {
if (o.type == 0) return { ...o, searchList, columnList };
return { ...o, searchList: o.searchList ? JSON.parse(o.searchList) : [], columnList: o.columnList ? JSON.parse(o.columnList) : [] };
});
if (currentId) {
state.currentView = state.viewList.filter(o => o.id === currentId)[0] || state.viewList[0];
} else {
state.currentView = state.viewList.filter(o => o.status === 1)[0] || state.viewList[0];
}
});
}
function handleViewClick(item) {
state.currentView = item;
}
function setListValue(data: any[] = [], defaultData: any[] = [], key) {
let list: any[] = [];
for (let i = 0; i < data.length; i++) {
for (let j = 0; j < defaultData.length; j++) {
if (data[i].show && data[i].id == defaultData[j][key]) list.push(defaultData[j]);
}
}
return list;
}
onMounted(() => {
init();
});
</script>

File diff suppressed because it is too large Load Diff