| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362 |
- <template>
- <div class="full-height">
- <vxe-grid
- v-bind="$attrs"
- ref="tableRef"
- :size="tableSizeConfig"
- :columns="columns"
- row-key
- highlight-hover-row
- stripe
- :data="data"
- align="center"
- >
- <template #table-drop="{ rowIndex }">
- <div class="table-drop" :data-id="rowIndex">
- <MenuOutlined />
- </div>
- </template>
- <template #table-title="{ row }">
- <a-input v-model:value="row.title" :size="formSizeConfig" />
- </template>
- <template #table-visible="{ row }">
- <a-checkbox v-model:checked="row.visible" :size="formSizeConfig" />
- </template>
- <template #table-hidden="{ row }">
- <a-checkbox v-model:checked="row.hidden" :size="formSizeConfig" />
- </template>
- <template #table-readonly="{ row }">
- <a-checkbox v-model:checked="row.readonly" :size="formSizeConfig" />
- </template>
- <template #table-useTableSearch="{ row }">
- <a-checkbox v-model:checked="row.useTableSearch" :size="formSizeConfig" />
- </template>
- <template #table-tableName="{ row }">
- <a-input
- v-model:value="row.tableName"
- :disabled="!row.useTableSearch"
- :size="formSizeConfig"
- />
- </template>
- <template #table-keyColumnName="{ row }">
- <a-input
- v-model:value="row.keyColumnName"
- :disabled="!row.useTableSearch"
- :size="formSizeConfig"
- />
- </template>
- <template #table-valueColumnName="{ row }">
- <a-input
- v-model:value="row.valueColumnName"
- :disabled="!row.useTableSearch"
- :size="formSizeConfig"
- />
- </template>
- <template #table-tableWhere="{ row }">
- <a-input v-model:value="row.tableWhere" :size="formSizeConfig" />
- </template>
- <template #table-controlType="{ row }">
- <a-select v-model:value="row.controlType" :size="formSizeConfig" style="width: 100px">
- <a-select-option v-for="item in controlList" :key="item.key" :value="item.key">
- {{ $t(item.value) }}
- </a-select-option>
- </a-select>
- <a-tooltip v-if="row.controlType === 'SELECT_TABLE'" placement="top">
- <template #title>
- <span>选择表格</span>
- </template>
- <PlusOutlined
- :style="{ cursor: 'pointer', 'margin-left': '5px' }"
- @click="() => handleShowChoseSelectTable(row)"
- />
- </a-tooltip>
- </template>
- <template #table-rules="{ row }">
- <Icon
- v-if="row.autoValidate === true || (row.ruleList && row.ruleList.length > 0)"
- color="red"
- icon="ant-design:info-circle-outlined"
- />
- <a-button :size="tableButtonSizeConfig" @click="() => openRuleSetModal(true, row)">
- 设置规则
- </a-button>
- </template>
- <template #table-visible-header="{ column }">
- <a-checkbox v-model:checked="headerVisibleCheckboxChecked" :size="formSizeConfig" />
- {{ $t(column.title.replace('{', '').replace('}', '')) }}
- </template>
- <template #table-hidden-header="{ column }">
- <a-checkbox v-model:checked="headerHiddenCheckboxChecked" :size="formSizeConfig" />
- {{ $t(column.title.replace('{', '').replace('}', '')) }}
- </template>
- <template #table-readonly-header="{ column }">
- <a-checkbox v-model:checked="headerReadonlyCheckboxChecked" :size="formSizeConfig" />
- {{ $t(column.title.replace('{', '').replace('}', '')) }}
- </template>
- <template #table-used-header="{ column }">
- <a-checkbox v-model:checked="headerUseCheckboxChecked" :size="formSizeConfig" />
- {{ $t(column.title.replace('{', '').replace('}', '')) }}
- </template>
- <template #table-used="{ row }">
- <a-checkbox v-model:checked="row.used" :disabled="!row.visible" :size="formSizeConfig" />
- </template>
- </vxe-grid>
- <!-- 下拉表格设置 -->
- <PageAddendumTableChoseModal
- @ok="handleChoseTable"
- :select-table-list="currentRow.selectTableList === null ? [] : currentRow.selectTableList"
- @register="registerSelectTableModal"
- />
- <!-- 验证规则 -->
- <FormRuleSetModal @register="registerFormRuleSetModal" />
- </div>
- </template>
- <script lang="ts">
- import { defineComponent, ref, onMounted, watch, toRefs } from 'vue';
- import type { Ref, PropType } from 'vue';
- import { useI18n } from '@/hooks/web/useI18n';
- import { MenuOutlined, PlusOutlined } from '@ant-design/icons-vue';
- import FormRuleSetModal from './FormRuleSetModal.vue';
- import { useSizeSetting } from '@/hooks/setting/UseSizeSetting';
- import { useModal } from '@/components/Modal';
- import PageAddendumTableChoseModal from '../PageAddendumTableChoseModal.vue';
- import { useVxeTableSortable } from '@/components/SmartTable';
- import {
- controlList,
- getRuleList,
- vueTableHeaderCheckboxSupport,
- vueChoseSelectTableSupport,
- } from '../PageSettingSupport';
- import Icon from '@/components/Icon/src/Icon.vue';
- const copyField = [
- 'columnName',
- 'remarks',
- 'nullable',
- 'javaProperty',
- 'extType',
- 'javaType',
- 'simpleJavaType',
- ];
- /**
- * 创建数据
- */
- const createDataFromTableData = (tableData: Array<any>, editData: Ref | undefined) => {
- if (editData && editData.value) {
- return editData.value;
- }
- return tableData.map((item) => {
- const data: any = {};
- copyField.forEach((field) => {
- data[field] = item[field];
- });
- return Object.assign(data, {
- title: data.remarks,
- readonly: false,
- visible: true,
- hidden: false,
- used: true,
- controlType: 'INPUT',
- rules: [],
- useTableSearch: false,
- });
- });
- };
- export default defineComponent({
- name: 'PageFormSetting',
- components: {
- Icon,
- MenuOutlined,
- PlusOutlined,
- FormRuleSetModal,
- PageAddendumTableChoseModal,
- },
- props: {
- tableData: {
- type: Array as PropType<Array<any>>,
- default: () => [],
- },
- editData: {
- type: Array as PropType<Array<any>>,
- },
- },
- setup(props) {
- const sizeConfigHoops = useSizeSetting();
- const { t } = useI18n();
- const { tableData, editData } = toRefs(props);
- const tableRef = ref();
- const data = ref<Array<any>>([]);
- const currentRow = ref<any>({});
- const [registerFormRuleSetModal, { openModal: openRuleSetModal }] = useModal();
- watch(tableData, () => {
- data.value = createDataFromTableData(tableData.value, editData);
- });
- onMounted(() => {
- data.value = createDataFromTableData(tableData.value, editData);
- });
- const getData = () => {
- return data.value;
- };
- const { checked } = vueTableHeaderCheckboxSupport(data, 'visible');
- return {
- data,
- getData,
- tableRef,
- currentRow,
- ...sizeConfigHoops,
- openRuleSetModal,
- registerFormRuleSetModal,
- ...vueChoseSelectTableSupport(currentRow),
- ...useVxeTableSortable(tableRef, '.table-drop', data),
- ruleList: ref(getRuleList(t)),
- controlList: ref(controlList),
- headerVisibleCheckboxChecked: checked,
- headerHiddenCheckboxChecked: vueTableHeaderCheckboxSupport(data, 'hidden', false).checked,
- headerReadonlyCheckboxChecked: vueTableHeaderCheckboxSupport(data, 'readonly', false)
- .checked,
- headerUseCheckboxChecked: vueTableHeaderCheckboxSupport(data, 'used', true).checked,
- };
- },
- data() {
- return {
- columns: [
- {
- title: '#',
- field: 'drop',
- width: 80,
- slots: {
- default: 'table-drop',
- },
- },
- {
- title: '{generator.views.tableField.title.columnName}',
- field: 'columnName',
- width: 160,
- align: 'left',
- headerAlign: 'center',
- },
- {
- title: '{generator.views.tableSetting.title.title}',
- field: 'title',
- width: 160,
- align: 'left',
- headerAlign: 'center',
- slots: {
- default: 'table-title',
- },
- },
- {
- title: '{generator.views.formSetting.title.controlType}',
- field: 'controlType',
- width: 150,
- slots: {
- default: 'table-controlType',
- },
- },
- {
- title: '{generator.views.formSetting.title.readonly}',
- field: 'readonly',
- width: 110,
- slots: {
- default: 'table-readonly',
- header: 'table-readonly-header',
- },
- },
- {
- title: '{generator.views.tableSetting.title.visible}',
- field: 'visible',
- width: 110,
- slots: {
- default: 'table-visible',
- header: 'table-visible-header',
- },
- },
- {
- title: '{generator.views.tableSetting.title.hidden}',
- field: 'hidden',
- width: 110,
- slots: {
- default: 'table-hidden',
- header: 'table-hidden-header',
- },
- },
- {
- title: '{generator.views.formSetting.title.used}',
- field: 'used',
- width: 110,
- slots: {
- default: 'table-used',
- header: 'table-used-header',
- },
- },
- {
- title: '{generator.views.formSetting.title.useTableSearch}',
- field: 'useTableSearch',
- width: 110,
- slots: {
- default: 'table-useTableSearch',
- },
- },
- {
- title: '{generator.views.design.formSetting.title.tableName}',
- field: 'tableName',
- width: 120,
- slots: {
- default: 'table-tableName',
- },
- },
- {
- title: '{generator.views.formSetting.title.keyColumnName}',
- field: 'keyColumnName',
- width: 120,
- slots: {
- default: 'table-keyColumnName',
- },
- },
- {
- title: '{generator.views.formSetting.title.valueColumnName}',
- field: 'valueColumnName',
- width: 120,
- slots: {
- default: 'table-valueColumnName',
- },
- },
- {
- title: '{generator.views.formSetting.title.tableWhere}',
- field: 'tableWhere',
- minWidth: 180,
- slots: {
- default: 'table-tableWhere',
- },
- },
- {
- title: '{generator.views.formSetting.title.rules}',
- field: 'rules',
- width: 180,
- slots: {
- default: 'table-rules',
- },
- },
- {
- title: '{generator.views.code.table.remarks}',
- field: 'remarks',
- width: 160,
- align: 'left',
- headerAlign: 'center',
- },
- ],
- };
- },
- });
- </script>
- <style scoped></style>
|