imm-element-ui 0.5.6 → 0.5.8
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/form/form/form.component.mjs +2 -2
- package/esm2022/lib/form/form-field/form-field.mjs +9 -3
- package/esm2022/lib/form/form-type/image.type.mjs +3 -3
- package/esm2022/lib/form/form-type/radio.type.mjs +2 -3
- package/esm2022/lib/grid/cell-render/chip-render.mjs +62 -0
- package/esm2022/lib/grid/grid/grid.component.mjs +2 -1
- package/esm2022/lib/grid/mock-data.mjs +3 -1
- package/esm2022/lib/import/import.component.mjs +1 -2
- package/esm2022/lib/service/action.service.mjs +15 -4
- package/esm2022/lib/share/utils.mjs +123 -1
- package/fesm2022/imm-element-ui.mjs +208 -13
- package/fesm2022/imm-element-ui.mjs.map +1 -1
- package/lib/crumb-action/crumb-action.component.d.ts +1 -1
- package/lib/grid/cell-render/chip-render.d.ts +8 -0
- package/lib/grid/grid/grid.component.d.ts +2 -1
- package/lib/grid/mock-data.d.ts +2 -0
- package/lib/service/action.service.d.ts +3 -1
- package/lib/share/utils.d.ts +8 -0
- package/package.json +1 -1
|
@@ -1,5 +1,7 @@
|
|
|
1
|
+
import { FormGroup } from '@angular/forms';
|
|
1
2
|
import { Observable, of, shareReplay, pipe } from 'rxjs';
|
|
2
3
|
import * as ts from 'typescript';
|
|
4
|
+
import { formTypeToProps } from '../../public-api';
|
|
3
5
|
export let toPascalCase = (str) => str
|
|
4
6
|
.replace(/_/g, ' ') // 下划线替换为空格
|
|
5
7
|
.replace(/([a-z])([A-Z])/g, '$1 $2') // 小驼峰分割为单词
|
|
@@ -166,4 +168,124 @@ export const convertAct = (act) => {
|
|
|
166
168
|
});
|
|
167
169
|
return act;
|
|
168
170
|
};
|
|
169
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../../../projects/imm-element-ui/src/lib/share/utils.ts"],"names":[],"mappings":"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","sourcesContent":["import { Observable, of, shareReplay, pipe } from 'rxjs';\r\nimport * as ts from 'typescript';\r\n\r\nexport let toPascalCase = (str: string) =>\r\n\tstr\r\n\t\t.replace(/_/g, ' ') // 下划线替换为空格\r\n\t\t.replace(/([a-z])([A-Z])/g, '$1 $2') // 小驼峰分割为单词\r\n\t\t.toLowerCase() // 转为小写\r\n\t\t.split(/\\s+/) // 按空格分割\r\n\t\t.map((word) => (word ? word[0].toUpperCase() + word.slice(1) : ''))\r\n\t\t.join('');\r\n\r\nexport const generateUniqueId = () => {\r\n\tconst timestamp = Date.now().toString(36); // 时间戳转36进制缩短长度\r\n\tconst random = Math.random().toString(36).substring(2, 4); // 随机部分\r\n\treturn `${timestamp}${random}`;\r\n};\r\n\r\nexport const createCircularIterator = (array: any[]) => {\r\n\tlet index = -1;\r\n\treturn {\r\n\t\tnext: () => {\r\n\t\t\tindex++;\r\n\t\t\treturn array[index % array.length];\r\n\t\t},\r\n\t\tprev: () => {\r\n\t\t\tindex--;\r\n\t\t\treturn array[((index % array.length) + array.length) % array.length];\r\n\t\t},\r\n\t};\r\n};\r\n\r\nexport const parseFunctions = (obj: any, _this: any): any => {\r\n\tif (typeof obj === 'string') {\r\n\t\t// 尝试检测是否是函数字符串\r\n\t\tif ((obj.includes('=>') || obj.includes('Promise')) && !isJSONParsable(obj)) {\r\n\t\t\tconst o = compileTsToJs(obj);\r\n\t\t\t// console.log('解析函数:', obj);\r\n\t\t\ttry {\r\n\t\t\t\tconst sandbox = {\r\n\t\t\t\t\tObservable,\r\n\t\t\t\t\tof,\r\n\t\t\t\t\tshareReplay,\r\n\t\t\t\t\tpipe,\r\n\t\t\t\t\tPromise, // 添加 Promise 到 sandbox\r\n\t\t\t\t\tasync: true, // 标记支持异步\r\n\t\t\t\t\tresolve: Promise.resolve.bind(Promise),\r\n\t\t\t\t\treject: Promise.reject.bind(Promise),\r\n\t\t\t\t};\r\n\r\n\t\t\t\t// 处理 Promise 构造函数的情况\r\n\t\t\t\tif (obj.includes('new Promise')) {\r\n\t\t\t\t\treturn new Function(\r\n\t\t\t\t\t\t'sandbox',\r\n\t\t\t\t\t\t`\r\n\t\t\t\t\t\t\twith(sandbox) {\r\n\t\t\t\t\t\t\t\treturn ${o};\r\n\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t`,\r\n\t\t\t\t\t).bind(_this)(sandbox);\r\n\t\t\t\t}\r\n\r\n\t\t\t\t// 处理普通函数和箭头函数\r\n\t\t\t\treturn new Function(\r\n\t\t\t\t\t'sandbox',\r\n\t\t\t\t\t`\r\n\t\t\t\t\t\twith(sandbox) {\r\n\t\t\t\t\t\t\treturn (${o});\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t`,\r\n\t\t\t\t).bind(_this)(sandbox);\r\n\t\t\t} catch (e) {\r\n\t\t\t\tconsole.error('函数解析失败:', e, '\\n原始字符串:', obj);\r\n\t\t\t\treturn obj;\r\n\t\t\t}\r\n\t\t}\r\n\t\tif (isJSONParsable(obj)) {\r\n\t\t\tlet json = JSON.parse(obj);\r\n\t\t\treturn parseFunctions(json, _this);\r\n\t\t}\r\n\t\treturn obj;\r\n\t}\r\n\tif (Array.isArray(obj)) {\r\n\t\treturn obj.map((item: any) => parseFunctions(item, _this));\r\n\t}\r\n\tif (typeof obj === 'object' && obj !== null) {\r\n\t\tconst result: any = {};\r\n\t\tfor (const key in obj) {\r\n\t\t\tif (obj.hasOwnProperty(key)) {\r\n\t\t\t\tresult[key] = parseFunctions(obj[key], _this);\r\n\t\t\t}\r\n\t\t}\r\n\t\treturn result;\r\n\t}\r\n\r\n\treturn obj;\r\n};\r\n\r\n// 辅助函数：检查是否包含 Promise 构造函数\r\nconst containsPromiseConstructor = (str: string): boolean => {\r\n\treturn /new\\s+Promise/.test(str);\r\n};\r\n\r\n// 修改 compileTsToJs 函数以更好地处理 Promise\r\nexport const compileTsToJs = (tsCode: string): string => {\r\n\t// 如果是 Promise 构造函数，不需要额外处理\r\n\tif (containsPromiseConstructor(tsCode)) {\r\n\t\treturn tsCode;\r\n\t}\r\n\r\n\tconst result = ts.transpileModule(tsCode, {\r\n\t\tcompilerOptions: {\r\n\t\t\tmodule: ts.ModuleKind.CommonJS,\r\n\t\t\ttarget: ts.ScriptTarget.ES2015,\r\n\t\t\t// 启用异步函数支持\r\n\t\t\tlib: ['es2015', 'es2015.promise', 'dom'],\r\n\t\t},\r\n\t});\r\n\treturn removeTrailingSemicolon(result.outputText);\r\n};\r\n\r\nconst removeTrailingSemicolon = (funcStr: string): string => {\r\n\t// 先去除前后空白\r\n\tconst trimmed = funcStr.trim();\r\n\t// 只替换最后一个分号（如果它不在花括号内）\r\n\tif (trimmed.endsWith(';')) {\r\n\t\treturn trimmed.slice(0, -1);\r\n\t}\r\n\treturn trimmed;\r\n};\r\n\r\nexport const isJSONParsable = (str: any) => {\r\n\ttry {\r\n\t\tJSON.parse(str);\r\n\t\treturn true;\r\n\t} catch (e) {\r\n\t\t// let strIsObj = /\\{[^}]*\\}|\\[[^\\]]*\\]/.test(str)\r\n\t\t// if(strIsObj){\r\n\t\t// \tconsole.error('JSON 解析失败:', e, '\\n原始字符串:', str)\r\n\t\t// }\r\n\t\treturn false;\r\n\t}\r\n};\r\n\r\n/**\r\n * 根据指定的键数组过滤对象\r\n * @param {Object} obj - 要过滤的原始对象\r\n * @param {Array} keys - 需要保留的键数组\r\n * @returns {Object} 过滤后的新对象\r\n */\r\nexport const filterObjectByKeys = (obj: any, keys: string[]) => {\r\n\t// 参数校验\r\n\tif (typeof obj !== 'object' || obj === null || Array.isArray(obj)) {\r\n\t\tthrow new TypeError('第一个参数必须是普通对象');\r\n\t}\r\n\r\n\tif (!Array.isArray(keys)) {\r\n\t\tthrow new TypeError('第二个参数必须是数组');\r\n\t}\r\n\r\n\t// 使用reduce创建新对象\r\n\treturn keys.reduce((acc: any, key: string) => {\r\n\t\t// 只有当原对象有该属性时才添加到新对象\r\n\t\tif (key in obj) {\r\n\t\t\tacc[key] = obj[key];\r\n\t\t}\r\n\t\treturn acc;\r\n\t}, {});\r\n};\r\n/**\r\n * 自定义函数去除空字符串\r\n * @param act \r\n * @returns \r\n */\r\nexport const convertAct = (act:any) =>{\r\n\tact.forEach((v:any) => {\r\n\t\tif(v.hasOwnProperty('btnHidden') &&typeof v.btnHidden != 'function'){\r\n\t\t\tdelete v.btnHidden\r\n\t\t}\r\n\t\tif(v.hasOwnProperty('btnDisabled') &&typeof v.btnDisabled != 'function'){\r\n\t\t\tdelete v.btnDisabled\r\n\t\t}\r\n\t\tif(v.hasOwnProperty('onClick') &&typeof v.onClick != 'function'){\r\n\t\t\tdelete v.onClick\r\n\t\t}\r\n\t})\r\n\treturn act;\r\n}"]}
|
|
171
|
+
/**
|
|
172
|
+
* formpage 通用content函数转移
|
|
173
|
+
* @param content
|
|
174
|
+
* @param thisArg
|
|
175
|
+
*/
|
|
176
|
+
export const changeContent = (content, thisArg) => {
|
|
177
|
+
let { gridList, hrefBtnList, getPrm, groups, statusKey, status, statusSteps, statusConf = null } = parseFunctions(content, thisArg);
|
|
178
|
+
if (statusKey) {
|
|
179
|
+
thisArg.statusKey = statusKey;
|
|
180
|
+
thisArg.steps = statusSteps;
|
|
181
|
+
statusConf && (thisArg.statusConf = statusConf);
|
|
182
|
+
}
|
|
183
|
+
// let act = parseFunctions(content.actions,thisArg)
|
|
184
|
+
thisArg.actions = convertAct(content.actions);
|
|
185
|
+
// content.formDisabled && (thisArg.formDisabled = parseFunctions(content.formDisabled, thisArg));
|
|
186
|
+
content.formDisabled && (thisArg.formDisabled = content.formDisabled);
|
|
187
|
+
thisArg.getPrm = getPrm;
|
|
188
|
+
thisArg.getPrm.orgField = content.orgField || '';
|
|
189
|
+
thisArg.grids = [];
|
|
190
|
+
let fiterPreloads = [];
|
|
191
|
+
// gridList = parseFunctions(gridList, thisArg);
|
|
192
|
+
// let groupArr = parseFunctions(groups, thisArg);
|
|
193
|
+
groups.forEach((item) => {
|
|
194
|
+
if (thisArg.authLevel < 3) {
|
|
195
|
+
item[formTypeToProps[item.type]].disabled = true;
|
|
196
|
+
}
|
|
197
|
+
});
|
|
198
|
+
thisArg.formOptions = {
|
|
199
|
+
fields: [
|
|
200
|
+
{
|
|
201
|
+
groupClass: 'flex flex-row flex-wrap',
|
|
202
|
+
group: groups,
|
|
203
|
+
},
|
|
204
|
+
],
|
|
205
|
+
form: new FormGroup({}),
|
|
206
|
+
mainField: content.sourceData.model.mainFields,
|
|
207
|
+
};
|
|
208
|
+
gridList.forEach(async (item) => {
|
|
209
|
+
!item.type && (item.type = 'grid');
|
|
210
|
+
let grid = { type: item.type };
|
|
211
|
+
if (item.fiterPreloads instanceof Array) {
|
|
212
|
+
fiterPreloads = [...fiterPreloads, ...item.fiterPreloads];
|
|
213
|
+
}
|
|
214
|
+
if (item.type == 'grid') {
|
|
215
|
+
let { gridOptions: { columnDefs, ...restGridOptions }, subTableSource, subDataKey, title, selectDataCb, fk, mainField, uniqueField, addDataCb, showDelete = true, scrollHeight, dragSort } = item;
|
|
216
|
+
grid = { subTableSource, subDataKey, title, showDelete, ...grid };
|
|
217
|
+
let gridOptions = {
|
|
218
|
+
...restGridOptions,
|
|
219
|
+
fk,
|
|
220
|
+
subTableSource,
|
|
221
|
+
subDataKey,
|
|
222
|
+
mainField,
|
|
223
|
+
};
|
|
224
|
+
if (scrollHeight) {
|
|
225
|
+
gridOptions.scrollHeight = `${scrollHeight}px`;
|
|
226
|
+
}
|
|
227
|
+
if (dragSort) {
|
|
228
|
+
gridOptions.rowDragManaged = true;
|
|
229
|
+
gridOptions.dragSort = dragSort;
|
|
230
|
+
}
|
|
231
|
+
convertCol(columnDefs, thisArg.authLevel, gridOptions.modelName, dragSort);
|
|
232
|
+
gridOptions.columnDefs = columnDefs;
|
|
233
|
+
if (subTableSource === 'select') {
|
|
234
|
+
thisArg.webget({ code: item.selectModelCode }).subscribe((res) => {
|
|
235
|
+
let selectContent = JSON.parse(res.content);
|
|
236
|
+
grid.selectOptions = parseFunctions(selectContent, thisArg)?.gridOptions;
|
|
237
|
+
grid.selectOptions.rowModelType = grid.selectOptions.rowModelType || 'serverSide';
|
|
238
|
+
if (grid.selectOptions.rowModelType == 'serverSide') {
|
|
239
|
+
grid.selectOptions.serverFunc = grid.selectOptions.serverFunc || thisArg.web_search.bind(thisArg);
|
|
240
|
+
}
|
|
241
|
+
else {
|
|
242
|
+
grid.selectOptions.clientFunc = grid.selectOptions.clientFunc || thisArg.web_search.bind(thisArg);
|
|
243
|
+
}
|
|
244
|
+
grid.uniqueField = uniqueField;
|
|
245
|
+
grid.selectDataCb = selectDataCb;
|
|
246
|
+
grid.selectOptions.scrollHeight = '300px';
|
|
247
|
+
gridOptionsHooker(grid.selectOptions, selectContent);
|
|
248
|
+
});
|
|
249
|
+
grid.searchPrm = { ...thisArg.searchPrm };
|
|
250
|
+
}
|
|
251
|
+
else {
|
|
252
|
+
addDataCb && (gridOptions.addDataCb = addDataCb);
|
|
253
|
+
}
|
|
254
|
+
grid.gridOptions = gridOptions;
|
|
255
|
+
}
|
|
256
|
+
else {
|
|
257
|
+
item.interactiveLabel = true;
|
|
258
|
+
grid = {
|
|
259
|
+
...item
|
|
260
|
+
};
|
|
261
|
+
grid.form = new FormGroup({});
|
|
262
|
+
}
|
|
263
|
+
thisArg.grids.push(grid);
|
|
264
|
+
});
|
|
265
|
+
thisArg.formDetail = content.formDetail;
|
|
266
|
+
thisArg.saveFunc = content.saveFunc;
|
|
267
|
+
thisArg.isLog = content.sourceData.model.log;
|
|
268
|
+
thisArg.getPrm['getLog'] = content.sourceData.model.log;
|
|
269
|
+
thisArg.getPrm['fiterPreloads'] = fiterPreloads;
|
|
270
|
+
thisArg.hrefBtnList = hrefBtnList;
|
|
271
|
+
};
|
|
272
|
+
export const convertCol = (col, authLevel, modelName, dragSort) => {
|
|
273
|
+
col.forEach((item, index) => {
|
|
274
|
+
item.hide = item.hideCol;
|
|
275
|
+
if (authLevel < 3) {
|
|
276
|
+
item.editable = false;
|
|
277
|
+
}
|
|
278
|
+
if (dragSort && index === 0) {
|
|
279
|
+
item.rowDrag = true;
|
|
280
|
+
}
|
|
281
|
+
});
|
|
282
|
+
};
|
|
283
|
+
export const gridOptionsHooker = (gridOptions, selectContent) => {
|
|
284
|
+
gridOptions?.columnDefs?.forEach((col) => {
|
|
285
|
+
if (col.hideCol) {
|
|
286
|
+
col.hide = col.hideCol;
|
|
287
|
+
delete col.hideCol;
|
|
288
|
+
}
|
|
289
|
+
});
|
|
290
|
+
};
|
|
291
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../../../../projects/imm-element-ui/src/lib/share/utils.ts"],"names":[],"mappings":"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","sourcesContent":["import { FormGroup } from '@angular/forms';\r\nimport { Observable, of, shareReplay, pipe } from 'rxjs';\r\nimport * as ts from 'typescript';\r\nimport { formTypeToProps } from '../../public-api';\r\n\r\nexport let toPascalCase = (str: string) =>\r\n\tstr\r\n\t\t.replace(/_/g, ' ') // 下划线替换为空格\r\n\t\t.replace(/([a-z])([A-Z])/g, '$1 $2') // 小驼峰分割为单词\r\n\t\t.toLowerCase() // 转为小写\r\n\t\t.split(/\\s+/) // 按空格分割\r\n\t\t.map((word) => (word ? word[0].toUpperCase() + word.slice(1) : ''))\r\n\t\t.join('');\r\n\r\nexport const generateUniqueId = () => {\r\n\tconst timestamp = Date.now().toString(36); // 时间戳转36进制缩短长度\r\n\tconst random = Math.random().toString(36).substring(2, 4); // 随机部分\r\n\treturn `${timestamp}${random}`;\r\n};\r\n\r\nexport const createCircularIterator = (array: any[]) => {\r\n\tlet index = -1;\r\n\treturn {\r\n\t\tnext: () => {\r\n\t\t\tindex++;\r\n\t\t\treturn array[index % array.length];\r\n\t\t},\r\n\t\tprev: () => {\r\n\t\t\tindex--;\r\n\t\t\treturn array[((index % array.length) + array.length) % array.length];\r\n\t\t},\r\n\t};\r\n};\r\n\r\nexport const parseFunctions = (obj: any, _this: any): any => {\r\n\tif (typeof obj === 'string') {\r\n\t\t// 尝试检测是否是函数字符串\r\n\t\tif ((obj.includes('=>') || obj.includes('Promise')) && !isJSONParsable(obj)) {\r\n\t\t\tconst o = compileTsToJs(obj);\r\n\t\t\t// console.log('解析函数:', obj);\r\n\t\t\ttry {\r\n\t\t\t\tconst sandbox = {\r\n\t\t\t\t\tObservable,\r\n\t\t\t\t\tof,\r\n\t\t\t\t\tshareReplay,\r\n\t\t\t\t\tpipe,\r\n\t\t\t\t\tPromise, // 添加 Promise 到 sandbox\r\n\t\t\t\t\tasync: true, // 标记支持异步\r\n\t\t\t\t\tresolve: Promise.resolve.bind(Promise),\r\n\t\t\t\t\treject: Promise.reject.bind(Promise),\r\n\t\t\t\t};\r\n\r\n\t\t\t\t// 处理 Promise 构造函数的情况\r\n\t\t\t\tif (obj.includes('new Promise')) {\r\n\t\t\t\t\treturn new Function(\r\n\t\t\t\t\t\t'sandbox',\r\n\t\t\t\t\t\t`\r\n\t\t\t\t\t\t\twith(sandbox) {\r\n\t\t\t\t\t\t\t\treturn ${o};\r\n\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t`,\r\n\t\t\t\t\t).bind(_this)(sandbox);\r\n\t\t\t\t}\r\n\r\n\t\t\t\t// 处理普通函数和箭头函数\r\n\t\t\t\treturn new Function(\r\n\t\t\t\t\t'sandbox',\r\n\t\t\t\t\t`\r\n\t\t\t\t\t\twith(sandbox) {\r\n\t\t\t\t\t\t\treturn (${o});\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t`,\r\n\t\t\t\t).bind(_this)(sandbox);\r\n\t\t\t} catch (e) {\r\n\t\t\t\tconsole.error('函数解析失败:', e, '\\n原始字符串:', obj);\r\n\t\t\t\treturn obj;\r\n\t\t\t}\r\n\t\t}\r\n\t\tif (isJSONParsable(obj)) {\r\n\t\t\tlet json = JSON.parse(obj);\r\n\t\t\treturn parseFunctions(json, _this);\r\n\t\t}\r\n\t\treturn obj;\r\n\t}\r\n\tif (Array.isArray(obj)) {\r\n\t\treturn obj.map((item: any) => parseFunctions(item, _this));\r\n\t}\r\n\tif (typeof obj === 'object' && obj !== null) {\r\n\t\tconst result: any = {};\r\n\t\tfor (const key in obj) {\r\n\t\t\tif (obj.hasOwnProperty(key)) {\r\n\t\t\t\tresult[key] = parseFunctions(obj[key], _this);\r\n\t\t\t}\r\n\t\t}\r\n\t\treturn result;\r\n\t}\r\n\r\n\treturn obj;\r\n};\r\n\r\n// 辅助函数：检查是否包含 Promise 构造函数\r\nconst containsPromiseConstructor = (str: string): boolean => {\r\n\treturn /new\\s+Promise/.test(str);\r\n};\r\n\r\n// 修改 compileTsToJs 函数以更好地处理 Promise\r\nexport const compileTsToJs = (tsCode: string): string => {\r\n\t// 如果是 Promise 构造函数，不需要额外处理\r\n\tif (containsPromiseConstructor(tsCode)) {\r\n\t\treturn tsCode;\r\n\t}\r\n\r\n\tconst result = ts.transpileModule(tsCode, {\r\n\t\tcompilerOptions: {\r\n\t\t\tmodule: ts.ModuleKind.CommonJS,\r\n\t\t\ttarget: ts.ScriptTarget.ES2015,\r\n\t\t\t// 启用异步函数支持\r\n\t\t\tlib: ['es2015', 'es2015.promise', 'dom'],\r\n\t\t},\r\n\t});\r\n\treturn removeTrailingSemicolon(result.outputText);\r\n};\r\n\r\nconst removeTrailingSemicolon = (funcStr: string): string => {\r\n\t// 先去除前后空白\r\n\tconst trimmed = funcStr.trim();\r\n\t// 只替换最后一个分号（如果它不在花括号内）\r\n\tif (trimmed.endsWith(';')) {\r\n\t\treturn trimmed.slice(0, -1);\r\n\t}\r\n\treturn trimmed;\r\n};\r\n\r\nexport const isJSONParsable = (str: any) => {\r\n\ttry {\r\n\t\tJSON.parse(str);\r\n\t\treturn true;\r\n\t} catch (e) {\r\n\t\t// let strIsObj = /\\{[^}]*\\}|\\[[^\\]]*\\]/.test(str)\r\n\t\t// if(strIsObj){\r\n\t\t// \tconsole.error('JSON 解析失败:', e, '\\n原始字符串:', str)\r\n\t\t// }\r\n\t\treturn false;\r\n\t}\r\n};\r\n\r\n/**\r\n * 根据指定的键数组过滤对象\r\n * @param {Object} obj - 要过滤的原始对象\r\n * @param {Array} keys - 需要保留的键数组\r\n * @returns {Object} 过滤后的新对象\r\n */\r\nexport const filterObjectByKeys = (obj: any, keys: string[]) => {\r\n\t// 参数校验\r\n\tif (typeof obj !== 'object' || obj === null || Array.isArray(obj)) {\r\n\t\tthrow new TypeError('第一个参数必须是普通对象');\r\n\t}\r\n\r\n\tif (!Array.isArray(keys)) {\r\n\t\tthrow new TypeError('第二个参数必须是数组');\r\n\t}\r\n\r\n\t// 使用reduce创建新对象\r\n\treturn keys.reduce((acc: any, key: string) => {\r\n\t\t// 只有当原对象有该属性时才添加到新对象\r\n\t\tif (key in obj) {\r\n\t\t\tacc[key] = obj[key];\r\n\t\t}\r\n\t\treturn acc;\r\n\t}, {});\r\n};\r\n/**\r\n * 自定义函数去除空字符串\r\n * @param act \r\n * @returns \r\n */\r\nexport const convertAct = (act:any) =>{\r\n\tact.forEach((v:any) => {\r\n\t\tif(v.hasOwnProperty('btnHidden') &&typeof v.btnHidden != 'function'){\r\n\t\t\tdelete v.btnHidden\r\n\t\t}\r\n\t\tif(v.hasOwnProperty('btnDisabled') &&typeof v.btnDisabled != 'function'){\r\n\t\t\tdelete v.btnDisabled\r\n\t\t}\r\n\t\tif(v.hasOwnProperty('onClick') &&typeof v.onClick != 'function'){\r\n\t\t\tdelete v.onClick\r\n\t\t}\r\n\t})\r\n\treturn act;\r\n}\r\n\r\n/**\r\n * formpage 通用content函数转移\r\n * @param content \r\n * @param thisArg\r\n */\r\nexport const changeContent = (content: any,thisArg:any)  =>{\r\n\tlet { gridList, hrefBtnList, getPrm, groups, statusKey, status, statusSteps,statusConf = null } = parseFunctions(content,thisArg);\r\n\tif (statusKey) {\r\n\t\tthisArg.statusKey = statusKey;\r\n\t\tthisArg.steps = statusSteps;\r\n\t\tstatusConf && (thisArg.statusConf = statusConf)\r\n\t}\r\n\r\n\t// let act = parseFunctions(content.actions,thisArg)\r\n\tthisArg.actions = convertAct(content.actions)\r\n\t// content.formDisabled && (thisArg.formDisabled = parseFunctions(content.formDisabled, thisArg));\r\n\tcontent.formDisabled && (thisArg.formDisabled = content.formDisabled);\r\n\tthisArg.getPrm = getPrm;\r\n\tthisArg.getPrm.orgField = content.orgField || '';\r\n\tthisArg.grids = [];\r\n\tlet fiterPreloads:any[] = []\r\n\t// gridList = parseFunctions(gridList, thisArg);\r\n\t// let groupArr = parseFunctions(groups, thisArg);\r\n\tgroups.forEach((item: any) => {\r\n\t\tif (thisArg.authLevel < 3) {\r\n\t\t\titem[formTypeToProps[item.type]].disabled = true;\r\n\t\t}\r\n\t});\r\n\tthisArg.formOptions = {\r\n\t\tfields: [\r\n\t\t\t{\r\n\t\t\t\tgroupClass: 'flex flex-row flex-wrap',\r\n\t\t\t\tgroup: groups,\r\n\t\t\t},\r\n\t\t],\r\n\t\tform: new FormGroup({}),\r\n\t\tmainField: content.sourceData.model.mainFields,\r\n\t};\r\n\tgridList.forEach(async (item: any) => {\r\n\t\t!item.type && (item.type = 'grid')\r\n\t\tlet grid:any = {type:item.type}\r\n\t\tif(item.fiterPreloads instanceof Array){\r\n\t\t\tfiterPreloads = [...fiterPreloads, ...item.fiterPreloads]\r\n\t\t}\r\n\t\tif(item.type == 'grid'){\r\n\t\t\tlet {\r\n\t\t\t\tgridOptions: { columnDefs, ...restGridOptions },\r\n\t\t\t\tsubTableSource,\r\n\t\t\t\tsubDataKey,\r\n\t\t\t\ttitle,\r\n\t\t\t\tselectDataCb,\r\n\t\t\t\tfk,\r\n\t\t\t\tmainField,\r\n\t\t\t\tuniqueField,\r\n\t\t\t\taddDataCb,\r\n\t\t\t\tshowDelete = true,\r\n\t\t\t\tscrollHeight,\r\n\t\t\t\tdragSort\r\n\t\t\t} = item;\r\n\t\t\tgrid = { subTableSource, subDataKey, title,showDelete, ...grid};\r\n\t\t\tlet gridOptions = {\r\n\t\t\t\t...restGridOptions,\r\n\t\t\t\tfk,\r\n\t\t\t\tsubTableSource,\r\n\t\t\t\tsubDataKey,\r\n\t\t\t\tmainField,\r\n\t\t\t};\r\n\t\t\tif(scrollHeight){\r\n\t\t\t\tgridOptions.scrollHeight = `${scrollHeight}px`\r\n\t\t\t}\r\n\t\t\tif(dragSort){\r\n\t\t\t\tgridOptions.rowDragManaged = true\r\n\t\t\t\tgridOptions.dragSort = dragSort\r\n\t\t\t}\r\n\t\t\tconvertCol(columnDefs,thisArg.authLevel, gridOptions.modelName,dragSort);\r\n\t\t\tgridOptions.columnDefs = columnDefs;\r\n\r\n\t\t\tif (subTableSource === 'select') {\r\n\t\t\t\tthisArg.webget({ code: item.selectModelCode }).subscribe((res:any) => {\r\n\t\t\t\t\tlet selectContent = JSON.parse(res.content);\r\n\t\t\t\t\tgrid.selectOptions = parseFunctions(selectContent, thisArg)?.gridOptions;\r\n\t\t\t\t\tgrid.selectOptions.rowModelType = grid.selectOptions.rowModelType || 'serverSide';\r\n\t\t\t\t\tif (grid.selectOptions.rowModelType == 'serverSide') {\r\n\t\t\t\t\t\tgrid.selectOptions.serverFunc = grid.selectOptions.serverFunc || thisArg.web_search.bind(thisArg);\r\n\t\t\t\t\t} else {\r\n\t\t\t\t\t\tgrid.selectOptions.clientFunc = grid.selectOptions.clientFunc || thisArg.web_search.bind(thisArg);\r\n\t\t\t\t\t}\r\n\t\t\t\t\tgrid.uniqueField = uniqueField;\r\n\t\t\t\t\tgrid.selectDataCb = selectDataCb;\r\n\t\t\t\t\tgrid.selectOptions.scrollHeight = '300px';\r\n\t\t\t\t\tgridOptionsHooker(grid.selectOptions, selectContent);\r\n\t\t\t\t});\r\n\t\t\t\tgrid.searchPrm = { ...thisArg.searchPrm };\r\n\t\t\t} else {\r\n\t\t\t\taddDataCb && (gridOptions.addDataCb = addDataCb);\r\n\t\t\t}\r\n\t\t\tgrid.gridOptions = gridOptions;\r\n\t\t} else {\r\n\t\t\titem.interactiveLabel = true\r\n\t\t\tgrid = {\r\n\t\t\t\t...item\r\n\t\t\t}\r\n\t\t\tgrid.form = new FormGroup({})\r\n\t\t}\r\n\t\tthisArg.grids.push(grid);\r\n\t});\r\n\tthisArg.formDetail =  content.formDetail\r\n\tthisArg.saveFunc = content.saveFunc\r\n\tthisArg.isLog = content.sourceData.model.log;\r\n\tthisArg.getPrm['getLog'] = content.sourceData.model.log;\r\n\tthisArg.getPrm['fiterPreloads'] = fiterPreloads\r\n\tthisArg.hrefBtnList  = hrefBtnList;\r\n}\r\n\r\nexport const convertCol = (col: any[], authLevel:number,modelName?: string,dragSort?:string,) => {\r\n\tcol.forEach((item: any,index:number) => {\r\n\t\titem.hide = item.hideCol;\r\n\t\tif (authLevel < 3) {\r\n\t\t\titem.editable = false;\r\n\t\t}\r\n\t\tif(dragSort && index ===0){\r\n\t\t\titem.rowDrag = true\r\n\t\t}\r\n\t});\r\n}\r\n\r\nexport const gridOptionsHooker = (gridOptions: any, selectContent: any) => {\r\n\tgridOptions?.columnDefs?.forEach((col: any) => {\r\n\t\tif (col.hideCol) {\r\n\t\t\tcol.hide = col.hideCol;\r\n\t\t\tdelete col.hideCol;\r\n\t\t}\r\n\t});\r\n}"]}
|
|
@@ -11,7 +11,7 @@ import { ActivatedRoute, Router, NavigationEnd } from '@angular/router';
|
|
|
11
11
|
import * as i1$5 from '@angular/common';
|
|
12
12
|
import { DOCUMENT, isPlatformBrowser, DatePipe, AsyncPipe, CommonModule, PlatformLocation } from '@angular/common';
|
|
13
13
|
import * as i2$1 from '@angular/forms';
|
|
14
|
-
import { FormControl, ReactiveFormsModule,
|
|
14
|
+
import { FormControl, ReactiveFormsModule, FormGroup, FormsModule, Validators } from '@angular/forms';
|
|
15
15
|
import { BehaviorSubject, tap, fromEvent, forkJoin, filter, Observable, of, shareReplay, pipe, lastValueFrom, isObservable, map as map$1 } from 'rxjs';
|
|
16
16
|
import * as i1$2 from '@ngx-translate/core';
|
|
17
17
|
import { TranslatePipe } from '@ngx-translate/core';
|
|
@@ -593,7 +593,6 @@ class ActionService {
|
|
|
593
593
|
this.pageAction = pageAction;
|
|
594
594
|
this.popAction = popAction;
|
|
595
595
|
this.popMode = false;
|
|
596
|
-
this.page = signal(undefined);
|
|
597
596
|
this.fieldLabelAction = signal(undefined);
|
|
598
597
|
this.fieldAction = signal(undefined);
|
|
599
598
|
this.action = signal(undefined);
|
|
@@ -695,10 +694,15 @@ class ActionService {
|
|
|
695
694
|
return this.pageAction.getSortItem();
|
|
696
695
|
}
|
|
697
696
|
setPage(page) {
|
|
698
|
-
this.
|
|
697
|
+
if (!this.popMode) {
|
|
698
|
+
this.pageAction.setPage(page);
|
|
699
|
+
}
|
|
699
700
|
}
|
|
700
701
|
getPage() {
|
|
701
|
-
|
|
702
|
+
if (!this.popMode) {
|
|
703
|
+
return this.pageAction.getPage();
|
|
704
|
+
}
|
|
705
|
+
return undefined;
|
|
702
706
|
}
|
|
703
707
|
setFieldLabelAction(key, type) {
|
|
704
708
|
this.fieldLabelAction.set({ key, type });
|
|
@@ -735,6 +739,7 @@ class PageActionService {
|
|
|
735
739
|
this.searchItem = signal(undefined);
|
|
736
740
|
this.searchClear = signal(undefined);
|
|
737
741
|
this.sortItem = signal(undefined);
|
|
742
|
+
this.page = signal(undefined);
|
|
738
743
|
}
|
|
739
744
|
setModelName(modelNameForSearch) {
|
|
740
745
|
if (modelNameForSearch == undefined) {
|
|
@@ -805,6 +810,12 @@ class PageActionService {
|
|
|
805
810
|
getSortItem() {
|
|
806
811
|
return this.sortItem();
|
|
807
812
|
}
|
|
813
|
+
setPage(page) {
|
|
814
|
+
this.page.set(page);
|
|
815
|
+
}
|
|
816
|
+
getPage() {
|
|
817
|
+
return this.page();
|
|
818
|
+
}
|
|
808
819
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: PageActionService, deps: [{ token: i1.Router }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
809
820
|
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: PageActionService, providedIn: 'root' }); }
|
|
810
821
|
}
|
|
@@ -2398,9 +2409,8 @@ class RadioComponent {
|
|
|
2398
2409
|
fromEvent(this.radioContainer.nativeElement, 'mouseenter')
|
|
2399
2410
|
.pipe(debounceTime(100))
|
|
2400
2411
|
.subscribe(() => {
|
|
2401
|
-
if (this.
|
|
2412
|
+
if (this.field()?.fieldControl?.disabled)
|
|
2402
2413
|
return;
|
|
2403
|
-
}
|
|
2404
2414
|
this.isEnter = true;
|
|
2405
2415
|
});
|
|
2406
2416
|
fromEvent(this.radioContainer.nativeElement, 'mouseleave')
|
|
@@ -2939,7 +2949,7 @@ class ImageComponent {
|
|
|
2939
2949
|
@for (image of imageList; track image; let index = $index) {
|
|
2940
2950
|
<div class="flex justify-between items-center file-item">
|
|
2941
2951
|
<p-image
|
|
2942
|
-
[src]="'
|
|
2952
|
+
[src]="'https://hrimage.myfoodiepet.com//' + image"
|
|
2943
2953
|
[preview]="true"
|
|
2944
2954
|
alt="Image">
|
|
2945
2955
|
<ng-template #indicator>
|
|
@@ -3008,7 +3018,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
3008
3018
|
@for (image of imageList; track image; let index = $index) {
|
|
3009
3019
|
<div class="flex justify-between items-center file-item">
|
|
3010
3020
|
<p-image
|
|
3011
|
-
[src]="'
|
|
3021
|
+
[src]="'https://hrimage.myfoodiepet.com//' + image"
|
|
3012
3022
|
[preview]="true"
|
|
3013
3023
|
alt="Image">
|
|
3014
3024
|
<ng-template #indicator>
|
|
@@ -3542,6 +3552,126 @@ const convertAct = (act) => {
|
|
|
3542
3552
|
});
|
|
3543
3553
|
return act;
|
|
3544
3554
|
};
|
|
3555
|
+
/**
|
|
3556
|
+
* formpage 通用content函数转移
|
|
3557
|
+
* @param content
|
|
3558
|
+
* @param thisArg
|
|
3559
|
+
*/
|
|
3560
|
+
const changeContent = (content, thisArg) => {
|
|
3561
|
+
let { gridList, hrefBtnList, getPrm, groups, statusKey, status, statusSteps, statusConf = null } = parseFunctions(content, thisArg);
|
|
3562
|
+
if (statusKey) {
|
|
3563
|
+
thisArg.statusKey = statusKey;
|
|
3564
|
+
thisArg.steps = statusSteps;
|
|
3565
|
+
statusConf && (thisArg.statusConf = statusConf);
|
|
3566
|
+
}
|
|
3567
|
+
// let act = parseFunctions(content.actions,thisArg)
|
|
3568
|
+
thisArg.actions = convertAct(content.actions);
|
|
3569
|
+
// content.formDisabled && (thisArg.formDisabled = parseFunctions(content.formDisabled, thisArg));
|
|
3570
|
+
content.formDisabled && (thisArg.formDisabled = content.formDisabled);
|
|
3571
|
+
thisArg.getPrm = getPrm;
|
|
3572
|
+
thisArg.getPrm.orgField = content.orgField || '';
|
|
3573
|
+
thisArg.grids = [];
|
|
3574
|
+
let fiterPreloads = [];
|
|
3575
|
+
// gridList = parseFunctions(gridList, thisArg);
|
|
3576
|
+
// let groupArr = parseFunctions(groups, thisArg);
|
|
3577
|
+
groups.forEach((item) => {
|
|
3578
|
+
if (thisArg.authLevel < 3) {
|
|
3579
|
+
item[formTypeToProps[item.type]].disabled = true;
|
|
3580
|
+
}
|
|
3581
|
+
});
|
|
3582
|
+
thisArg.formOptions = {
|
|
3583
|
+
fields: [
|
|
3584
|
+
{
|
|
3585
|
+
groupClass: 'flex flex-row flex-wrap',
|
|
3586
|
+
group: groups,
|
|
3587
|
+
},
|
|
3588
|
+
],
|
|
3589
|
+
form: new FormGroup({}),
|
|
3590
|
+
mainField: content.sourceData.model.mainFields,
|
|
3591
|
+
};
|
|
3592
|
+
gridList.forEach(async (item) => {
|
|
3593
|
+
!item.type && (item.type = 'grid');
|
|
3594
|
+
let grid = { type: item.type };
|
|
3595
|
+
if (item.fiterPreloads instanceof Array) {
|
|
3596
|
+
fiterPreloads = [...fiterPreloads, ...item.fiterPreloads];
|
|
3597
|
+
}
|
|
3598
|
+
if (item.type == 'grid') {
|
|
3599
|
+
let { gridOptions: { columnDefs, ...restGridOptions }, subTableSource, subDataKey, title, selectDataCb, fk, mainField, uniqueField, addDataCb, showDelete = true, scrollHeight, dragSort } = item;
|
|
3600
|
+
grid = { subTableSource, subDataKey, title, showDelete, ...grid };
|
|
3601
|
+
let gridOptions = {
|
|
3602
|
+
...restGridOptions,
|
|
3603
|
+
fk,
|
|
3604
|
+
subTableSource,
|
|
3605
|
+
subDataKey,
|
|
3606
|
+
mainField,
|
|
3607
|
+
};
|
|
3608
|
+
if (scrollHeight) {
|
|
3609
|
+
gridOptions.scrollHeight = `${scrollHeight}px`;
|
|
3610
|
+
}
|
|
3611
|
+
if (dragSort) {
|
|
3612
|
+
gridOptions.rowDragManaged = true;
|
|
3613
|
+
gridOptions.dragSort = dragSort;
|
|
3614
|
+
}
|
|
3615
|
+
convertCol(columnDefs, thisArg.authLevel, gridOptions.modelName, dragSort);
|
|
3616
|
+
gridOptions.columnDefs = columnDefs;
|
|
3617
|
+
if (subTableSource === 'select') {
|
|
3618
|
+
thisArg.webget({ code: item.selectModelCode }).subscribe((res) => {
|
|
3619
|
+
let selectContent = JSON.parse(res.content);
|
|
3620
|
+
grid.selectOptions = parseFunctions(selectContent, thisArg)?.gridOptions;
|
|
3621
|
+
grid.selectOptions.rowModelType = grid.selectOptions.rowModelType || 'serverSide';
|
|
3622
|
+
if (grid.selectOptions.rowModelType == 'serverSide') {
|
|
3623
|
+
grid.selectOptions.serverFunc = grid.selectOptions.serverFunc || thisArg.web_search.bind(thisArg);
|
|
3624
|
+
}
|
|
3625
|
+
else {
|
|
3626
|
+
grid.selectOptions.clientFunc = grid.selectOptions.clientFunc || thisArg.web_search.bind(thisArg);
|
|
3627
|
+
}
|
|
3628
|
+
grid.uniqueField = uniqueField;
|
|
3629
|
+
grid.selectDataCb = selectDataCb;
|
|
3630
|
+
grid.selectOptions.scrollHeight = '300px';
|
|
3631
|
+
gridOptionsHooker(grid.selectOptions, selectContent);
|
|
3632
|
+
});
|
|
3633
|
+
grid.searchPrm = { ...thisArg.searchPrm };
|
|
3634
|
+
}
|
|
3635
|
+
else {
|
|
3636
|
+
addDataCb && (gridOptions.addDataCb = addDataCb);
|
|
3637
|
+
}
|
|
3638
|
+
grid.gridOptions = gridOptions;
|
|
3639
|
+
}
|
|
3640
|
+
else {
|
|
3641
|
+
item.interactiveLabel = true;
|
|
3642
|
+
grid = {
|
|
3643
|
+
...item
|
|
3644
|
+
};
|
|
3645
|
+
grid.form = new FormGroup({});
|
|
3646
|
+
}
|
|
3647
|
+
thisArg.grids.push(grid);
|
|
3648
|
+
});
|
|
3649
|
+
thisArg.formDetail = content.formDetail;
|
|
3650
|
+
thisArg.saveFunc = content.saveFunc;
|
|
3651
|
+
thisArg.isLog = content.sourceData.model.log;
|
|
3652
|
+
thisArg.getPrm['getLog'] = content.sourceData.model.log;
|
|
3653
|
+
thisArg.getPrm['fiterPreloads'] = fiterPreloads;
|
|
3654
|
+
thisArg.hrefBtnList = hrefBtnList;
|
|
3655
|
+
};
|
|
3656
|
+
const convertCol = (col, authLevel, modelName, dragSort) => {
|
|
3657
|
+
col.forEach((item, index) => {
|
|
3658
|
+
item.hide = item.hideCol;
|
|
3659
|
+
if (authLevel < 3) {
|
|
3660
|
+
item.editable = false;
|
|
3661
|
+
}
|
|
3662
|
+
if (dragSort && index === 0) {
|
|
3663
|
+
item.rowDrag = true;
|
|
3664
|
+
}
|
|
3665
|
+
});
|
|
3666
|
+
};
|
|
3667
|
+
const gridOptionsHooker = (gridOptions, selectContent) => {
|
|
3668
|
+
gridOptions?.columnDefs?.forEach((col) => {
|
|
3669
|
+
if (col.hideCol) {
|
|
3670
|
+
col.hide = col.hideCol;
|
|
3671
|
+
delete col.hideCol;
|
|
3672
|
+
}
|
|
3673
|
+
});
|
|
3674
|
+
};
|
|
3545
3675
|
|
|
3546
3676
|
const _gridUtils = {
|
|
3547
3677
|
calcRowIds: (api, isServerSide) => {
|
|
@@ -4269,6 +4399,64 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
4269
4399
|
}]
|
|
4270
4400
|
}] });
|
|
4271
4401
|
|
|
4402
|
+
const ColorMap = {
|
|
4403
|
+
emerald: '#10B981',
|
|
4404
|
+
green: '#22C55E',
|
|
4405
|
+
lime: '#84CC16',
|
|
4406
|
+
orange: '#F97316',
|
|
4407
|
+
amber: '#F59E0B',
|
|
4408
|
+
sky: '#0EA5E9',
|
|
4409
|
+
blue: '#3B82F6',
|
|
4410
|
+
violet: '#6B26C1',
|
|
4411
|
+
pink: '#EC4899',
|
|
4412
|
+
purple: '#9A72C8',
|
|
4413
|
+
red: '#EF4444',
|
|
4414
|
+
yellow: '#F59E0B',
|
|
4415
|
+
gray: '#4B5563',
|
|
4416
|
+
teal: '#16A34A',
|
|
4417
|
+
cyan: '#25D366',
|
|
4418
|
+
indigo: '#6574CD',
|
|
4419
|
+
fushsia: '#E10098',
|
|
4420
|
+
};
|
|
4421
|
+
class ChipRenderer {
|
|
4422
|
+
constructor() {
|
|
4423
|
+
this.label = '';
|
|
4424
|
+
this.color = '';
|
|
4425
|
+
}
|
|
4426
|
+
agInit(params) {
|
|
4427
|
+
const options = params.options;
|
|
4428
|
+
const item = options?.find((item) => item.value === params.value);
|
|
4429
|
+
this.label = item.label || '';
|
|
4430
|
+
this.color = item.chip ? ColorMap[item.chip] : '';
|
|
4431
|
+
}
|
|
4432
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ChipRenderer, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
4433
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: ChipRenderer, isStandalone: true, selector: "ng-component", providers: [AsyncPipe], ngImport: i0, template: `
|
|
4434
|
+
@if (color) {
|
|
4435
|
+
<span
|
|
4436
|
+
class="cell-chip"
|
|
4437
|
+
[style]="{ background: color }"
|
|
4438
|
+
>{{ label }}</span
|
|
4439
|
+
>
|
|
4440
|
+
} @else {
|
|
4441
|
+
<span>{{ label }}</span>
|
|
4442
|
+
}
|
|
4443
|
+
`, isInline: true, styles: [".cell-chip{padding:2px 5px;color:#fff;border-radius:2px;font-size:12px}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }] }); }
|
|
4444
|
+
}
|
|
4445
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ChipRenderer, decorators: [{
|
|
4446
|
+
type: Component,
|
|
4447
|
+
args: [{ standalone: true, imports: [CommonModule], providers: [AsyncPipe], template: `
|
|
4448
|
+
@if (color) {
|
|
4449
|
+
<span
|
|
4450
|
+
class="cell-chip"
|
|
4451
|
+
[style]="{ background: color }"
|
|
4452
|
+
>{{ label }}</span
|
|
4453
|
+
>
|
|
4454
|
+
} @else {
|
|
4455
|
+
<span>{{ label }}</span>
|
|
4456
|
+
}
|
|
4457
|
+
`, styles: [".cell-chip{padding:2px 5px;color:#fff;border-radius:2px;font-size:12px}\n"] }]
|
|
4458
|
+
}] });
|
|
4459
|
+
|
|
4272
4460
|
// rowModelType 使用clientSide的最大值
|
|
4273
4461
|
const CLIENTLIMIT = 9999;
|
|
4274
4462
|
const components = {
|
|
@@ -4277,10 +4465,12 @@ const components = {
|
|
|
4277
4465
|
cellEditSelectComponent: CellEditSelectComponent,
|
|
4278
4466
|
linkRenderer: LinkRenderer,
|
|
4279
4467
|
asyncRenderer: AsyncRenderer,
|
|
4468
|
+
chipRenderer: ChipRenderer,
|
|
4280
4469
|
cellEditAutoCompleteComponent: CellEditAutoCompleteComponent,
|
|
4281
4470
|
};
|
|
4282
4471
|
|
|
4283
4472
|
const defaultOption = {
|
|
4473
|
+
// popupParent: document.body,
|
|
4284
4474
|
defaultColDef: {
|
|
4285
4475
|
flex: 1,
|
|
4286
4476
|
minWidth: 100,
|
|
@@ -6005,6 +6195,9 @@ class FormFieldComponent {
|
|
|
6005
6195
|
@if (props(field()!).required) {
|
|
6006
6196
|
<span class="field-required">*</span>
|
|
6007
6197
|
}
|
|
6198
|
+
@if (!field()?.fieldControl?.disabled) {
|
|
6199
|
+
<span class="iconfont icon-edit-flag field-editable"></span>
|
|
6200
|
+
}
|
|
6008
6201
|
</label>
|
|
6009
6202
|
</div>
|
|
6010
6203
|
<div class="flex-1 min-h-8 pt-1 w-0 flex flex-row-reverse">
|
|
@@ -6017,7 +6210,7 @@ class FormFieldComponent {
|
|
|
6017
6210
|
</div>
|
|
6018
6211
|
</div>
|
|
6019
6212
|
}
|
|
6020
|
-
`, isInline: true, styles: [".p-field>label{margin:2px;text-overflow:ellipsis;display:block;color:#1e293b}.p-field>label:not(.ng-valid).ng-dirty{color:var(--p-red-500)!important}.p-field>label:not(.ng-valid).ng-dirty>.field-required{color:var(--p-red-500)!important}.field-required{padding-left:2.5px;color:var(--p-primary-color)}.field-label{display:inline-block;overflow-wrap:break-word;word-break:break-word;white-space:normal}\n"], dependencies: [{ kind: "component", type: FormFieldComponent, selector: "form-field", inputs: ["field"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "component", type: FormTypeComponent, selector: "form-type", inputs: ["field"] }, { kind: "pipe", type: TranslatePipe, name: "translate" }, { kind: "directive", type: LabelDirective, selector: "[fieldLabel]", inputs: ["fieldLabel"] }] }); }
|
|
6213
|
+
`, isInline: true, styles: [".p-field>label{margin:2px;text-overflow:ellipsis;display:block;color:#1e293b}.p-field>label:not(.ng-valid).ng-dirty{color:var(--p-red-500)!important}.p-field>label:not(.ng-valid).ng-dirty>.field-required{color:var(--p-red-500)!important}.field-required{padding-left:2.5px;color:var(--p-primary-color)}.p-field>label:not(.ng-valid).ng-dirty>.field-editable{color:var(--p-red-500)!important}.field-editable{padding-left:1px;font-size:6px;color:var(--p-primary-color)}.field-label{display:inline-block;overflow-wrap:break-word;word-break:break-word;white-space:normal}\n"], dependencies: [{ kind: "component", type: FormFieldComponent, selector: "form-field", inputs: ["field"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "component", type: FormTypeComponent, selector: "form-type", inputs: ["field"] }, { kind: "pipe", type: TranslatePipe, name: "translate" }, { kind: "directive", type: LabelDirective, selector: "[fieldLabel]", inputs: ["fieldLabel"] }] }); }
|
|
6021
6214
|
}
|
|
6022
6215
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FormFieldComponent, decorators: [{
|
|
6023
6216
|
type: Component,
|
|
@@ -6052,6 +6245,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
6052
6245
|
@if (props(field()!).required) {
|
|
6053
6246
|
<span class="field-required">*</span>
|
|
6054
6247
|
}
|
|
6248
|
+
@if (!field()?.fieldControl?.disabled) {
|
|
6249
|
+
<span class="iconfont icon-edit-flag field-editable"></span>
|
|
6250
|
+
}
|
|
6055
6251
|
</label>
|
|
6056
6252
|
</div>
|
|
6057
6253
|
<div class="flex-1 min-h-8 pt-1 w-0 flex flex-row-reverse">
|
|
@@ -6064,7 +6260,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
6064
6260
|
</div>
|
|
6065
6261
|
</div>
|
|
6066
6262
|
}
|
|
6067
|
-
`, styles: [".p-field>label{margin:2px;text-overflow:ellipsis;display:block;color:#1e293b}.p-field>label:not(.ng-valid).ng-dirty{color:var(--p-red-500)!important}.p-field>label:not(.ng-valid).ng-dirty>.field-required{color:var(--p-red-500)!important}.field-required{padding-left:2.5px;color:var(--p-primary-color)}.field-label{display:inline-block;overflow-wrap:break-word;word-break:break-word;white-space:normal}\n"] }]
|
|
6263
|
+
`, styles: [".p-field>label{margin:2px;text-overflow:ellipsis;display:block;color:#1e293b}.p-field>label:not(.ng-valid).ng-dirty{color:var(--p-red-500)!important}.p-field>label:not(.ng-valid).ng-dirty>.field-required{color:var(--p-red-500)!important}.field-required{padding-left:2.5px;color:var(--p-primary-color)}.p-field>label:not(.ng-valid).ng-dirty>.field-editable{color:var(--p-red-500)!important}.field-editable{padding-left:1px;font-size:6px;color:var(--p-primary-color)}.field-label{display:inline-block;overflow-wrap:break-word;word-break:break-word;white-space:normal}\n"] }]
|
|
6068
6264
|
}], ctorParameters: () => [], propDecorators: { fieldComponents: [{
|
|
6069
6265
|
type: ViewChildren,
|
|
6070
6266
|
args: [FormFieldComponent]
|
|
@@ -6273,7 +6469,7 @@ class FormComponent {
|
|
|
6273
6469
|
const fieldLabels = [];
|
|
6274
6470
|
this.getFieldLabels(this.fieldComponents, fieldLabels);
|
|
6275
6471
|
const offsetWidths = fieldLabels.map((fieldLabel) => fieldLabel.nativeElement.offsetWidth);
|
|
6276
|
-
this.labelMinWidth.set(Math.max(...offsetWidths) +
|
|
6472
|
+
this.labelMinWidth.set(Math.max(...offsetWidths) + 24 + 'px');
|
|
6277
6473
|
}
|
|
6278
6474
|
getFieldLabels(fieldComponents, fieldLabels) {
|
|
6279
6475
|
if (!fieldComponents) {
|
|
@@ -6650,7 +6846,6 @@ class ImportComponent {
|
|
|
6650
6846
|
link.href = isDevMode()
|
|
6651
6847
|
? '/importFiles/' + this.fileName() + '.xlsx'
|
|
6652
6848
|
: `/${baseHref.replace(/\/(.*?)\//, "$1")}/importFiles/${this.fileName()}.xlsx`;
|
|
6653
|
-
console.log('link-----', link.href);
|
|
6654
6849
|
link.download = this.fileName() + '.xlsx';
|
|
6655
6850
|
document.body.appendChild(link);
|
|
6656
6851
|
link.click();
|
|
@@ -7593,5 +7788,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
7593
7788
|
* Generated bundle index. Do not edit.
|
|
7594
7789
|
*/
|
|
7595
7790
|
|
|
7596
|
-
export { ActionService, ActionsComponent, AmComponent, AsyncRenderer, CellEditAutoCompleteComponent, CellEditDatePickerComponent, CellEditInputNumberCompoent, CellEditInputTextCompoent, CellEditSelectComponent, CrumbActionComponent, FormComponent, GridComponent, HeadComponent, HrefBtnListComponent, I18N_Token, I18nService, ImportComponent, LANGS, LinkRenderer, LogComponent, PageActionService, PageFormComponent, PageGridListComponent, PagerComponent, PopActionService, RowSelectorComponent$1 as RowSelectorComponent, SearchComponent, StepsComponent, ThemeConfigComponent, ThemeConfigService, UserHistoryService, compileTsToJs, convertAct, createCircularIterator, filterObjectByKeys, formTypeToProps, generateUniqueId, gridUtils, isJSONParsable, parseFunctions, toPascalCase };
|
|
7791
|
+
export { ActionService, ActionsComponent, AmComponent, AsyncRenderer, CellEditAutoCompleteComponent, CellEditDatePickerComponent, CellEditInputNumberCompoent, CellEditInputTextCompoent, CellEditSelectComponent, CrumbActionComponent, FormComponent, GridComponent, HeadComponent, HrefBtnListComponent, I18N_Token, I18nService, ImportComponent, LANGS, LinkRenderer, LogComponent, PageActionService, PageFormComponent, PageGridListComponent, PagerComponent, PopActionService, RowSelectorComponent$1 as RowSelectorComponent, SearchComponent, StepsComponent, ThemeConfigComponent, ThemeConfigService, UserHistoryService, changeContent, compileTsToJs, convertAct, convertCol, createCircularIterator, filterObjectByKeys, formTypeToProps, generateUniqueId, gridOptionsHooker, gridUtils, isJSONParsable, parseFunctions, toPascalCase };
|
|
7597
7792
|
//# sourceMappingURL=imm-element-ui.mjs.map
|