提交 f891f28a 编写于 作者: ibizdev's avatar ibizdev

lxm1993 发布系统代码 [TrainSys,网页端]

上级 4056b098
因为 它太大了无法显示 源差异 。您可以改为 查看blob
...@@ -12,14 +12,14 @@ ...@@ -12,14 +12,14 @@
}, },
"dependencies": { "dependencies": {
"@floating-ui/dom": "^1.0.4", "@floating-ui/dom": "^1.0.4",
"@ibiz-template/command": "^0.0.1-alpha.44", "@ibiz-template/command": "^0.0.1-beta.1",
"@ibiz-template/controller": "^0.0.1-alpha.44", "@ibiz-template/controller": "^0.0.1-beta.1",
"@ibiz-template/core": "^0.0.1-alpha.44", "@ibiz-template/core": "^0.0.1-beta.1",
"@ibiz-template/model": "^0.0.1-alpha.44", "@ibiz-template/model": "^0.0.1-beta.1",
"@ibiz-template/runtime": "^0.0.1-alpha.44", "@ibiz-template/runtime": "^0.0.1-beta.1",
"@ibiz-template/service": "^0.0.1-alpha.44", "@ibiz-template/service": "^0.0.1-beta.1",
"@ibiz-template/theme": "^0.0.1-alpha.44", "@ibiz-template/theme": "^0.0.1-beta.1",
"@ibiz-template/vue-util": "^0.0.1-alpha.44", "@ibiz-template/vue-util": "^0.0.1-beta.1",
"@ibiz/dynamic-model-api": "^2.1.5", "@ibiz/dynamic-model-api": "^2.1.5",
"dayjs": "^1.11.6", "dayjs": "^1.11.6",
"lodash-es": "^4.17.21", "lodash-es": "^4.17.21",
......
...@@ -101,6 +101,7 @@ import { ...@@ -101,6 +101,7 @@ import {
IBizGridDropdown, IBizGridDropdown,
IBizGridRadio, IBizGridRadio,
IBizGridPicker, IBizGridPicker,
GridEditor,
} from './components/editor'; } from './components/editor';
export const AppRegister = { export const AppRegister = {
...@@ -178,6 +179,7 @@ export const AppRegister = { ...@@ -178,6 +179,7 @@ export const AppRegister = {
v.component('DataImport', DataImport); v.component('DataImport', DataImport);
v.component('DataExport', DataExport); v.component('DataExport', DataExport);
// 注册编辑器组件 // 注册编辑器组件
v.component('GridEditor', GridEditor);
v.component('IBizSpan', IBizSpan); v.component('IBizSpan', IBizSpan);
v.component('IBizInput', IBizInput); v.component('IBizInput', IBizInput);
v.component('IBizInputNumber', IBizInputNumber); v.component('IBizInputNumber', IBizInputNumber);
......
...@@ -26,23 +26,22 @@ export const IBizGridCheckbox = defineComponent({ ...@@ -26,23 +26,22 @@ export const IBizGridCheckbox = defineComponent({
}, },
render(h) { render(h) {
return ( return (
<div <grid-editor
disabled={this.disabled}
ref='componentRef' ref='componentRef'
class={`${this.ns.b()} ibiz-grid-editor`} class={`${this.ns.b()}`}
onDblclick={evt => evt.stopPropagation()}
onClick={evt => evt.stopPropagation()}
> >
{h('IBizCheckbox', { {h('IBizCheckbox', {
props: { props: {
...this.$props, ...this.$props,
infoMode: this.isInfoMode, infoMode: this.disabled || this.isInfoMode,
}, },
on: { on: {
change: this.onChange, change: this.onChange,
operate: this.onOperateChange, operate: this.onOperateChange,
}, },
})} })}
</div> </grid-editor>
); );
}, },
}); });
...@@ -43,24 +43,23 @@ export const IBizGridPicker = defineComponent({ ...@@ -43,24 +43,23 @@ export const IBizGridPicker = defineComponent({
}, },
render(h) { render(h) {
return ( return (
<div <grid-editor
disabled={this.disabled}
ref='componentRef' ref='componentRef'
class={`${this.ns.b()} ibiz-grid-editor`} class={`${this.ns.b()}`}
onDblclick={evt => evt.stopPropagation()}
onClick={evt => evt.stopPropagation()}
> >
{this.provider && {this.provider &&
h(this.provider.formEditor, { h(this.provider.formEditor, {
props: { props: {
...this.$props, ...this.$props,
infoMode: this.isInfoMode, infoMode: this.disabled || this.isInfoMode,
}, },
on: { on: {
change: this.onChange, change: this.onChange,
operate: this.onOperateChange, operate: this.onOperateChange,
}, },
})} })}
</div> </grid-editor>
); );
}, },
}); });
...@@ -47,7 +47,8 @@ export const IBizDatePicker = defineComponent({ ...@@ -47,7 +47,8 @@ export const IBizDatePicker = defineComponent({
watch( watch(
() => props.value, () => props.value,
(newVal, oldVal) => { (newVal, oldVal) => {
if (newVal !== oldVal) { // 空值不转换
if (newVal && newVal !== oldVal) {
formatValue.value = dayjs(newVal).format(valueFormat); formatValue.value = dayjs(newVal).format(valueFormat);
} }
}, },
......
...@@ -25,16 +25,15 @@ export const IBizGridDatePicker = defineComponent({ ...@@ -25,16 +25,15 @@ export const IBizGridDatePicker = defineComponent({
}, },
render(h) { render(h) {
return ( return (
<div <grid-editor
disabled={this.disabled}
ref='componentRef' ref='componentRef'
class={`${this.ns.b()} ibiz-grid-editor`} class={`${this.ns.b()}`}
onDblclick={evt => evt.stopPropagation()}
onClick={evt => evt.stopPropagation()}
> >
{h('IBizDatePicker', { {h('IBizDatePicker', {
props: { props: {
...this.$props, ...this.$props,
infoMode: this.isInfoMode, infoMode: this.disabled || this.isInfoMode,
autoFocus: true, autoFocus: true,
}, },
on: { on: {
...@@ -42,7 +41,7 @@ export const IBizGridDatePicker = defineComponent({ ...@@ -42,7 +41,7 @@ export const IBizGridDatePicker = defineComponent({
operate: this.onOperateChange, operate: this.onOperateChange,
}, },
})} })}
</div> </grid-editor>
); );
}, },
}); });
...@@ -25,16 +25,15 @@ export const IBizGridDropdown = defineComponent({ ...@@ -25,16 +25,15 @@ export const IBizGridDropdown = defineComponent({
}, },
render(h) { render(h) {
return ( return (
<div <grid-editor
disabled={this.disabled}
ref='componentRef' ref='componentRef'
class={`${this.ns.b()} ibiz-grid-editor`} class={`${this.ns.b()}`}
onDblclick={evt => evt.stopPropagation()}
onClick={evt => evt.stopPropagation()}
> >
{h('IBizDropdown', { {h('IBizDropdown', {
props: { props: {
...this.$props, ...this.$props,
infoMode: this.isInfoMode, infoMode: this.disabled || this.isInfoMode,
autoFocus: true, autoFocus: true,
}, },
on: { on: {
...@@ -42,7 +41,7 @@ export const IBizGridDropdown = defineComponent({ ...@@ -42,7 +41,7 @@ export const IBizGridDropdown = defineComponent({
operate: this.onOperateChange, operate: this.onOperateChange,
}, },
})} })}
</div> </grid-editor>
); );
}, },
}); });
import { useNamespace } from '@ibiz-template/vue-util';
import { defineComponent } from 'vue';
import '@ibiz-template/theme/style/components/widgets/grid/grid-editor.scss';
export const GridEditor = defineComponent({
name: 'GridEditor',
props: {
disabled: {
type: Boolean,
},
},
setup() {
const ns = useNamespace('grid-editor');
return { ns };
},
render() {
return (
<div
class={[this.ns.b(), !this.disabled ? this.ns.m('editable') : '']}
onDblclick={evt => evt.stopPropagation()}
onClick={evt => evt.stopPropagation()}
>
{this.$slots.default}
</div>
);
},
});
export default GridEditor;
export * from './grid-editor/grid-editor';
export * from './span'; export * from './span';
export * from './text-box'; export * from './text-box';
export * from './check-box-list'; export * from './check-box-list';
......
...@@ -25,23 +25,22 @@ export const IBizGridRadio = defineComponent({ ...@@ -25,23 +25,22 @@ export const IBizGridRadio = defineComponent({
}, },
render(h) { render(h) {
return ( return (
<div <grid-editor
disabled={this.disabled}
ref='componentRef' ref='componentRef'
class={`${this.ns.b()} ibiz-grid-editor`} class={`${this.ns.b()}`}
onDblclick={evt => evt.stopPropagation()}
onClick={evt => evt.stopPropagation()}
> >
{h('IBizRadio', { {h('IBizRadio', {
props: { props: {
...this.$props, ...this.$props,
infoMode: this.isInfoMode, infoMode: this.disabled || this.isInfoMode,
}, },
on: { on: {
change: this.onChange, change: this.onChange,
operate: this.onOperateChange, operate: this.onOperateChange,
}, },
})} })}
</div> </grid-editor>
); );
}, },
}); });
...@@ -25,16 +25,15 @@ export const IBizGridInputNumber = defineComponent({ ...@@ -25,16 +25,15 @@ export const IBizGridInputNumber = defineComponent({
}, },
render(h) { render(h) {
return ( return (
<div <grid-editor
disabled={this.disabled}
ref='componentRef' ref='componentRef'
class={`${this.ns.b()} ibiz-grid-editor`} class={`${this.ns.b()}`}
onDblclick={evt => evt.stopPropagation()}
onClick={evt => evt.stopPropagation()}
> >
{h('IBizInputNumber', { {h('IBizInputNumber', {
props: { props: {
...this.$props, ...this.$props,
infoMode: this.isInfoMode, infoMode: this.disabled || this.isInfoMode,
autoFocus: true, autoFocus: true,
}, },
on: { on: {
...@@ -42,7 +41,7 @@ export const IBizGridInputNumber = defineComponent({ ...@@ -42,7 +41,7 @@ export const IBizGridInputNumber = defineComponent({
operate: this.onOperateChange, operate: this.onOperateChange,
}, },
})} })}
</div> </grid-editor>
); );
}, },
}); });
...@@ -25,16 +25,15 @@ export const IBizGridInput = defineComponent({ ...@@ -25,16 +25,15 @@ export const IBizGridInput = defineComponent({
}, },
render(h) { render(h) {
return ( return (
<div <grid-editor
disabled={this.disabled}
ref='componentRef' ref='componentRef'
class={`${this.ns.b()} ibiz-grid-editor`} class={`${this.ns.b()}`}
onDblclick={evt => evt.stopPropagation()}
onClick={evt => evt.stopPropagation()}
> >
{h('IBizInput', { {h('IBizInput', {
props: { props: {
...this.$props, ...this.$props,
infoMode: this.isInfoMode, infoMode: this.disabled || this.isInfoMode,
autoFocus: true, autoFocus: true,
}, },
on: { on: {
...@@ -42,7 +41,7 @@ export const IBizGridInput = defineComponent({ ...@@ -42,7 +41,7 @@ export const IBizGridInput = defineComponent({
operate: this.onOperateChange, operate: this.onOperateChange,
}, },
})} })}
</div> </grid-editor>
); );
}, },
}); });
...@@ -52,6 +52,9 @@ export const IBizInputNumber = defineComponent({ ...@@ -52,6 +52,9 @@ export const IBizInputNumber = defineComponent({
render() { render() {
return ( return (
<div class={this.ns.b()}> <div class={this.ns.b()}>
{this.infoMode ? (
this.currentVal
) : (
<i-input-number <i-input-number
ref='inputRef' ref='inputRef'
value={this.currentVal} value={this.currentVal}
...@@ -60,6 +63,7 @@ export const IBizInputNumber = defineComponent({ ...@@ -60,6 +63,7 @@ export const IBizInputNumber = defineComponent({
precision={this.c.model.precision} precision={this.c.model.precision}
on-on-change={this.handleChange} on-on-change={this.handleChange}
></i-input-number> ></i-input-number>
)}
</div> </div>
); );
}, },
......
import { getCookie } from 'qx-util'; import { defineComponent } from 'vue';
import { onMounted, ref, Ref, watch, defineComponent } from 'vue';
import { import {
getEditorEmits, getEditorEmits,
getUploadProps, getUploadProps,
useNamespace, useNamespace,
} from '@ibiz-template/vue-util'; } from '@ibiz-template/vue-util';
import { RuntimeError } from '@ibiz-template/core';
import '@ibiz-template/theme/style/components/editor/ibiz-file-upload/ibiz-file-upload.scss'; import '@ibiz-template/theme/style/components/editor/ibiz-file-upload/ibiz-file-upload.scss';
import { useIViewUpload } from '../use/use-iview-upload';
export const IBizFileUpload = defineComponent({ export const IBizFileUpload = defineComponent({
name: 'IBizFileUpload', name: 'IBizFileUpload',
...@@ -16,269 +15,23 @@ export const IBizFileUpload = defineComponent({ ...@@ -16,269 +15,23 @@ export const IBizFileUpload = defineComponent({
const ns = useNamespace('file-upload'); const ns = useNamespace('file-upload');
const c = props.controller; const c = props.controller;
// 文件列表 const {
const files: Ref<IData[]> = ref([]); uploadUrl,
headers,
// 请求头 files,
const headers: Ref<IData> = ref({}); onDownload,
onError,
// 上传文件路径 onRemove,
const uploadUrl: Ref<string> = ref(ibiz.env.baseUrl + ibiz.env.UploadFile); onSuccess,
beforeUpload,
// 下载文件路径 } = useIViewUpload(
const downloadUrl: Ref<string> = ref(ibiz.env.ExportFile); props,
value => {
// 设置files
const setFiles = (value: string | null | undefined) => {
if (value === null) {
files.value = [];
}
if (!value) {
return;
}
const _files = JSON.parse(value);
if (
value &&
Object.prototype.toString.call(_files) === '[object Array]'
) {
files.value = _files;
} else {
files.value = [];
}
};
// 文件上传缓存对象
const uploadCache: IData = {
count: 0,
cacheFiles: [],
};
// 处理参数
const dataProcess = () => {
let _url = ibiz.env.baseUrl + ibiz.env.UploadFile;
if (c.upload_params.length > 0) {
_url += '?';
c.upload_params.forEach((item: IData, i: number) => {
_url += `${Object.keys(item)[0]}=${Object.values(item)[0]}`;
if (i < c.upload_params.length - 1) {
_url += '&';
}
});
}
uploadUrl.value = _url;
files.value.forEach((file: IData) => {
let url = `${downloadUrl.value}/${file.id}`;
if (c.export_params.length > 0) {
url += '?';
c.export_params.forEach((item: IData, i: number) => {
url += `${Object.keys(item)[0]}=${Object.values(item)[0]}`;
if (i < c.export_params.length - 1) {
url += '&';
}
});
}
// eslint-disable-next-line no-param-reassign
file.url = url;
});
};
// 设置头
const setHeaders = () => {
if (getCookie('access_token')) {
headers.value.Authorization = `Bearer ${getCookie('access_token')}`;
}
};
setHeaders();
watch(
() => props.value,
newVal => {
setFiles(newVal);
dataProcess();
},
{ immediate: true },
);
watch(
() => props.data,
newVal => {
c.getParams(newVal!);
},
{ immediate: true, deep: true },
);
onMounted(() => {
c.getParams(props.data!);
setFiles(props.value);
dataProcess();
});
// 上传前回调
const beforeUpload = () => {
uploadCache.count += 1;
};
// 上传成功回调
const onSuccess = (response: IData) => {
if (!response) {
return;
}
// 处理回调数据,并缓存
const arr: IData[] = [];
if (response?.length > 0) {
for (let index = 0; index < response.length; index++) {
const file = response[index];
arr.push({ name: file.filename, id: file.fileid });
}
} else {
arr.push({ name: response.filename, id: response.fileid });
}
uploadCache.cacheFiles.push(arr);
uploadCache.count -= 1;
// 回调都结束后的处理
if (uploadCache.count === 0) {
const result: IData[] = [];
// 添加已有的文件数据
files.value.forEach((_file: IData) => {
result.push({ name: _file.name, id: _file.id });
});
// 添加缓存的文件数据
uploadCache.cacheFiles.forEach((item: IData[]) => {
result.push(...item);
});
// 抛出值变更事件
const value: string | null =
result.length > 0 ? JSON.stringify(result) : null;
emit('change', value);
// 清空缓存的文件数据
uploadCache.cacheFiles = [];
}
};
// 上传失败回调
const onError = (error: IData) => {
uploadCache.count -= 1;
throw error;
};
// 删除回调
const onRemove = (file: IData, fileList: IData[]) => {
const arr: Array<IData> = [];
fileList.forEach((f: IData) => {
if (f.id !== file.id) {
arr.push({ name: f.name, id: f.id });
}
});
const value: string | null = arr.length > 0 ? JSON.stringify(arr) : null;
emit('change', value); emit('change', value);
};
// 计算文件mime类型
const calcFilemime = (filetype: string) => {
let mime = 'image/png';
switch (filetype) {
case '.wps':
mime = 'application/kswps';
break;
case '.doc':
mime = 'application/msword';
break;
case '.docx':
mime =
'application/vnd.openxmlformats-officedocument.wordprocessingml.document';
break;
case '.txt':
mime = 'text/plain';
break;
case '.zip':
mime = 'application/zip';
break;
case '.png':
mime = 'image/png';
break;
case '.gif':
mime = 'image/gif';
break;
case '.jpeg':
mime = 'image/jpeg';
break;
case '.jpg':
mime = 'image/jpeg';
break;
case '.rtf':
mime = 'application/rtf';
break;
case '.avi':
mime = 'video/x-msvideo';
break;
case '.gz':
mime = 'application/x-gzip';
break;
case '.tar':
mime = 'application/x-tar';
break;
default:
mime = 'image/png';
}
return mime;
};
/**
* 下载文件
*/
const DownloadFile = (url: string, file: IData) => {
// 发送get请求
ibiz.net
.get(
url,
{},
{},
{
responseType: 'blob',
}, },
) c,
.then((response: IData) => { );
if (!response || response.status !== 200) {
throw new RuntimeError('下载文件失败');
}
// 请求成功,后台返回的是一个文件流
if (response.data) {
// 获取文件名
const filename = file.name;
const ext = `.${filename.split('.').pop()}`;
const filetype = calcFilemime(ext);
// 用blob对象获取文件流
const blob = new Blob([response.data], { type: filetype });
// 通过文件流创建下载链接
const href = URL.createObjectURL(blob);
// 创建一个a元素并设置相关属性
const a = document.createElement('a');
a.href = href;
a.download = filename;
// 添加a元素到当前网页
document.body.appendChild(a);
// 触发a元素的点击事件,实现下载
a.click();
// 从当前网页移除a元素
document.body.removeChild(a);
// 释放blob对象
URL.revokeObjectURL(href);
} else {
throw new RuntimeError('文件流数据不存在');
}
});
};
// 下载文件
const onDownload = (file: IData) => {
const url = `${downloadUrl.value}/${file.id}`;
DownloadFile(url, file);
};
return { return {
ns, ns,
c, c,
...@@ -305,9 +58,9 @@ export const IBizFileUpload = defineComponent({ ...@@ -305,9 +58,9 @@ export const IBizFileUpload = defineComponent({
action: this.uploadUrl, action: this.uploadUrl,
headers: this.headers, headers: this.headers,
'default-file-list': this.files, 'default-file-list': this.files,
multiple: this.c.multiple, multiple: this.c.model.multiple,
type: this.c.isDrag ? 'drag' : 'select', type: this.c.model.isDrag ? 'drag' : 'select',
accept: this.c.accept, accept: this.c.model.accept,
'before-upload': this.beforeUpload, 'before-upload': this.beforeUpload,
'on-success': this.onSuccess, 'on-success': this.onSuccess,
'on-error': this.onError, 'on-error': this.onError,
......
import { useClickOutside, useNamespace } from '@ibiz-template/vue-util';
import { defineComponent, ref, watch } from 'vue';
import { IBizUpload, UploadFile } from '../ibiz-upload/ibiz-upload';
export const IBizGridFileUploadPopover = defineComponent({
name: 'IBizGridFileUploadPopover',
props: {
uploadUrl: {
type: String,
required: true,
},
downloadUrl: {
type: String,
required: true,
},
value: {
type: Array<{
name: string;
id: string;
url: string;
}>,
required: true,
},
},
emits: {
close: (_result: { isModified: boolean; resultFiles: UploadFile[] }) =>
true,
},
setup(props, { emit }) {
const ns = useNamespace('grid-upload');
const upload = ref();
const componentRef = ref();
const isModified = ref(false);
const fileList = ref<UploadFile[]>([]);
// 点击外部处理
useClickOutside(componentRef, async _evt => {
emit('close', {
isModified: isModified.value,
resultFiles: fileList.value,
});
});
// 值响应式变更
watch(
() => props.value,
newVal => {
fileList.value = newVal.map(item => {
return { ...item, status: 'finished', percentage: 100 };
});
},
{ immediate: true },
);
const onFinish = (files: UploadFile[]) => {
fileList.value.push(...files);
isModified.value = true;
};
const selectFile = () => {
upload.value.selectFile();
};
const deleteFile = (file: UploadFile) => {
const index = fileList.value.findIndex(item => item.id === file.id);
fileList.value.splice(index, 1);
isModified.value = true;
};
return {
ns,
componentRef,
upload,
fileList,
onFinish,
selectFile,
deleteFile,
};
},
render() {
return (
<div
ref='componentRef'
style={'width:300px;height:200px'}
class={this.ns.b()}
>
<IBizUpload
ref='upload'
uploadUrl={this.uploadUrl}
downloadUrl={this.downloadUrl}
multiple={true}
on-finish={this.onFinish}
></IBizUpload>
<div class={this.ns.b('list')}>
{this.fileList.map(file => {
return (
<div class={this.ns.be('list', 'item')}>
<div class={this.ns.be('list', 'info')}>
<a
class={this.ns.be('list', 'file-name')}
href={file.url}
download={file.name}
>
{file.name}
</a>
<div class={this.ns.be('list', 'actions')}>
<i-icon
onClick={() => this.deleteFile(file)}
type='md-close'
/>
</div>
</div>
</div>
);
})}
</div>
<i-button
type='text'
onClick={this.selectFile}
class={this.ns.e('add-button')}
>
<i-icon type='md-add' />
添加文件
</i-button>
</div>
);
},
});
import { defineComponent, onMounted, ref, watch } from 'vue'; /* eslint-disable no-param-reassign */
import { getGridUploadProps, useNamespace } from '@ibiz-template/vue-util';
import { getCookie } from 'qx-util';
import { RuntimeError } from '@ibiz-template/core'; import { RuntimeError } from '@ibiz-template/core';
import {
getGridUploadProps,
useGridCellEditor,
useNamespace,
} from '@ibiz-template/vue-util';
import { CreateElement, defineComponent, ref, Ref, watch } from 'vue';
import { UploadFile } from '../ibiz-upload/ibiz-upload';
import { IBizGridFileUploadPopover } from './ibiz-grid-file-upload-popover';
export const IBizGridFileUpload = defineComponent({ export const IBizGridFileUpload = defineComponent({
name: 'IBizGridFileUpload', name: 'IBizGridFileUpload',
props: getGridUploadProps(), props: getGridUploadProps(),
setup(props) { setup(props) {
const ns = useNamespace('grid-file-upload'); const ns = useNamespace('grid-upload');
const c = props.controller;
// 文件列表
const files = ref<IData[]>([]);
// 请求头
const headers = ref<IData>({});
// 上传文件路径 // 上传文件路径
const uploadUrl = ref<string>(ibiz.env.baseUrl + ibiz.env.UploadFile); const uploadUrl: Ref<string> = ref('');
// 下载文件路径 // 下载文件路径
const downloadUrl = ref<string>(ibiz.env.baseUrl + ibiz.env.ExportFile); const downloadUrl: Ref<string> = ref('');
// 模态框是否显示
const dialogVisible = ref<boolean>(false);
// 行为是否显示
const showActions = ref<boolean>(false);
const onDialogVisibleChange = (value: boolean) => {
dialogVisible.value = value;
};
// 设置files
const setFiles = (value: string | null | undefined) => {
if (value === null) {
files.value = [];
}
if (!value) {
return;
}
const _files = JSON.parse(value);
if (
value &&
Object.prototype.toString.call(_files) === '[object Array]'
) {
files.value = _files;
} else {
files.value = [];
}
};
// 文件上传缓存对象
const uploadCache: IData = {
count: 0,
cacheFiles: [],
};
// 处理参数 // 文件列表
const dataProcess = () => { const fileList: Ref<UploadFile[]> = ref([]);
let _url = ibiz.env.baseUrl + ibiz.env.UploadFile;
if (c.upload_params.length > 0) {
_url += '?';
c.upload_params.forEach((item: IData, i: number) => {
_url += `${Object.keys(item)[0]}=${Object.values(item)[0]}`;
if (i < c.upload_params.length - 1) {
_url += '&';
}
});
}
uploadUrl.value = _url;
files.value.forEach((file: IData) => {
let url = `${downloadUrl.value}/${file.id}`;
if (c.export_params.length > 0) {
url += '?';
c.export_params.forEach((item: IData, i: number) => {
url += `${Object.keys(item)[0]}=${Object.values(item)[0]}`;
if (i < c.export_params.length - 1) {
url += '&';
}
});
}
// eslint-disable-next-line no-param-reassign
file.url = url;
});
};
// 设置头 // data响应式变更基础路径
const setHeaders = () => { watch(
if (getCookie('access_token')) { () => props.data,
headers.value.Authorization = `Bearer ${getCookie('access_token')}`; newVal => {
if (newVal) {
const urls = props.controller.calcBaseUrl(newVal);
uploadUrl.value = urls.uploadUrl;
downloadUrl.value = urls.downloadUrl;
} }
}; },
setHeaders(); { immediate: true, deep: true },
);
// 值响应式变更
watch( watch(
() => props.value, () => props.value,
newVal => { newVal => {
setFiles(newVal); fileList.value = !newVal ? [] : JSON.parse(newVal);
dataProcess();
}, },
{ immediate: true }, { immediate: true },
); );
watch( watch(
() => props.data, fileList,
newVal => { newVal => {
c.getParams(newVal); // 变更后且下载基础路径存在时解析
if (newVal?.length && downloadUrl.value) {
newVal.forEach((file: IData) => {
file.url =
file.url || downloadUrl.value.replace('%fileId%', file.id);
});
}
}, },
{ immediate: true, deep: true }, { immediate: true },
); );
onMounted(() => { watch(
c.getParams(props.data); downloadUrl,
setFiles(props.value); newVal => {
dataProcess(); // 变更后且下载基础路径存在时解析
if (newVal && fileList.value.length) {
fileList.value.forEach((file: IData) => {
file.url = downloadUrl.value.replace('%fileId%', file.id);
}); });
// 上传前回调
const beforeUpload = () => {
uploadCache.count += 1;
};
// 上传成功回调
const onSuccess = (response: IData) => {
if (!response) {
return;
}
// 处理回调数据,并缓存
const arr: IData[] = [];
if (response?.length > 0) {
for (let index = 0; index < response.length; index++) {
const file = response[index];
arr.push({ name: file.filename, id: file.fileid });
}
} else {
arr.push({ name: response.filename, id: response.fileid });
} }
uploadCache.cacheFiles.push(arr); },
uploadCache.count -= 1; { immediate: true },
);
// 回调都结束后的处理
if (uploadCache.count === 0) {
const result: IData[] = [];
// 添加已有的文件数据
files.value.forEach((_file: IData) => {
result.push({ name: _file.name, id: _file.id });
});
// 添加缓存的文件数据 const { isInfoMode, componentRef, onOperateChange, onChange } =
uploadCache.cacheFiles.forEach((item: IData[]) => { useGridCellEditor(props.rowDataChange, props.rowSave, {
result.push(...item); isDelaySave: false,
}); });
// 抛出值变更事件 const emitValue = (files: UploadFile[]) => {
const value: string | null = const value: string | null =
result.length > 0 ? JSON.stringify(result) : null; files.length > 0
props.rowDataChange(value); ? JSON.stringify(
// 清空缓存的文件数据 files.map(file => ({ name: file.name, id: file.id })),
uploadCache.cacheFiles = []; )
} : null;
}; console.log(value);
// 上传失败回调 onChange(value);
const onError = (error: IData) => {
uploadCache.count -= 1;
throw error;
}; };
// 删除回调 const openPopover = async () => {
const onRemove = (file: IData, fileList: IData[]) => { if (!componentRef.value) {
const arr: Array<IData> = []; throw new RuntimeError('容器元素不存在');
fileList.forEach((f: IData) => {
if (f.id !== file.id) {
arr.push({ name: f.name, id: f.id });
} }
const el = componentRef.value.$el as HTMLElement;
const elHeight = el.offsetHeight;
const popover = ibiz.overlay.createPopover(
(h: CreateElement) => {
return h(IBizGridFileUploadPopover, {
props: {
value: fileList.value,
uploadUrl: uploadUrl.value,
downloadUrl: downloadUrl.value,
},
on: {
close: (result: {
isModified: boolean;
resultFiles: UploadFile[];
}) => {
popover.dismiss(result);
},
},
}); });
const value: string | null = arr.length > 0 ? JSON.stringify(arr) : null; },
props.rowDataChange(value); undefined,
};
// 计算文件mime类型
const calcFilemime = (filetype: string) => {
let mime = 'image/png';
switch (filetype) {
case '.wps':
mime = 'application/kswps';
break;
case '.doc':
mime = 'application/msword';
break;
case '.docx':
mime =
'application/vnd.openxmlformats-officedocument.wordprocessingml.document';
break;
case '.txt':
mime = 'text/plain';
break;
case '.zip':
mime = 'application/zip';
break;
case '.png':
mime = 'image/png';
break;
case '.gif':
mime = 'image/gif';
break;
case '.jpeg':
mime = 'image/jpeg';
break;
case '.jpg':
mime = 'image/jpeg';
break;
case '.rtf':
mime = 'application/rtf';
break;
case '.avi':
mime = 'video/x-msvideo';
break;
case '.gz':
mime = 'application/x-gzip';
break;
case '.tar':
mime = 'application/x-tar';
break;
default:
mime = 'image/png';
}
return mime;
};
/**
* 下载文件
*/
const DownloadFile = (url: string, file: IData) => {
let tempDownloadUrl: string = url;
const BaseUrl = ibiz.env.baseUrl;
if (url.startsWith(BaseUrl)) {
tempDownloadUrl = url.replace(BaseUrl, '');
}
// 发送get请求
ibiz.net
.get(
tempDownloadUrl,
{},
{},
{ {
responseType: 'blob', noArrow: true,
placement: 'bottom-start',
offsetOpts: { mainAxis: -elHeight, crossAxis: 0 },
}, },
) );
.then((response: IData) => { await popover.present(el);
if (!response || response.status !== 200) { const result = await popover.onWillDismiss<{
throw new RuntimeError('下载文件失败'); isModified: boolean;
} resultFiles: UploadFile[];
// 请求成功,后台返回的是一个文件流 }>();
if (response.data) { if (result.isModified) {
// 获取文件名 emitValue(result.resultFiles);
const filename = file.name;
const ext = `.${filename.split('.').pop()}`;
const filetype = calcFilemime(ext);
// 用blob对象获取文件流
const blob = new Blob([response.data], { type: filetype });
// 通过文件流创建下载链接
const href = URL.createObjectURL(blob);
// 创建一个a元素并设置相关属性
const a = document.createElement('a');
a.href = href;
a.download = filename;
// 添加a元素到当前网页
document.body.appendChild(a);
// 触发a元素的点击事件,实现下载
a.click();
// 从当前网页移除a元素
document.body.removeChild(a);
// 释放blob对象
URL.revokeObjectURL(href);
} else {
throw new RuntimeError('文件流数据不存在');
} }
});
}; };
// 下载文件 watch(isInfoMode, async newVal => {
const onDownload = (file: IData) => { if (!props.disabled && newVal === false) {
const url = `${downloadUrl.value}/${file.id}`; onOperateChange(true);
DownloadFile(url, file); await openPopover();
}; onOperateChange(false);
}
});
return { return {
ns, ns,
c, isInfoMode,
files, fileList,
headers, componentRef,
uploadUrl, onOperateChange,
dialogVisible, onChange,
showActions,
onDialogVisibleChange,
beforeUpload,
onSuccess,
onError,
onRemove,
onDownload,
}; };
}, },
render(h) { render() {
return ( return (
<div class={this.ns.b()}> <grid-editor
<i-row> disabled={this.disabled}
{this.files.length > 0 ? ( ref='componentRef'
<i-col span={12}> class={`${this.ns.b()}`}
<i-button
on-click={() => {
this.dialogVisible = true;
}}
>
查看
<i-badge count={this.files.length}></i-badge>
</i-button>
</i-col>
) : null}
<i-col span={this.files.length > 0 ? 12 : 24}>
{h(
'IUpload',
{
ref: 'fileUploadRowPreview',
props: {
action: this.uploadUrl,
headers: this.headers,
'default-file-list': this.files,
multiple: this.c.multiple,
type: this.c.isDrag ? 'drag' : 'select',
accept: this.c.accept,
'show-upload-list': false,
'before-upload': this.beforeUpload,
'on-success': this.onSuccess,
'on-error': this.onError,
'on-remove': this.onRemove,
'on-preview': this.onDownload,
},
},
[<i-button icon='ios-cloud-upload-outline'>上传文件</i-button>],
)}
</i-col>
</i-row>
<i-modal
class-name={this.ns.b('upload-preview-modal')}
width='80%'
footer-hide={true}
value={this.dialogVisible}
on-on-visible-change={this.onDialogVisibleChange}
>
<ul class={this.ns.be('upload-preview-modal', 'ul')}>
{this.files.map((file, index) => (
<li key={index} class={this.ns.be('upload-preview-modal', 'li')}>
<div class={this.ns.be('upload-preview-modal', 'box')}>
<img
class={this.ns.be('upload-preview-modal', 'img')}
src={file.url}
/>
<div
class={this.ns.be('upload-preview-modal', 'actions')}
on-mouseenter={() => {
this.showActions = true;
}}
on-mouseleave={() => {
this.showActions = false;
}}
>
{this.showActions ? (
<span
class={this.ns.be('upload-preview-modal', 'download')}
>
<i-icon
type='ios-download-outline'
on-click={() => {
this.onDownload(file);
}}
></i-icon>
</span>
) : null}
{this.showActions ? (
<span
class={this.ns.be('upload-preview-modal', 'delete')}
> >
<i-icon {this.fileList.map(file => {
type='ios-trash-outline' return <span>{file.name}</span>;
on-click={() => { })}
this.onRemove(file, this.files); </grid-editor>
}}
></i-icon>
</span>
) : null}
</div>
</div>
<div class={this.ns.be('upload-preview-modal', 'filename')}>
{file.name}
</div>
</li>
))}
</ul>
</i-modal>
</div>
); );
}, },
}); });
import { defineComponent, onMounted, ref, watch } from 'vue'; /* eslint-disable no-param-reassign */
import { defineComponent, ref } from 'vue';
import { import {
getEditorEmits, getEditorEmits,
getUploadProps, getUploadProps,
useNamespace, useNamespace,
} from '@ibiz-template/vue-util'; } from '@ibiz-template/vue-util';
import { getCookie } from 'qx-util';
import { RuntimeError } from '@ibiz-template/core';
import '@ibiz-template/theme/style/components/editor/ibiz-image-upload/ibiz-image-upload.scss'; import '@ibiz-template/theme/style/components/editor/ibiz-image-upload/ibiz-image-upload.scss';
import { useIViewUpload } from '../use/use-iview-upload';
export const IBizImageUpload = defineComponent({ export const IBizImageUpload = defineComponent({
name: 'IBizImageUpload', name: 'IBizImageUpload',
...@@ -17,274 +17,22 @@ export const IBizImageUpload = defineComponent({ ...@@ -17,274 +17,22 @@ export const IBizImageUpload = defineComponent({
const c = props.controller; const c = props.controller;
// 文件列表 const {
const files = ref<IData[]>([]); uploadUrl,
headers,
// 请求头 files,
const headers = ref<IData>({}); onDownload,
onError,
// 上传文件路径 onRemove,
const uploadUrl = ref<string>(ibiz.env.baseUrl + ibiz.env.UploadFile); onSuccess,
beforeUpload,
// 下载文件路径 } = useIViewUpload(
const downloadUrl = ref<string>(ibiz.env.baseUrl + ibiz.env.ExportFile); props,
value => {
// 设置files
const setFiles = (value: string | null | undefined) => {
if (value === null) {
files.value = [];
}
if (!value) {
return;
}
const _files = JSON.parse(value);
if (
value &&
Object.prototype.toString.call(_files) === '[object Array]'
) {
files.value = _files;
} else {
files.value = [];
}
};
// 文件上传缓存对象
const uploadCache: IData = {
count: 0,
cacheFiles: [],
};
// 处理参数
const dataProcess = () => {
let _url = ibiz.env.baseUrl + ibiz.env.UploadFile;
if (c.upload_params.length > 0) {
_url += '?';
c.upload_params.forEach((item: IData, i: number) => {
_url += `${Object.keys(item)[0]}=${Object.values(item)[0]}`;
if (i < c.upload_params.length - 1) {
_url += '&';
}
});
}
uploadUrl.value = _url;
files.value.forEach((file: IData) => {
let url = `${downloadUrl.value}/${file.id}`;
if (c.export_params.length > 0) {
url += '?';
c.export_params.forEach((item: IData, i: number) => {
url += `${Object.keys(item)[0]}=${Object.values(item)[0]}`;
if (i < c.export_params.length - 1) {
url += '&';
}
});
}
// eslint-disable-next-line no-param-reassign
file.url = url;
});
};
// 设置头
const setHeaders = () => {
if (getCookie('access_token')) {
headers.value.Authorization = `Bearer ${getCookie('access_token')}`;
}
};
setHeaders();
watch(
() => props.value,
newVal => {
setFiles(newVal);
dataProcess();
},
{ immediate: true },
);
watch(
() => props.data,
newVal => {
c.getParams(newVal);
},
{ immediate: true, deep: true },
);
onMounted(() => {
c.getParams(props.data);
setFiles(props.value);
dataProcess();
});
// 上传前回调
const beforeUpload = () => {
uploadCache.count += 1;
};
// 上传成功回调
const onSuccess = (response: IData) => {
if (!response) {
return;
}
// 处理回调数据,并缓存
const arr: IData[] = [];
if (response?.length > 0) {
for (let index = 0; index < response.length; index++) {
const file = response[index];
arr.push({ name: file.filename, id: file.fileid });
}
} else {
arr.push({ name: response.filename, id: response.fileid });
}
uploadCache.cacheFiles.push(arr);
uploadCache.count -= 1;
// 回调都结束后的处理
if (uploadCache.count === 0) {
const result: IData[] = [];
// 添加已有的文件数据
files.value.forEach((_file: IData) => {
result.push({ name: _file.name, id: _file.id });
});
// 添加缓存的文件数据
uploadCache.cacheFiles.forEach((item: IData[]) => {
result.push(...item);
});
// 抛出值变更事件
const value: string | null =
result.length > 0 ? JSON.stringify(result) : null;
emit('change', value);
// 清空缓存的文件数据
uploadCache.cacheFiles = [];
}
};
// 上传失败回调
const onError = (error: IData) => {
uploadCache.count -= 1;
throw error;
};
// 删除回调
const onRemove = (file: IData, fileList: IData[]) => {
const arr: Array<IData> = [];
fileList.forEach((f: IData) => {
if (f.id !== file.id) {
arr.push({ name: f.name, id: f.id });
}
});
const value: string | null = arr.length > 0 ? JSON.stringify(arr) : null;
emit('change', value); emit('change', value);
};
// 计算文件mime类型
const calcFilemime = (filetype: string) => {
let mime = 'image/png';
switch (filetype) {
case '.wps':
mime = 'application/kswps';
break;
case '.doc':
mime = 'application/msword';
break;
case '.docx':
mime =
'application/vnd.openxmlformats-officedocument.wordprocessingml.document';
break;
case '.txt':
mime = 'text/plain';
break;
case '.zip':
mime = 'application/zip';
break;
case '.png':
mime = 'image/png';
break;
case '.gif':
mime = 'image/gif';
break;
case '.jpeg':
mime = 'image/jpeg';
break;
case '.jpg':
mime = 'image/jpeg';
break;
case '.rtf':
mime = 'application/rtf';
break;
case '.avi':
mime = 'video/x-msvideo';
break;
case '.gz':
mime = 'application/x-gzip';
break;
case '.tar':
mime = 'application/x-tar';
break;
default:
mime = 'image/png';
}
return mime;
};
/**
* 下载文件
*/
const DownloadFile = (url: string, file: IData) => {
let tempDownloadUrl: string = url;
const BaseUrl = ibiz.env.baseUrl;
if (url.startsWith(BaseUrl)) {
tempDownloadUrl = url.replace(BaseUrl, '');
}
// 发送get请求
ibiz.net
.get(
tempDownloadUrl,
{},
{},
{
responseType: 'blob',
}, },
) c,
.then((response: IData) => { );
if (!response || response.status !== 200) {
throw new RuntimeError('下载文件失败');
}
// 请求成功,后台返回的是一个文件流
if (response.data) {
// 获取文件名
const filename = file.name;
const ext = `.${filename.split('.').pop()}`;
const filetype = calcFilemime(ext);
// 用blob对象获取文件流
const blob = new Blob([response.data], { type: filetype });
// 通过文件流创建下载链接
const href = URL.createObjectURL(blob);
// 创建一个a元素并设置相关属性
const a = document.createElement('a');
a.href = href;
a.download = filename;
// 添加a元素到当前网页
document.body.appendChild(a);
// 触发a元素的点击事件,实现下载
a.click();
// 从当前网页移除a元素
document.body.removeChild(a);
// 释放blob对象
URL.revokeObjectURL(href);
} else {
throw new RuntimeError('文件流数据不存在');
}
});
};
// 下载文件
const onDownload = (file: IData) => {
const url = file.url;
DownloadFile(url, file);
};
const dialogImageUrl = ref<string>(''); const dialogImageUrl = ref<string>('');
const dialogVisible = ref<boolean>(false); const dialogVisible = ref<boolean>(false);
...@@ -316,11 +64,15 @@ export const IBizImageUpload = defineComponent({ ...@@ -316,11 +64,15 @@ export const IBizImageUpload = defineComponent({
onPreview, onPreview,
}; };
}, },
render(h) { render() {
// 信息模式
if (this.infoMode) {
return <div class={this.ns.b()}>{this.value}</div>;
}
// 编辑态展示
return ( return (
<div class={this.ns.b()}> <div class={this.ns.b()}>
{this.infoMode && this.value}
{!this.infoMode && (
<div class={this.ns.e('image-upload-list')}> <div class={this.ns.e('image-upload-list')}>
{this.files.map(item => ( {this.files.map(item => (
<div key={item.id} class={this.ns.e('list-item')}> <div key={item.id} class={this.ns.e('list-item')}>
...@@ -336,41 +88,33 @@ export const IBizImageUpload = defineComponent({ ...@@ -336,41 +88,33 @@ export const IBizImageUpload = defineComponent({
></i-icon> ></i-icon>
<i-icon <i-icon
type='ios-trash-outline' type='ios-trash-outline'
on-click={() => this.onRemove(item, this.files)} on-click={() => this.onRemove(item)}
></i-icon> ></i-icon>
</div> </div>
</div> </div>
))} ))}
</div> </div>
)} <i-upload
ref='imageUpload'
{!this.infoMode && action={this.uploadUrl}
h( headers={this.headers}
'IUpload', default-file-list={this.files}
{ multiple={this.c.model.multiple}
ref: 'imageUpload', type={'drag'}
props: { accept={this.c.model.accept}
action: this.uploadUrl, show-upload-list={false}
headers: this.headers, before-upload={this.beforeUpload}
'default-file-list': this.files, props={{
multiple: this.c.multiple,
type: 'drag',
accept: this.c.accept,
'show-upload-list': false,
'before-upload': this.beforeUpload,
'on-success': this.onSuccess, 'on-success': this.onSuccess,
'on-error': this.onError, 'on-error': this.onError,
'on-remove': this.onRemove, 'on-remove': this.onRemove,
'on-preview': this.onDownload, 'on-preview': this.onDownload,
}, }}
}, >
[
<div class={this.ns.e('btn')}> <div class={this.ns.e('btn')}>
<i-icon type='ios-add' size='30'></i-icon> <i-icon type='ios-add' size='30'></i-icon>
</div>, </div>
], </i-upload>
)}
<i-modal <i-modal
class-name={this.ns.b('modal')} class-name={this.ns.b('modal')}
footer-hide={true} footer-hide={true}
......
import { useNamespace } from '@ibiz-template/vue-util';
import { defineComponent, ref } from 'vue';
export type UploadFile = {
name: string;
status: 'uploading' | 'finished' | 'fail';
percentage: number;
url?: string;
id: string;
};
export const IBizUpload = defineComponent({
name: 'IBizUpload',
props: {
uploadUrl: {
type: String,
required: true,
},
downloadUrl: {
type: String,
},
accept: String,
multiple: {
type: Boolean,
default: false,
},
},
emits: {
finish: (_resultFiles: UploadFile[]) => true,
},
setup(props, { emit }) {
const ns = useNamespace('upload');
const upload = ref();
const selectFile = () => {
upload.value.click();
};
const uploadFiles = async (files: FileList) => {
const resultFiles: UploadFile[] = [];
await Promise.allSettled(
Array.from({ length: files.length }).map(async (_value, i) => {
const file = files[i];
// 上传前处理
const resultFile: UploadFile = {
status: 'uploading',
name: file.name,
percentage: 0,
id: '',
};
resultFiles.push(resultFile);
const data = new FormData();
console.log(file);
data.append('file', file);
try {
const res = await ibiz.net.request(props.uploadUrl, {
method: 'post',
baseURL: '',
data,
headers: { 'Content-Type': 'multipart/form-data' },
});
if (res.ok && res.data) {
console.log(res.data);
Object.assign(resultFile, {
id: res.data.id,
url: props.downloadUrl
? props.downloadUrl.replace('%fileId%', res.data.id)
: undefined,
});
}
} catch (error) {
ibiz.log.error(error);
ibiz.message.error(`${file.name}上传失败`);
}
}),
);
emit('finish', resultFiles);
};
const handleChange = (e: Event) => {
const inputEl = e.target as HTMLInputElement;
const files = inputEl.files;
if (!files) {
return;
}
uploadFiles(files);
inputEl.value = ''; // 如果不置空,相同的文件不会触发change事件
};
return { ns, upload, selectFile, handleChange };
},
render() {
return (
<input
accept={this.accept}
multiple={this.multiple}
onChange={this.handleChange}
ref='upload'
type='file'
style='display: none'
/>
);
},
});
/* eslint-disable no-param-reassign */
import { UploadEditorController } from '@ibiz-template/controller';
import { getCookie } from 'qx-util';
import { Ref, ref, watch } from 'vue';
/**
* iview的Upload适配逻辑
*
* @author lxm
* @date 2022-11-17 16:11:12
* @export
* @param {IParams} props
* @param {(_value: string | null) => {}} valueChange
* @param {UploadEditorController} c
* @returns {*}
*/
export function useIViewUpload(
props: IParams,
valueChange: (_value: string | null) => void,
c: UploadEditorController,
) {
// 文件列表
const files: Ref<
{
id: string;
name: string;
url?: string;
}[]
> = ref([]);
// 请求头
const headers: Ref<IData> = ref({
Authorization: `Bearer ${getCookie('access_token')}`,
});
// 上传文件路径
const uploadUrl: Ref<string> = ref('');
// 下载文件路径
const downloadUrl: Ref<string> = ref('');
// 文件上传缓存对象
const uploadCache: IData = {
count: 0,
cacheFiles: [], // iview上传过程中不能改default-file-list,所以需要缓存
};
// 值响应式变更
watch(
() => props.value,
newVal => {
files.value = !newVal ? [] : JSON.parse(newVal);
},
{ immediate: true },
);
// data响应式变更基础路径
watch(
() => props.data,
newVal => {
if (newVal) {
const urls = c.calcBaseUrl(newVal);
uploadUrl.value = urls.uploadUrl;
downloadUrl.value = urls.downloadUrl;
}
},
{ immediate: true, deep: true },
);
watch(
files,
newVal => {
// 变更后且下载基础路径存在时解析
if (newVal?.length && downloadUrl.value) {
newVal.forEach((file: IData) => {
file.url = file.url || downloadUrl.value.replace('%fileId%', file.id);
});
}
},
{ immediate: true },
);
watch(
downloadUrl,
newVal => {
// 变更后且下载基础路径存在时解析
if (newVal && files.value.length) {
files.value.forEach((file: IData) => {
file.url = downloadUrl.value.replace('%fileId%', file.id);
});
}
},
{ immediate: true },
);
/**
* 抛出值变更事件,根据files计算value
*
* @author lxm
* @date 2022-11-17 14:11:54
*/
const emitValue = () => {
const _files = [...files.value, ...uploadCache.cacheFiles];
const value: string | null =
_files.length > 0
? JSON.stringify(_files.map(file => ({ name: file.name, id: file.id })))
: null;
uploadCache.cacheFiles = [];
valueChange(value);
};
// 上传前回调
const beforeUpload = () => {
uploadCache.count += 1;
};
// 上传成功回调
const onSuccess = (response: IData) => {
if (!response) {
return;
}
uploadCache.cacheFiles.push({
name: response.filename,
id: response.fileid,
});
uploadCache.count -= 1;
// 回调都结束后抛出值变更
if (uploadCache.count === 0) {
emitValue();
}
};
// 上传失败回调
const onError = (error: IData) => {
uploadCache.count -= 1;
throw error;
};
// 删除回调
const onRemove = (file: IData) => {
const index = files.value.findIndex(item => item.id === file.id);
if (index !== -1) {
files.value.splice(index, 1);
}
emitValue();
};
// 下载文件
const onDownload = (file: IData) => {
const url = file.url || downloadUrl.value.replace('%fileId%', file.id);
c.fileDownload(url, file);
};
return {
uploadUrl,
downloadUrl,
headers,
files,
onDownload,
onError,
onRemove,
onSuccess,
beforeUpload,
};
}
...@@ -141,7 +141,7 @@ export const MPickupView = defineComponent({ ...@@ -141,7 +141,7 @@ export const MPickupView = defineComponent({
on-click={() => this.handleSelectionClick(item)} on-click={() => this.handleSelectionClick(item)}
> >
{item.srfmajortext} {item.srfmajortext}
<icon <i-icon
type='ios-close' type='ios-close'
size={24} size={24}
on-click={() => { on-click={() => {
......
...@@ -62,8 +62,8 @@ export function useITableColumns(c: GridController) { ...@@ -62,8 +62,8 @@ export function useITableColumns(c: GridController) {
const copy = [...originColumns.value]; const copy = [...originColumns.value];
// 如果没有自适应列,深拷贝最后一个对象,改成自适应 // 如果没有自适应列,深拷贝最后一个对象,改成自适应
const flexColumn = copy.find(column => !!column.width); const flexColumn = copy.find(column => !column.width);
if (flexColumn) { if (!flexColumn) {
// 修改自适应列的索引,默认最后一个 // 修改自适应列的索引,默认最后一个
let index = copy.length - 1; let index = copy.length - 1;
if (copy[index].key === 'rowEdit') { if (copy[index].key === 'rowEdit') {
......
...@@ -22,7 +22,7 @@ export class TextBoxEditorProvider implements IEditorProvider { ...@@ -22,7 +22,7 @@ export class TextBoxEditorProvider implements IEditorProvider {
constructor(editorType?: string) { constructor(editorType?: string) {
if (editorType === 'NUMBER') { if (editorType === 'NUMBER') {
this.formEditor = 'IBizInputNumber'; this.formEditor = 'IBizInputNumber';
this.gridEditor = 'IBizInputNumber'; this.gridEditor = 'IBizGridInputNumber';
} }
} }
......
...@@ -31,10 +31,14 @@ async function computePos( ...@@ -31,10 +31,14 @@ async function computePos(
arrEl: HTMLElement, arrEl: HTMLElement,
opts: IPopoverOptions, opts: IPopoverOptions,
): Promise<void> { ): Promise<void> {
const middlewareArr = [offset(opts.offsetOpts || 6), flip(), shift()];
if (!opts.noArrow) {
middlewareArr.push(arrow({ element: arrEl! }));
}
const options = await computePosition(element, el, { const options = await computePosition(element, el, {
placement: opts.placement, placement: opts.placement,
strategy: 'absolute', strategy: 'absolute',
middleware: [offset(6), flip(), shift(), arrow({ element: arrEl! })], middleware: middlewareArr,
}); });
{ {
const { x, y, placement, middlewareData } = options; const { x, y, placement, middlewareData } = options;
...@@ -42,6 +46,7 @@ async function computePos( ...@@ -42,6 +46,7 @@ async function computePos(
style.left = `${x}px`; style.left = `${x}px`;
style.top = `${y}px`; style.top = `${y}px`;
if (!opts.noArrow) {
// 箭头位置 // 箭头位置
const { x: arrowX, y: arrowY } = middlewareData.arrow!; const { x: arrowX, y: arrowY } = middlewareData.arrow!;
...@@ -60,6 +65,7 @@ async function computePos( ...@@ -60,6 +65,7 @@ async function computePos(
[staticSide]: '-4px', [staticSide]: '-4px',
}); });
} }
}
} }
const AppPopoverComponent = defineComponent({ const AppPopoverComponent = defineComponent({
...@@ -165,7 +171,9 @@ const AppPopoverComponent = defineComponent({ ...@@ -165,7 +171,9 @@ const AppPopoverComponent = defineComponent({
onMouseenter={this.onMouseenter} onMouseenter={this.onMouseenter}
onMouseleave={this.onMouseleave} onMouseleave={this.onMouseleave}
> >
{!this.opts.noArrow && (
<div class={[this.ns.e('arrow')]} ref='arrEl'></div> <div class={[this.ns.e('arrow')]} ref='arrEl'></div>
)}
{this.$slots.default} {this.$slots.default}
</div> </div>
); );
......
因为 它太大了无法显示 源差异 。您可以改为 查看blob
...@@ -1914,34 +1914,34 @@ ...@@ -1914,34 +1914,34 @@
"getPSAppViewLogics" : [ { "getPSAppViewLogics" : [ {
"logicTrigger" : "CUSTOM", "logicTrigger" : "CUSTOM",
"logicType" : "APPVIEWUIACTION", "logicType" : "APPVIEWUIACTION",
"name" : "grid_uagridcolumn1_ua98d563_click", "name" : "grid_uagridcolumn1_u479f517_click",
"getPSAppViewUIAction" : { "getPSAppViewUIAction" : {
"modelref" : true, "modelref" : true,
"id" : "表格界面_行编辑开关操作" "id" : "表格界面_编辑操作"
} }
}, { }, {
"logicTrigger" : "CUSTOM", "logicTrigger" : "CUSTOM",
"logicType" : "APPVIEWUIACTION", "logicType" : "APPVIEWUIACTION",
"name" : "grid_uagridcolumn1_u479f517_click", "name" : "grid_uagridcolumn1_ua98d563_click",
"getPSAppViewUIAction" : { "getPSAppViewUIAction" : {
"modelref" : true, "modelref" : true,
"id" : "表格界面_编辑操作" "id" : "表格界面_行编辑开关操作"
} }
} ], } ],
"getPSAppViewUIActions" : [ { "getPSAppViewUIActions" : [ {
"name" : "表格界面_行编辑开关操作", "name" : "表格界面_编辑操作",
"getPSUIAction" : { "getPSUIAction" : {
"modelref" : true, "modelref" : true,
"id" : "ToggleRowEdit" "id" : "Edit"
}, },
"uIActionTarget" : "SINGLEKEY",
"xDataControlName" : "grid" "xDataControlName" : "grid"
}, { }, {
"name" : "表格界面_编辑操作", "name" : "表格界面_行编辑开关操作",
"getPSUIAction" : { "getPSUIAction" : {
"modelref" : true, "modelref" : true,
"id" : "Edit" "id" : "ToggleRowEdit"
}, },
"uIActionTarget" : "SINGLEKEY",
"xDataControlName" : "grid" "xDataControlName" : "grid"
} ], } ],
"getPSControlHandler" : { "getPSControlHandler" : {
...@@ -2173,30 +2173,6 @@ ...@@ -2173,30 +2173,6 @@
"mOSFilePath" : "pssysapps/Web/psappdataentities/Reginfo/psappdeuagroups/A046596b6afb50f9e5b", "mOSFilePath" : "pssysapps/Web/psappdataentities/Reginfo/psappdeuagroups/A046596b6afb50f9e5b",
"name" : "操作列", "name" : "操作列",
"getPSUIActionGroupDetails" : [ { "getPSUIActionGroupDetails" : [ {
"detailType" : "DEUIACTION",
"name" : "ua98d563",
"getPSUIAction" : {
"caption" : "行编辑",
"codeName" : "ToggleRowEdit",
"fullCodeName" : "ToggleRowEdit",
"mOSFilePath" : "pssysapps/Web/pssysappdeuiactions/ToggleRowEdit",
"name" : "表格界面_行编辑开关操作",
"getPSSysImage" : {
"glyph" : "xf0ce@FontAwesome",
"cssClass" : "fa fa-table"
},
"predefinedType" : "GRIDVIEW_ROWEDITACTION",
"rTMOSFilePath" : "pssysapps/Web/pssysappdeuiactions/ToggleRowEdit",
"timeout" : 60000,
"uIActionMode" : "SYS",
"uIActionTag" : "ToggleRowEdit",
"uIActionType" : "DEUIACTION",
"enableToggleMode" : true
},
"addSeparator" : true,
"showCaption" : true,
"showIcon" : false
}, {
"detailType" : "DEUIACTION", "detailType" : "DEUIACTION",
"name" : "u479f517", "name" : "u479f517",
"getPSUIAction" : { "getPSUIAction" : {
...@@ -2230,6 +2206,30 @@ ...@@ -2230,6 +2206,30 @@
"addSeparator" : true, "addSeparator" : true,
"showCaption" : true, "showCaption" : true,
"showIcon" : true "showIcon" : true
}, {
"detailType" : "DEUIACTION",
"name" : "ua98d563",
"getPSUIAction" : {
"caption" : "行编辑",
"codeName" : "ToggleRowEdit",
"fullCodeName" : "ToggleRowEdit",
"mOSFilePath" : "pssysapps/Web/pssysappdeuiactions/ToggleRowEdit",
"name" : "表格界面_行编辑开关操作",
"getPSSysImage" : {
"glyph" : "xf0ce@FontAwesome",
"cssClass" : "fa fa-table"
},
"predefinedType" : "GRIDVIEW_ROWEDITACTION",
"rTMOSFilePath" : "pssysapps/Web/pssysappdeuiactions/ToggleRowEdit",
"timeout" : 60000,
"uIActionMode" : "SYS",
"uIActionTag" : "ToggleRowEdit",
"uIActionType" : "DEUIACTION",
"enableToggleMode" : true
},
"addSeparator" : true,
"showCaption" : true,
"showIcon" : false
} ], } ],
"rTMOSFilePath" : "pssysapps/Web/psappdataentities/Reginfo/psappdeuagroups/A046596b6afb50f9e5b" "rTMOSFilePath" : "pssysapps/Web/psappdataentities/Reginfo/psappdeuagroups/A046596b6afb50f9e5b"
}, },
......
...@@ -19,34 +19,34 @@ ...@@ -19,34 +19,34 @@
"getPSAppViewLogics" : [ { "getPSAppViewLogics" : [ {
"logicTrigger" : "CUSTOM", "logicTrigger" : "CUSTOM",
"logicType" : "APPVIEWUIACTION", "logicType" : "APPVIEWUIACTION",
"name" : "grid_uagridcolumn1_ua98d563_click", "name" : "grid_uagridcolumn1_u479f517_click",
"getPSAppViewUIAction" : { "getPSAppViewUIAction" : {
"modelref" : true, "modelref" : true,
"id" : "表格界面_行编辑开关操作" "id" : "表格界面_编辑操作"
} }
}, { }, {
"logicTrigger" : "CUSTOM", "logicTrigger" : "CUSTOM",
"logicType" : "APPVIEWUIACTION", "logicType" : "APPVIEWUIACTION",
"name" : "grid_uagridcolumn1_u479f517_click", "name" : "grid_uagridcolumn1_ua98d563_click",
"getPSAppViewUIAction" : { "getPSAppViewUIAction" : {
"modelref" : true, "modelref" : true,
"id" : "表格界面_编辑操作" "id" : "表格界面_行编辑开关操作"
} }
} ], } ],
"getPSAppViewUIActions" : [ { "getPSAppViewUIActions" : [ {
"name" : "表格界面_行编辑开关操作", "name" : "表格界面_编辑操作",
"getPSUIAction" : { "getPSUIAction" : {
"modelref" : true, "modelref" : true,
"id" : "ToggleRowEdit" "id" : "Edit"
}, },
"uIActionTarget" : "SINGLEKEY",
"xDataControlName" : "grid" "xDataControlName" : "grid"
}, { }, {
"name" : "表格界面_编辑操作", "name" : "表格界面_行编辑开关操作",
"getPSUIAction" : { "getPSUIAction" : {
"modelref" : true, "modelref" : true,
"id" : "Edit" "id" : "ToggleRowEdit"
}, },
"uIActionTarget" : "SINGLEKEY",
"xDataControlName" : "grid" "xDataControlName" : "grid"
} ], } ],
"getPSControlLogics" : [ { "getPSControlLogics" : [ {
...@@ -191,30 +191,6 @@ ...@@ -191,30 +191,6 @@
"mOSFilePath" : "pssysapps/Web/psappdataentities/Reginfo/psappdeuagroups/A046596b6afb50f9e5b", "mOSFilePath" : "pssysapps/Web/psappdataentities/Reginfo/psappdeuagroups/A046596b6afb50f9e5b",
"name" : "操作列", "name" : "操作列",
"getPSUIActionGroupDetails" : [ { "getPSUIActionGroupDetails" : [ {
"detailType" : "DEUIACTION",
"name" : "ua98d563",
"getPSUIAction" : {
"caption" : "行编辑",
"codeName" : "ToggleRowEdit",
"fullCodeName" : "ToggleRowEdit",
"mOSFilePath" : "pssysapps/Web/pssysappdeuiactions/ToggleRowEdit",
"name" : "表格界面_行编辑开关操作",
"getPSSysImage" : {
"glyph" : "xf0ce@FontAwesome",
"cssClass" : "fa fa-table"
},
"predefinedType" : "GRIDVIEW_ROWEDITACTION",
"rTMOSFilePath" : "pssysapps/Web/pssysappdeuiactions/ToggleRowEdit",
"timeout" : 60000,
"uIActionMode" : "SYS",
"uIActionTag" : "ToggleRowEdit",
"uIActionType" : "DEUIACTION",
"enableToggleMode" : true
},
"addSeparator" : true,
"showCaption" : true,
"showIcon" : false
}, {
"detailType" : "DEUIACTION", "detailType" : "DEUIACTION",
"name" : "u479f517", "name" : "u479f517",
"getPSUIAction" : { "getPSUIAction" : {
...@@ -248,6 +224,30 @@ ...@@ -248,6 +224,30 @@
"addSeparator" : true, "addSeparator" : true,
"showCaption" : true, "showCaption" : true,
"showIcon" : true "showIcon" : true
}, {
"detailType" : "DEUIACTION",
"name" : "ua98d563",
"getPSUIAction" : {
"caption" : "行编辑",
"codeName" : "ToggleRowEdit",
"fullCodeName" : "ToggleRowEdit",
"mOSFilePath" : "pssysapps/Web/pssysappdeuiactions/ToggleRowEdit",
"name" : "表格界面_行编辑开关操作",
"getPSSysImage" : {
"glyph" : "xf0ce@FontAwesome",
"cssClass" : "fa fa-table"
},
"predefinedType" : "GRIDVIEW_ROWEDITACTION",
"rTMOSFilePath" : "pssysapps/Web/pssysappdeuiactions/ToggleRowEdit",
"timeout" : 60000,
"uIActionMode" : "SYS",
"uIActionTag" : "ToggleRowEdit",
"uIActionType" : "DEUIACTION",
"enableToggleMode" : true
},
"addSeparator" : true,
"showCaption" : true,
"showIcon" : false
} ], } ],
"rTMOSFilePath" : "pssysapps/Web/psappdataentities/Reginfo/psappdeuagroups/A046596b6afb50f9e5b" "rTMOSFilePath" : "pssysapps/Web/psappdataentities/Reginfo/psappdeuagroups/A046596b6afb50f9e5b"
}, },
......
...@@ -609,34 +609,34 @@ ...@@ -609,34 +609,34 @@
"getPSAppViewLogics" : [ { "getPSAppViewLogics" : [ {
"logicTrigger" : "CUSTOM", "logicTrigger" : "CUSTOM",
"logicType" : "APPVIEWUIACTION", "logicType" : "APPVIEWUIACTION",
"name" : "grid_uagridcolumn1_ua98d563_click", "name" : "grid_uagridcolumn1_u479f517_click",
"getPSAppViewUIAction" : { "getPSAppViewUIAction" : {
"modelref" : true, "modelref" : true,
"id" : "表格界面_行编辑开关操作" "id" : "表格界面_编辑操作"
} }
}, { }, {
"logicTrigger" : "CUSTOM", "logicTrigger" : "CUSTOM",
"logicType" : "APPVIEWUIACTION", "logicType" : "APPVIEWUIACTION",
"name" : "grid_uagridcolumn1_u479f517_click", "name" : "grid_uagridcolumn1_ua98d563_click",
"getPSAppViewUIAction" : { "getPSAppViewUIAction" : {
"modelref" : true, "modelref" : true,
"id" : "表格界面_编辑操作" "id" : "表格界面_行编辑开关操作"
} }
} ], } ],
"getPSAppViewUIActions" : [ { "getPSAppViewUIActions" : [ {
"name" : "表格界面_行编辑开关操作", "name" : "表格界面_编辑操作",
"getPSUIAction" : { "getPSUIAction" : {
"modelref" : true, "modelref" : true,
"id" : "ToggleRowEdit" "id" : "Edit"
}, },
"uIActionTarget" : "SINGLEKEY",
"xDataControlName" : "grid" "xDataControlName" : "grid"
}, { }, {
"name" : "表格界面_编辑操作", "name" : "表格界面_行编辑开关操作",
"getPSUIAction" : { "getPSUIAction" : {
"modelref" : true, "modelref" : true,
"id" : "Edit" "id" : "ToggleRowEdit"
}, },
"uIActionTarget" : "SINGLEKEY",
"xDataControlName" : "grid" "xDataControlName" : "grid"
} ], } ],
"getPSControlHandler" : { "getPSControlHandler" : {
...@@ -868,30 +868,6 @@ ...@@ -868,30 +868,6 @@
"mOSFilePath" : "pssysapps/Web/psappdataentities/Reginfo/psappdeuagroups/A046596b6afb50f9e5b", "mOSFilePath" : "pssysapps/Web/psappdataentities/Reginfo/psappdeuagroups/A046596b6afb50f9e5b",
"name" : "操作列", "name" : "操作列",
"getPSUIActionGroupDetails" : [ { "getPSUIActionGroupDetails" : [ {
"detailType" : "DEUIACTION",
"name" : "ua98d563",
"getPSUIAction" : {
"caption" : "行编辑",
"codeName" : "ToggleRowEdit",
"fullCodeName" : "ToggleRowEdit",
"mOSFilePath" : "pssysapps/Web/pssysappdeuiactions/ToggleRowEdit",
"name" : "表格界面_行编辑开关操作",
"getPSSysImage" : {
"glyph" : "xf0ce@FontAwesome",
"cssClass" : "fa fa-table"
},
"predefinedType" : "GRIDVIEW_ROWEDITACTION",
"rTMOSFilePath" : "pssysapps/Web/pssysappdeuiactions/ToggleRowEdit",
"timeout" : 60000,
"uIActionMode" : "SYS",
"uIActionTag" : "ToggleRowEdit",
"uIActionType" : "DEUIACTION",
"enableToggleMode" : true
},
"addSeparator" : true,
"showCaption" : true,
"showIcon" : false
}, {
"detailType" : "DEUIACTION", "detailType" : "DEUIACTION",
"name" : "u479f517", "name" : "u479f517",
"getPSUIAction" : { "getPSUIAction" : {
...@@ -925,6 +901,30 @@ ...@@ -925,6 +901,30 @@
"addSeparator" : true, "addSeparator" : true,
"showCaption" : true, "showCaption" : true,
"showIcon" : true "showIcon" : true
}, {
"detailType" : "DEUIACTION",
"name" : "ua98d563",
"getPSUIAction" : {
"caption" : "行编辑",
"codeName" : "ToggleRowEdit",
"fullCodeName" : "ToggleRowEdit",
"mOSFilePath" : "pssysapps/Web/pssysappdeuiactions/ToggleRowEdit",
"name" : "表格界面_行编辑开关操作",
"getPSSysImage" : {
"glyph" : "xf0ce@FontAwesome",
"cssClass" : "fa fa-table"
},
"predefinedType" : "GRIDVIEW_ROWEDITACTION",
"rTMOSFilePath" : "pssysapps/Web/pssysappdeuiactions/ToggleRowEdit",
"timeout" : 60000,
"uIActionMode" : "SYS",
"uIActionTag" : "ToggleRowEdit",
"uIActionType" : "DEUIACTION",
"enableToggleMode" : true
},
"addSeparator" : true,
"showCaption" : true,
"showIcon" : false
} ], } ],
"rTMOSFilePath" : "pssysapps/Web/psappdataentities/Reginfo/psappdeuagroups/A046596b6afb50f9e5b" "rTMOSFilePath" : "pssysapps/Web/psappdataentities/Reginfo/psappdeuagroups/A046596b6afb50f9e5b"
}, },
......
...@@ -389,34 +389,34 @@ ...@@ -389,34 +389,34 @@
"getPSAppViewLogics" : [ { "getPSAppViewLogics" : [ {
"logicTrigger" : "CUSTOM", "logicTrigger" : "CUSTOM",
"logicType" : "APPVIEWUIACTION", "logicType" : "APPVIEWUIACTION",
"name" : "grid_uagridcolumn1_ua98d563_click", "name" : "grid_uagridcolumn1_u479f517_click",
"getPSAppViewUIAction" : { "getPSAppViewUIAction" : {
"modelref" : true, "modelref" : true,
"id" : "表格界面_行编辑开关操作" "id" : "表格界面_编辑操作"
} }
}, { }, {
"logicTrigger" : "CUSTOM", "logicTrigger" : "CUSTOM",
"logicType" : "APPVIEWUIACTION", "logicType" : "APPVIEWUIACTION",
"name" : "grid_uagridcolumn1_u479f517_click", "name" : "grid_uagridcolumn1_ua98d563_click",
"getPSAppViewUIAction" : { "getPSAppViewUIAction" : {
"modelref" : true, "modelref" : true,
"id" : "表格界面_编辑操作" "id" : "表格界面_行编辑开关操作"
} }
} ], } ],
"getPSAppViewUIActions" : [ { "getPSAppViewUIActions" : [ {
"name" : "表格界面_行编辑开关操作", "name" : "表格界面_编辑操作",
"getPSUIAction" : { "getPSUIAction" : {
"modelref" : true, "modelref" : true,
"id" : "ToggleRowEdit" "id" : "Edit"
}, },
"uIActionTarget" : "SINGLEKEY",
"xDataControlName" : "grid" "xDataControlName" : "grid"
}, { }, {
"name" : "表格界面_编辑操作", "name" : "表格界面_行编辑开关操作",
"getPSUIAction" : { "getPSUIAction" : {
"modelref" : true, "modelref" : true,
"id" : "Edit" "id" : "ToggleRowEdit"
}, },
"uIActionTarget" : "SINGLEKEY",
"xDataControlName" : "grid" "xDataControlName" : "grid"
} ], } ],
"getPSControlHandler" : { "getPSControlHandler" : {
...@@ -648,30 +648,6 @@ ...@@ -648,30 +648,6 @@
"mOSFilePath" : "pssysapps/Web/psappdataentities/Reginfo/psappdeuagroups/A046596b6afb50f9e5b", "mOSFilePath" : "pssysapps/Web/psappdataentities/Reginfo/psappdeuagroups/A046596b6afb50f9e5b",
"name" : "操作列", "name" : "操作列",
"getPSUIActionGroupDetails" : [ { "getPSUIActionGroupDetails" : [ {
"detailType" : "DEUIACTION",
"name" : "ua98d563",
"getPSUIAction" : {
"caption" : "行编辑",
"codeName" : "ToggleRowEdit",
"fullCodeName" : "ToggleRowEdit",
"mOSFilePath" : "pssysapps/Web/pssysappdeuiactions/ToggleRowEdit",
"name" : "表格界面_行编辑开关操作",
"getPSSysImage" : {
"glyph" : "xf0ce@FontAwesome",
"cssClass" : "fa fa-table"
},
"predefinedType" : "GRIDVIEW_ROWEDITACTION",
"rTMOSFilePath" : "pssysapps/Web/pssysappdeuiactions/ToggleRowEdit",
"timeout" : 60000,
"uIActionMode" : "SYS",
"uIActionTag" : "ToggleRowEdit",
"uIActionType" : "DEUIACTION",
"enableToggleMode" : true
},
"addSeparator" : true,
"showCaption" : true,
"showIcon" : false
}, {
"detailType" : "DEUIACTION", "detailType" : "DEUIACTION",
"name" : "u479f517", "name" : "u479f517",
"getPSUIAction" : { "getPSUIAction" : {
...@@ -705,6 +681,30 @@ ...@@ -705,6 +681,30 @@
"addSeparator" : true, "addSeparator" : true,
"showCaption" : true, "showCaption" : true,
"showIcon" : true "showIcon" : true
}, {
"detailType" : "DEUIACTION",
"name" : "ua98d563",
"getPSUIAction" : {
"caption" : "行编辑",
"codeName" : "ToggleRowEdit",
"fullCodeName" : "ToggleRowEdit",
"mOSFilePath" : "pssysapps/Web/pssysappdeuiactions/ToggleRowEdit",
"name" : "表格界面_行编辑开关操作",
"getPSSysImage" : {
"glyph" : "xf0ce@FontAwesome",
"cssClass" : "fa fa-table"
},
"predefinedType" : "GRIDVIEW_ROWEDITACTION",
"rTMOSFilePath" : "pssysapps/Web/pssysappdeuiactions/ToggleRowEdit",
"timeout" : 60000,
"uIActionMode" : "SYS",
"uIActionTag" : "ToggleRowEdit",
"uIActionType" : "DEUIACTION",
"enableToggleMode" : true
},
"addSeparator" : true,
"showCaption" : true,
"showIcon" : false
} ], } ],
"rTMOSFilePath" : "pssysapps/Web/psappdataentities/Reginfo/psappdeuagroups/A046596b6afb50f9e5b" "rTMOSFilePath" : "pssysapps/Web/psappdataentities/Reginfo/psappdeuagroups/A046596b6afb50f9e5b"
}, },
......
...@@ -440,34 +440,34 @@ ...@@ -440,34 +440,34 @@
"getPSAppViewLogics" : [ { "getPSAppViewLogics" : [ {
"logicTrigger" : "CUSTOM", "logicTrigger" : "CUSTOM",
"logicType" : "APPVIEWUIACTION", "logicType" : "APPVIEWUIACTION",
"name" : "grid_uagridcolumn1_ua98d563_click", "name" : "grid_uagridcolumn1_u479f517_click",
"getPSAppViewUIAction" : { "getPSAppViewUIAction" : {
"modelref" : true, "modelref" : true,
"id" : "表格界面_行编辑开关操作" "id" : "表格界面_编辑操作"
} }
}, { }, {
"logicTrigger" : "CUSTOM", "logicTrigger" : "CUSTOM",
"logicType" : "APPVIEWUIACTION", "logicType" : "APPVIEWUIACTION",
"name" : "grid_uagridcolumn1_u479f517_click", "name" : "grid_uagridcolumn1_ua98d563_click",
"getPSAppViewUIAction" : { "getPSAppViewUIAction" : {
"modelref" : true, "modelref" : true,
"id" : "表格界面_编辑操作" "id" : "表格界面_行编辑开关操作"
} }
} ], } ],
"getPSAppViewUIActions" : [ { "getPSAppViewUIActions" : [ {
"name" : "表格界面_行编辑开关操作", "name" : "表格界面_编辑操作",
"getPSUIAction" : { "getPSUIAction" : {
"modelref" : true, "modelref" : true,
"id" : "ToggleRowEdit" "id" : "Edit"
}, },
"uIActionTarget" : "SINGLEKEY",
"xDataControlName" : "grid" "xDataControlName" : "grid"
}, { }, {
"name" : "表格界面_编辑操作", "name" : "表格界面_行编辑开关操作",
"getPSUIAction" : { "getPSUIAction" : {
"modelref" : true, "modelref" : true,
"id" : "Edit" "id" : "ToggleRowEdit"
}, },
"uIActionTarget" : "SINGLEKEY",
"xDataControlName" : "grid" "xDataControlName" : "grid"
} ], } ],
"getPSControlHandler" : { "getPSControlHandler" : {
...@@ -699,30 +699,6 @@ ...@@ -699,30 +699,6 @@
"mOSFilePath" : "pssysapps/Web/psappdataentities/Reginfo/psappdeuagroups/A046596b6afb50f9e5b", "mOSFilePath" : "pssysapps/Web/psappdataentities/Reginfo/psappdeuagroups/A046596b6afb50f9e5b",
"name" : "操作列", "name" : "操作列",
"getPSUIActionGroupDetails" : [ { "getPSUIActionGroupDetails" : [ {
"detailType" : "DEUIACTION",
"name" : "ua98d563",
"getPSUIAction" : {
"caption" : "行编辑",
"codeName" : "ToggleRowEdit",
"fullCodeName" : "ToggleRowEdit",
"mOSFilePath" : "pssysapps/Web/pssysappdeuiactions/ToggleRowEdit",
"name" : "表格界面_行编辑开关操作",
"getPSSysImage" : {
"glyph" : "xf0ce@FontAwesome",
"cssClass" : "fa fa-table"
},
"predefinedType" : "GRIDVIEW_ROWEDITACTION",
"rTMOSFilePath" : "pssysapps/Web/pssysappdeuiactions/ToggleRowEdit",
"timeout" : 60000,
"uIActionMode" : "SYS",
"uIActionTag" : "ToggleRowEdit",
"uIActionType" : "DEUIACTION",
"enableToggleMode" : true
},
"addSeparator" : true,
"showCaption" : true,
"showIcon" : false
}, {
"detailType" : "DEUIACTION", "detailType" : "DEUIACTION",
"name" : "u479f517", "name" : "u479f517",
"getPSUIAction" : { "getPSUIAction" : {
...@@ -756,6 +732,30 @@ ...@@ -756,6 +732,30 @@
"addSeparator" : true, "addSeparator" : true,
"showCaption" : true, "showCaption" : true,
"showIcon" : true "showIcon" : true
}, {
"detailType" : "DEUIACTION",
"name" : "ua98d563",
"getPSUIAction" : {
"caption" : "行编辑",
"codeName" : "ToggleRowEdit",
"fullCodeName" : "ToggleRowEdit",
"mOSFilePath" : "pssysapps/Web/pssysappdeuiactions/ToggleRowEdit",
"name" : "表格界面_行编辑开关操作",
"getPSSysImage" : {
"glyph" : "xf0ce@FontAwesome",
"cssClass" : "fa fa-table"
},
"predefinedType" : "GRIDVIEW_ROWEDITACTION",
"rTMOSFilePath" : "pssysapps/Web/pssysappdeuiactions/ToggleRowEdit",
"timeout" : 60000,
"uIActionMode" : "SYS",
"uIActionTag" : "ToggleRowEdit",
"uIActionType" : "DEUIACTION",
"enableToggleMode" : true
},
"addSeparator" : true,
"showCaption" : true,
"showIcon" : false
} ], } ],
"rTMOSFilePath" : "pssysapps/Web/psappdataentities/Reginfo/psappdeuagroups/A046596b6afb50f9e5b" "rTMOSFilePath" : "pssysapps/Web/psappdataentities/Reginfo/psappdeuagroups/A046596b6afb50f9e5b"
}, },
......
...@@ -2059,34 +2059,34 @@ ...@@ -2059,34 +2059,34 @@
"getPSAppViewLogics" : [ { "getPSAppViewLogics" : [ {
"logicTrigger" : "CUSTOM", "logicTrigger" : "CUSTOM",
"logicType" : "APPVIEWUIACTION", "logicType" : "APPVIEWUIACTION",
"name" : "grid_uagridcolumn1_ua98d563_click", "name" : "grid_uagridcolumn1_u479f517_click",
"getPSAppViewUIAction" : { "getPSAppViewUIAction" : {
"modelref" : true, "modelref" : true,
"id" : "表格界面_行编辑开关操作" "id" : "表格界面_编辑操作"
} }
}, { }, {
"logicTrigger" : "CUSTOM", "logicTrigger" : "CUSTOM",
"logicType" : "APPVIEWUIACTION", "logicType" : "APPVIEWUIACTION",
"name" : "grid_uagridcolumn1_u479f517_click", "name" : "grid_uagridcolumn1_ua98d563_click",
"getPSAppViewUIAction" : { "getPSAppViewUIAction" : {
"modelref" : true, "modelref" : true,
"id" : "表格界面_编辑操作" "id" : "表格界面_行编辑开关操作"
} }
} ], } ],
"getPSAppViewUIActions" : [ { "getPSAppViewUIActions" : [ {
"name" : "表格界面_行编辑开关操作", "name" : "表格界面_编辑操作",
"getPSUIAction" : { "getPSUIAction" : {
"modelref" : true, "modelref" : true,
"id" : "ToggleRowEdit" "id" : "Edit"
}, },
"uIActionTarget" : "SINGLEKEY",
"xDataControlName" : "grid" "xDataControlName" : "grid"
}, { }, {
"name" : "表格界面_编辑操作", "name" : "表格界面_行编辑开关操作",
"getPSUIAction" : { "getPSUIAction" : {
"modelref" : true, "modelref" : true,
"id" : "Edit" "id" : "ToggleRowEdit"
}, },
"uIActionTarget" : "SINGLEKEY",
"xDataControlName" : "grid" "xDataControlName" : "grid"
} ], } ],
"getPSControlHandler" : { "getPSControlHandler" : {
...@@ -2318,30 +2318,6 @@ ...@@ -2318,30 +2318,6 @@
"mOSFilePath" : "pssysapps/Web/psappdataentities/Reginfo/psappdeuagroups/A046596b6afb50f9e5b", "mOSFilePath" : "pssysapps/Web/psappdataentities/Reginfo/psappdeuagroups/A046596b6afb50f9e5b",
"name" : "操作列", "name" : "操作列",
"getPSUIActionGroupDetails" : [ { "getPSUIActionGroupDetails" : [ {
"detailType" : "DEUIACTION",
"name" : "ua98d563",
"getPSUIAction" : {
"caption" : "行编辑",
"codeName" : "ToggleRowEdit",
"fullCodeName" : "ToggleRowEdit",
"mOSFilePath" : "pssysapps/Web/pssysappdeuiactions/ToggleRowEdit",
"name" : "表格界面_行编辑开关操作",
"getPSSysImage" : {
"glyph" : "xf0ce@FontAwesome",
"cssClass" : "fa fa-table"
},
"predefinedType" : "GRIDVIEW_ROWEDITACTION",
"rTMOSFilePath" : "pssysapps/Web/pssysappdeuiactions/ToggleRowEdit",
"timeout" : 60000,
"uIActionMode" : "SYS",
"uIActionTag" : "ToggleRowEdit",
"uIActionType" : "DEUIACTION",
"enableToggleMode" : true
},
"addSeparator" : true,
"showCaption" : true,
"showIcon" : false
}, {
"detailType" : "DEUIACTION", "detailType" : "DEUIACTION",
"name" : "u479f517", "name" : "u479f517",
"getPSUIAction" : { "getPSUIAction" : {
...@@ -2375,6 +2351,30 @@ ...@@ -2375,6 +2351,30 @@
"addSeparator" : true, "addSeparator" : true,
"showCaption" : true, "showCaption" : true,
"showIcon" : true "showIcon" : true
}, {
"detailType" : "DEUIACTION",
"name" : "ua98d563",
"getPSUIAction" : {
"caption" : "行编辑",
"codeName" : "ToggleRowEdit",
"fullCodeName" : "ToggleRowEdit",
"mOSFilePath" : "pssysapps/Web/pssysappdeuiactions/ToggleRowEdit",
"name" : "表格界面_行编辑开关操作",
"getPSSysImage" : {
"glyph" : "xf0ce@FontAwesome",
"cssClass" : "fa fa-table"
},
"predefinedType" : "GRIDVIEW_ROWEDITACTION",
"rTMOSFilePath" : "pssysapps/Web/pssysappdeuiactions/ToggleRowEdit",
"timeout" : 60000,
"uIActionMode" : "SYS",
"uIActionTag" : "ToggleRowEdit",
"uIActionType" : "DEUIACTION",
"enableToggleMode" : true
},
"addSeparator" : true,
"showCaption" : true,
"showIcon" : false
} ], } ],
"rTMOSFilePath" : "pssysapps/Web/psappdataentities/Reginfo/psappdeuagroups/A046596b6afb50f9e5b" "rTMOSFilePath" : "pssysapps/Web/psappdataentities/Reginfo/psappdeuagroups/A046596b6afb50f9e5b"
}, },
......
...@@ -1682,34 +1682,34 @@ ...@@ -1682,34 +1682,34 @@
"getPSAppViewLogics" : [ { "getPSAppViewLogics" : [ {
"logicTrigger" : "CUSTOM", "logicTrigger" : "CUSTOM",
"logicType" : "APPVIEWUIACTION", "logicType" : "APPVIEWUIACTION",
"name" : "grid_uagridcolumn1_ua98d563_click", "name" : "grid_uagridcolumn1_u479f517_click",
"getPSAppViewUIAction" : { "getPSAppViewUIAction" : {
"modelref" : true, "modelref" : true,
"id" : "表格界面_行编辑开关操作" "id" : "表格界面_编辑操作"
} }
}, { }, {
"logicTrigger" : "CUSTOM", "logicTrigger" : "CUSTOM",
"logicType" : "APPVIEWUIACTION", "logicType" : "APPVIEWUIACTION",
"name" : "grid_uagridcolumn1_u479f517_click", "name" : "grid_uagridcolumn1_ua98d563_click",
"getPSAppViewUIAction" : { "getPSAppViewUIAction" : {
"modelref" : true, "modelref" : true,
"id" : "表格界面_编辑操作" "id" : "表格界面_行编辑开关操作"
} }
} ], } ],
"getPSAppViewUIActions" : [ { "getPSAppViewUIActions" : [ {
"name" : "表格界面_行编辑开关操作", "name" : "表格界面_编辑操作",
"getPSUIAction" : { "getPSUIAction" : {
"modelref" : true, "modelref" : true,
"id" : "ToggleRowEdit" "id" : "Edit"
}, },
"uIActionTarget" : "SINGLEKEY",
"xDataControlName" : "grid" "xDataControlName" : "grid"
}, { }, {
"name" : "表格界面_编辑操作", "name" : "表格界面_行编辑开关操作",
"getPSUIAction" : { "getPSUIAction" : {
"modelref" : true, "modelref" : true,
"id" : "Edit" "id" : "ToggleRowEdit"
}, },
"uIActionTarget" : "SINGLEKEY",
"xDataControlName" : "grid" "xDataControlName" : "grid"
} ], } ],
"getPSControlHandler" : { "getPSControlHandler" : {
...@@ -1941,30 +1941,6 @@ ...@@ -1941,30 +1941,6 @@
"mOSFilePath" : "pssysapps/Web/psappdataentities/Reginfo/psappdeuagroups/A046596b6afb50f9e5b", "mOSFilePath" : "pssysapps/Web/psappdataentities/Reginfo/psappdeuagroups/A046596b6afb50f9e5b",
"name" : "操作列", "name" : "操作列",
"getPSUIActionGroupDetails" : [ { "getPSUIActionGroupDetails" : [ {
"detailType" : "DEUIACTION",
"name" : "ua98d563",
"getPSUIAction" : {
"caption" : "行编辑",
"codeName" : "ToggleRowEdit",
"fullCodeName" : "ToggleRowEdit",
"mOSFilePath" : "pssysapps/Web/pssysappdeuiactions/ToggleRowEdit",
"name" : "表格界面_行编辑开关操作",
"getPSSysImage" : {
"glyph" : "xf0ce@FontAwesome",
"cssClass" : "fa fa-table"
},
"predefinedType" : "GRIDVIEW_ROWEDITACTION",
"rTMOSFilePath" : "pssysapps/Web/pssysappdeuiactions/ToggleRowEdit",
"timeout" : 60000,
"uIActionMode" : "SYS",
"uIActionTag" : "ToggleRowEdit",
"uIActionType" : "DEUIACTION",
"enableToggleMode" : true
},
"addSeparator" : true,
"showCaption" : true,
"showIcon" : false
}, {
"detailType" : "DEUIACTION", "detailType" : "DEUIACTION",
"name" : "u479f517", "name" : "u479f517",
"getPSUIAction" : { "getPSUIAction" : {
...@@ -1998,6 +1974,30 @@ ...@@ -1998,6 +1974,30 @@
"addSeparator" : true, "addSeparator" : true,
"showCaption" : true, "showCaption" : true,
"showIcon" : true "showIcon" : true
}, {
"detailType" : "DEUIACTION",
"name" : "ua98d563",
"getPSUIAction" : {
"caption" : "行编辑",
"codeName" : "ToggleRowEdit",
"fullCodeName" : "ToggleRowEdit",
"mOSFilePath" : "pssysapps/Web/pssysappdeuiactions/ToggleRowEdit",
"name" : "表格界面_行编辑开关操作",
"getPSSysImage" : {
"glyph" : "xf0ce@FontAwesome",
"cssClass" : "fa fa-table"
},
"predefinedType" : "GRIDVIEW_ROWEDITACTION",
"rTMOSFilePath" : "pssysapps/Web/pssysappdeuiactions/ToggleRowEdit",
"timeout" : 60000,
"uIActionMode" : "SYS",
"uIActionTag" : "ToggleRowEdit",
"uIActionType" : "DEUIACTION",
"enableToggleMode" : true
},
"addSeparator" : true,
"showCaption" : true,
"showIcon" : false
} ], } ],
"rTMOSFilePath" : "pssysapps/Web/psappdataentities/Reginfo/psappdeuagroups/A046596b6afb50f9e5b" "rTMOSFilePath" : "pssysapps/Web/psappdataentities/Reginfo/psappdeuagroups/A046596b6afb50f9e5b"
}, },
......
...@@ -7304,34 +7304,34 @@ ...@@ -7304,34 +7304,34 @@
"getPSAppViewLogics" : [ { "getPSAppViewLogics" : [ {
"logicTrigger" : "CUSTOM", "logicTrigger" : "CUSTOM",
"logicType" : "APPVIEWUIACTION", "logicType" : "APPVIEWUIACTION",
"name" : "grid_uagridcolumn1_ua98d563_click", "name" : "grid_uagridcolumn1_u479f517_click",
"getPSAppViewUIAction" : { "getPSAppViewUIAction" : {
"modelref" : true, "modelref" : true,
"id" : "表格界面_行编辑开关操作" "id" : "表格界面_编辑操作"
} }
}, { }, {
"logicTrigger" : "CUSTOM", "logicTrigger" : "CUSTOM",
"logicType" : "APPVIEWUIACTION", "logicType" : "APPVIEWUIACTION",
"name" : "grid_uagridcolumn1_u479f517_click", "name" : "grid_uagridcolumn1_ua98d563_click",
"getPSAppViewUIAction" : { "getPSAppViewUIAction" : {
"modelref" : true, "modelref" : true,
"id" : "表格界面_编辑操作" "id" : "表格界面_行编辑开关操作"
} }
} ], } ],
"getPSAppViewUIActions" : [ { "getPSAppViewUIActions" : [ {
"name" : "表格界面_行编辑开关操作", "name" : "表格界面_编辑操作",
"getPSUIAction" : { "getPSUIAction" : {
"modelref" : true, "modelref" : true,
"id" : "ToggleRowEdit" "id" : "Edit"
}, },
"uIActionTarget" : "SINGLEKEY",
"xDataControlName" : "grid" "xDataControlName" : "grid"
}, { }, {
"name" : "表格界面_编辑操作", "name" : "表格界面_行编辑开关操作",
"getPSUIAction" : { "getPSUIAction" : {
"modelref" : true, "modelref" : true,
"id" : "Edit" "id" : "ToggleRowEdit"
}, },
"uIActionTarget" : "SINGLEKEY",
"xDataControlName" : "grid" "xDataControlName" : "grid"
} ], } ],
"getPSControlHandler" : { "getPSControlHandler" : {
...@@ -7563,30 +7563,6 @@ ...@@ -7563,30 +7563,6 @@
"mOSFilePath" : "pssysapps/Web/psappdataentities/Reginfo/psappdeuagroups/A046596b6afb50f9e5b", "mOSFilePath" : "pssysapps/Web/psappdataentities/Reginfo/psappdeuagroups/A046596b6afb50f9e5b",
"name" : "操作列", "name" : "操作列",
"getPSUIActionGroupDetails" : [ { "getPSUIActionGroupDetails" : [ {
"detailType" : "DEUIACTION",
"name" : "ua98d563",
"getPSUIAction" : {
"caption" : "行编辑",
"codeName" : "ToggleRowEdit",
"fullCodeName" : "ToggleRowEdit",
"mOSFilePath" : "pssysapps/Web/pssysappdeuiactions/ToggleRowEdit",
"name" : "表格界面_行编辑开关操作",
"getPSSysImage" : {
"glyph" : "xf0ce@FontAwesome",
"cssClass" : "fa fa-table"
},
"predefinedType" : "GRIDVIEW_ROWEDITACTION",
"rTMOSFilePath" : "pssysapps/Web/pssysappdeuiactions/ToggleRowEdit",
"timeout" : 60000,
"uIActionMode" : "SYS",
"uIActionTag" : "ToggleRowEdit",
"uIActionType" : "DEUIACTION",
"enableToggleMode" : true
},
"addSeparator" : true,
"showCaption" : true,
"showIcon" : false
}, {
"detailType" : "DEUIACTION", "detailType" : "DEUIACTION",
"name" : "u479f517", "name" : "u479f517",
"getPSUIAction" : { "getPSUIAction" : {
...@@ -7620,6 +7596,30 @@ ...@@ -7620,6 +7596,30 @@
"addSeparator" : true, "addSeparator" : true,
"showCaption" : true, "showCaption" : true,
"showIcon" : true "showIcon" : true
}, {
"detailType" : "DEUIACTION",
"name" : "ua98d563",
"getPSUIAction" : {
"caption" : "行编辑",
"codeName" : "ToggleRowEdit",
"fullCodeName" : "ToggleRowEdit",
"mOSFilePath" : "pssysapps/Web/pssysappdeuiactions/ToggleRowEdit",
"name" : "表格界面_行编辑开关操作",
"getPSSysImage" : {
"glyph" : "xf0ce@FontAwesome",
"cssClass" : "fa fa-table"
},
"predefinedType" : "GRIDVIEW_ROWEDITACTION",
"rTMOSFilePath" : "pssysapps/Web/pssysappdeuiactions/ToggleRowEdit",
"timeout" : 60000,
"uIActionMode" : "SYS",
"uIActionTag" : "ToggleRowEdit",
"uIActionType" : "DEUIACTION",
"enableToggleMode" : true
},
"addSeparator" : true,
"showCaption" : true,
"showIcon" : false
} ], } ],
"rTMOSFilePath" : "pssysapps/Web/psappdataentities/Reginfo/psappdeuagroups/A046596b6afb50f9e5b" "rTMOSFilePath" : "pssysapps/Web/psappdataentities/Reginfo/psappdeuagroups/A046596b6afb50f9e5b"
}, },
...@@ -12103,34 +12103,34 @@ ...@@ -12103,34 +12103,34 @@
"getPSAppViewLogics" : [ { "getPSAppViewLogics" : [ {
"logicTrigger" : "CUSTOM", "logicTrigger" : "CUSTOM",
"logicType" : "APPVIEWUIACTION", "logicType" : "APPVIEWUIACTION",
"name" : "grid_uagridcolumn1_ua98d563_click", "name" : "grid_uagridcolumn1_u479f517_click",
"getPSAppViewUIAction" : { "getPSAppViewUIAction" : {
"modelref" : true, "modelref" : true,
"id" : "表格界面_行编辑开关操作" "id" : "表格界面_编辑操作"
} }
}, { }, {
"logicTrigger" : "CUSTOM", "logicTrigger" : "CUSTOM",
"logicType" : "APPVIEWUIACTION", "logicType" : "APPVIEWUIACTION",
"name" : "grid_uagridcolumn1_u479f517_click", "name" : "grid_uagridcolumn1_ua98d563_click",
"getPSAppViewUIAction" : { "getPSAppViewUIAction" : {
"modelref" : true, "modelref" : true,
"id" : "表格界面_编辑操作" "id" : "表格界面_行编辑开关操作"
} }
} ], } ],
"getPSAppViewUIActions" : [ { "getPSAppViewUIActions" : [ {
"name" : "表格界面_行编辑开关操作", "name" : "表格界面_编辑操作",
"getPSUIAction" : { "getPSUIAction" : {
"modelref" : true, "modelref" : true,
"id" : "ToggleRowEdit" "id" : "Edit"
}, },
"uIActionTarget" : "SINGLEKEY",
"xDataControlName" : "grid" "xDataControlName" : "grid"
}, { }, {
"name" : "表格界面_编辑操作", "name" : "表格界面_行编辑开关操作",
"getPSUIAction" : { "getPSUIAction" : {
"modelref" : true, "modelref" : true,
"id" : "Edit" "id" : "ToggleRowEdit"
}, },
"uIActionTarget" : "SINGLEKEY",
"xDataControlName" : "grid" "xDataControlName" : "grid"
} ], } ],
"getPSControlHandler" : { "getPSControlHandler" : {
...@@ -12362,30 +12362,6 @@ ...@@ -12362,30 +12362,6 @@
"mOSFilePath" : "pssysapps/Web/psappdataentities/Reginfo/psappdeuagroups/A046596b6afb50f9e5b", "mOSFilePath" : "pssysapps/Web/psappdataentities/Reginfo/psappdeuagroups/A046596b6afb50f9e5b",
"name" : "操作列", "name" : "操作列",
"getPSUIActionGroupDetails" : [ { "getPSUIActionGroupDetails" : [ {
"detailType" : "DEUIACTION",
"name" : "ua98d563",
"getPSUIAction" : {
"caption" : "行编辑",
"codeName" : "ToggleRowEdit",
"fullCodeName" : "ToggleRowEdit",
"mOSFilePath" : "pssysapps/Web/pssysappdeuiactions/ToggleRowEdit",
"name" : "表格界面_行编辑开关操作",
"getPSSysImage" : {
"glyph" : "xf0ce@FontAwesome",
"cssClass" : "fa fa-table"
},
"predefinedType" : "GRIDVIEW_ROWEDITACTION",
"rTMOSFilePath" : "pssysapps/Web/pssysappdeuiactions/ToggleRowEdit",
"timeout" : 60000,
"uIActionMode" : "SYS",
"uIActionTag" : "ToggleRowEdit",
"uIActionType" : "DEUIACTION",
"enableToggleMode" : true
},
"addSeparator" : true,
"showCaption" : true,
"showIcon" : false
}, {
"detailType" : "DEUIACTION", "detailType" : "DEUIACTION",
"name" : "u479f517", "name" : "u479f517",
"getPSUIAction" : { "getPSUIAction" : {
...@@ -12419,6 +12395,30 @@ ...@@ -12419,6 +12395,30 @@
"addSeparator" : true, "addSeparator" : true,
"showCaption" : true, "showCaption" : true,
"showIcon" : true "showIcon" : true
}, {
"detailType" : "DEUIACTION",
"name" : "ua98d563",
"getPSUIAction" : {
"caption" : "行编辑",
"codeName" : "ToggleRowEdit",
"fullCodeName" : "ToggleRowEdit",
"mOSFilePath" : "pssysapps/Web/pssysappdeuiactions/ToggleRowEdit",
"name" : "表格界面_行编辑开关操作",
"getPSSysImage" : {
"glyph" : "xf0ce@FontAwesome",
"cssClass" : "fa fa-table"
},
"predefinedType" : "GRIDVIEW_ROWEDITACTION",
"rTMOSFilePath" : "pssysapps/Web/pssysappdeuiactions/ToggleRowEdit",
"timeout" : 60000,
"uIActionMode" : "SYS",
"uIActionTag" : "ToggleRowEdit",
"uIActionType" : "DEUIACTION",
"enableToggleMode" : true
},
"addSeparator" : true,
"showCaption" : true,
"showIcon" : false
} ], } ],
"rTMOSFilePath" : "pssysapps/Web/psappdataentities/Reginfo/psappdeuagroups/A046596b6afb50f9e5b" "rTMOSFilePath" : "pssysapps/Web/psappdataentities/Reginfo/psappdeuagroups/A046596b6afb50f9e5b"
}, },
Markdown 格式
0% or
您添加了 0 到此讨论。请谨慎行事。
先完成此消息的编辑!
想要评论请 注册