mirror of
https://github.com/pure-admin/vue-pure-admin.git
synced 2025-06-08 01:17:23 +08:00
fix: some small chang
This commit is contained in:
parent
b1751beab9
commit
074213c656
31
package-lock.json
generated
31
package-lock.json
generated
@ -33,7 +33,7 @@
|
|||||||
"vue-types": "^3.0.2",
|
"vue-types": "^3.0.2",
|
||||||
"vuedraggable": "^4.0.1",
|
"vuedraggable": "^4.0.1",
|
||||||
"vuex": "^4.0.0",
|
"vuex": "^4.0.0",
|
||||||
"vxe-table": "^4.0.14",
|
"vxe-table": "^4.0.15-beta.2",
|
||||||
"wangeditor": "^4.0.3",
|
"wangeditor": "^4.0.3",
|
||||||
"xe-ajax": "^4.0.5",
|
"xe-ajax": "^4.0.5",
|
||||||
"xe-utils": "^3.1.12",
|
"xe-utils": "^3.1.12",
|
||||||
@ -2710,9 +2710,13 @@
|
|||||||
"integrity": "sha1-rId6p2qcRTaMl5Rx5GG1INOObPU="
|
"integrity": "sha1-rId6p2qcRTaMl5Rx5GG1INOObPU="
|
||||||
},
|
},
|
||||||
"node_modules/vxe-table": {
|
"node_modules/vxe-table": {
|
||||||
"version": "4.0.14",
|
"version": "4.0.15-beta.2",
|
||||||
"resolved": "https://registry.npmjs.org/vxe-table/-/vxe-table-4.0.14.tgz",
|
"resolved": "https://registry.npmjs.org/vxe-table/-/vxe-table-4.0.15-beta.2.tgz",
|
||||||
"integrity": "sha512-0fwddIk7X+NPneZuucvy6BbTmZ9oRfTxP02ZfWOu5c4KegVSFTIxMWlGkDOhtwf67HcA6gh9UwWkyoPiKhvvCQ=="
|
"integrity": "sha512-XbyoVFAbvwnOzCcvNiGpe8vHBCUTwQzv2GBv5HjlzGKEy+e99eEAeIcEzYfXvu4ttIva+5u+at9svwRNKT8EBA==",
|
||||||
|
"peerDependencies": {
|
||||||
|
"vue": "^3.0.0",
|
||||||
|
"xe-utils": "^3.2.0"
|
||||||
|
}
|
||||||
},
|
},
|
||||||
"node_modules/wangeditor": {
|
"node_modules/wangeditor": {
|
||||||
"version": "4.6.14",
|
"version": "4.6.14",
|
||||||
@ -2750,9 +2754,9 @@
|
|||||||
"integrity": "sha1-N2kPiaN9m19U7yrk79PpJXDzLfM="
|
"integrity": "sha1-N2kPiaN9m19U7yrk79PpJXDzLfM="
|
||||||
},
|
},
|
||||||
"node_modules/xe-utils": {
|
"node_modules/xe-utils": {
|
||||||
"version": "3.1.13",
|
"version": "3.2.1",
|
||||||
"resolved": "https://registry.npm.taobao.org/xe-utils/download/xe-utils-3.1.13.tgz",
|
"resolved": "https://registry.npmjs.org/xe-utils/-/xe-utils-3.2.1.tgz",
|
||||||
"integrity": "sha1-6YPu28XoJNEnbOfvB3wFbfsdakk="
|
"integrity": "sha512-NiupDI5mIziz4i152UCk78c/qxYH/TDexGylLj81kxPbrePEg43LQ8hITCbsqpJDTcu9dmXESUtZyQDD1oB0hw=="
|
||||||
},
|
},
|
||||||
"node_modules/xgplayer": {
|
"node_modules/xgplayer": {
|
||||||
"version": "2.19.1",
|
"version": "2.19.1",
|
||||||
@ -5050,9 +5054,10 @@
|
|||||||
"integrity": "sha1-rId6p2qcRTaMl5Rx5GG1INOObPU="
|
"integrity": "sha1-rId6p2qcRTaMl5Rx5GG1INOObPU="
|
||||||
},
|
},
|
||||||
"vxe-table": {
|
"vxe-table": {
|
||||||
"version": "4.0.14",
|
"version": "4.0.15-beta.2",
|
||||||
"resolved": "https://registry.npmjs.org/vxe-table/-/vxe-table-4.0.14.tgz",
|
"resolved": "https://registry.npmjs.org/vxe-table/-/vxe-table-4.0.15-beta.2.tgz",
|
||||||
"integrity": "sha512-0fwddIk7X+NPneZuucvy6BbTmZ9oRfTxP02ZfWOu5c4KegVSFTIxMWlGkDOhtwf67HcA6gh9UwWkyoPiKhvvCQ=="
|
"integrity": "sha512-XbyoVFAbvwnOzCcvNiGpe8vHBCUTwQzv2GBv5HjlzGKEy+e99eEAeIcEzYfXvu4ttIva+5u+at9svwRNKT8EBA==",
|
||||||
|
"requires": {}
|
||||||
},
|
},
|
||||||
"wangeditor": {
|
"wangeditor": {
|
||||||
"version": "4.6.14",
|
"version": "4.6.14",
|
||||||
@ -5086,9 +5091,9 @@
|
|||||||
"integrity": "sha1-N2kPiaN9m19U7yrk79PpJXDzLfM="
|
"integrity": "sha1-N2kPiaN9m19U7yrk79PpJXDzLfM="
|
||||||
},
|
},
|
||||||
"xe-utils": {
|
"xe-utils": {
|
||||||
"version": "3.1.13",
|
"version": "3.2.1",
|
||||||
"resolved": "https://registry.npm.taobao.org/xe-utils/download/xe-utils-3.1.13.tgz",
|
"resolved": "https://registry.npmjs.org/xe-utils/-/xe-utils-3.2.1.tgz",
|
||||||
"integrity": "sha1-6YPu28XoJNEnbOfvB3wFbfsdakk="
|
"integrity": "sha512-NiupDI5mIziz4i152UCk78c/qxYH/TDexGylLj81kxPbrePEg43LQ8hITCbsqpJDTcu9dmXESUtZyQDD1oB0hw=="
|
||||||
},
|
},
|
||||||
"xgplayer": {
|
"xgplayer": {
|
||||||
"version": "2.19.1",
|
"version": "2.19.1",
|
||||||
|
@ -36,7 +36,7 @@
|
|||||||
"vue-types": "^3.0.2",
|
"vue-types": "^3.0.2",
|
||||||
"vuedraggable": "^4.0.1",
|
"vuedraggable": "^4.0.1",
|
||||||
"vuex": "^4.0.0",
|
"vuex": "^4.0.0",
|
||||||
"vxe-table": "^4.0.14",
|
"vxe-table": "^4.0.15-beta.2",
|
||||||
"wangeditor": "^4.0.3",
|
"wangeditor": "^4.0.3",
|
||||||
"xe-ajax": "^4.0.5",
|
"xe-ajax": "^4.0.5",
|
||||||
"xe-utils": "^3.1.12",
|
"xe-utils": "^3.1.12",
|
||||||
|
@ -53,13 +53,16 @@ VXETable.setup({
|
|||||||
version: 0,
|
version: 0,
|
||||||
zIndex: 100,
|
zIndex: 100,
|
||||||
table: {
|
table: {
|
||||||
|
// 自动监听父元素的变化去重新计算表格
|
||||||
autoResize: true,
|
autoResize: true,
|
||||||
|
// 鼠标移到行是否要高亮显示
|
||||||
|
highlightHoverRow: true,
|
||||||
},
|
},
|
||||||
// 对组件内置的提示语进行国际化翻译
|
// 对组件内置的提示语进行国际化翻译
|
||||||
i18n: (key, args) => i18n.global.t(key, args),
|
i18n: (key, args) => i18n.global.t(key, args),
|
||||||
// 可选,对参数中的列头、校验提示..等进行自动翻译(只对支持国际化的有效)
|
// 可选,对参数中的列头、校验提示..等进行自动翻译(只对支持国际化的有效)
|
||||||
translate(key, args) {
|
translate(key, args) {
|
||||||
// 例如,只翻译 "app." 开头的键值
|
// 例如,只翻译 "message." 开头的键值
|
||||||
if (key && key.indexOf("message.") > -1) {
|
if (key && key.indexOf("message.") > -1) {
|
||||||
return i18n.global.t(key, args);
|
return i18n.global.t(key, args);
|
||||||
}
|
}
|
||||||
|
72
src/utils/useCopyToClipboard.ts
Normal file
72
src/utils/useCopyToClipboard.ts
Normal file
@ -0,0 +1,72 @@
|
|||||||
|
import { ref, watch } from "vue";
|
||||||
|
|
||||||
|
import { isDef } from "/@/utils/is";
|
||||||
|
interface Options {
|
||||||
|
target?: HTMLElement;
|
||||||
|
}
|
||||||
|
export function useCopyToClipboard(initial?: string) {
|
||||||
|
const clipboardRef = ref(initial || "");
|
||||||
|
const isSuccessRef = ref(false);
|
||||||
|
const copiedRef = ref(false);
|
||||||
|
|
||||||
|
watch(
|
||||||
|
clipboardRef,
|
||||||
|
(str?: string) => {
|
||||||
|
if (isDef(str)) {
|
||||||
|
copiedRef.value = true;
|
||||||
|
isSuccessRef.value = copyTextToClipboard(str);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{ immediate: !!initial, flush: "sync" }
|
||||||
|
);
|
||||||
|
|
||||||
|
return { clipboardRef, isSuccessRef, copiedRef };
|
||||||
|
}
|
||||||
|
|
||||||
|
export function copyTextToClipboard(
|
||||||
|
input: string,
|
||||||
|
{ target = document.body }: Options = {}
|
||||||
|
) {
|
||||||
|
const element = document.createElement("textarea");
|
||||||
|
const previouslyFocusedElement = document.activeElement;
|
||||||
|
|
||||||
|
element.value = input;
|
||||||
|
|
||||||
|
element.setAttribute("readonly", "");
|
||||||
|
|
||||||
|
(element.style as any).contain = "strict";
|
||||||
|
element.style.position = "absolute";
|
||||||
|
element.style.left = "-9999px";
|
||||||
|
element.style.fontSize = "12pt";
|
||||||
|
|
||||||
|
const selection = document.getSelection();
|
||||||
|
let originalRange;
|
||||||
|
if (selection && selection.rangeCount > 0) {
|
||||||
|
originalRange = selection.getRangeAt(0);
|
||||||
|
}
|
||||||
|
|
||||||
|
target.append(element);
|
||||||
|
element.select();
|
||||||
|
|
||||||
|
element.selectionStart = 0;
|
||||||
|
element.selectionEnd = input.length;
|
||||||
|
|
||||||
|
let isSuccess = false;
|
||||||
|
try {
|
||||||
|
isSuccess = document.execCommand("copy");
|
||||||
|
} catch (e) {
|
||||||
|
throw new Error(e);
|
||||||
|
}
|
||||||
|
|
||||||
|
element.remove();
|
||||||
|
|
||||||
|
if (originalRange && selection) {
|
||||||
|
selection.removeAllRanges();
|
||||||
|
selection.addRange(originalRange);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (previouslyFocusedElement) {
|
||||||
|
(previouslyFocusedElement as HTMLElement).focus();
|
||||||
|
}
|
||||||
|
return isSuccess;
|
||||||
|
}
|
@ -1,15 +1,20 @@
|
|||||||
<template>
|
<template>
|
||||||
<div class="dict-container">
|
<div class="dict-container">
|
||||||
|
<!-- 工具栏 -->
|
||||||
<vxe-toolbar>
|
<vxe-toolbar>
|
||||||
<template #buttons>
|
<template #buttons>
|
||||||
<vxe-input
|
<vxe-input
|
||||||
v-model="demo1.filterName"
|
v-model="dictData.filterName"
|
||||||
:placeholder="$t('message.hssearch')"
|
:placeholder="$t('message.hssearch')"
|
||||||
@keyup="searchEvent"
|
@keyup="searchEvent"
|
||||||
></vxe-input>
|
></vxe-input>
|
||||||
</template>
|
</template>
|
||||||
<template #tools>
|
<template #tools>
|
||||||
<vxe-button icon="el-icon-circle-plus-outline" status="primary">{{$t('message.hsadd')}}</vxe-button>
|
<vxe-button
|
||||||
|
icon="el-icon-circle-plus-outline"
|
||||||
|
status="primary"
|
||||||
|
@click="onAdd"
|
||||||
|
>{{$t('message.hsadd')}}</vxe-button>
|
||||||
<vxe-button
|
<vxe-button
|
||||||
icon="el-icon-folder-opened"
|
icon="el-icon-folder-opened"
|
||||||
status="primary"
|
status="primary"
|
||||||
@ -23,108 +28,75 @@
|
|||||||
</template>
|
</template>
|
||||||
</vxe-toolbar>
|
</vxe-toolbar>
|
||||||
|
|
||||||
|
<!-- 列表 -->
|
||||||
<vxe-table
|
<vxe-table
|
||||||
ref="xTree"
|
ref="xTree"
|
||||||
border
|
border
|
||||||
resizable
|
resizable
|
||||||
:tree-config="{children: 'children', iconOpen: 'fa fa-minus-square-o', iconClose: 'fa fa-plus-square-o'}"
|
:tree-config="{children: 'children', iconOpen: 'fa fa-minus-square-o', iconClose: 'fa fa-plus-square-o'}"
|
||||||
:data="demo1.tableData"
|
:data="dictData.tableData"
|
||||||
@cell-dblclick="cellDBLClickEvent"
|
@cell-dblclick="cellDBLClickEvent"
|
||||||
>
|
>
|
||||||
<vxe-table-column tree-node field="name" title="字典名称"></vxe-table-column>
|
<vxe-table-column tree-node field="name" title="字典名称"></vxe-table-column>
|
||||||
<vxe-table-column field="model" title="字典类型"></vxe-table-column>
|
<vxe-table-column title="字典类型">
|
||||||
|
<template #default="{ row }">
|
||||||
|
<el-tooltip effect="dark" :content="'双击复制:'+row.model" placement="top-end">
|
||||||
|
<span class="text-model">{{ row.model }}</span>
|
||||||
|
</el-tooltip>
|
||||||
|
</template>
|
||||||
|
</vxe-table-column>
|
||||||
<vxe-table-column title="操作" width="330" fixed="right">
|
<vxe-table-column title="操作" width="330" fixed="right">
|
||||||
<template #default="{ row }">
|
<template #default="{ row }">
|
||||||
<vxe-button type="text" icon="el-icon-edit" @click="demo1.value8 = true">编辑</vxe-button>
|
<vxe-button type="text" icon="el-icon-edit" @click="onEdit(row)">编辑</vxe-button>
|
||||||
<vxe-button type="text" icon="el-icon-circle-plus-outline">新增子类型</vxe-button>
|
<vxe-button type="text" icon="el-icon-circle-plus-outline" @click="onAddChild(row)">新增子类型</vxe-button>
|
||||||
<vxe-button v-show="row.model" type="text" icon="el-icon-setting">字典配置</vxe-button>
|
<vxe-button v-show="row.model" type="text" icon="el-icon-setting">字典配置</vxe-button>
|
||||||
<vxe-button type="text" icon="el-icon-delete" @click="confirmEvent">删除</vxe-button>
|
<vxe-button type="text" icon="el-icon-delete" @click="confirmEvent">删除</vxe-button>
|
||||||
</template>
|
</template>
|
||||||
</vxe-table-column>
|
</vxe-table-column>
|
||||||
</vxe-table>
|
</vxe-table>
|
||||||
|
|
||||||
|
<!-- 配置弹框 -->
|
||||||
<vxe-modal
|
<vxe-modal
|
||||||
v-model="demo1.showEdit"
|
|
||||||
:title="demo1.selectRow ? '编辑&保存' : '新增&保存'"
|
|
||||||
width="800"
|
|
||||||
min-width="600"
|
|
||||||
min-height="300"
|
|
||||||
:loading="demo1.submitLoading"
|
|
||||||
resize
|
resize
|
||||||
destroy-on-close
|
width="450"
|
||||||
|
v-model="dictData.showEdit"
|
||||||
|
:title="dictData.selectRow ? '编辑' : '新增'"
|
||||||
|
:loading="dictData.submitLoading"
|
||||||
|
@hide="$refs.xForm.reset();"
|
||||||
>
|
>
|
||||||
<template #default>
|
<template #default>
|
||||||
<vxe-form
|
<vxe-form
|
||||||
:data="demo1.formData"
|
ref="xForm"
|
||||||
:items="demo1.formItems"
|
:data="dictData.formData"
|
||||||
:rules="demo1.formRules"
|
:items="dictData.formItems"
|
||||||
title-align="right"
|
title-align="right"
|
||||||
title-width="100"
|
title-width="100"
|
||||||
@submit="demo1.submitEvent"
|
@submit="dictData.submitEvent"
|
||||||
></vxe-form>
|
></vxe-form>
|
||||||
</template>
|
</template>
|
||||||
</vxe-modal>
|
</vxe-modal>
|
||||||
<!-- <vxe-modal
|
|
||||||
v-model="demo1.value8"
|
|
||||||
title="记忆功能的窗口"
|
|
||||||
width="440"
|
|
||||||
height="230"
|
|
||||||
show-zoom
|
|
||||||
resize
|
|
||||||
remember
|
|
||||||
>
|
|
||||||
<template #default>
|
|
||||||
<vxe-form>
|
|
||||||
<vxe-form-item span="24">
|
|
||||||
<template #default>
|
|
||||||
<vxe-form
|
|
||||||
:data="demo1.formData3"
|
|
||||||
:rules="demo1.formRules3"
|
|
||||||
title-align="right"
|
|
||||||
title-width="80"
|
|
||||||
>
|
|
||||||
<vxe-form-item
|
|
||||||
title="字典名称"
|
|
||||||
field="name"
|
|
||||||
span="24"
|
|
||||||
:item-render="{name: 'input', attrs: {placeholder: '请输入字典名称'}}"
|
|
||||||
></vxe-form-item>
|
|
||||||
<vxe-form-item
|
|
||||||
title="字典类型"
|
|
||||||
field="nickname"
|
|
||||||
span="24"
|
|
||||||
:item-render="{name: 'input', attrs: {placeholder: '请输入字典类型'}}"
|
|
||||||
></vxe-form-item>
|
|
||||||
<vxe-form-item align="right" span="24">
|
|
||||||
<template #default>
|
|
||||||
<vxe-button @click="demo1.value8 = false">取消</vxe-button>
|
|
||||||
<vxe-button status="primary" @click="onEdit">保存</vxe-button>
|
|
||||||
</template>
|
|
||||||
</vxe-form-item>
|
|
||||||
</vxe-form>
|
|
||||||
</template>
|
|
||||||
</vxe-form-item>
|
|
||||||
</vxe-form>
|
|
||||||
</template>
|
|
||||||
</vxe-modal>-->
|
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
<script lang="ts">
|
<script lang="ts">
|
||||||
import { reactive, ref, nextTick } from "vue";
|
import { reactive, ref, unref, nextTick } from "vue";
|
||||||
import XEUtils from "xe-utils";
|
import XEUtils from "xe-utils";
|
||||||
import { cloneDeep } from "lodash-es";
|
import { cloneDeep } from "lodash-es";
|
||||||
import { templateRef } from "@vueuse/core";
|
import { templateRef } from "@vueuse/core";
|
||||||
|
import { useCopyToClipboard } from "/@/utils/useCopyToClipboard";
|
||||||
import {
|
import {
|
||||||
VxeTablePropTypes,
|
|
||||||
VxeTableInstance,
|
|
||||||
VXETable,
|
VXETable,
|
||||||
VxeTableEvents
|
VxeTableInstance,
|
||||||
|
VxeTableEvents,
|
||||||
|
VxeTablePropTypes,
|
||||||
|
VxeFormPropTypes
|
||||||
} from "vxe-table";
|
} from "vxe-table";
|
||||||
|
|
||||||
export default {
|
export default {
|
||||||
setup() {
|
setup() {
|
||||||
const demo1 = reactive({
|
const dictData = reactive({
|
||||||
|
submitLoading: false,
|
||||||
showEdit: false,
|
showEdit: false,
|
||||||
|
selectRow: null,
|
||||||
filterName: "",
|
filterName: "",
|
||||||
tableData: [
|
tableData: [
|
||||||
{
|
{
|
||||||
@ -145,26 +117,65 @@ export default {
|
|||||||
]
|
]
|
||||||
},
|
},
|
||||||
{ id: 2, name: "操作系统", model: "operatingSystem" }
|
{ id: 2, name: "操作系统", model: "operatingSystem" }
|
||||||
|
],
|
||||||
|
formData: {
|
||||||
|
name: "",
|
||||||
|
model: ""
|
||||||
|
},
|
||||||
|
formItems: [
|
||||||
|
{
|
||||||
|
field: "name",
|
||||||
|
title: "字典名称",
|
||||||
|
span: 24,
|
||||||
|
itemRender: {
|
||||||
|
name: "$input",
|
||||||
|
props: { placeholder: "请输入字典名称", clearable: true }
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
field: "model",
|
||||||
|
title: "字典类型",
|
||||||
|
span: 24,
|
||||||
|
itemRender: {
|
||||||
|
name: "$input",
|
||||||
|
props: {
|
||||||
|
placeholder: "请输入字典类型",
|
||||||
|
//这里vxe-table文档并没有提到,可以配置所选组件的所有属性,比如这里可以配置关于vxe-input的所有属性
|
||||||
|
disabled: true,
|
||||||
|
clearable: true
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
align: "right",
|
||||||
|
span: 24,
|
||||||
|
itemRender: {
|
||||||
|
name: "$buttons",
|
||||||
|
children: [
|
||||||
|
{ props: { type: "submit", content: "提交", status: "primary" } },
|
||||||
|
{ props: { type: "reset", content: "重置" } }
|
||||||
]
|
]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
] as VxeFormPropTypes.Items
|
||||||
});
|
});
|
||||||
|
|
||||||
let originData = cloneDeep(demo1.tableData);
|
let originData = cloneDeep(dictData.tableData);
|
||||||
|
|
||||||
const xTree = templateRef<HTMLElement | null>("xTree", null);
|
const xTree = templateRef<HTMLElement | any>("xTree", null);
|
||||||
// const = ref({} as VxeTableInstance);
|
|
||||||
|
|
||||||
const formatDate = (value: any) => {
|
const formatDate = (value: any) => {
|
||||||
return XEUtils.toDateString(value, "yyyy-MM-dd HH:mm:ss.S");
|
return XEUtils.toDateString(value, "yyyy-MM-dd HH:mm:ss.S");
|
||||||
};
|
};
|
||||||
|
|
||||||
const handleSearch = () => {
|
const handleSearch = () => {
|
||||||
const filterName = XEUtils.toValueString(demo1.filterName).trim();
|
const filterName = XEUtils.toValueString(dictData.filterName).trim();
|
||||||
|
|
||||||
if (filterName) {
|
if (filterName) {
|
||||||
const options = { children: "children" };
|
const options = { children: "children" };
|
||||||
const searchProps = ["name"];
|
const searchProps = ["name"];
|
||||||
|
|
||||||
demo1.tableData = XEUtils.searchTree(
|
dictData.tableData = XEUtils.searchTree(
|
||||||
originData,
|
originData,
|
||||||
item =>
|
item =>
|
||||||
searchProps.some(
|
searchProps.some(
|
||||||
@ -179,7 +190,7 @@ export default {
|
|||||||
$table.setAllTreeExpand(true);
|
$table.setAllTreeExpand(true);
|
||||||
});
|
});
|
||||||
} else {
|
} else {
|
||||||
demo1.tableData = originData;
|
dictData.tableData = originData;
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -201,29 +212,74 @@ export default {
|
|||||||
});
|
});
|
||||||
};
|
};
|
||||||
|
|
||||||
function onEdit() {
|
function commonFn(value, disabled) {
|
||||||
demo1.value8 = false;
|
dictData.selectRow = value;
|
||||||
VXETable.modal.message({
|
dictData.showEdit = true;
|
||||||
content: "测试数据,不可编辑",
|
dictData.formItems[1].itemRender.props.disabled = disabled;
|
||||||
status: "error"
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
|
|
||||||
const cellDBLClickEvent: VxeTableEvents.CellDblclick = ({ row }) => {
|
// 新增
|
||||||
|
function onAdd() {
|
||||||
|
commonFn(null, false);
|
||||||
|
}
|
||||||
|
|
||||||
|
// 新增子类型
|
||||||
|
function onAddChild(row: any) {
|
||||||
console.log(
|
console.log(
|
||||||
"%crow===>>>: ",
|
"%crow===>>>: ",
|
||||||
"color: MidnightBlue; background: Aquamarine; font-size: 20px;",
|
"color: MidnightBlue; background: Aquamarine; font-size: 20px;",
|
||||||
row
|
row
|
||||||
);
|
);
|
||||||
|
commonFn(null, false);
|
||||||
|
}
|
||||||
|
|
||||||
|
// 编辑
|
||||||
|
function onEdit(row: any) {
|
||||||
|
dictData.formData = {
|
||||||
|
name: row.name,
|
||||||
|
model: row.model ? row.model : "暂无字典类型"
|
||||||
|
};
|
||||||
|
commonFn(row, true);
|
||||||
|
// VXETable.modal.message({
|
||||||
|
// content: "测试数据,不可编辑",
|
||||||
|
// status: "error"
|
||||||
|
// });
|
||||||
|
}
|
||||||
|
|
||||||
|
// 拷贝当前列表项的数据(字典类型)
|
||||||
|
const { clipboardRef } = useCopyToClipboard();
|
||||||
|
const cellDBLClickEvent: VxeTableEvents.CellDblclick = ({ row }) => {
|
||||||
|
clipboardRef.value = unref(row).model;
|
||||||
|
};
|
||||||
|
|
||||||
|
const xTable = ref({} as VxeTableInstance);
|
||||||
|
|
||||||
|
const submitEvent = () => {
|
||||||
|
dictData.submitLoading = true;
|
||||||
|
setTimeout(() => {
|
||||||
|
const $table = xTable.value;
|
||||||
|
dictData.submitLoading = false;
|
||||||
|
dictData.showEdit = false;
|
||||||
|
if (dictData.selectRow) {
|
||||||
|
VXETable.modal.message({ content: "保存成功", status: "success" });
|
||||||
|
Object.assign(dictData.selectRow, dictData.formData);
|
||||||
|
} else {
|
||||||
|
VXETable.modal.message({ content: "新增成功", status: "success" });
|
||||||
|
$table.insert(dictData.formData);
|
||||||
|
}
|
||||||
|
}, 500);
|
||||||
};
|
};
|
||||||
|
|
||||||
return {
|
return {
|
||||||
demo1,
|
dictData,
|
||||||
formatDate,
|
formatDate,
|
||||||
searchEvent,
|
searchEvent,
|
||||||
confirmEvent,
|
confirmEvent,
|
||||||
|
cellDBLClickEvent,
|
||||||
|
submitEvent,
|
||||||
onEdit,
|
onEdit,
|
||||||
cellDBLClickEvent
|
onAddChild,
|
||||||
|
onAdd
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
@ -244,4 +300,9 @@ export default {
|
|||||||
.vxe-button.size--medium.type--button {
|
.vxe-button.size--medium.type--button {
|
||||||
margin-right: 0.07em;
|
margin-right: 0.07em;
|
||||||
}
|
}
|
||||||
|
.text-model {
|
||||||
|
&:hover {
|
||||||
|
cursor: pointer;
|
||||||
|
}
|
||||||
|
}
|
||||||
</style>
|
</style>
|
@ -15,7 +15,8 @@ const { VITE_PORT, VITE_PUBLIC_PATH, VITE_PROXY, VITE_OPEN } = loadEnv();
|
|||||||
|
|
||||||
const alias: Record<string, string> = {
|
const alias: Record<string, string> = {
|
||||||
"/@": pathResolve("src"),
|
"/@": pathResolve("src"),
|
||||||
"vue-i18n": "vue-i18n/dist/vue-i18n.cjs.js", //解决警告You are running the esm-bundler build of vue-i18n. It is recommended to configure your bundler to explicitly replace feature flag globals with boolean literals to get proper tree-shaking in the final bundle.
|
//解决开发环境下的警告 You are running the esm-bundler build of vue-i18n. It is recommended to configure your bundler to explicitly replace feature flag globals with boolean literals to get proper tree-shaking in the final bundle.
|
||||||
|
"vue-i18n": "vue-i18n/dist/vue-i18n.cjs.js",
|
||||||
};
|
};
|
||||||
|
|
||||||
const root: string = process.cwd();
|
const root: string = process.cwd();
|
||||||
|
Loading…
x
Reference in New Issue
Block a user