diff --git a/.env.front b/.env.front index 2641417d..1629ff9f 100644 --- a/.env.front +++ b/.env.front @@ -17,3 +17,18 @@ VITE_API_URL=/admin-api # 打包路径 VITE_BASE_PATH=/ + +# 项目本地运行端口号, 与.vscode/launch.json配合 +VITE_PORT=80 + +# 是否删除debugger +VITE_DROP_DEBUGGER=false + +# 是否删除console.log +VITE_DROP_CONSOLE=false + +# 是否sourcemap +VITE_SOURCEMAP=true + +# 验证码的开关 +VITE_APP_CAPTCHA_ENABLE=false diff --git a/.vscode/launch.json b/.vscode/launch.json new file mode 100644 index 00000000..f43edc03 --- /dev/null +++ b/.vscode/launch.json @@ -0,0 +1,16 @@ +{ + // Use IntelliSense to learn about possible attributes. + // Hover to view descriptions of existing attributes. + // For more information, visit: https://go.microsoft.com/fwlink/?linkid=830387 + "version": "0.2.0", + "configurations": [ + { + "type": "msedge", + "request": "launch", + "name": "Launch Edge against localhost", + "url": "http://localhost", + "webRoot": "${workspaceFolder}/src", + "sourceMaps": true + } + ] +} diff --git a/README.md b/README.md index ea6214cc..503cbe83 100644 --- a/README.md +++ b/README.md @@ -42,7 +42,6 @@ | [TypeScript](https://www.typescriptlang.org/docs/) | JavaScript 的超集 | 4.9.5 | | [pinia](https://pinia.vuejs.org/) | Vue 存储库 替代 vuex5 | 2.0.33 | | [vueuse](https://vueuse.org/) | 常用工具集 | 9.13.0 | -| [vxe-table](https://vxetable.cn/) | Vue 最强表单 | 4.3.10 | | [vue-i18n](https://kazupon.github.io/vue-i18n/zh/introduction.html/) | 国际化 | 9.2.2 | | [vue-router](https://router.vuejs.org/) | Vue 路由 | 4.1.6 | | [windicss](https://cn.windicss.org/) | 下一代工具优先的 CSS 框架 | 3.5.6 | diff --git a/build/vite/index.ts b/build/vite/index.ts index 0e721ce9..288ec93b 100644 --- a/build/vite/index.ts +++ b/build/vite/index.ts @@ -13,7 +13,7 @@ import Components from 'unplugin-vue-components/vite' import { ElementPlusResolver } from 'unplugin-vue-components/resolvers' import viteCompression from 'vite-plugin-compression' import topLevelAwait from 'vite-plugin-top-level-await' -import vueSetupExtend from 'vite-plugin-vue-setup-extend' +import vueSetupExtend from 'vite-plugin-vue-setup-extend-plus' import VueI18nPlugin from '@intlify/unplugin-vue-i18n/vite' import { createSvgIconsPlugin } from 'vite-plugin-svg-icons' @@ -98,7 +98,8 @@ export function createVitePlugins() { deleteOriginFile: false //压缩后是否删除源文件 }), ViteEjsPlugin(), - topLevelAwait({ // https://juejin.cn/post/7152191742513512485 + topLevelAwait({ + // https://juejin.cn/post/7152191742513512485 // The export name of top-level await promise for each chunk module promiseExportName: '__tla', // The function to generate import names of top-level await promise in each chunk module diff --git a/build/vite/optimize.ts b/build/vite/optimize.ts index 3d90dbac..416ea02e 100644 --- a/build/vite/optimize.ts +++ b/build/vite/optimize.ts @@ -18,10 +18,6 @@ const include = [ 'lodash-es', 'nprogress', 'animate.css', - 'vxe-table', - 'vxe-table/es/style', - 'vxe-table/lib/locale/lang/zh-CN', - 'vxe-table/lib/locale/lang/en-US', 'web-storage-cache', '@iconify/iconify', '@vueuse/core', @@ -79,7 +75,8 @@ const include = [ 'element-plus/es/components/dropdown-item/style/css', 'element-plus/es/components/badge/style/css', 'element-plus/es/components/breadcrumb/style/css', - 'element-plus/es/components/breadcrumb-item/style/css' + 'element-plus/es/components/breadcrumb-item/style/css', + 'element-plus/es/components/image/style/css' ] const exclude = ['@iconify/json'] diff --git a/package.json b/package.json index def1f5c7..1d020d6d 100644 --- a/package.json +++ b/package.json @@ -68,7 +68,6 @@ "vue-router": "^4.1.6", "vue-types": "^5.0.2", "vuedraggable": "^4.1.0", - "vxe-table": "^4.3.11", "web-storage-cache": "^1.1.1", "xe-utils": "^3.5.7", "xml-js": "^1.6.11" @@ -126,7 +125,7 @@ "vite-plugin-purge-icons": "^0.9.2", "vite-plugin-svg-icons": "^2.0.1", "vite-plugin-top-level-await": "^1.3.0", - "vite-plugin-vue-setup-extend": "^0.4.0", + "vite-plugin-vue-setup-extend-plus": "^0.1.0", "vite-plugin-windicss": "^1.8.10", "vue-tsc": "^1.2.0", "windicss": "^3.5.6" diff --git a/src/api/pay/merchant/index.ts b/src/api/pay/merchant/index.ts index bfb8f5e4..bb630c36 100644 --- a/src/api/pay/merchant/index.ts +++ b/src/api/pay/merchant/index.ts @@ -39,9 +39,9 @@ export const getMerchant = (id: number) => { } // 根据商户名称搜索商户列表 -export const getMerchantListByName = (name: string) => { +export const getMerchantListByName = (name?: string) => { return request.get({ - url: '/pay/merchant/list-by-name?id=', + url: '/pay/merchant/list-by-name', params: { name: name } diff --git a/src/api/pay/order/index.ts b/src/api/pay/order/index.ts index 6088c172..6621381a 100644 --- a/src/api/pay/order/index.ts +++ b/src/api/pay/order/index.ts @@ -88,6 +88,11 @@ export const getOrder = async (id: number) => { return await request.get({ url: '/pay/order/get?id=' + id }) } +// 获得支付订单的明细 +export const getOrderDetail = async (id: number) => { + return await request.get({ url: '/pay/order/get-detail?id=' + id }) +} + // 新增支付订单 export const createOrder = async (data: OrderVO) => { return await request.post({ url: '/pay/order/create', data }) diff --git a/src/components/Icon/src/IconSelect.vue b/src/components/Icon/src/IconSelect.vue index f5be8d3a..9b77fb2b 100644 --- a/src/components/Icon/src/IconSelect.vue +++ b/src/components/Icon/src/IconSelect.vue @@ -95,7 +95,7 @@ watch( return props.modelValue }, () => { - if (props.modelValue) { + if (props.modelValue && props.modelValue.indexOf(':') >= 0) { currentActiveType.value = props.modelValue.substring(0, props.modelValue.indexOf(':') + 1) icon.value = props.modelValue.substring(props.modelValue.indexOf(':') + 1) } diff --git a/src/components/XModal/index.ts b/src/components/XModal/index.ts deleted file mode 100644 index 65a72bd7..00000000 --- a/src/components/XModal/index.ts +++ /dev/null @@ -1,3 +0,0 @@ -import XModal from './src/XModal.vue' - -export { XModal } diff --git a/src/components/XModal/src/XModal.vue b/src/components/XModal/src/XModal.vue deleted file mode 100644 index 95b9f4be..00000000 --- a/src/components/XModal/src/XModal.vue +++ /dev/null @@ -1,44 +0,0 @@ - - - - - - - - - - - - - - - - - - - - diff --git a/src/components/XTable/index.ts b/src/components/XTable/index.ts deleted file mode 100644 index 4abe968e..00000000 --- a/src/components/XTable/index.ts +++ /dev/null @@ -1,3 +0,0 @@ -import XTable from './src/XTable.vue' - -export { XTable } diff --git a/src/components/XTable/src/XTable.vue b/src/components/XTable/src/XTable.vue deleted file mode 100644 index fac292d4..00000000 --- a/src/components/XTable/src/XTable.vue +++ /dev/null @@ -1,442 +0,0 @@ - - - - - - - - - diff --git a/src/components/XTable/src/style/dark.scss b/src/components/XTable/src/style/dark.scss deleted file mode 100644 index d981b041..00000000 --- a/src/components/XTable/src/style/dark.scss +++ /dev/null @@ -1,81 +0,0 @@ -// 修改样式变量 -//@import 'vxe-table/styles/variable.scss'; - -/*font*/ -$vxe-font-color: #e5e7eb; -// $vxe-font-size: 14px !default; -// $vxe-font-size-medium: 16px !default; -// $vxe-font-size-small: 14px !default; -// $vxe-font-size-mini: 12px !default; - -/*color*/ -$vxe-primary-color: #409eff !default; -$vxe-success-color: #67c23a !default; -$vxe-info-color: #909399 !default; -$vxe-warning-color: #e6a23c !default; -$vxe-danger-color: #f56c6c !default; -$vxe-disabled-color: #bfbfbf !default; -$vxe-primary-disabled-color: #c0c4cc !default; - -/*loading*/ -$vxe-loading-color: $vxe-primary-color !default; -$vxe-loading-background-color: #1d1e1f !default; -$vxe-loading-z-index: 999 !default; - -/*icon*/ -$vxe-icon-font-family: Verdana, Arial, Tahoma !default; -$vxe-icon-background-color: #e5e7eb !default; - -/*toolbar*/ -$vxe-toolbar-background-color: #1d1e1f !default; -$vxe-toolbar-button-border: #dcdfe6 !default; -$vxe-toolbar-custom-active-background-color: #d9dadb !default; -$vxe-toolbar-panel-background-color: #e5e7eb !default; - -$vxe-table-font-color: #e5e7eb; -$vxe-table-header-background-color: #1d1e1f; -$vxe-table-body-background-color: #141414; -$vxe-table-row-striped-background-color: #1d1d1d; -$vxe-table-row-hover-background-color: #1d1e1f; -$vxe-table-row-hover-striped-background-color: #1e1e1e; -$vxe-table-footer-background-color: #1d1e1f; -$vxe-table-row-current-background-color: #302d2d; -$vxe-table-column-current-background-color: #302d2d; -$vxe-table-column-hover-background-color: #302d2d; -$vxe-table-row-hover-current-background-color: #302d2d; -$vxe-table-row-checkbox-checked-background-color: #3e3c37 !default; -$vxe-table-row-hover-checkbox-checked-background-color: #615a4a !default; -$vxe-table-menu-background-color: #1d1e1f; -$vxe-table-border-width: 1px !default; -$vxe-table-border-color: #4c4d4f !default; -$vxe-table-fixed-left-scrolling-box-shadow: 8px 0px 10px -5px rgba(0, 0, 0, 0.12) !default; -$vxe-table-fixed-right-scrolling-box-shadow: -8px 0px 10px -5px rgba(0, 0, 0, 0.12) !default; - -$vxe-form-background-color: #141414; - -/*pager*/ -$vxe-pager-background-color: #1d1e1f !default; -$vxe-pager-perfect-background-color: #262727 !default; -$vxe-pager-perfect-button-background-color: #a7a3a3 !default; - -$vxe-input-background-color: #141414; -$vxe-input-border-color: #4c4d4f !default; - -$vxe-select-option-hover-background-color: #262626 !default; -$vxe-select-panel-background-color: #141414 !default; -$vxe-select-empty-color: #262626 !default; -$vxe-optgroup-title-color: #909399 !default; - -/*button*/ -$vxe-button-default-background-color: #262626; -$vxe-button-dropdown-panel-background-color: #141414; - -/*modal*/ -$vxe-modal-header-background-color: #141414; -$vxe-modal-body-background-color: #141414; -$vxe-modal-border-color: #3b3b3b; - -/*pulldown*/ -$vxe-pulldown-panel-background-color: #262626 !default; - -@import 'vxe-table/styles/index.scss'; diff --git a/src/components/XTable/src/style/index.scss b/src/components/XTable/src/style/index.scss deleted file mode 100644 index e37af37a..00000000 --- a/src/components/XTable/src/style/index.scss +++ /dev/null @@ -1,6 +0,0 @@ -// @import 'vxe-table/styles/variable.scss'; -// @import 'vxe-table/styles/modules.scss'; -// @import './theme/light.scss'; -i { - border-color: initial; -} diff --git a/src/components/XTable/src/style/light.scss b/src/components/XTable/src/style/light.scss deleted file mode 100644 index f2f1309f..00000000 --- a/src/components/XTable/src/style/light.scss +++ /dev/null @@ -1,16 +0,0 @@ -// 修改样式变量 -// /*font*/ -// $vxe-font-size: 12px !default; -// $vxe-font-size-medium: 16px !default; -// $vxe-font-size-small: 14px !default; -// $vxe-font-size-mini: 12px !default; -/*color*/ -$vxe-primary-color: #409eff !default; -$vxe-success-color: #67c23a !default; -$vxe-info-color: #909399 !default; -$vxe-warning-color: #e6a23c !default; -$vxe-danger-color: #f56c6c !default; -$vxe-disabled-color: #bfbfbf !default; -$vxe-primary-disabled-color: #c0c4cc !default; - -@import 'vxe-table/styles/index.scss'; diff --git a/src/components/XTable/src/type.ts b/src/components/XTable/src/type.ts deleted file mode 100644 index 5e5251e4..00000000 --- a/src/components/XTable/src/type.ts +++ /dev/null @@ -1,26 +0,0 @@ -import { CrudSchema } from '@/hooks/web/useCrudSchemas' -import type { VxeGridProps, VxeGridPropTypes, VxeTablePropTypes } from 'vxe-table' - -export type XTableProps = VxeGridProps & { - allSchemas?: CrudSchema - height?: number // 高度 默认730 - topActionSlots?: boolean // 是否开启表格内顶部操作栏插槽 - treeConfig?: VxeTablePropTypes.TreeConfig // 树形表单配置 - isList?: boolean // 是否不带分页的list - getListApi?: Function // 获取列表接口 - getAllListApi?: Function // 获取全部数据接口 用于 vxe 导出 - deleteApi?: Function // 删除接口 - deleteListApi?: Function // 批量删除接口 - exportListApi?: Function // 导出接口 - exportName?: string // 导出文件夹名称 - params?: any // 其他查询参数 - pagination?: boolean | VxeGridPropTypes.PagerConfig // 分页配置参数 - toolBar?: boolean | VxeGridPropTypes.ToolbarConfig // 右侧工具栏配置参数 -} -export type XColumns = VxeGridPropTypes.Columns - -export type VxeTableColumn = { - field: string - title?: string - children?: VxeTableColumn[] -} & Recordable diff --git a/src/components/bpmnProcessDesigner/package/designer/ProcessDesigner.vue b/src/components/bpmnProcessDesigner/package/designer/ProcessDesigner.vue index a14b0b60..fb1af307 100644 --- a/src/components/bpmnProcessDesigner/package/designer/ProcessDesigner.vue +++ b/src/components/bpmnProcessDesigner/package/designer/ProcessDesigner.vue @@ -188,7 +188,13 @@ - + @@ -196,10 +202,7 @@ {{ previewResult }} - - + @@ -231,7 +234,7 @@ import activitiModdleExtension from './plugins/extension-moddle/activiti' import flowableModdleExtension from './plugins/extension-moddle/flowable' // 引入json转换与高亮 // import xml2js from 'xml-js' -import xml2js from 'fast-xml-parser' +// import xml2js from 'fast-xml-parser' import { XmlNode, XmlNodeType, parseXmlString } from 'steady-xml' // 代码高亮插件 // import hljs from 'highlight.js/lib/highlight' @@ -626,7 +629,7 @@ const elementsAlign = (align) => { const previewProcessXML = () => { console.log(bpmnModeler.saveXML, 'bpmnModeler') bpmnModeler.saveXML({ format: true }).then(({ xml }) => { - console.log(xml, 'xml111111') + // console.log(xml, 'xml111111') previewResult.value = xml previewType.value = 'xml' previewModelVisible.value = true @@ -634,7 +637,7 @@ const previewProcessXML = () => { } const previewProcessJson = () => { bpmnModeler.saveXML({ format: true }).then(({ xml }) => { - console.log(xml, 'xml') + // console.log(xml, 'xml') // const rootNode = parseXmlString(xml) // console.log(rootNode, 'rootNoderootNode') @@ -644,9 +647,9 @@ const previewProcessJson = () => { // console.log(JSON.stringify(rootNodes.parent.toJsObject()), 'rootNodes.toJSON()') // console.log(JSON.stringify(rootNodes.parent.toJSON()), 'rootNodes.toJSON()') - const parser = new xml2js.XMLParser() - let jObj = parser.parse(xml) - console.log(jObj, 'jObjjObjjObjjObjjObj') + // const parser = new xml2js.XMLParser() + // let jObj = parser.parse(xml) + // console.log(jObj, 'jObjjObjjObjjObjjObj') // const builder = new xml2js.XMLBuilder(xml) // const xmlContent = builder // console.log(xmlContent, 'xmlContent') diff --git a/src/components/index.ts b/src/components/index.ts index 19b2aac6..35df3da6 100644 --- a/src/components/index.ts +++ b/src/components/index.ts @@ -3,8 +3,6 @@ import { Icon } from './Icon' import { Form } from '@/components/Form' import { Table } from '@/components/Table' import { Search } from '@/components/Search' -import { XModal } from '@/components/XModal' -import { XTable } from '@/components/XTable' import { XButton, XTextButton } from '@/components/XButton' import { DictTag } from '@/components/DictTag' import { ContentWrap } from '@/components/ContentWrap' @@ -15,8 +13,6 @@ export const setupGlobCom = (app: App): void => { app.component('Form', Form) app.component('Table', Table) app.component('Search', Search) - app.component('XModal', XModal) - app.component('XTable', XTable) app.component('XButton', XButton) app.component('XTextButton', XTextButton) app.component('DictTag', DictTag) diff --git a/src/hooks/web/useVxeCrudSchemas.ts b/src/hooks/web/useVxeCrudSchemas.ts deleted file mode 100644 index 5c765d4f..00000000 --- a/src/hooks/web/useVxeCrudSchemas.ts +++ /dev/null @@ -1,354 +0,0 @@ -import { - FormItemRenderOptions, - VxeColumnPropTypes, - VxeFormItemProps, - VxeGridPropTypes, - VxeTableDefines -} from 'vxe-table' -import { eachTree } from 'xe-utils' - -import { getBoolDictOptions, getDictOptions, getIntDictOptions } from '@/utils/dict' -import { FormSchema } from '@/types/form' -import { VxeTableColumn } from '@/types/table' -import { ComponentOptions } from '@/types/components' -import { DescriptionsSchema } from '@/types/descriptions' - -export type VxeCrudSchema = { - primaryKey?: string // 主键ID - primaryTitle?: string // 主键标题 默认为序号 - primaryType?: VxeColumnPropTypes.Type | 'id' // 还支持 "id" | "seq" | "radio" | "checkbox" | "expand" | "html" | null - firstColumn?: VxeColumnPropTypes.Type // 第一列显示类型 - action?: boolean // 是否开启表格内右侧操作栏插槽 - actionTitle?: string // 操作栏标题 默认为操作 - actionWidth?: string // 操作栏插槽宽度,一般2个字带图标 text 类型按钮 50-70 - columns: VxeCrudColumns[] - searchSpan?: number -} -type VxeCrudColumns = Omit & { - field: string // 字段名 - title?: string // 标题名 - formatter?: VxeColumnPropTypes.Formatter // vxe formatter格式化 - isSearch?: boolean // 是否在查询显示 - search?: CrudSearchParams // 查询的详细配置 - isTable?: boolean // 是否在列表显示 - table?: CrudTableParams // 列表的详细配置 - isForm?: boolean // 是否在表单显示 - form?: CrudFormParams // 表单的详细配置 - isDetail?: boolean // 是否在详情显示 - detail?: CrudDescriptionsParams // 详情的详细配置 - print?: CrudPrintParams // vxe 打印的字段 - children?: VxeCrudColumns[] // 子级 - dictType?: string // 字典类型 - dictClass?: 'string' | 'number' | 'boolean' // 字典数据类型 string | number | boolean -} - -type CrudSearchParams = { - // 是否显示在查询项 - show?: boolean -} & Omit - -type CrudTableParams = { - // 是否显示表头 - show?: boolean -} & Omit - -type CrudFormParams = { - // 是否显示表单项 - show?: boolean -} & Omit - -type CrudDescriptionsParams = { - // 是否显示表单项 - show?: boolean -} & Omit - -type CrudPrintParams = { - // 是否显示打印项 - show?: boolean -} & Omit - -export type VxeAllSchemas = { - searchSchema: VxeFormItemProps[] - tableSchema: VxeGridPropTypes.Columns - formSchema: FormSchema[] - detailSchema: DescriptionsSchema[] - printSchema: VxeTableDefines.ColumnInfo[] -} - -// 过滤所有结构 -export const useVxeCrudSchemas = ( - crudSchema: VxeCrudSchema -): { - allSchemas: VxeAllSchemas -} => { - // 所有结构数据 - const allSchemas = reactive({ - searchSchema: [], - tableSchema: [], - formSchema: [], - detailSchema: [], - printSchema: [] - }) - - const searchSchema = filterSearchSchema(crudSchema) - allSchemas.searchSchema = searchSchema || [] - - const tableSchema = filterTableSchema(crudSchema) - allSchemas.tableSchema = tableSchema || [] - - const formSchema = filterFormSchema(crudSchema) - allSchemas.formSchema = formSchema - - const detailSchema = filterDescriptionsSchema(crudSchema) - allSchemas.detailSchema = detailSchema - - const printSchema = filterPrintSchema(crudSchema) - allSchemas.printSchema = printSchema - - return { - allSchemas - } -} - -// 过滤 Search 结构 -const filterSearchSchema = (crudSchema: VxeCrudSchema): VxeFormItemProps[] => { - const { t } = useI18n() - const span = crudSchema.searchSpan ? crudSchema.searchSpan : 6 - const spanLength = 24 / span - const searchSchema: VxeFormItemProps[] = [] - eachTree(crudSchema.columns, (schemaItem: VxeCrudColumns) => { - // 判断是否显示 - if (schemaItem?.isSearch || schemaItem.search?.show) { - let itemRenderName = schemaItem?.search?.itemRender?.name || '$input' - const options: any[] = [] - let itemRender: FormItemRenderOptions = {} - - if (schemaItem.dictType) { - const allOptions = { label: '全部', value: '' } - options.push(allOptions) - getDictOptions(schemaItem.dictType).forEach((dict) => { - options.push(dict) - }) - itemRender.options = options - if (!schemaItem?.search?.itemRender?.name) itemRenderName = '$select' - itemRender = { - name: itemRenderName, - options: options, - props: { placeholder: t('common.selectText') } - } - } else { - if (schemaItem.search?.itemRender) { - itemRender = schemaItem.search.itemRender - } else { - itemRender = { - name: itemRenderName, - props: - itemRenderName == '$input' - ? { placeholder: t('common.inputText') } - : { placeholder: t('common.selectText') } - } - } - } - const searchSchemaItem = { - // 默认为 input - folding: searchSchema.length > spanLength - 1, - itemRender: schemaItem.itemRender ? schemaItem.itemRender : itemRender, - field: schemaItem.field, - title: schemaItem.search?.title || schemaItem.title, - slots: schemaItem.search?.slots, - span: span - } - searchSchema.push(searchSchemaItem) - } - }) - if (searchSchema.length > 0) { - // 添加搜索按钮 - const buttons: VxeFormItemProps = { - span: 24, - align: 'right', - collapseNode: searchSchema.length > spanLength, - itemRender: { - name: '$buttons', - children: [ - { props: { type: 'submit', content: t('common.query'), status: 'primary' } }, - { props: { type: 'reset', content: t('common.reset') } } - ] - } - } - searchSchema.push(buttons) - } - return searchSchema -} - -// 过滤 table 结构 -const filterTableSchema = (crudSchema: VxeCrudSchema): VxeGridPropTypes.Columns => { - const { t } = useI18n() - const tableSchema: VxeGridPropTypes.Columns = [] - // 第一列 - if (crudSchema.firstColumn) { - const tableSchemaItem = { - type: crudSchema.firstColumn, - width: '50px' - } - tableSchema.push(tableSchemaItem) - } - // 主键ID - if (crudSchema.primaryKey && crudSchema.primaryType) { - const primaryTitle = crudSchema.primaryTitle ? crudSchema.primaryTitle : t('common.index') - const primaryWidth = primaryTitle.length * 30 + 'px' - - let tableSchemaItem: { [x: string]: any } = { - title: primaryTitle, - field: crudSchema.primaryKey, - width: primaryWidth - } - if (crudSchema.primaryType != 'id') { - tableSchemaItem = { - ...tableSchemaItem, - type: crudSchema.primaryType - } - } - tableSchema.push(tableSchemaItem) - } - - eachTree(crudSchema.columns, (schemaItem: VxeCrudColumns) => { - // 判断是否显示 - if (schemaItem?.isTable !== false && schemaItem?.table?.show !== false) { - const tableSchemaItem = { - ...schemaItem.table, - field: schemaItem.field, - title: schemaItem.table?.title || schemaItem.title, - minWidth: '80px' - } - tableSchemaItem.showOverflow = 'tooltip' - if (schemaItem?.formatter) { - tableSchemaItem.formatter = schemaItem.formatter - tableSchemaItem.width = tableSchemaItem.width ? tableSchemaItem.width : 160 - } - if (schemaItem?.dictType) { - tableSchemaItem.cellRender = { - name: 'XDict', - content: schemaItem.dictType - } - tableSchemaItem.width = tableSchemaItem.width ? tableSchemaItem.width : 160 - } - - tableSchema.push(tableSchemaItem) - } - }) - // 操作栏插槽 - if (crudSchema.action && crudSchema.action == true) { - const tableSchemaItem = { - title: crudSchema.actionTitle ? crudSchema.actionTitle : t('table.action'), - field: 'actionbtns', - fixed: 'right' as unknown as VxeColumnPropTypes.Fixed, - width: crudSchema.actionWidth ? crudSchema.actionWidth : '200px', - slots: { - default: 'actionbtns_default' - } - } - tableSchema.push(tableSchemaItem) - } - return tableSchema -} - -// 过滤 form 结构 -const filterFormSchema = (crudSchema: VxeCrudSchema): FormSchema[] => { - const formSchema: FormSchema[] = [] - - eachTree(crudSchema.columns, (schemaItem: VxeCrudColumns) => { - // 判断是否显示 - if (schemaItem?.isForm !== false && schemaItem?.form?.show !== false) { - // 默认为 input - let component = schemaItem?.form?.component || 'Input' - let defaultValue: any = '' - if (schemaItem.form?.value) { - defaultValue = schemaItem.form?.value - } else { - if (component === 'InputNumber') { - defaultValue = 0 - } - } - let comonentProps = {} - if (schemaItem.dictType) { - const options: ComponentOptions[] = [] - if (schemaItem.dictClass && schemaItem.dictClass === 'number') { - getIntDictOptions(schemaItem.dictType).forEach((dict) => { - options.push(dict) - }) - } else if (schemaItem.dictClass && schemaItem.dictClass === 'boolean') { - getBoolDictOptions(schemaItem.dictType).forEach((dict) => { - options.push(dict) - }) - } else { - getDictOptions(schemaItem.dictType).forEach((dict) => { - options.push(dict) - }) - } - comonentProps = { - options: options - } - if (!(schemaItem.form && schemaItem.form.component)) component = 'Select' - } - const formSchemaItem = { - component: component, - componentProps: comonentProps, - value: defaultValue, - ...schemaItem.form, - field: schemaItem.field, - label: schemaItem.form?.label || schemaItem.title - } - - formSchema.push(formSchemaItem) - } - }) - - return formSchema -} - -// 过滤 descriptions 结构 -const filterDescriptionsSchema = (crudSchema: VxeCrudSchema): DescriptionsSchema[] => { - const descriptionsSchema: DescriptionsSchema[] = [] - - eachTree(crudSchema.columns, (schemaItem: VxeCrudColumns) => { - // 判断是否显示 - if (schemaItem?.isDetail !== false && schemaItem.detail?.show !== false) { - const descriptionsSchemaItem = { - ...schemaItem.detail, - field: schemaItem.field, - label: schemaItem.detail?.label || schemaItem.title - } - if (schemaItem.dictType) { - descriptionsSchemaItem.dictType = schemaItem.dictType - } - if (schemaItem.detail?.dateFormat || schemaItem.formatter == 'formatDate') { - // 优先使用 detail 下的配置,如果没有默认为 YYYY-MM-DD HH:mm:ss - descriptionsSchemaItem.dateFormat = schemaItem?.detail?.dateFormat - ? schemaItem?.detail?.dateFormat - : 'YYYY-MM-DD HH:mm:ss' - } - - descriptionsSchema.push(descriptionsSchemaItem) - } - }) - - return descriptionsSchema -} - -// 过滤 打印 结构 -const filterPrintSchema = (crudSchema: VxeCrudSchema): any[] => { - const printSchema: any[] = [] - - eachTree(crudSchema.columns, (schemaItem: VxeCrudColumns) => { - // 判断是否显示 - if (schemaItem?.print?.show !== false) { - const printSchemaItem = { - field: schemaItem.field - } - - printSchema.push(printSchemaItem) - } - }) - - return printSchema -} diff --git a/src/hooks/web/useVxeGrid.ts b/src/hooks/web/useVxeGrid.ts deleted file mode 100644 index 5ac07c86..00000000 --- a/src/hooks/web/useVxeGrid.ts +++ /dev/null @@ -1,264 +0,0 @@ -import { computed, nextTick, reactive } from 'vue' -import { SizeType, VxeGridProps, VxeTablePropTypes } from 'vxe-table' -import { useAppStore } from '@/store/modules/app' -import { VxeAllSchemas } from './useVxeCrudSchemas' - -import download from '@/utils/download' - -const { t } = useI18n() -const message = useMessage() // 消息弹窗 - -interface UseVxeGridConfig { - allSchemas: VxeAllSchemas - height?: number // 高度 默认730 - topActionSlots?: boolean // 是否开启表格内顶部操作栏插槽 - treeConfig?: VxeTablePropTypes.TreeConfig // 树形表单配置 - isList?: boolean // 是否不带分页的list - getListApi: (option: any) => Promise // 获取列表接口 - getAllListApi?: (option: any) => Promise // 获取全部数据接口 用于VXE导出 - deleteApi?: (option: any) => Promise // 删除接口 - exportListApi?: (option: any) => Promise // 导出接口 - exportName?: string // 导出文件夹名称 - queryParams?: any // 其他查询参数 -} - -const appStore = useAppStore() - -const currentSize = computed(() => { - let resSize: SizeType = 'small' - const appsize = appStore.getCurrentSize - switch (appsize) { - case 'large': - resSize = 'medium' - break - case 'default': - resSize = 'small' - break - case 'small': - resSize = 'mini' - break - } - return resSize -}) - -export const useVxeGrid = (config?: UseVxeGridConfig) => { - /** - * grid options 初始化 - */ - const gridOptions = reactive>({ - loading: true, - size: currentSize as any, - height: config?.height ? config.height : 730, - rowConfig: { - isCurrent: true, // 当鼠标点击行时,是否要高亮当前行 - isHover: true // 当鼠标移到行时,是否要高亮当前行 - }, - toolbarConfig: { - slots: - !config?.topActionSlots && config?.topActionSlots != false - ? { buttons: 'toolbar_buttons' } - : {} - }, - printConfig: { - columns: config?.allSchemas.printSchema - }, - formConfig: { - enabled: true, - titleWidth: 100, - titleAlign: 'right', - items: config?.allSchemas.searchSchema - }, - columns: config?.allSchemas.tableSchema, - proxyConfig: { - seq: true, // 启用动态序号代理(分页之后索引自动计算为当前页的起始序号) - form: true, // 启用表单代理,当点击表单提交按钮时会自动触发 reload 行为 - props: { result: 'list', total: 'total' }, - ajax: { - query: ({ page, form }) => { - let queryParams: any = Object.assign({}, JSON.parse(JSON.stringify(form))) - if (config?.queryParams) { - queryParams = Object.assign(queryParams, config.queryParams) - } - if (!config?.treeConfig) { - queryParams.pageSize = page.pageSize - queryParams.pageNo = page.currentPage - } - gridOptions.loading = false - return new Promise(async (resolve) => { - resolve(await config?.getListApi(queryParams)) - }) - }, - delete: ({ body }) => { - return new Promise(async (resolve) => { - if (config?.deleteApi) { - resolve(await config?.deleteApi(JSON.stringify(body))) - } else { - Promise.reject('未设置deleteApi') - } - }) - }, - queryAll: ({ form }) => { - const queryParams = Object.assign({}, JSON.parse(JSON.stringify(form))) - return new Promise(async (resolve) => { - if (config?.getAllListApi) { - resolve(await config?.getAllListApi(queryParams)) - } else { - resolve(await config?.getListApi(queryParams)) - } - }) - } - } - }, - exportConfig: { - filename: config?.exportName, - // 默认选中类型 - type: 'csv', - // 自定义数据量列表 - modes: config?.getAllListApi ? ['current', 'all'] : ['current'], - columns: config?.allSchemas.printSchema - } - }) - - if (config?.treeConfig) { - gridOptions.treeConfig = config.treeConfig - } else if (config?.isList) { - gridOptions.proxyConfig = { - seq: true, // 启用动态序号代理(分页之后索引自动计算为当前页的起始序号) - form: true, // 启用表单代理,当点击表单提交按钮时会自动触发 reload 行为 - props: { result: 'data' }, - ajax: { - query: ({ form }) => { - let queryParams: any = Object.assign({}, JSON.parse(JSON.stringify(form))) - if (config?.queryParams) { - queryParams = Object.assign(queryParams, config.queryParams) - } - gridOptions.loading = false - return new Promise(async (resolve) => { - resolve(await config?.getListApi(queryParams)) - }) - } - } - } - } else { - gridOptions.pagerConfig = { - border: false, // 带边框 - background: true, // 带背景颜色 - perfect: false, // 配套的样式 - pageSize: 10, // 每页大小 - pagerCount: 7, // 显示页码按钮的数量 - autoHidden: false, // 当只有一页时自动隐藏 - pageSizes: [5, 10, 20, 30, 50, 100], // 每页大小选项列表 - layouts: [ - 'PrevJump', - 'PrevPage', - 'JumpNumber', - 'NextPage', - 'NextJump', - 'Sizes', - 'FullJump', - 'Total' - ] - } - } - - /** - * 刷新列表 - * @param ref - * @returns - */ - const getList = async (ref) => { - if (!ref) { - console.error('未传入gridRef') - return - } - await nextTick() - ref.value.commitProxy('query') - } - - // 获取查询参数 - const getSearchData = async (ref) => { - if (!ref) { - console.error('未传入gridRef') - return - } - await nextTick() - const queryParams = Object.assign( - {}, - JSON.parse(JSON.stringify(ref.value.getProxyInfo()?.form)) - ) - return queryParams - } - - /** - * 删除 - * @param ref - * @param ids rowid - * @returns - */ - const deleteData = async (ref, ids: string | number) => { - if (!ref) { - console.error('未传入gridRef') - return - } - if (!config?.deleteApi) { - console.error('未传入delListApi') - return - } - await nextTick() - return new Promise(async () => { - message.delConfirm().then(async () => { - await (config?.deleteApi && config?.deleteApi(ids)) - message.success(t('common.delSuccess')) - // 刷新列表 - ref.value.commitProxy('query') - }) - }) - } - /** - * 导出 - * @param ref - * @param fileName 文件名,默认excel.xls - * @returns - */ - const exportList = async (ref, fileName?: string) => { - if (!ref) { - console.error('未传入gridRef') - return - } - if (!config?.exportListApi) { - console.error('未传入exportListApi') - return - } - await nextTick() - const queryParams = Object.assign( - {}, - JSON.parse(JSON.stringify(ref.value?.getProxyInfo()?.form)) - ) - message.exportConfirm().then(async () => { - const res = await (config?.exportListApi && config?.exportListApi(queryParams)) - download.excel(res as unknown as Blob, fileName ? fileName : 'excel.xls') - }) - } - /** - * 表格最大/最小化 - * @param ref - * @returns - */ - const zoom = async (ref) => { - if (!ref) { - console.error('未传入gridRef') - return - } - await nextTick() - ref.value.zoom(!ref.value.isMaximized()) - } - - return { - gridOptions, - getList, - getSearchData, - deleteData, - exportList, - zoom - } -} diff --git a/src/hooks/web/useXTable.ts b/src/hooks/web/useXTable.ts deleted file mode 100644 index 501f982b..00000000 --- a/src/hooks/web/useXTable.ts +++ /dev/null @@ -1,39 +0,0 @@ -import { XTableProps } from '@/components/XTable/src/type' - -export interface tableMethod { - reload: () => void // 刷新表格 - setProps: (props: XTableProps) => void - deleteData: (id: string | number) => void // 删除数据 - deleteBatch: () => void // 批量删除 - exportList: (fileName?: string) => void // 导出列表 - getCurrentColumn: () => void // 获取当前列 - getRadioRecord: () => void // 获取当前选中列,radio - getCheckboxRecords: () => void //获取当前选中列, checkbox -} - -export const useXTable = (props: XTableProps): [Function, tableMethod] => { - const tableRef = ref>(null) - - const register = (instance) => { - tableRef.value = instance - props && instance.setProps(props) - } - const getInstance = (): tableMethod => { - const table = unref(tableRef) - if (!table) { - console.error('表格实例不存在') - } - return table as tableMethod - } - const methods: tableMethod = { - reload: () => getInstance().reload(), - setProps: (props) => getInstance().setProps(props), - deleteData: (id: string | number) => getInstance().deleteData(id), - deleteBatch: () => getInstance().deleteBatch(), - exportList: (fileName?: string) => getInstance().exportList(fileName), - getCurrentColumn: () => getInstance().getCheckboxRecords(), - getRadioRecord: () => getInstance().getRadioRecord(), - getCheckboxRecords: () => getInstance().getCheckboxRecords() - } - return [register, methods] -} diff --git a/src/main.ts b/src/main.ts index f24560b5..8dd1fff0 100644 --- a/src/main.ts +++ b/src/main.ts @@ -16,9 +16,6 @@ import { setupGlobCom } from '@/components' // 引入 element-plus import { setupElementPlus } from '@/plugins/elementPlus' -// 引入 vxe-table -import { setupVxeTable } from '@/plugins/vxeTable' - // 引入 form-create import { setupFormCreate } from '@/plugins/formCreate' @@ -83,8 +80,6 @@ const setupAll = async () => { setupElementPlus(app) - setupVxeTable(app) - setupFormCreate(app) setupRouter(app) diff --git a/src/plugins/vxeTable/index.ts b/src/plugins/vxeTable/index.ts deleted file mode 100644 index 6b61bb5c..00000000 --- a/src/plugins/vxeTable/index.ts +++ /dev/null @@ -1,223 +0,0 @@ -import { App } from 'vue' -import XEUtils from 'xe-utils' -import './renderer' -import 'vxe-table/lib/style.css' -import { i18n } from '@/plugins/vueI18n' -import zhCN from 'vxe-table/lib/locale/lang/zh-CN' -import enUS from 'vxe-table/lib/locale/lang/en-US' -import { - // 全局对象 - VXETable, - // 表格功能 - Filter, - Edit, - Menu, - Export, - Keyboard, - Validator, - // 可选组件 - Icon, - Column, - Colgroup, - Grid, - Tooltip, - Toolbar, - Pager, - Form, - FormItem, - FormGather, - Checkbox, - CheckboxGroup, - Radio, - RadioGroup, - RadioButton, - Switch, - Input, - Select, - Optgroup, - Option, - Textarea, - Button, - Modal, - List, - Pulldown, - // 表格 - Table -} from 'vxe-table' - -// 全局默认参数 -VXETable.setup({ - size: 'medium', // 全局尺寸 - version: 0, // 版本号,对于某些带数据缓存的功能有用到,上升版本号可以用于重置数据 - zIndex: 1008, // 全局 zIndex 起始值,如果项目的的 z-index 样式值过大时就需要跟随设置更大,避免被遮挡 - loadingText: '加载中...', // 全局loading提示内容,如果为null则不显示文本 - height: 600, - table: { - border: 'inner', // default(默认), full(完整边框), outer(外边框), inner(内边框), none(无边框) - align: 'center', // eft(左对齐), center(居中对齐), right(右对齐) - autoResize: true, // 自动监听父元素的变化去重新计算表格 - resizable: true, // 列是否允许拖动列宽调整大小 - emptyText: '暂无数据', // 空表单 - highlightHoverRow: true, // 自动监听父元素的变化去重新计算表格 - treeConfig: { - rowField: 'id', - parentField: 'parentId', - children: 'children', - indent: 20, - showIcon: true - } - }, - grid: { - toolbarConfig: { - refresh: true, - export: true, - print: true, - zoom: true, - custom: true - }, - pagerConfig: { - border: false, - background: false, - autoHidden: true, - perfect: true, - pageSize: 10, - pagerCount: 7, - pageSizes: [5, 10, 15, 20, 50, 100, 200, 500], - layouts: [ - 'Sizes', - 'PrevJump', - 'PrevPage', - 'Number', - 'NextPage', - 'NextJump', - 'FullJump', - 'Total' - ] - } - }, - pager: { - background: false, - autoHidden: false, - perfect: true, - pageSize: 10, - pagerCount: 7, - pageSizes: [10, 15, 20, 50, 100], - layouts: ['PrevJump', 'PrevPage', 'Jump', 'PageCount', 'NextPage', 'NextJump', 'Sizes', 'Total'] - }, - input: { - clearable: true - }, - form: { - titleColon: true // 是否显示标题冒号 - }, - modal: { - width: 800, // 窗口的宽度 - height: 600, // 窗口的高度 - minWidth: 460, - minHeight: 320, - showZoom: true, // 标题是否标显示最大化与还原按钮 - resize: true, // 是否允许窗口边缘拖动调整窗口大小 - marginSize: 0, // 只对 resize 启用后有效,用于设置可拖动界限范围,如果为负数则允许拖动超出屏幕边界 - remember: false, // 记忆功能,会记住最后操作状态,再次打开窗口时还原窗口状态 - destroyOnClose: true, // 在窗口关闭时销毁内容 - storage: false, // 是否启用 localStorage 本地保存,会将窗口拖动的状态保存到本地 - transfer: true, // 是否将弹框容器插入于 body 内 - showFooter: true, // 是否显示底部 - mask: true, // 是否显示遮罩层 - maskClosable: true, // 是否允许点击遮罩层关闭窗口 - escClosable: true // 是否允许按 Esc 键关闭窗口 - }, - i18n: (key, args) => { - return unref(i18n.global.locale) === 'zh-CN' - ? XEUtils.toFormatString(XEUtils.get(zhCN, key), args) - : XEUtils.toFormatString(XEUtils.get(enUS, key), args) - } -}) -// 自定义全局的格式化处理函数 -VXETable.formats.mixin({ - // 格式精简日期,默认 yyyy-MM-dd HH:mm:ss - formatDay({ cellValue }, format) { - if (cellValue != null) { - return XEUtils.toDateString(cellValue, format || 'yyyy-MM-dd') - } else { - return '' - } - }, - // 格式完整日期,默认 yyyy-MM-dd HH:mm:ss - formatDate({ cellValue }, format) { - if (cellValue != null) { - return XEUtils.toDateString(cellValue, format || 'yyyy-MM-dd HH:mm:ss') - } else { - return '' - } - }, - // 四舍五入金额,每隔3位逗号分隔,默认2位数 - formatAmount({ cellValue }, digits = 2) { - return XEUtils.commafy(Number(cellValue), { digits }) - }, - // 格式化银行卡,默认每4位空格隔开 - formatBankcard({ cellValue }) { - return XEUtils.commafy(XEUtils.toValueString(cellValue), { spaceNumber: 4, separator: ' ' }) - }, - // 四舍五入,默认两位数 - formatFixedNumber({ cellValue }, digits = 2) { - return XEUtils.toFixed(XEUtils.round(cellValue, digits), digits) - }, - // 向下舍入,默认两位数 - formatCutNumber({ cellValue }, digits = 2) { - return XEUtils.toFixed(XEUtils.floor(cellValue, digits), digits) - }, - // 格式化图片,将图片链接转换为html标签 - formatImg({ cellValue }) { - return ' ' - }, - // 格式化文件大小 - formatSize({ cellValue }, digits = 0) { - const unitArr = ['Bytes', 'KB', 'MB', 'GB', 'TB', 'PB', 'EB', 'ZB', 'YB'] - const srcSize = parseFloat(cellValue) - const index = Math.floor(Math.log(srcSize) / Math.log(1024)) - const size = srcSize / Math.pow(1024, index) - return XEUtils.toFixed(XEUtils.floor(size, 2), 2) + ' ' + unitArr[digits] - } -}) -export const setupVxeTable = (app: App) => { - // 表格功能 - app.use(Filter).use(Edit).use(Menu).use(Export).use(Keyboard).use(Validator) - - // 可选组件 - app - .use(Icon) - .use(Column) - .use(Colgroup) - .use(Grid) - .use(Tooltip) - .use(Toolbar) - .use(Pager) - .use(Form) - .use(FormItem) - .use(FormGather) - .use(Checkbox) - .use(CheckboxGroup) - .use(Radio) - .use(RadioGroup) - .use(RadioButton) - .use(Switch) - .use(Input) - .use(Select) - .use(Optgroup) - .use(Option) - .use(Textarea) - .use(Button) - .use(Modal) - .use(List) - .use(Pulldown) - - // 安装表格 - .use(Table) - - // 给 vue 实例挂载内部对象,例如: - // app.config.globalProperties.$XModal = VXETable.modal - // app.config.globalProperties.$XPrint = VXETable.print - // app.config.globalProperties.$XSaveFile = VXETable.saveFile - // app.config.globalProperties.$XReadFile = VXETable.readFile -} diff --git a/src/plugins/vxeTable/renderer/dataPicker.tsx b/src/plugins/vxeTable/renderer/dataPicker.tsx deleted file mode 100644 index 6a1c1d8f..00000000 --- a/src/plugins/vxeTable/renderer/dataPicker.tsx +++ /dev/null @@ -1,20 +0,0 @@ -import { ElDatePicker } from 'element-plus' -import { VXETable } from 'vxe-table' - -// 日期区间选择渲染 -VXETable.renderer.add('XDataPicker', { - // 默认显示模板 - renderItemContent(renderOpts, params) { - const { data, field } = params - const { content } = renderOpts - return ( - - ) - } -}) diff --git a/src/plugins/vxeTable/renderer/dataTimeRangePicker.tsx b/src/plugins/vxeTable/renderer/dataTimeRangePicker.tsx deleted file mode 100644 index d6508d2c..00000000 --- a/src/plugins/vxeTable/renderer/dataTimeRangePicker.tsx +++ /dev/null @@ -1,23 +0,0 @@ -import { ElDatePicker } from 'element-plus' -import { VXETable } from 'vxe-table' - -// 日期区间选择渲染 -VXETable.renderer.add('XDataTimePicker', { - // 默认显示模板 - renderItemContent(renderOpts, params) { - const { t } = useI18n() - const { data, field } = params - const { content } = renderOpts - return ( - - ) - } -}) diff --git a/src/plugins/vxeTable/renderer/dict.tsx b/src/plugins/vxeTable/renderer/dict.tsx deleted file mode 100644 index 9cdf282d..00000000 --- a/src/plugins/vxeTable/renderer/dict.tsx +++ /dev/null @@ -1,12 +0,0 @@ -import { DictTag } from '@/components/DictTag' -import { VXETable } from 'vxe-table' - -// 字典渲染 -VXETable.renderer.add('XDict', { - // 默认显示模板 - renderDefault(renderOpts, params) { - const { row, column } = params - const { content } = renderOpts - return - } -}) diff --git a/src/plugins/vxeTable/renderer/html.tsx b/src/plugins/vxeTable/renderer/html.tsx deleted file mode 100644 index 46483a1c..00000000 --- a/src/plugins/vxeTable/renderer/html.tsx +++ /dev/null @@ -1,10 +0,0 @@ -import { VXETable } from 'vxe-table' - -// 图片渲染 -VXETable.renderer.add('XHtml', { - // 默认显示模板 - renderDefault(_renderOpts, params) { - const { row, column } = params - return - } -}) diff --git a/src/plugins/vxeTable/renderer/img.tsx b/src/plugins/vxeTable/renderer/img.tsx deleted file mode 100644 index fbbf24a1..00000000 --- a/src/plugins/vxeTable/renderer/img.tsx +++ /dev/null @@ -1,20 +0,0 @@ -import { VXETable } from 'vxe-table' -import { ElImage } from 'element-plus' - -// 图片渲染 -VXETable.renderer.add('XImg', { - // 默认显示模板 - renderDefault(_renderOpts, params) { - const { row, column } = params - return ( - - ) - } -}) diff --git a/src/plugins/vxeTable/renderer/index.tsx b/src/plugins/vxeTable/renderer/index.tsx deleted file mode 100644 index 744e46c3..00000000 --- a/src/plugins/vxeTable/renderer/index.tsx +++ /dev/null @@ -1,7 +0,0 @@ -import './dataPicker' -import './dataTimeRangePicker' -import './dict' -import './html' -import './link' -import './img' -import './preview' diff --git a/src/plugins/vxeTable/renderer/link.tsx b/src/plugins/vxeTable/renderer/link.tsx deleted file mode 100644 index 84e1a5a1..00000000 --- a/src/plugins/vxeTable/renderer/link.tsx +++ /dev/null @@ -1,15 +0,0 @@ -import { VXETable } from 'vxe-table' - -// 超链接渲染 -VXETable.renderer.add('XLink', { - // 默认显示模板 - renderDefault(renderOpts, params) { - const { row, column } = params - const { events = {} } = renderOpts - return ( - events.click(params)}> - {row[column.field]} - - ) - } -}) diff --git a/src/plugins/vxeTable/renderer/preview.tsx b/src/plugins/vxeTable/renderer/preview.tsx deleted file mode 100644 index a737dd51..00000000 --- a/src/plugins/vxeTable/renderer/preview.tsx +++ /dev/null @@ -1,35 +0,0 @@ -import { VXETable } from 'vxe-table' -import { ElImage, ElLink } from 'element-plus' - -// 图片渲染 -VXETable.renderer.add('XPreview', { - // 默认显示模板 - renderDefault(_renderOpts, params) { - const { row, column } = params - if (row.type.indexOf('image/') === 0) { - return ( - - ) - } else if (row.type.indexOf('video/') === 0) { - return ( - - - - ) - } else { - return ( - // @ts-ignore - - {row[column.field]} - - ) - } - } -}) diff --git a/src/types/auto-components.d.ts b/src/types/auto-components.d.ts index e9e992f1..a3afbb94 100644 --- a/src/types/auto-components.d.ts +++ b/src/types/auto-components.d.ts @@ -120,8 +120,6 @@ declare module '@vue/runtime-core' { VerifyPoints: typeof import('./../components/Verifition/src/Verify/VerifyPoints.vue')['default'] VerifySlide: typeof import('./../components/Verifition/src/Verify/VerifySlide.vue')['default'] XButton: typeof import('./../components/XButton/src/XButton.vue')['default'] - XModal: typeof import('./../components/XModal/src/XModal.vue')['default'] - XTable: typeof import('./../components/XTable/src/XTable.vue')['default'] XTextButton: typeof import('./../components/XButton/src/XTextButton.vue')['default'] } export interface ComponentCustomProperties { diff --git a/src/types/auto-imports.d.ts b/src/types/auto-imports.d.ts index 6558357f..75cf16d9 100644 --- a/src/types/auto-imports.d.ts +++ b/src/types/auto-imports.d.ts @@ -6,7 +6,6 @@ export {} declare global { const DICT_TYPE: typeof import('@/utils/dict')['DICT_TYPE'] const EffectScope: typeof import('vue')['EffectScope'] - const ElMessageBox: typeof import('element-plus/es')['ElMessageBox'] const computed: typeof import('vue')['computed'] const createApp: typeof import('vue')['createApp'] const customRef: typeof import('vue')['customRef'] diff --git a/src/utils/constants.ts b/src/utils/constants.ts index 901c04e9..5cda391f 100644 --- a/src/utils/constants.ts +++ b/src/utils/constants.ts @@ -114,6 +114,10 @@ export const PayChannelEnum = { ALIPAY_QR: { code: 'alipay_qr', name: '支付宝扫码支付' + }, + ALIPAY_BAR: { + code: 'alipay_bar', + name: '支付宝条码支付' } } diff --git a/src/utils/dict.ts b/src/utils/dict.ts index d1d84242..03e17e75 100644 --- a/src/utils/dict.ts +++ b/src/utils/dict.ts @@ -21,7 +21,7 @@ export interface DictDataType { } export const getDictOptions = (dictType: string) => { - return dictStore.getDictByType(dictType) + return dictStore.getDictByType(dictType) || [] } export const getIntDictOptions = (dictType: string) => { @@ -117,6 +117,7 @@ export enum DICT_TYPE { INFRA_API_ERROR_LOG_PROCESS_STATUS = 'infra_api_error_log_process_status', INFRA_CONFIG_TYPE = 'infra_config_type', INFRA_CODEGEN_TEMPLATE_TYPE = 'infra_codegen_template_type', + INFRA_CODEGEN_FRONT_TYPE = 'infra_codegen_front_type', INFRA_CODEGEN_SCENE = 'infra_codegen_scene', INFRA_FILE_STORAGE = 'infra_file_storage', diff --git a/src/views/bpm/oa/leave/detail.vue b/src/views/bpm/oa/leave/detail.vue index 31e54de3..838be149 100644 --- a/src/views/bpm/oa/leave/detail.vue +++ b/src/views/bpm/oa/leave/detail.vue @@ -1,5 +1,5 @@ - + @@ -21,13 +21,13 @@ import { DICT_TYPE } from '@/utils/dict' import { formatDate } from '@/utils/formatTime' import * as LeaveApi from '@/api/bpm/leave' -const modelVisible = ref(false) // 弹窗的是否展示 +const dialogVisible = ref(false) // 弹窗的是否展示 const detailLoading = ref(false) // 表单的加载中 const detailData = ref() // 详情数据 /** 打开弹窗 */ const open = async (data: LeaveApi.LeaveVO) => { - modelVisible.value = true + dialogVisible.value = true // 设置数据 detailLoading.value = true try { diff --git a/src/views/infra/codegen/EditTable.vue b/src/views/infra/codegen/EditTable.vue index e8cae410..8d9f498e 100644 --- a/src/views/infra/codegen/EditTable.vue +++ b/src/views/infra/codegen/EditTable.vue @@ -30,7 +30,7 @@ const { query } = useRoute() // 查询参数 const { delView } = useTagsViewStore() // 视图操作 const formLoading = ref(false) // 表单的加载中:1)修改时的数据加载;2)提交的按钮禁用 -const activeName = ref('basicInfo') // Tag 激活的窗口 +const activeName = ref('colum') // Tag 激活的窗口 const basicInfoRef = ref>() const columInfoRef = ref>() const generateInfoRef = ref>() diff --git a/src/views/infra/codegen/PreviewCode.vue b/src/views/infra/codegen/PreviewCode.vue index 6a81499d..5dd3907b 100644 --- a/src/views/infra/codegen/PreviewCode.vue +++ b/src/views/infra/codegen/PreviewCode.vue @@ -15,7 +15,7 @@ v-loading="loading" element-loading-text="生成文件目录中..." > - + + + + + + + + + @@ -25,6 +38,26 @@ + + + + + 上级菜单 + + + + + + + + @@ -115,27 +148,6 @@ - - - - - 上级菜单 - - - - - - - - - @@ -297,6 +309,7 @@ const props = defineProps({ const formRef = ref() const formData = ref({ templateType: null, + frontType: null, scene: null, moduleName: '', businessName: '', @@ -315,6 +328,7 @@ const formData = ref({ const rules = reactive({ templateType: [required], + frontType: [required], scene: [required], moduleName: [required], businessName: [required], diff --git a/src/views/mp/autoReply/index.vue b/src/views/mp/autoReply/index.vue index 03f98b54..4c8eb388 100644 --- a/src/views/mp/autoReply/index.vue +++ b/src/views/mp/autoReply/index.vue @@ -3,33 +3,16 @@ - + - - - - - - 搜索 - 重置 + - + @@ -38,26 +21,26 @@ plain @click="handleAdd" v-hasPermi="['mp:auto-reply:create']" - v-if="type !== '1' || list.length <= 0" + v-if="msgType !== MsgType.Follow || list.length <= 0" > 新增 - + - 关注时回复 + 关注时回复 - + 消息回复 - + - 关键词回复 + 关键词回复 @@ -67,10 +50,20 @@ label="请求消息类型" align="center" prop="requestMessageType" - v-if="type === '2'" + v-if="msgType === MsgType.Message" /> - - + + @@ -84,7 +77,7 @@ {{ scope.row.responseContent }} - + @@ -97,7 +90,11 @@ scope.row.responseMessageType === 'shortvideo' " > - + @@ -143,21 +140,21 @@ - - - - + + + + - - + + - - + + @@ -180,45 +177,47 @@ - diff --git a/src/views/mp/components/wx-account-select/main.vue b/src/views/mp/components/wx-account-select/main.vue new file mode 100644 index 00000000..4eb99615 --- /dev/null +++ b/src/views/mp/components/wx-account-select/main.vue @@ -0,0 +1,44 @@ + + + + + + + + + + + + + + + diff --git a/src/views/mp/components/wx-editor/WxEditor.vue b/src/views/mp/components/wx-editor/WxEditor.vue index 50c65c6e..d2220e10 100644 --- a/src/views/mp/components/wx-editor/WxEditor.vue +++ b/src/views/mp/components/wx-editor/WxEditor.vue @@ -1,11 +1,11 @@ diff --git a/src/views/mp/menu/index.vue b/src/views/mp/menu/index.vue index 2d4b7c76..fea08614 100644 --- a/src/views/mp/menu/index.vue +++ b/src/views/mp/menu/index.vue @@ -4,18 +4,7 @@ - - - - - - 搜索 - 重置 + @@ -26,7 +15,7 @@ - {{ name }} + {{ accountName }} @@ -82,7 +71,7 @@ - + 删除当前菜单 @@ -169,7 +158,7 @@ - + 素材库选择 @@ -199,26 +188,26 @@ - + diff --git a/src/views/pay/order/index.vue b/src/views/pay/order/index.vue index 21b8cca4..72e5128b 100644 --- a/src/views/pay/order/index.vue +++ b/src/views/pay/order/index.vue @@ -1,79 +1,336 @@ - - - - - + + + + + + + + + + + + + + + + + - - + + - - - - + + + + + + + + + + + + + + + + + - - + + + 搜索 + 重置 + + 导出 + + + - - - - - - - - - + + + + + + + + + + + + + + + + + + + + 商户 + {{ scope.row.merchantOrderId }} + + + 支付 + {{ scope.row.channelOrderNo }} + + + + + + ¥{{ parseFloat(scope.row.amount / 100).toFixed(2) }} + + + + + ¥{{ parseFloat(scope.row.channelFeeAmount / 100).toFixed(2) }} + + + + + ¥{{ parseFloat(scope.row.refundAmount / 100).toFixed(2) }} + + + + + + + + + + + + + + + + + + 详情 + + + + + + + + + + + diff --git a/src/views/pay/order/order.data.ts b/src/views/pay/order/order.data.ts deleted file mode 100644 index 7b993088..00000000 --- a/src/views/pay/order/order.data.ts +++ /dev/null @@ -1,152 +0,0 @@ -import type { VxeCrudSchema } from '@/hooks/web/useVxeCrudSchemas' -const { t } = useI18n() // 国际化 - -// 表单校验 -export const rules = reactive({ - merchantId: [required], - appId: [required], - merchantOrderId: [required], - subject: [required], - body: [required], - notifyUrl: [required], - notifyStatus: [required], - amount: [required], - status: [required], - userIp: [required], - expireTime: [required], - refundStatus: [required], - refundTimes: [required], - refundAmount: [required] -}) -// CrudSchema -const crudSchemas = reactive({ - primaryKey: 'id', - primaryType: 'seq', - primaryTitle: '岗位编号', - action: true, - columns: [ - { - title: '商户编号', - field: 'merchantId', - isSearch: true - }, - { - title: '应用编号', - field: 'appId', - isSearch: true - }, - { - title: '渠道编号', - field: 'channelId' - }, - { - title: '渠道编码', - field: 'channelCode', - isSearch: true - }, - { - title: '渠道订单号', - field: 'merchantOrderId', - isSearch: true - }, - { - title: '商品标题', - field: 'subject' - }, - { - title: '商品描述', - field: 'body' - }, - { - title: '异步通知地址', - field: 'notifyUrl' - }, - { - title: '回调状态', - field: 'notifyStatus', - dictType: DICT_TYPE.PAY_ORDER_NOTIFY_STATUS, - dictClass: 'number' - }, - { - title: '支付金额', - field: 'amount', - isSearch: true - }, - { - title: '渠道手续费', - field: 'channelFeeRate', - isSearch: true - }, - { - title: '渠道手续金额', - field: 'channelFeeAmount', - isSearch: true - }, - { - title: '支付状态', - field: 'status', - dictType: DICT_TYPE.PAY_ORDER_STATUS, - dictClass: 'number', - isSearch: true - }, - { - title: '用户 IP', - field: 'userIp' - }, - { - title: '订单失效时间', - field: 'expireTime', - formatter: 'formatDate' - }, - { - title: '支付时间', - field: 'successTime', - formatter: 'formatDate' - }, - { - title: '支付通知时间', - field: 'notifyTime', - formatter: 'formatDate' - }, - { - title: '拓展编号', - field: 'successExtensionId' - }, - { - title: '退款状态', - field: 'refundStatus', - dictType: DICT_TYPE.PAY_ORDER_REFUND_STATUS, - dictClass: 'number', - isSearch: true - }, - { - title: '退款次数', - field: 'refundTimes' - }, - { - title: '退款总金额', - field: 'refundAmount' - }, - { - title: '渠道用户编号', - field: 'channelUserId' - }, - { - title: '渠道订单号', - field: 'channelOrderNo' - }, - { - title: t('common.createTime'), - field: 'createTime', - formatter: 'formatDate', - isForm: false, - search: { - show: true, - itemRender: { - name: 'XDataTimePicker' - } - } - } - ] -}) -export const { allSchemas } = useVxeCrudSchemas(crudSchemas) diff --git a/src/views/pay/refund/RefundDetail.vue b/src/views/pay/refund/RefundDetail.vue new file mode 100644 index 00000000..8a47c6f6 --- /dev/null +++ b/src/views/pay/refund/RefundDetail.vue @@ -0,0 +1,115 @@ + + + + {{ detailData.merchantName }} + {{ detailData.appName }} + {{ detailData.subject }} + + + + + {{ detailData.merchantRefundNo }} + + + {{ detailData.merchantOrderId }} + + {{ detailData.tradeNo }} + + + + + ¥{{ parseFloat(detailData.payAmount / 100, 2).toFixed(2) }} + + + + ¥{{ parseFloat(detailData.refundAmount / 100).toFixed(2) }} + + + + + + + + + + {{ formatDate(detailData.createTime) }} + + + {{ formatDate(detailData.successTime) }} + + + {{ formatDate(detailData.expireTime) }} + + + {{ formatDate(detailData.updateTime) }} + + + + + + {{ detailData.channelCodeName }} + + + {{ detailData.userIp }} + + {{ detailData.notifyUrl }} + + + + + {{ formatDate(detailData.notifyTime) }} + + + + + + {{ detailData.channelOrderNo }} + + + {{ detailData.channelRefundNo }} + + + {{ detailData.channelErrorCode }} + + + {{ detailData.channelErrorMsg }} + + + + + + {{ detailData.channelExtras }} + + {{ detailData.reason }} + + + + + diff --git a/src/views/pay/refund/index.vue b/src/views/pay/refund/index.vue index ec8bf12c..17ca2a0d 100644 --- a/src/views/pay/refund/index.vue +++ b/src/views/pay/refund/index.vue @@ -1,59 +1,341 @@ + - - - - - + + + + + + + + + + + + + + + + + + + + + + - - - - + + + + + + + + + + + + - - + + + 搜索 + 重置 + + 导出 + + + - - - - - - {{ t('dialog.close') }} - - + + + + + + + + + + + + 退款 + {{ scope.row.merchantRefundNo }} + + + 交易 + {{ scope.row.merchantOrderId }} + + + + + + + 交易 + {{ scope.row.tradeNo }} + + + 渠道 + {{ scope.row.channelOrderNo }} + + + + + + ¥{{ parseFloat(scope.row.payAmount / 100).toFixed(2) }} + + + + + ¥{{ parseFloat(scope.row.refundAmount / 100).toFixed(2) }} + + + + + + + + + + + + + + + + + + + + + + + + 详情 + + + + + + + + + + + + diff --git a/src/views/pay/refund/refund.data.ts b/src/views/pay/refund/refund.data.ts deleted file mode 100644 index 456f441d..00000000 --- a/src/views/pay/refund/refund.data.ts +++ /dev/null @@ -1,173 +0,0 @@ -import type { VxeCrudSchema } from '@/hooks/web/useVxeCrudSchemas' -const { t } = useI18n() // 国际化 - -// CrudSchema -const crudSchemas = reactive({ - primaryKey: 'id', - primaryType: 'seq', - primaryTitle: '序号', - action: true, - columns: [ - { - title: '商户编号', - field: 'merchantId', - isSearch: true - }, - { - title: '应用编号', - field: 'appId', - isSearch: true - }, - { - title: '渠道编号', - field: 'channelId', - isSearch: true - }, - { - title: '渠道编码', - field: 'channelCode', - dictType: DICT_TYPE.PAY_CHANNEL_CODE_TYPE, - dictClass: 'number', - isSearch: true - }, - { - title: '支付订单编号', - field: 'orderId', - isSearch: true - }, - { - title: '交易订单号', - field: 'tradeNo', - isSearch: true - }, - { - title: '商户订单号', - field: 'merchantOrderId', - isSearch: true - }, - { - title: '商户退款单号', - field: 'merchantRefundNo', - isSearch: true - }, - { - title: '回调地址', - field: 'notifyUrl', - isSearch: true - }, - { - title: '回调状态', - field: 'notifyStatus', - dictType: DICT_TYPE.PAY_ORDER_NOTIFY_STATUS, - dictClass: 'number', - isSearch: true - }, - { - title: '退款类型', - field: 'type', - dictType: DICT_TYPE.PAY_REFUND_ORDER_TYPE, - dictClass: 'number', - isSearch: true - }, - { - title: t('common.status'), - field: 'status', - dictType: DICT_TYPE.PAY_REFUND_ORDER_STATUS, - dictClass: 'number', - isSearch: true - }, - { - title: '支付金额', - field: 'payAmount', - formatter: 'formatAmount', - isSearch: true - }, - { - title: '退款金额', - field: 'refundAmount', - formatter: 'formatAmount', - isSearch: true - }, - { - title: '退款原因', - field: 'reason', - isSearch: true - }, - { - title: '用户IP', - field: 'userIp', - isSearch: true - }, - { - title: '渠道订单号', - field: 'channelOrderNo', - isSearch: true - }, - { - title: '渠道退款单号', - field: 'channelRefundNo', - isSearch: true - }, - { - title: '渠道调用报错时', - field: 'channelErrorCode' - }, - { - title: '渠道调用报错时', - field: 'channelErrorMsg' - }, - { - title: '支付渠道的额外参数', - field: 'channelExtras' - }, - { - title: '退款失效时间', - field: 'expireTime', - formatter: 'formatDate', - isForm: false, - search: { - show: true, - itemRender: { - name: 'XDataTimePicker' - } - } - }, - { - title: '退款成功时间', - field: 'successTime', - formatter: 'formatDate', - isForm: false, - search: { - show: true, - itemRender: { - name: 'XDataTimePicker' - } - } - }, - { - title: '退款通知时间', - field: 'notifyTime', - formatter: 'formatDate', - isForm: false, - search: { - show: true, - itemRender: { - name: 'XDataTimePicker' - } - } - }, - { - title: t('common.createTime'), - field: 'createTime', - formatter: 'formatDate', - isForm: false, - search: { - show: true, - itemRender: { - name: 'XDataTimePicker' - } - } - } - ] -}) -export const { allSchemas } = useVxeCrudSchemas(crudSchemas) diff --git a/src/views/system/dept/index.vue b/src/views/system/dept/index.vue index 36d3ca5c..e4c83bc7 100644 --- a/src/views/system/dept/index.vue +++ b/src/views/system/dept/index.vue @@ -19,7 +19,7 @@ diff --git a/src/views/system/dict/data/DictDataForm.vue b/src/views/system/dict/data/DictDataForm.vue index 3bef7893..dc2f6057 100644 --- a/src/views/system/dict/data/DictDataForm.vue +++ b/src/views/system/dict/data/DictDataForm.vue @@ -115,11 +115,12 @@ const colorTypeOptions = readonly([ ]) /** 打开弹窗 */ -const open = async (type: string, id?: number) => { +const open = async (type: string, id?: number, dictType?: string) => { dialogVisible.value = true dialogTitle.value = t('action.' + type) formType.value = type resetForm() + formData.value.dictType = dictType // 修改时,设置数据 if (id) { formLoading.value = true diff --git a/src/views/system/dict/data/index.vue b/src/views/system/dict/data/index.vue index 77770dda..cb4c076e 100644 --- a/src/views/system/dict/data/index.vue +++ b/src/views/system/dict/data/index.vue @@ -167,7 +167,7 @@ const resetQuery = () => { /** 添加/修改操作 */ const formRef = ref() const openForm = (type: string, id?: number) => { - formRef.value.open(type, id) + formRef.value.open(type, id, queryParams.dictType) } /** 删除按钮操作 */ diff --git a/src/views/system/mail/account/account.data.ts b/src/views/system/mail/account/account.data.ts index eaa0673a..8b33edc5 100644 --- a/src/views/system/mail/account/account.data.ts +++ b/src/views/system/mail/account/account.data.ts @@ -19,7 +19,7 @@ export const rules = reactive({ sslEnable: [required] }) -// CrudSchema:https://kailong110120130.gitee.io/vue-element-plus-admin-doc/hooks/useCrudSchemas.html +// CrudSchema:https://doc.iocoder.cn/vue3/crud-schema/ const crudSchemas = reactive([ { label: '邮箱', diff --git a/src/views/system/mail/account/index.vue b/src/views/system/mail/account/index.vue index eeaf8bcf..f66bbf66 100644 --- a/src/views/system/mail/account/index.vue +++ b/src/views/system/mail/account/index.vue @@ -72,7 +72,7 @@ import MailAccountDetail from './MailAccountDetail.vue' // tableObject:表格的属性对象,可获得分页大小、条数等属性 // tableMethods:表格的操作对象,可进行获得分页、删除记录等操作 -// 详细可见:https://kailong110120130.gitee.io/vue-element-plus-admin-doc/components/table.html#usetable +// 详细可见:https://doc.iocoder.cn/vue3/crud-schema/ const { tableObject, tableMethods } = useTable({ getListApi: MailAccountApi.getMailAccountPage, // 分页接口 delListApi: MailAccountApi.deleteMailAccount // 删除接口 diff --git a/src/views/system/mail/log/index.vue b/src/views/system/mail/log/index.vue index f039e66e..c24ff009 100644 --- a/src/views/system/mail/log/index.vue +++ b/src/views/system/mail/log/index.vue @@ -41,7 +41,7 @@ import MailLogDetail from './MailLogDetail.vue' // tableObject:表格的属性对象,可获得分页大小、条数等属性 // tableMethods:表格的操作对象,可进行获得分页、删除记录等操作 -// 详细可见:https://kailong110120130.gitee.io/vue-element-plus-admin-doc/components/table.html#usetable +// 详细可见:https://doc.iocoder.cn/vue3/crud-schema/ const { tableObject, tableMethods } = useTable({ getListApi: MailLogApi.getMailLogPage // 分页接口 }) diff --git a/src/views/system/mail/log/log.data.ts b/src/views/system/mail/log/log.data.ts index 0fa695e4..62cbf516 100644 --- a/src/views/system/mail/log/log.data.ts +++ b/src/views/system/mail/log/log.data.ts @@ -5,7 +5,7 @@ import * as MailAccountApi from '@/api/system/mail/account' // 邮箱账号的列表 const accountList = await MailAccountApi.getSimpleMailAccountList() -// CrudSchema:https://kailong110120130.gitee.io/vue-element-plus-admin-doc/hooks/useCrudSchemas.html +// CrudSchema:https://doc.iocoder.cn/vue3/crud-schema/ const crudSchemas = reactive([ { label: '编号', diff --git a/src/views/system/mail/template/index.vue b/src/views/system/mail/template/index.vue index 357b028f..a964a6fb 100644 --- a/src/views/system/mail/template/index.vue +++ b/src/views/system/mail/template/index.vue @@ -73,7 +73,7 @@ import MailTemplateSendForm from './MailTemplateSendForm.vue' // tableObject:表格的属性对象,可获得分页大小、条数等属性 // tableMethods:表格的操作对象,可进行获得分页、删除记录等操作 -// 详细可见:https://kailong110120130.gitee.io/vue-element-plus-admin-doc/components/table.html#usetable +// 详细可见:https://doc.iocoder.cn/vue3/crud-schema/ const { tableObject, tableMethods } = useTable({ getListApi: MailTemplateApi.getMailTemplatePage, // 分页接口 delListApi: MailTemplateApi.deleteMailTemplate // 删除接口 diff --git a/src/views/system/mail/template/template.data.ts b/src/views/system/mail/template/template.data.ts index 99e6764a..e68f875a 100644 --- a/src/views/system/mail/template/template.data.ts +++ b/src/views/system/mail/template/template.data.ts @@ -17,7 +17,7 @@ export const rules = reactive({ status: [required] }) -// CrudSchema:https://kailong110120130.gitee.io/vue-element-plus-admin-doc/hooks/useCrudSchemas.html +// CrudSchema:https://doc.iocoder.cn/vue3/crud-schema/ const crudSchemas = reactive([ { label: '模板编码', diff --git a/src/views/system/notify/template/index.vue b/src/views/system/notify/template/index.vue index 69fda907..45c1be6d 100644 --- a/src/views/system/notify/template/index.vue +++ b/src/views/system/notify/template/index.vue @@ -46,7 +46,7 @@ - + - + - + @@ -112,7 +112,7 @@ /> - +
@@ -196,10 +202,7 @@ {{ previewResult }}
+ 商户 + {{ scope.row.merchantOrderId }} +
+ 支付 + {{ scope.row.channelOrderNo }} +
+ 退款 + {{ scope.row.merchantRefundNo }} +
+ 交易 + {{ scope.row.merchantOrderId }} +
+ 交易 + {{ scope.row.tradeNo }} +
+ 渠道 + {{ scope.row.channelOrderNo }} +