imm-element-ui 1.3.7 → 1.3.9
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-field/field-utils.mjs +3 -3
- package/esm2022/lib/form/form-type/datepicker.type.mjs +43 -1
- package/esm2022/lib/form/form-type/image.type.mjs +62 -9
- package/esm2022/lib/grid/grid-utils.mjs +2 -2
- package/esm2022/lib/page-form/page-form.component.mjs +3 -3
- package/esm2022/lib/search/search/search.component.mjs +2 -2
- package/esm2022/lib/search/search-utils.mjs +11 -4
- package/fesm2022/imm-element-ui.mjs +116 -15
- package/fesm2022/imm-element-ui.mjs.map +1 -1
- package/lib/crumb-action/crumb-action.component.d.ts +1 -1
- package/lib/form/form-type/datepicker.type.d.ts +3 -0
- package/lib/form/form-type/image.type.d.ts +6 -1
- package/lib/grid/grid/grid.component.d.ts +1 -1
- package/lib/search/search-utils.d.ts +1 -1
- package/package.json +1 -1
- package/src/lib/page-form/page-form.component.scss +5 -1
|
@@ -176,8 +176,8 @@ const _fieldUtils = {
|
|
|
176
176
|
return '';
|
|
177
177
|
}
|
|
178
178
|
if (_fieldUtils.isISO8601(raw)) {
|
|
179
|
-
const
|
|
180
|
-
return datePipe.transform(raw,
|
|
179
|
+
const datePipeFormat = field.datePickerProps?.datePipeFormat ?? 'yyyy-MM-dd';
|
|
180
|
+
return datePipe.transform(raw, datePipeFormat, 'GMT') || raw;
|
|
181
181
|
}
|
|
182
182
|
if (!stringMode && field?.datePickerProps?.selectionMode == 'range' && raw.includes('~')) {
|
|
183
183
|
const [start, end] = raw.split('~');
|
|
@@ -269,4 +269,4 @@ export const fieldUtils = {
|
|
|
269
269
|
transLog: _fieldUtils.transLog,
|
|
270
270
|
isFakedChange: _fieldUtils.isFakedChange,
|
|
271
271
|
};
|
|
272
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"field-utils.js","sourceRoot":"","sources":["../../../../../../projects/imm-element-ui/src/lib/form/form-field/field-utils.ts"],"names":[],"mappings":"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","sourcesContent":["import { FormField, FieldProps } from './form-field';\nimport { DatePipe } from '@angular/common';\nimport { I18nService } from '../../service/i18n.service';\nimport { isObservable, tap } from 'rxjs';\n\nconst _fieldUtils = {\n\tprops: (field: FormField): FieldProps => {\n\t\tlet props: FieldProps = {};\n\t\tswitch (field.type) {\n\t\t\tcase 'inputtext':\n\t\t\t\tprops = field.inputTextProps!;\n\t\t\t\tbreak;\n\t\t\tcase 'inputnumber':\n\t\t\t\tprops = field.inputNumberProps!;\n\t\t\t\tbreak;\n\t\t\tcase 'select':\n\t\t\t\tprops = field.selectProps!;\n\t\t\t\tbreak;\n\t\t\tcase 'treeselect':\n\t\t\t\tprops = field.treeSelectProps!;\n\t\t\t\tbreak;\n\t\t\tcase 'datepicker':\n\t\t\t\tprops = field.datePickerProps!;\n\t\t\t\tbreak;\n\t\t\tcase 'autocomplete':\n\t\t\t\tprops = field.autoCompleteProps!;\n\t\t\t\tbreak;\n\t\t\tcase 'multiselect':\n\t\t\t\tprops = field.multiSelectProps!;\n\t\t\t\tbreak;\n\t\t\tcase 'radio':\n\t\t\t\tprops = field.radioProps!;\n\t\t\t\tbreak;\n\t\t\tcase 'textarea':\n\t\t\t\tprops = field.textAreaProps!;\n\t\t\t\tbreak;\n\t\t\tcase 'upload':\n\t\t\t\tprops = field.uploadProps!;\n\t\t\t\tbreak;\n\t\t\tcase 'image':\n\t\t\t\tprops = field.imageProps!;\n\t\t\t\tbreak;\n\t\t\tcase 'codemirror':\n\t\t\t\tprops = field.codeMirrorProps!;\n\t\t\t\tbreak;\n\t\t\tcase 'rowselector':\n\t\t\t\tprops = field.rowSelectorProps!;\n\t\t\t\tbreak;\n\t\t}\n\t\treturn props;\n\t},\n\tlabel: (field: FormField, i18nService: I18nService): string | undefined => {\n\t\tconst i18nKey = _fieldUtils.props(field).i18nKey;\n\t\tif (i18nKey) {\n\t\t\treturn i18nService.fanyi(i18nKey);\n\t\t}\n\t\treturn _fieldUtils.props(field).label;\n\t},\n\tsetModel(model: any, key: string, value: any) {\n\t\tconst keys = key.split('.');\n\t\tif (keys.length == 1) {\n\t\t\tmodel[key] = value;\n\t\t\treturn;\n\t\t} else {\n\t\t\tconst k: any = keys.shift();\n\t\t\tif (model[k] == undefined) {\n\t\t\t\tmodel[k] = {};\n\t\t\t}\n\t\t\tthis.setModel(model[k], keys.join('.'), value);\n\t\t}\n\t},\n\tgetModel(model: any, key: string): any {\n\t\tconst keys = key.split('.');\n\t\tif (keys.length == 1) {\n\t\t\treturn model[key];\n\t\t} else {\n\t\t\tconst k: any = keys.shift();\n\t\t\tif (model[k] == undefined) {\n\t\t\t\tmodel[k] = {};\n\t\t\t}\n\t\t\treturn this.getModel(model[k], keys.join('.'));\n\t\t}\n\t},\n\tfieldHandler(field: FormField) {\n\t\tif (!['select', 'treeselect', 'multiselect', 'radio'].includes(field.type!)) return;\n\t\t(_fieldUtils.props(field) as any)!.options = Array.isArray((_fieldUtils.props(field) as any)!.options)\n\t\t\t? (_fieldUtils.props(field) as any)!.options\n\t\t\t: undefined;\n\t},\n\ttriggerHookAndSetValue: (\n\t\tfield: FormField,\n\t\tvalue: any,\n\t\temitEvent: boolean,\n\t\temitHook: boolean,\n\t\thookObservers: any[],\n\t\tcallback: any,\n\t\tdatePipe: DatePipe,\n\t) => {\n\t\tif (field.hook && isObservable(field.hook)) {\n\t\t\tconst sub = field.hook\n\t\t\t\t.pipe(\n\t\t\t\t\ttap((func) => {\n\t\t\t\t\t\tfunc(field);\n\t\t\t\t\t}),\n\t\t\t\t)\n\t\t\t\t.subscribe(() => {\n\t\t\t\t\tfield.fieldControl?.setValue(_fieldUtils.toFieldValue(field, value, datePipe), { emitEvent }, emitHook), callback && callback();\n\t\t\t\t});\n\t\t\thookObservers.push(() => sub.unsubscribe());\n\t\t} else {\n\t\t\tfield.fieldControl?.setValue(_fieldUtils.toFieldValue(field, value, datePipe), { emitEvent }, emitHook);\n\t\t\tcallback && callback();\n\t\t}\n\t},\n\tfromFieldValue: (field: FormField, target: any, datePipe: DatePipe): any => {\n\t\tif (field.type == 'treeselect') {\n\t\t\treturn _fieldUtils.fromTreeSelectValue(field, target);\n\t\t}\n\t\tif (field.type == 'multiselect') {\n\t\t\treturn _fieldUtils.fromMultiSelectValue(field, target);\n\t\t}\n\t\tif (field.type == 'image') {\n\t\t\treturn _fieldUtils.fromImageValue(field, target);\n\t\t}\n\t\tif (field.type == 'upload') {\n\t\t\treturn _fieldUtils.fromUploadValue(field, target);\n\t\t}\n\t\tif (field.type == 'datepicker') {\n\t\t\treturn _fieldUtils.fromDatePickerValue(field, target, datePipe);\n\t\t}\n\t\treturn target;\n\t},\n\tfromTreeSelectValue: (field: FormField, target: any): string => {\n\t\tif (field.treeSelectProps?.selectionMode == 'single') {\n\t\t\treturn target?.key;\n\t\t}\n\t\treturn target.map((item: any) => item.key).join(',');\n\t},\n\tfromMultiSelectValue: (field: FormField, target: any): string => {\n\t\tif (!field.multiSelectProps?.optionValue) {\n\t\t\treturn target;\n\t\t}\n\t\treturn target.join(',');\n\t},\n\tfromImageValue: (field: FormField, target: any): string => {\n\t\treturn target.join(';');\n\t},\n\tfromUploadValue: (field: FormField, target: any): string => {\n\t\treturn target.join(';');\n\t},\n\tfromDatePickerValue: (field: FormField, target: any, datePipe: any): string => {\n\t\tif (field?.datePickerProps?.selectionMode == 'range' && target.length == 2) {\n\t\t\tconsole.log(target.join('~'));\n\t\t\treturn target.join('~');\n\t\t}\n\t\treturn target;\n\t},\n\ttoFieldValue: (field: FormField, raw: any, datePipe: DatePipe): any => {\n\t\tif (field.type == 'treeselect') {\n\t\t\treturn _fieldUtils.toTreeSelectValue(field, raw);\n\t\t}\n\t\tif (field.type == 'datepicker') {\n\t\t\treturn _fieldUtils.toDatePickerValue(field, raw, datePipe);\n\t\t}\n\t\tif (field.type == 'multiselect') {\n\t\t\treturn _fieldUtils.toMultiSelectValue(field, raw);\n\t\t}\n\t\tif (field.type == 'image') {\n\t\t\treturn _fieldUtils.toImageValue(field, raw);\n\t\t}\n\t\tif (field.type == 'upload') {\n\t\t\treturn _fieldUtils.toUploadValue(field, raw);\n\t\t}\n\t\treturn raw || '';\n\t},\n\ttoTreeSelectValue: (field: FormField, raw: any): any => {\n\t\tif (field.treeSelectProps?.selectionMode == 'single') {\n\t\t\treturn _fieldUtils.findTreeNode(raw, field.treeSelectProps?.options);\n\t\t}\n\t\tconst nodes: any[] = [];\n\t\t_fieldUtils.findTreeNodes(raw?.split(',') || [], field.treeSelectProps?.options || [], nodes);\n\t\treturn nodes;\n\t},\n\ttoDatePickerValue: (field: FormField, raw: any, datePipe: DatePipe, stringMode: boolean = false): any => {\n\t\tif (!raw || raw == '0001-01-01T00:00:00Z') {\n\t\t\treturn '';\n\t\t}\n\t\tif (_fieldUtils.isISO8601(raw)) {\n\t\t\tconst dateFormat = field.datePickerProps?.showTime ? 'yyyy-MM-dd HH:mm:ss' : 'yyyy-MM-dd';\n\t\t\treturn datePipe.transform(raw, dateFormat, 'GMT') || raw;\n\t\t}\n\t\tif (!stringMode && field?.datePickerProps?.selectionMode == 'range' && raw.includes('~')) {\n\t\t\tconst [start, end] = raw.split('~');\n\t\t\treturn [new Date(start), new Date(end)];\n\t\t}\n\t\treturn raw;\n\t},\n\ttoMultiSelectValue: (field: FormField, raw: any): any => {\n\t\tif (!field.multiSelectProps?.optionValue) {\n\t\t\treturn raw || '';\n\t\t}\n\t\treturn (raw && raw.split(',')) || '';\n\t},\n\ttoImageValue: (field: FormField, raw: any): any => {\n\t\treturn (raw && raw.split(';')) || [];\n\t},\n\ttoUploadValue: (field: FormField, raw: any): any => {\n\t\treturn (raw && raw.split(';')) || [];\n\t},\n\tfindTreeNode(value: string, children?: any[]): any {\n\t\tif (!children || children.length == 0) return;\n\t\tconst n = children.find((o) => o.key == value);\n\t\tif (n) return n;\n\t\tfor (const ch of children) {\n\t\t\tconst cn = this.findTreeNode(value, ch.children);\n\t\t\tif (cn) return cn;\n\t\t}\n\t\treturn;\n\t},\n\tfindTreeNodes(values: string[], children?: any[], nodes?: any[]): void {\n\t\tif (!children || children.length == 0) return;\n\t\tconst tars = children.filter((o) => values.indexOf(o.key) != -1);\n\t\tnodes?.push(...tars);\n\t\tfor (const ch of children) {\n\t\t\tthis.findTreeNodes(values, ch.children, nodes);\n\t\t}\n\t},\n\tpreloadLog(rawModel: any, fieldList: FormField[], datePipe: DatePipe): any {\n\t\tconst target: any = {};\n\t\tObject.keys(rawModel).forEach((key) => {\n\t\t\tconst field = fieldList.find((field) => field.key === key);\n\t\t\tif (field?.type == 'datepicker') {\n\t\t\t\ttarget[key] = _fieldUtils.toDatePickerValue(field, rawModel[key], datePipe, true);\n\t\t\t\treturn;\n\t\t\t}\n\t\t\ttarget[key] = rawModel[key];\n\t\t});\n\t\treturn target;\n\t},\n\ttransLog(rawModel: any, changedModel: any, mainValue: any, isNew: boolean): string {\n\t\tif (isNew) {\n\t\t\treturn '新建：' + mainValue;\n\t\t}\n\t\tconst detail: string[] = [];\n\t\tObject.keys(changedModel).forEach((key) => {\n\t\t\tif (changedModel[key].type == 'codemirror') {\n\t\t\t\tdetail.push(`[${changedModel[key].name}] 变更`);\n\t\t\t\treturn;\n\t\t\t}\n\t\t\tdetail.push(`[${changedModel[key].name}] ${rawModel[key] || ''} -> ${changedModel[key].value || ''}`);\n\t\t});\n\t\treturn detail.join(';');\n\t},\n\t// 经测试select组件有内部bug\n\t// 设置model时，fieldControl.setValue的emitEvent参数为false,仍会触发valueChanges事件\n\t// 触发valueChanges会影响日志保存的准确性，故此方法仅是为了防止组件内部意外触发的变动\n\tisFakedChange(newValue: any, oldValue: any, field: FormField): boolean {\n\t\tconst changeTypes = ['inputtext', 'inputnumber', 'select', 'treeselect', 'datepicker', 'autocomplete', 'multiselect', 'radio'];\n\t\tif (changeTypes.includes(field.type!)) {\n\t\t\treturn (oldValue || '') == (newValue || '');\n\t\t}\n\t\treturn false;\n\t},\n\tisISO8601(timeStr: string): boolean {\n\t\treturn /^\\d{4}-\\d{2}-\\d{2}T\\d{2}:\\d{2}:\\d{2}(\\.\\d+)?(Z|[+-]\\d{2}:\\d{2})$/.test(timeStr);\n\t},\n};\n\nexport const fieldUtils = {\n\tprops: _fieldUtils.props,\n\tlabel: _fieldUtils.label,\n\tfieldHandler: _fieldUtils.fieldHandler,\n\ttriggerHookAndSetValue: _fieldUtils.triggerHookAndSetValue,\n\tfromFieldValue: _fieldUtils.fromFieldValue,\n\tpreloadLog: _fieldUtils.preloadLog,\n\ttransLog: _fieldUtils.transLog,\n\tisFakedChange: _fieldUtils.isFakedChange,\n};\n"]}
|
|
272
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"field-utils.js","sourceRoot":"","sources":["../../../../../../projects/imm-element-ui/src/lib/form/form-field/field-utils.ts"],"names":[],"mappings":"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","sourcesContent":["import { FormField, FieldProps } from './form-field';\nimport { DatePipe } from '@angular/common';\nimport { I18nService } from '../../service/i18n.service';\nimport { isObservable, tap } from 'rxjs';\n\nconst _fieldUtils = {\n\tprops: (field: FormField): FieldProps => {\n\t\tlet props: FieldProps = {};\n\t\tswitch (field.type) {\n\t\t\tcase 'inputtext':\n\t\t\t\tprops = field.inputTextProps!;\n\t\t\t\tbreak;\n\t\t\tcase 'inputnumber':\n\t\t\t\tprops = field.inputNumberProps!;\n\t\t\t\tbreak;\n\t\t\tcase 'select':\n\t\t\t\tprops = field.selectProps!;\n\t\t\t\tbreak;\n\t\t\tcase 'treeselect':\n\t\t\t\tprops = field.treeSelectProps!;\n\t\t\t\tbreak;\n\t\t\tcase 'datepicker':\n\t\t\t\tprops = field.datePickerProps!;\n\t\t\t\tbreak;\n\t\t\tcase 'autocomplete':\n\t\t\t\tprops = field.autoCompleteProps!;\n\t\t\t\tbreak;\n\t\t\tcase 'multiselect':\n\t\t\t\tprops = field.multiSelectProps!;\n\t\t\t\tbreak;\n\t\t\tcase 'radio':\n\t\t\t\tprops = field.radioProps!;\n\t\t\t\tbreak;\n\t\t\tcase 'textarea':\n\t\t\t\tprops = field.textAreaProps!;\n\t\t\t\tbreak;\n\t\t\tcase 'upload':\n\t\t\t\tprops = field.uploadProps!;\n\t\t\t\tbreak;\n\t\t\tcase 'image':\n\t\t\t\tprops = field.imageProps!;\n\t\t\t\tbreak;\n\t\t\tcase 'codemirror':\n\t\t\t\tprops = field.codeMirrorProps!;\n\t\t\t\tbreak;\n\t\t\tcase 'rowselector':\n\t\t\t\tprops = field.rowSelectorProps!;\n\t\t\t\tbreak;\n\t\t}\n\t\treturn props;\n\t},\n\tlabel: (field: FormField, i18nService: I18nService): string | undefined => {\n\t\tconst i18nKey = _fieldUtils.props(field).i18nKey;\n\t\tif (i18nKey) {\n\t\t\treturn i18nService.fanyi(i18nKey);\n\t\t}\n\t\treturn _fieldUtils.props(field).label;\n\t},\n\tsetModel(model: any, key: string, value: any) {\n\t\tconst keys = key.split('.');\n\t\tif (keys.length == 1) {\n\t\t\tmodel[key] = value;\n\t\t\treturn;\n\t\t} else {\n\t\t\tconst k: any = keys.shift();\n\t\t\tif (model[k] == undefined) {\n\t\t\t\tmodel[k] = {};\n\t\t\t}\n\t\t\tthis.setModel(model[k], keys.join('.'), value);\n\t\t}\n\t},\n\tgetModel(model: any, key: string): any {\n\t\tconst keys = key.split('.');\n\t\tif (keys.length == 1) {\n\t\t\treturn model[key];\n\t\t} else {\n\t\t\tconst k: any = keys.shift();\n\t\t\tif (model[k] == undefined) {\n\t\t\t\tmodel[k] = {};\n\t\t\t}\n\t\t\treturn this.getModel(model[k], keys.join('.'));\n\t\t}\n\t},\n\tfieldHandler(field: FormField) {\n\t\tif (!['select', 'treeselect', 'multiselect', 'radio'].includes(field.type!)) return;\n\t\t(_fieldUtils.props(field) as any)!.options = Array.isArray((_fieldUtils.props(field) as any)!.options)\n\t\t\t? (_fieldUtils.props(field) as any)!.options\n\t\t\t: undefined;\n\t},\n\ttriggerHookAndSetValue: (\n\t\tfield: FormField,\n\t\tvalue: any,\n\t\temitEvent: boolean,\n\t\temitHook: boolean,\n\t\thookObservers: any[],\n\t\tcallback: any,\n\t\tdatePipe: DatePipe,\n\t) => {\n\t\tif (field.hook && isObservable(field.hook)) {\n\t\t\tconst sub = field.hook\n\t\t\t\t.pipe(\n\t\t\t\t\ttap((func) => {\n\t\t\t\t\t\tfunc(field);\n\t\t\t\t\t}),\n\t\t\t\t)\n\t\t\t\t.subscribe(() => {\n\t\t\t\t\tfield.fieldControl?.setValue(_fieldUtils.toFieldValue(field, value, datePipe), { emitEvent }, emitHook), callback && callback();\n\t\t\t\t});\n\t\t\thookObservers.push(() => sub.unsubscribe());\n\t\t} else {\n\t\t\tfield.fieldControl?.setValue(_fieldUtils.toFieldValue(field, value, datePipe), { emitEvent }, emitHook);\n\t\t\tcallback && callback();\n\t\t}\n\t},\n\tfromFieldValue: (field: FormField, target: any, datePipe: DatePipe): any => {\n\t\tif (field.type == 'treeselect') {\n\t\t\treturn _fieldUtils.fromTreeSelectValue(field, target);\n\t\t}\n\t\tif (field.type == 'multiselect') {\n\t\t\treturn _fieldUtils.fromMultiSelectValue(field, target);\n\t\t}\n\t\tif (field.type == 'image') {\n\t\t\treturn _fieldUtils.fromImageValue(field, target);\n\t\t}\n\t\tif (field.type == 'upload') {\n\t\t\treturn _fieldUtils.fromUploadValue(field, target);\n\t\t}\n\t\tif (field.type == 'datepicker') {\n\t\t\treturn _fieldUtils.fromDatePickerValue(field, target, datePipe);\n\t\t}\n\t\treturn target;\n\t},\n\tfromTreeSelectValue: (field: FormField, target: any): string => {\n\t\tif (field.treeSelectProps?.selectionMode == 'single') {\n\t\t\treturn target?.key;\n\t\t}\n\t\treturn target.map((item: any) => item.key).join(',');\n\t},\n\tfromMultiSelectValue: (field: FormField, target: any): string => {\n\t\tif (!field.multiSelectProps?.optionValue) {\n\t\t\treturn target;\n\t\t}\n\t\treturn target.join(',');\n\t},\n\tfromImageValue: (field: FormField, target: any): string => {\n\t\treturn target.join(';');\n\t},\n\tfromUploadValue: (field: FormField, target: any): string => {\n\t\treturn target.join(';');\n\t},\n\tfromDatePickerValue: (field: FormField, target: any, datePipe: any): string => {\n\t\tif (field?.datePickerProps?.selectionMode == 'range' && target.length == 2) {\n\t\t\tconsole.log(target.join('~'));\n\t\t\treturn target.join('~');\n\t\t}\n\t\treturn target;\n\t},\n\ttoFieldValue: (field: FormField, raw: any, datePipe: DatePipe): any => {\n\t\tif (field.type == 'treeselect') {\n\t\t\treturn _fieldUtils.toTreeSelectValue(field, raw);\n\t\t}\n\t\tif (field.type == 'datepicker') {\n\t\t\treturn _fieldUtils.toDatePickerValue(field, raw, datePipe);\n\t\t}\n\t\tif (field.type == 'multiselect') {\n\t\t\treturn _fieldUtils.toMultiSelectValue(field, raw);\n\t\t}\n\t\tif (field.type == 'image') {\n\t\t\treturn _fieldUtils.toImageValue(field, raw);\n\t\t}\n\t\tif (field.type == 'upload') {\n\t\t\treturn _fieldUtils.toUploadValue(field, raw);\n\t\t}\n\t\treturn raw || '';\n\t},\n\ttoTreeSelectValue: (field: FormField, raw: any): any => {\n\t\tif (field.treeSelectProps?.selectionMode == 'single') {\n\t\t\treturn _fieldUtils.findTreeNode(raw, field.treeSelectProps?.options);\n\t\t}\n\t\tconst nodes: any[] = [];\n\t\t_fieldUtils.findTreeNodes(raw?.split(',') || [], field.treeSelectProps?.options || [], nodes);\n\t\treturn nodes;\n\t},\n\ttoDatePickerValue: (field: FormField, raw: any, datePipe: DatePipe, stringMode: boolean = false): any => {\n\t\tif (!raw || raw == '0001-01-01T00:00:00Z') {\n\t\t\treturn '';\n\t\t}\n\t\tif (_fieldUtils.isISO8601(raw)) {\n\t\t\tconst datePipeFormat = field.datePickerProps?.datePipeFormat ?? 'yyyy-MM-dd';\n\t\t\treturn datePipe.transform(raw, datePipeFormat, 'GMT') || raw;\n\t\t}\n\t\tif (!stringMode && field?.datePickerProps?.selectionMode == 'range' && raw.includes('~')) {\n\t\t\tconst [start, end] = raw.split('~');\n\t\t\treturn [new Date(start), new Date(end)];\n\t\t}\n\t\treturn raw;\n\t},\n\ttoMultiSelectValue: (field: FormField, raw: any): any => {\n\t\tif (!field.multiSelectProps?.optionValue) {\n\t\t\treturn raw || '';\n\t\t}\n\t\treturn (raw && raw.split(',')) || '';\n\t},\n\ttoImageValue: (field: FormField, raw: any): any => {\n\t\treturn (raw && raw.split(';')) || [];\n\t},\n\ttoUploadValue: (field: FormField, raw: any): any => {\n\t\treturn (raw && raw.split(';')) || [];\n\t},\n\tfindTreeNode(value: string, children?: any[]): any {\n\t\tif (!children || children.length == 0) return;\n\t\tconst n = children.find((o) => o.key == value);\n\t\tif (n) return n;\n\t\tfor (const ch of children) {\n\t\t\tconst cn = this.findTreeNode(value, ch.children);\n\t\t\tif (cn) return cn;\n\t\t}\n\t\treturn;\n\t},\n\tfindTreeNodes(values: string[], children?: any[], nodes?: any[]): void {\n\t\tif (!children || children.length == 0) return;\n\t\tconst tars = children.filter((o) => values.indexOf(o.key) != -1);\n\t\tnodes?.push(...tars);\n\t\tfor (const ch of children) {\n\t\t\tthis.findTreeNodes(values, ch.children, nodes);\n\t\t}\n\t},\n\tpreloadLog(rawModel: any, fieldList: FormField[], datePipe: DatePipe): any {\n\t\tconst target: any = {};\n\t\tObject.keys(rawModel).forEach((key) => {\n\t\t\tconst field = fieldList.find((field) => field.key === key);\n\t\t\tif (field?.type == 'datepicker') {\n\t\t\t\ttarget[key] = _fieldUtils.toDatePickerValue(field, rawModel[key], datePipe, true);\n\t\t\t\treturn;\n\t\t\t}\n\t\t\ttarget[key] = rawModel[key];\n\t\t});\n\t\treturn target;\n\t},\n\ttransLog(rawModel: any, changedModel: any, mainValue: any, isNew: boolean): string {\n\t\tif (isNew) {\n\t\t\treturn '新建：' + mainValue;\n\t\t}\n\t\tconst detail: string[] = [];\n\t\tObject.keys(changedModel).forEach((key) => {\n\t\t\tif (changedModel[key].type == 'codemirror') {\n\t\t\t\tdetail.push(`[${changedModel[key].name}] 变更`);\n\t\t\t\treturn;\n\t\t\t}\n\t\t\tdetail.push(`[${changedModel[key].name}] ${rawModel[key] || ''} -> ${changedModel[key].value || ''}`);\n\t\t});\n\t\treturn detail.join(';');\n\t},\n\t// 经测试select组件有内部bug\n\t// 设置model时，fieldControl.setValue的emitEvent参数为false,仍会触发valueChanges事件\n\t// 触发valueChanges会影响日志保存的准确性，故此方法仅是为了防止组件内部意外触发的变动\n\tisFakedChange(newValue: any, oldValue: any, field: FormField): boolean {\n\t\tconst changeTypes = ['inputtext', 'inputnumber', 'select', 'treeselect', 'datepicker', 'autocomplete', 'multiselect', 'radio'];\n\t\tif (changeTypes.includes(field.type!)) {\n\t\t\treturn (oldValue || '') == (newValue || '');\n\t\t}\n\t\treturn false;\n\t},\n\tisISO8601(timeStr: string): boolean {\n\t\treturn /^\\d{4}-\\d{2}-\\d{2}T\\d{2}:\\d{2}:\\d{2}(\\.\\d+)?(Z|[+-]\\d{2}:\\d{2})$/.test(timeStr);\n\t},\n};\n\nexport const fieldUtils = {\n\tprops: _fieldUtils.props,\n\tlabel: _fieldUtils.label,\n\tfieldHandler: _fieldUtils.fieldHandler,\n\ttriggerHookAndSetValue: _fieldUtils.triggerHookAndSetValue,\n\tfromFieldValue: _fieldUtils.fromFieldValue,\n\tpreloadLog: _fieldUtils.preloadLog,\n\ttransLog: _fieldUtils.transLog,\n\tisFakedChange: _fieldUtils.isFakedChange,\n};\n"]}
|
|
@@ -18,6 +18,7 @@ export class DatePickerComponent {
|
|
|
18
18
|
this.props = this.field().datePickerProps;
|
|
19
19
|
this.handleHookChange();
|
|
20
20
|
this.handleDisabled();
|
|
21
|
+
this.handleDatePipeFormat();
|
|
21
22
|
}
|
|
22
23
|
});
|
|
23
24
|
effect(() => {
|
|
@@ -74,6 +75,47 @@ export class DatePickerComponent {
|
|
|
74
75
|
throw new Error('Invalid date format. Expected yyyy-MM-dd hh:mm:ss');
|
|
75
76
|
}
|
|
76
77
|
}
|
|
78
|
+
handleDatePipeFormat() {
|
|
79
|
+
this.props.datePipeFormat = this.convertPrimeNgToDatePipeFormat(this.props.dateFormat);
|
|
80
|
+
if (!this.props.showTime)
|
|
81
|
+
return;
|
|
82
|
+
const timeSeparator = this.props.timeSeparator ?? ':';
|
|
83
|
+
const timeFormat = `HH${timeSeparator}mm${timeSeparator}ss`;
|
|
84
|
+
this.props.datePipeFormat += ` ${timeFormat}`;
|
|
85
|
+
}
|
|
86
|
+
convertPrimeNgToDatePipeFormat(primeNgFormat) {
|
|
87
|
+
if (!primeNgFormat)
|
|
88
|
+
return 'yyyy-MM-dd';
|
|
89
|
+
const formatMap = {
|
|
90
|
+
d: 'd',
|
|
91
|
+
dd: 'dd',
|
|
92
|
+
m: 'M',
|
|
93
|
+
mm: 'MM',
|
|
94
|
+
M: 'MMM',
|
|
95
|
+
MM: 'MMMM',
|
|
96
|
+
y: 'yy',
|
|
97
|
+
yy: 'yyyy',
|
|
98
|
+
};
|
|
99
|
+
const commonFormats = {
|
|
100
|
+
'mm/dd/yy': 'MM/dd/yyyy',
|
|
101
|
+
'dd/mm/yy': 'dd/MM/yyyy',
|
|
102
|
+
'yy-mm-dd': 'yyyy-MM-dd',
|
|
103
|
+
'dd-mm-yy': 'dd-MM-yyyy',
|
|
104
|
+
'mm-dd-yy': 'MM-dd-yyyy',
|
|
105
|
+
};
|
|
106
|
+
if (commonFormats[primeNgFormat]) {
|
|
107
|
+
return commonFormats[primeNgFormat];
|
|
108
|
+
}
|
|
109
|
+
// 替换转义字符
|
|
110
|
+
let result = primeNgFormat.replace(/'([^']*)'/g, (match, p1) => {
|
|
111
|
+
return `'${p1}'`;
|
|
112
|
+
});
|
|
113
|
+
// 替换格式标记
|
|
114
|
+
result = result.replace(/[a-zA-Z]+/g, (match) => {
|
|
115
|
+
return formatMap[match] || match;
|
|
116
|
+
});
|
|
117
|
+
return result;
|
|
118
|
+
}
|
|
77
119
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DatePickerComponent, deps: [{ token: i1.ActionService }, { token: i0.Renderer2 }, { token: i2.DatePipe }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
78
120
|
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: DatePickerComponent, isStandalone: true, selector: "form-datepicker", inputs: { field: { classPropertyName: "field", publicName: "field", isSignal: true, isRequired: false, transformFunction: null } }, providers: [DatePipe], viewQueries: [{ propertyName: "datePicker", first: true, predicate: DatePicker, descendants: true }, { propertyName: "datePickerRef", first: true, predicate: DatePicker, descendants: true, read: ElementRef }], ngImport: i0, template: `<p-datepicker
|
|
79
121
|
[id]="field()?.uuid"
|
|
@@ -263,4 +305,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
263
305
|
type: ViewChild,
|
|
264
306
|
args: [DatePicker, { read: ElementRef, static: false }]
|
|
265
307
|
}] } });
|
|
266
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datepicker.type.js","sourceRoot":"","sources":["../../../../../../projects/imm-element-ui/src/lib/form/form-type/datepicker.type.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, input, effect, ViewChild, ElementRef, Renderer2 } from '@angular/core';\nimport { ReactiveFormsModule } from '@angular/forms';\nimport { DatePicker } from 'primeng/datepicker';\nimport { FormField, FieldProps, AttributeEvent } from '../form-field/form-field';\nimport { ActionService } from '../../service/action.service';\nimport { DatePipe } from '@angular/common';\n\nexport interface DatePickerProps extends FieldProps {\n\tfluid?: boolean;\n\ticonAriaLabel?: string;\n\tdateFormat?: string;\n\tmultipleSeparator?: string;\n\trangeSeparator?: string;\n\tinline?: boolean;\n\tshowOtherMonths?: boolean;\n\tselectOtherMonths?: boolean;\n\tshowIcon?: boolean;\n\ticon?: string;\n\tappendTo?: any;\n\treadonlyInput?: boolean;\n\tshortYearCutoff?: any;\n\thourFormat?: string;\n\ttimeOnly?: boolean;\n\tstepHour?: number;\n\tstepMinute?: number;\n\tstepSecond?: number;\n\tshowOnFocus?: boolean;\n\tshowWeek?: boolean;\n\tstartWeekFromFirstDayOfYear?: boolean;\n\tshowClear?: boolean;\n\tdataType?: string;\n\tselectionMode?: 'range' | 'single' | 'multiple';\n\tmaxDateCount?: number;\n\tshowButtonBar?: boolean;\n\ttodayButtonStyleClass?: string;\n\tclearButtonStyleClass?: string;\n\tbaseZIndex?: number;\n\tpanelStyleClass?: string;\n\tpanelStyle?: any;\n\tkeepInvalid?: boolean;\n\thideOnDateTimeSelect?: boolean;\n\ttouchUI?: boolean;\n\ttimeSeparator?: string;\n\tfocusTrap?: boolean;\n\tshowTransitionOptions?: string;\n\thideTransitionOptions?: string;\n\tminDate?: Date;\n\tmaxDate?: Date;\n\tdisabledDates?: Date[];\n\tdisabledDays?: number[];\n\tshowTime?: boolean;\n\tshowSeconds?: boolean;\n\tresponsiveOptions?: any[];\n\tnumberOfMonths?: number;\n\tfirstDayOfWeek?: number;\n\tview?: any;\n\tdefaultDate?: Date;\n\ttabindex?: number;\n\tautoZIndex?: boolean;\n\n\tonHookChange?: AttributeEvent;\n\tonInput?: AttributeEvent;\n\tonFocus?: AttributeEvent;\n\tonBlur?: AttributeEvent;\n\tonClose?: AttributeEvent;\n\tonSelect?: AttributeEvent;\n\tonClear?: AttributeEvent;\n\tonTodayClick?: AttributeEvent;\n\tonClearClick?: AttributeEvent;\n\tonMonthChange?: AttributeEvent;\n\tonYearChange?: AttributeEvent;\n\tonClickOutside?: AttributeEvent;\n\tonShow?: AttributeEvent;\n}\n\n@Component({\n\tselector: 'form-datepicker',\n\tstandalone: true,\n\tproviders: [DatePipe],\n\timports: [DatePicker, ReactiveFormsModule],\n\ttemplate: `<p-datepicker\n\t\t[id]=\"field()?.uuid\"\n\t\t[inputId]=\"field()?.uuid\"\n\t\t[variant]=\"props.variant ?? 'outlined'\"\n\t\t[fluid]=\"props.fluid\"\n\t\t[size]=\"props.size\"\n\t\t[styleClass]=\"props.styleClass\"\n\t\t[inputStyle]=\"props.inputStyle\"\n\t\t[inputStyleClass]=\"props.inputStyleClass\"\n\t\t[name]=\"props.name\"\n\t\t[placeholder]=\"props.placeholder\"\n\t\t[ariaLabelledBy]=\"props.ariaLabelledBy\"\n\t\t[ariaLabel]=\"props.ariaLabel\"\n\t\t[iconAriaLabel]=\"props.iconAriaLabel\"\n\t\t[dateFormat]=\"props.dateFormat ?? 'yy-mm-dd'\"\n\t\t[multipleSeparator]=\"props.multipleSeparator ?? ','\"\n\t\t[rangeSeparator]=\"props.rangeSeparator ?? '-'\"\n\t\t[inline]=\"props.inline\"\n\t\t[showOtherMonths]=\"props.showOtherMonths ?? true\"\n\t\t[selectOtherMonths]=\"props.selectOtherMonths\"\n\t\t[showIcon]=\"props.showIcon\"\n\t\t[fluid]=\"props.fluid ?? true\"\n\t\t[icon]=\"props.icon\"\n\t\t[appendTo]=\"props.appendTo ?? 'body'\"\n\t\t[readonlyInput]=\"props.readonlyInput\"\n\t\t[shortYearCutoff]=\"props.shortYearCutoff\"\n\t\t[hourFormat]=\"props.hourFormat ?? '24'\"\n\t\t[timeOnly]=\"props.timeOnly\"\n\t\t[stepHour]=\"props.stepHour ?? 1\"\n\t\t[stepMinute]=\"props.stepMinute ?? 1\"\n\t\t[stepSecond]=\"props.stepSecond ?? 1\"\n\t\t[showSeconds]=\"props.showSeconds ?? !!props.showTime\"\n\t\t[showOnFocus]=\"props.showOnFocus ?? true\"\n\t\t[showWeek]=\"props.showWeek\"\n\t\t[startWeekFromFirstDayOfYear]=\"!!props.startWeekFromFirstDayOfYear\"\n\t\t[showClear]=\"props.showClear\"\n\t\t[dataType]=\"props.dataType ?? 'string'\"\n\t\t[selectionMode]=\"props.selectionMode ?? 'single'\"\n\t\t[maxDateCount]=\"props.maxDateCount\"\n\t\t[showButtonBar]=\"props.showButtonBar\"\n\t\t[todayButtonStyleClass]=\"props.todayButtonStyleClass\"\n\t\t[clearButtonStyleClass]=\"props.clearButtonStyleClass\"\n\t\t[autofocus]=\"props.autofocus\"\n\t\t[autoZIndex]=\"props.autoZIndex ?? true\"\n\t\t[baseZIndex]=\"props.baseZIndex ?? 0\"\n\t\t[panelStyleClass]=\"props.panelStyleClass\"\n\t\t[panelStyle]=\"props.panelStyle\"\n\t\t[keepInvalid]=\"props.keepInvalid\"\n\t\t[hideOnDateTimeSelect]=\"props.hideOnDateTimeSelect ?? true\"\n\t\t[touchUI]=\"props.touchUI\"\n\t\t[timeSeparator]=\"props.timeSeparator ?? ':'\"\n\t\t[focusTrap]=\"props.focusTrap ?? true\"\n\t\t[showTransitionOptions]=\"props.showTransitionOptions ?? '.12s cubic-bezier(0, 0, 0.2, 1)'\"\n\t\t[hideTransitionOptions]=\"props.hideTransitionOptions ?? '.1s linear'\"\n\t\t[tabindex]=\"props.tabindex\"\n\t\t[minDate]=\"props.minDate\"\n\t\t[maxDate]=\"props.maxDate\"\n\t\t[disabledDates]=\"props.disabledDates ?? []\"\n\t\t[disabledDays]=\"props.disabledDays ?? []\"\n\t\t[showTime]=\"!!props.showTime\"\n\t\t[responsiveOptions]=\"props.responsiveOptions ?? []\"\n\t\t[numberOfMonths]=\"props.numberOfMonths ?? 1\"\n\t\t[firstDayOfWeek]=\"props.firstDayOfWeek ?? 7\"\n\t\t[view]=\"props.view ?? 'date'\"\n\t\t[defaultDate]=\"props.defaultDate!\"\n\t\t(onInput)=\"props.onInput?.(field()!, $event)\"\n\t\t(onFocus)=\"props.onFocus?.(field()!, $event)\"\n\t\t(onBlur)=\"props.onBlur?.(field()!, $event)\"\n\t\t(onClose)=\"props.onClose?.(field()!, $event)\"\n\t\t(onSelect)=\"props.onSelect?.(field()!, $event)\"\n\t\t(onClear)=\"props.onClear?.(field()!, $event)\"\n\t\t(onTodayClick)=\"props.onTodayClick?.(field()!, $event)\"\n\t\t(onClearClick)=\"props.onClearClick?.(field()!, $event)\"\n\t\t(onMonthChange)=\"props.onMonthChange?.(field()!, $event)\"\n\t\t(onYearChange)=\"props.onYearChange?.(field()!, $event)\"\n\t\t(onClickOutside)=\"props.onClickOutside?.(field()!, $event)\"\n\t\t(onShow)=\"props.onShow?.(field()!, $event)\"\n\t\t[class]=\"props.class\"\n\t\t[formControl]=\"field()!.fieldControl!\">\n\t\t<ng-template #footer>\n\t\t\t@if (!!props.showTime && !props.timeOnly) {\n\t\t\t\t<div class=\"flex flex-row-reverse text-[12px] text-[var(--p-primary-color)] cursor-pointer\">\n\t\t\t\t\t<i\n\t\t\t\t\t\tclass=\"pi pi-replay\"\n\t\t\t\t\t\t(click)=\"resetTime($event)\"></i>\n\t\t\t\t</div>\n\t\t\t}\n\t\t</ng-template>\n\t</p-datepicker>`,\n\tstyleUrl: '../../styles/styles.scss',\n})\nexport class DatePickerComponent {\n\t@ViewChild(DatePicker, { static: false }) datePicker!: DatePicker;\n\t@ViewChild(DatePicker, { read: ElementRef, static: false }) datePickerRef!: ElementRef;\n\tfield = input<FormField>();\n\tprops: DatePickerProps = {};\n\n\tconstructor(\n\t\tprivate action: ActionService,\n\t\tprivate renderer: Renderer2,\n\t\tprivate datePipe: DatePipe,\n\t) {\n\t\teffect(() => {\n\t\t\tif (this.field()) {\n\t\t\t\tthis.props = this.field()!.datePickerProps!;\n\t\t\t\tthis.handleHookChange();\n\t\t\t\tthis.handleDisabled();\n\t\t\t}\n\t\t});\n\t\teffect(\n\t\t\t() => {\n\t\t\t\tconst labelAction = this.action.getFieldLabelAction();\n\t\t\t\tif (!labelAction || labelAction?.key != this.field()?.uuid) {\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t\tif (labelAction.type == 'mouseenter') {\n\t\t\t\t\tthis.renderer.addClass(this.datePickerRef.nativeElement, 'ng-hovered');\n\t\t\t\t} else if (labelAction.type == 'mouseleave') {\n\t\t\t\t\tthis.renderer.removeClass(this.datePickerRef.nativeElement, 'ng-hovered');\n\t\t\t\t} else if (labelAction.type == 'click') {\n\t\t\t\t\tthis.datePicker.overlayVisible = true;\n\t\t\t\t\tthis.datePicker.onShow.emit(false);\n\t\t\t\t\tthis.datePicker.cd.markForCheck();\n\t\t\t\t}\n\t\t\t},\n\t\t\t{ allowSignalWrites: true },\n\t\t);\n\t}\n\n\tngOnInit(): void {}\n\n\thandleHookChange() {\n\t\tthis.field()?.fieldControl?.hookChange.subscribe((value) => {\n\t\t\tif (!value) {\n\t\t\t\treturn;\n\t\t\t}\n\t\t\tthis.props.onHookChange?.(this.field()!, { value });\n\t\t});\n\t}\n\n\thandleDisabled() {\n\t\tsetTimeout(() => {\n\t\t\tif (this.props?.disabled) {\n\t\t\t\tthis.field()!.fieldControl!.disable({ emitEvent: false });\n\t\t\t}\n\t\t});\n\t}\n\n\tresetTime(event: any) {\n\t\tif (!this.field()!.fieldControl!.value) return;\n\t\tconst currentDate = this.formatToMidnight(this.field()!.fieldControl!.value);\n\t\tthis.field()?.fieldControl?.setValue(currentDate, { emitEvent: true });\n\t}\n\n\tformatToMidnight(dateStr: string): string {\n\t\tif (this.props?.showSeconds === false) {\n\t\t\tif (/^\\d{4}-\\d{2}-\\d{2} \\d{2}:\\d{2}$/.test(dateStr)) {\n\t\t\t\treturn dateStr.split(' ')[0] + ' 00:00';\n\t\t\t}\n\t\t\tthrow new Error('Invalid date format. Expected yyyy-MM-dd hh:mm');\n\t\t} else {\n\t\t\tif (/^\\d{4}-\\d{2}-\\d{2} \\d{2}:\\d{2}:\\d{2}$/.test(dateStr)) {\n\t\t\t\treturn dateStr.split(' ')[0] + ' 00:00:00';\n\t\t\t}\n\t\t\tthrow new Error('Invalid date format. Expected yyyy-MM-dd hh:mm:ss');\n\t\t}\n\t}\n}\n"]}
|
|
308
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"datepicker.type.js","sourceRoot":"","sources":["../../../../../../projects/imm-element-ui/src/lib/form/form-type/datepicker.type.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, input, effect, ViewChild, ElementRef, Renderer2 } from '@angular/core';\nimport { ReactiveFormsModule } from '@angular/forms';\nimport { DatePicker } from 'primeng/datepicker';\nimport { FormField, FieldProps, AttributeEvent } from '../form-field/form-field';\nimport { ActionService } from '../../service/action.service';\nimport { DatePipe } from '@angular/common';\n\nexport interface DatePickerProps extends FieldProps {\n\tfluid?: boolean;\n\ticonAriaLabel?: string;\n\tdateFormat?: string;\n\tdatePipeFormat?: string;\n\tmultipleSeparator?: string;\n\trangeSeparator?: string;\n\tinline?: boolean;\n\tshowOtherMonths?: boolean;\n\tselectOtherMonths?: boolean;\n\tshowIcon?: boolean;\n\ticon?: string;\n\tappendTo?: any;\n\treadonlyInput?: boolean;\n\tshortYearCutoff?: any;\n\thourFormat?: string;\n\ttimeOnly?: boolean;\n\tstepHour?: number;\n\tstepMinute?: number;\n\tstepSecond?: number;\n\tshowOnFocus?: boolean;\n\tshowWeek?: boolean;\n\tstartWeekFromFirstDayOfYear?: boolean;\n\tshowClear?: boolean;\n\tdataType?: string;\n\tselectionMode?: 'range' | 'single' | 'multiple';\n\tmaxDateCount?: number;\n\tshowButtonBar?: boolean;\n\ttodayButtonStyleClass?: string;\n\tclearButtonStyleClass?: string;\n\tbaseZIndex?: number;\n\tpanelStyleClass?: string;\n\tpanelStyle?: any;\n\tkeepInvalid?: boolean;\n\thideOnDateTimeSelect?: boolean;\n\ttouchUI?: boolean;\n\ttimeSeparator?: string;\n\tfocusTrap?: boolean;\n\tshowTransitionOptions?: string;\n\thideTransitionOptions?: string;\n\tminDate?: Date;\n\tmaxDate?: Date;\n\tdisabledDates?: Date[];\n\tdisabledDays?: number[];\n\tshowTime?: boolean;\n\tshowSeconds?: boolean;\n\tresponsiveOptions?: any[];\n\tnumberOfMonths?: number;\n\tfirstDayOfWeek?: number;\n\tview?: any;\n\tdefaultDate?: Date;\n\ttabindex?: number;\n\tautoZIndex?: boolean;\n\n\tonHookChange?: AttributeEvent;\n\tonInput?: AttributeEvent;\n\tonFocus?: AttributeEvent;\n\tonBlur?: AttributeEvent;\n\tonClose?: AttributeEvent;\n\tonSelect?: AttributeEvent;\n\tonClear?: AttributeEvent;\n\tonTodayClick?: AttributeEvent;\n\tonClearClick?: AttributeEvent;\n\tonMonthChange?: AttributeEvent;\n\tonYearChange?: AttributeEvent;\n\tonClickOutside?: AttributeEvent;\n\tonShow?: AttributeEvent;\n}\n\n@Component({\n\tselector: 'form-datepicker',\n\tstandalone: true,\n\tproviders: [DatePipe],\n\timports: [DatePicker, ReactiveFormsModule],\n\ttemplate: `<p-datepicker\n\t\t[id]=\"field()?.uuid\"\n\t\t[inputId]=\"field()?.uuid\"\n\t\t[variant]=\"props.variant ?? 'outlined'\"\n\t\t[fluid]=\"props.fluid\"\n\t\t[size]=\"props.size\"\n\t\t[styleClass]=\"props.styleClass\"\n\t\t[inputStyle]=\"props.inputStyle\"\n\t\t[inputStyleClass]=\"props.inputStyleClass\"\n\t\t[name]=\"props.name\"\n\t\t[placeholder]=\"props.placeholder\"\n\t\t[ariaLabelledBy]=\"props.ariaLabelledBy\"\n\t\t[ariaLabel]=\"props.ariaLabel\"\n\t\t[iconAriaLabel]=\"props.iconAriaLabel\"\n\t\t[dateFormat]=\"props.dateFormat ?? 'yy-mm-dd'\"\n\t\t[multipleSeparator]=\"props.multipleSeparator ?? ','\"\n\t\t[rangeSeparator]=\"props.rangeSeparator ?? '-'\"\n\t\t[inline]=\"props.inline\"\n\t\t[showOtherMonths]=\"props.showOtherMonths ?? true\"\n\t\t[selectOtherMonths]=\"props.selectOtherMonths\"\n\t\t[showIcon]=\"props.showIcon\"\n\t\t[fluid]=\"props.fluid ?? true\"\n\t\t[icon]=\"props.icon\"\n\t\t[appendTo]=\"props.appendTo ?? 'body'\"\n\t\t[readonlyInput]=\"props.readonlyInput\"\n\t\t[shortYearCutoff]=\"props.shortYearCutoff\"\n\t\t[hourFormat]=\"props.hourFormat ?? '24'\"\n\t\t[timeOnly]=\"props.timeOnly\"\n\t\t[stepHour]=\"props.stepHour ?? 1\"\n\t\t[stepMinute]=\"props.stepMinute ?? 1\"\n\t\t[stepSecond]=\"props.stepSecond ?? 1\"\n\t\t[showSeconds]=\"props.showSeconds ?? !!props.showTime\"\n\t\t[showOnFocus]=\"props.showOnFocus ?? true\"\n\t\t[showWeek]=\"props.showWeek\"\n\t\t[startWeekFromFirstDayOfYear]=\"!!props.startWeekFromFirstDayOfYear\"\n\t\t[showClear]=\"props.showClear\"\n\t\t[dataType]=\"props.dataType ?? 'string'\"\n\t\t[selectionMode]=\"props.selectionMode ?? 'single'\"\n\t\t[maxDateCount]=\"props.maxDateCount\"\n\t\t[showButtonBar]=\"props.showButtonBar\"\n\t\t[todayButtonStyleClass]=\"props.todayButtonStyleClass\"\n\t\t[clearButtonStyleClass]=\"props.clearButtonStyleClass\"\n\t\t[autofocus]=\"props.autofocus\"\n\t\t[autoZIndex]=\"props.autoZIndex ?? true\"\n\t\t[baseZIndex]=\"props.baseZIndex ?? 0\"\n\t\t[panelStyleClass]=\"props.panelStyleClass\"\n\t\t[panelStyle]=\"props.panelStyle\"\n\t\t[keepInvalid]=\"props.keepInvalid\"\n\t\t[hideOnDateTimeSelect]=\"props.hideOnDateTimeSelect ?? true\"\n\t\t[touchUI]=\"props.touchUI\"\n\t\t[timeSeparator]=\"props.timeSeparator ?? ':'\"\n\t\t[focusTrap]=\"props.focusTrap ?? true\"\n\t\t[showTransitionOptions]=\"props.showTransitionOptions ?? '.12s cubic-bezier(0, 0, 0.2, 1)'\"\n\t\t[hideTransitionOptions]=\"props.hideTransitionOptions ?? '.1s linear'\"\n\t\t[tabindex]=\"props.tabindex\"\n\t\t[minDate]=\"props.minDate\"\n\t\t[maxDate]=\"props.maxDate\"\n\t\t[disabledDates]=\"props.disabledDates ?? []\"\n\t\t[disabledDays]=\"props.disabledDays ?? []\"\n\t\t[showTime]=\"!!props.showTime\"\n\t\t[responsiveOptions]=\"props.responsiveOptions ?? []\"\n\t\t[numberOfMonths]=\"props.numberOfMonths ?? 1\"\n\t\t[firstDayOfWeek]=\"props.firstDayOfWeek ?? 7\"\n\t\t[view]=\"props.view ?? 'date'\"\n\t\t[defaultDate]=\"props.defaultDate!\"\n\t\t(onInput)=\"props.onInput?.(field()!, $event)\"\n\t\t(onFocus)=\"props.onFocus?.(field()!, $event)\"\n\t\t(onBlur)=\"props.onBlur?.(field()!, $event)\"\n\t\t(onClose)=\"props.onClose?.(field()!, $event)\"\n\t\t(onSelect)=\"props.onSelect?.(field()!, $event)\"\n\t\t(onClear)=\"props.onClear?.(field()!, $event)\"\n\t\t(onTodayClick)=\"props.onTodayClick?.(field()!, $event)\"\n\t\t(onClearClick)=\"props.onClearClick?.(field()!, $event)\"\n\t\t(onMonthChange)=\"props.onMonthChange?.(field()!, $event)\"\n\t\t(onYearChange)=\"props.onYearChange?.(field()!, $event)\"\n\t\t(onClickOutside)=\"props.onClickOutside?.(field()!, $event)\"\n\t\t(onShow)=\"props.onShow?.(field()!, $event)\"\n\t\t[class]=\"props.class\"\n\t\t[formControl]=\"field()!.fieldControl!\">\n\t\t<ng-template #footer>\n\t\t\t@if (!!props.showTime && !props.timeOnly) {\n\t\t\t\t<div class=\"flex flex-row-reverse text-[12px] text-[var(--p-primary-color)] cursor-pointer\">\n\t\t\t\t\t<i\n\t\t\t\t\t\tclass=\"pi pi-replay\"\n\t\t\t\t\t\t(click)=\"resetTime($event)\"></i>\n\t\t\t\t</div>\n\t\t\t}\n\t\t</ng-template>\n\t</p-datepicker>`,\n\tstyleUrl: '../../styles/styles.scss',\n})\nexport class DatePickerComponent {\n\t@ViewChild(DatePicker, { static: false }) datePicker!: DatePicker;\n\t@ViewChild(DatePicker, { read: ElementRef, static: false }) datePickerRef!: ElementRef;\n\tfield = input<FormField>();\n\tprops: DatePickerProps = {};\n\n\tconstructor(\n\t\tprivate action: ActionService,\n\t\tprivate renderer: Renderer2,\n\t\tprivate datePipe: DatePipe,\n\t) {\n\t\teffect(() => {\n\t\t\tif (this.field()) {\n\t\t\t\tthis.props = this.field()!.datePickerProps!;\n\t\t\t\tthis.handleHookChange();\n\t\t\t\tthis.handleDisabled();\n\t\t\t\tthis.handleDatePipeFormat();\n\t\t\t}\n\t\t});\n\t\teffect(\n\t\t\t() => {\n\t\t\t\tconst labelAction = this.action.getFieldLabelAction();\n\t\t\t\tif (!labelAction || labelAction?.key != this.field()?.uuid) {\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t\tif (labelAction.type == 'mouseenter') {\n\t\t\t\t\tthis.renderer.addClass(this.datePickerRef.nativeElement, 'ng-hovered');\n\t\t\t\t} else if (labelAction.type == 'mouseleave') {\n\t\t\t\t\tthis.renderer.removeClass(this.datePickerRef.nativeElement, 'ng-hovered');\n\t\t\t\t} else if (labelAction.type == 'click') {\n\t\t\t\t\tthis.datePicker.overlayVisible = true;\n\t\t\t\t\tthis.datePicker.onShow.emit(false);\n\t\t\t\t\tthis.datePicker.cd.markForCheck();\n\t\t\t\t}\n\t\t\t},\n\t\t\t{ allowSignalWrites: true },\n\t\t);\n\t}\n\n\tngOnInit(): void {}\n\n\thandleHookChange() {\n\t\tthis.field()?.fieldControl?.hookChange.subscribe((value) => {\n\t\t\tif (!value) {\n\t\t\t\treturn;\n\t\t\t}\n\t\t\tthis.props.onHookChange?.(this.field()!, { value });\n\t\t});\n\t}\n\n\thandleDisabled() {\n\t\tsetTimeout(() => {\n\t\t\tif (this.props?.disabled) {\n\t\t\t\tthis.field()!.fieldControl!.disable({ emitEvent: false });\n\t\t\t}\n\t\t});\n\t}\n\n\tresetTime(event: any) {\n\t\tif (!this.field()!.fieldControl!.value) return;\n\t\tconst currentDate = this.formatToMidnight(this.field()!.fieldControl!.value);\n\t\tthis.field()?.fieldControl?.setValue(currentDate, { emitEvent: true });\n\t}\n\n\tformatToMidnight(dateStr: string): string {\n\t\tif (this.props?.showSeconds === false) {\n\t\t\tif (/^\\d{4}-\\d{2}-\\d{2} \\d{2}:\\d{2}$/.test(dateStr)) {\n\t\t\t\treturn dateStr.split(' ')[0] + ' 00:00';\n\t\t\t}\n\t\t\tthrow new Error('Invalid date format. Expected yyyy-MM-dd hh:mm');\n\t\t} else {\n\t\t\tif (/^\\d{4}-\\d{2}-\\d{2} \\d{2}:\\d{2}:\\d{2}$/.test(dateStr)) {\n\t\t\t\treturn dateStr.split(' ')[0] + ' 00:00:00';\n\t\t\t}\n\t\t\tthrow new Error('Invalid date format. Expected yyyy-MM-dd hh:mm:ss');\n\t\t}\n\t}\n\n\thandleDatePipeFormat() {\n\t\tthis.props.datePipeFormat = this.convertPrimeNgToDatePipeFormat(this.props.dateFormat);\n\t\tif (!this.props.showTime) return;\n\t\tconst timeSeparator = this.props.timeSeparator ?? ':';\n\t\tconst timeFormat = `HH${timeSeparator}mm${timeSeparator}ss`;\n\t\tthis.props.datePipeFormat += ` ${timeFormat}`;\n\t}\n\n\tconvertPrimeNgToDatePipeFormat(primeNgFormat: string | undefined): string {\n\t\tif (!primeNgFormat) return 'yyyy-MM-dd';\n\t\tconst formatMap: { [key: string]: string } = {\n\t\t\td: 'd',\n\t\t\tdd: 'dd',\n\t\t\tm: 'M',\n\t\t\tmm: 'MM',\n\t\t\tM: 'MMM',\n\t\t\tMM: 'MMMM',\n\t\t\ty: 'yy',\n\t\t\tyy: 'yyyy',\n\t\t};\n\t\tconst commonFormats: { [key: string]: string } = {\n\t\t\t'mm/dd/yy': 'MM/dd/yyyy',\n\t\t\t'dd/mm/yy': 'dd/MM/yyyy',\n\t\t\t'yy-mm-dd': 'yyyy-MM-dd',\n\t\t\t'dd-mm-yy': 'dd-MM-yyyy',\n\t\t\t'mm-dd-yy': 'MM-dd-yyyy',\n\t\t};\n\t\tif (commonFormats[primeNgFormat]) {\n\t\t\treturn commonFormats[primeNgFormat];\n\t\t}\n\t\t// 替换转义字符\n\t\tlet result = primeNgFormat.replace(/'([^']*)'/g, (match, p1) => {\n\t\t\treturn `'${p1}'`;\n\t\t});\n\t\t// 替换格式标记\n\t\tresult = result.replace(/[a-zA-Z]+/g, (match) => {\n\t\t\treturn formatMap[match] || match;\n\t\t});\n\t\treturn result;\n\t}\n}\n"]}
|
|
@@ -8,12 +8,14 @@ import { filter } from 'rxjs';
|
|
|
8
8
|
import * as i0 from "@angular/core";
|
|
9
9
|
import * as i1 from "@angular/common/http";
|
|
10
10
|
import * as i2 from "../../service/action.service";
|
|
11
|
-
import * as i3 from "
|
|
11
|
+
import * as i3 from "@angular/common";
|
|
12
|
+
import * as i4 from "primeng/button";
|
|
12
13
|
export class ImageComponent {
|
|
13
|
-
constructor(http, action, renderer) {
|
|
14
|
+
constructor(http, action, renderer, datePipe) {
|
|
14
15
|
this.http = http;
|
|
15
16
|
this.action = action;
|
|
16
17
|
this.renderer = renderer;
|
|
18
|
+
this.datePipe = datePipe;
|
|
17
19
|
this.field = input();
|
|
18
20
|
this.props = {};
|
|
19
21
|
this.imageList = [];
|
|
@@ -62,9 +64,58 @@ export class ImageComponent {
|
|
|
62
64
|
return this.http.post('imageDelete', { fid: image });
|
|
63
65
|
}
|
|
64
66
|
uploadHandler(field, event, fu) {
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
67
|
+
console.log(event, 'file----events');
|
|
68
|
+
event.files.forEach(async (v) => {
|
|
69
|
+
if (this.props.watermark) {
|
|
70
|
+
let blob = await this.addWatermark(v);
|
|
71
|
+
const newFile = new File([blob], v.name, { type: v.type });
|
|
72
|
+
this.uploadImage(newFile).subscribe((response) => {
|
|
73
|
+
this.imageList?.push(response.body.fid);
|
|
74
|
+
this.field()?.fieldControl?.setValue(this.imageList);
|
|
75
|
+
});
|
|
76
|
+
}
|
|
77
|
+
else {
|
|
78
|
+
this.uploadImage(v).subscribe((response) => {
|
|
79
|
+
this.imageList?.push(response.body.fid);
|
|
80
|
+
this.field()?.fieldControl?.setValue(this.imageList);
|
|
81
|
+
});
|
|
82
|
+
}
|
|
83
|
+
});
|
|
84
|
+
}
|
|
85
|
+
addWatermark(imageFile) {
|
|
86
|
+
return new Promise((resolve, reject) => {
|
|
87
|
+
const reader = new FileReader();
|
|
88
|
+
reader.onload = (event) => {
|
|
89
|
+
const img = document.createElement('img');
|
|
90
|
+
img.onload = () => {
|
|
91
|
+
const canvas = document.createElement('canvas');
|
|
92
|
+
const ctx = canvas.getContext('2d');
|
|
93
|
+
// 设置画布大小为图片大小
|
|
94
|
+
canvas.width = Number(img.width);
|
|
95
|
+
canvas.height = Number(img.height);
|
|
96
|
+
// 绘制原始图片
|
|
97
|
+
ctx.drawImage(img, 0, 0);
|
|
98
|
+
// 添加水印
|
|
99
|
+
ctx.font = `italic bold 30px Courier`;
|
|
100
|
+
ctx.fillStyle = 'red';
|
|
101
|
+
ctx.textAlign = 'center';
|
|
102
|
+
ctx.textBaseline = 'middle';
|
|
103
|
+
const currentTime = this.datePipe.transform(new Date(), 'yyyy-MM-dd HH:mm:ss') || '';
|
|
104
|
+
ctx.fillText(currentTime, canvas.width / 2, canvas.height - 50);
|
|
105
|
+
// 转换为Blob
|
|
106
|
+
canvas.toBlob((blob) => {
|
|
107
|
+
if (blob) {
|
|
108
|
+
resolve(blob);
|
|
109
|
+
}
|
|
110
|
+
else {
|
|
111
|
+
reject(new Error('Canvas to Blob conversion failed'));
|
|
112
|
+
}
|
|
113
|
+
}, 'image/jpeg', 0.8);
|
|
114
|
+
};
|
|
115
|
+
img.src = event.target?.result;
|
|
116
|
+
};
|
|
117
|
+
reader.onerror = (error) => reject(error);
|
|
118
|
+
reader.readAsDataURL(imageFile);
|
|
68
119
|
});
|
|
69
120
|
}
|
|
70
121
|
deleteHandler(image, index) {
|
|
@@ -105,7 +156,7 @@ export class ImageComponent {
|
|
|
105
156
|
parentDiv.appendChild(childDiv);
|
|
106
157
|
}
|
|
107
158
|
}
|
|
108
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ImageComponent, deps: [{ token: i1.HttpClient }, { token: i2.ActionService }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
159
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ImageComponent, deps: [{ token: i1.HttpClient }, { token: i2.ActionService }, { token: i0.Renderer2 }, { token: i3.DatePipe }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
109
160
|
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: ImageComponent, isStandalone: true, selector: "form-image", inputs: { field: { classPropertyName: "field", publicName: "field", isSignal: true, isRequired: false, transformFunction: null } }, viewQueries: [{ propertyName: "imageCompRef", first: true, predicate: ["imageComp"], descendants: true, read: ElementRef }], ngImport: i0, template: `<p-fileUpload
|
|
110
161
|
#fu
|
|
111
162
|
auto
|
|
@@ -121,6 +172,7 @@ export class ImageComponent {
|
|
|
121
172
|
[headers]="props.headers"
|
|
122
173
|
[fileLimit]="props.fileLimit"
|
|
123
174
|
[customUpload]="props.customUpload ?? true"
|
|
175
|
+
[multiple]="props.multiple ?? false"
|
|
124
176
|
(onBeforeUpload)="props.onBeforeUpload?.(field()!, $event)"
|
|
125
177
|
(onSend)="props.onSend?.(field()!, $event)"
|
|
126
178
|
(onUpload)="props.onUpload?.(field()!, $event)"
|
|
@@ -210,7 +262,7 @@ export class ImageComponent {
|
|
|
210
262
|
}
|
|
211
263
|
</ng-template>
|
|
212
264
|
<ng-template #file> </ng-template>
|
|
213
|
-
</p-fileUpload>`, isInline: true, styles: [":host ::ng-deep .p-disabled,:host ::ng-deep .p-component:disabled{opacity:1}:host ::ng-deep .p-inputtext{border-width:0;border-radius:0;box-shadow:none;background:#fff;padding:0}:host ::ng-deep .p-inputtext:not(.ng-valid).ng-dirty{background:var(--p-red-200)!important;border-bottom:1px solid var(--p-red-500)!important}:host ::ng-deep .p-inputtext:not(:disabled):hover{border-bottom:1px solid var(--p-primary-color)}:host ::ng-deep .p-inputtext:not(:disabled).ng-hovered{border-bottom:1px solid var(--p-primary-color)}:host ::ng-deep .p-inputtext:focus{border-bottom:1px solid var(--p-primary-color)}:host ::ng-deep .ng-hovered .p-autocomplete-input:not(.p-disabled){border-bottom:1px solid var(--p-primary-color)}:host ::ng-deep .p-select-label{padding:0}:host ::ng-deep .p-select{border-width:0;border-radius:0;box-shadow:none;background:#fff}:host ::ng-deep .p-select .p-select-dropdown{display:none}:host ::ng-deep .p-select .p-select-clear-icon{display:none}:host ::ng-deep .p-select:not(.ng-valid).ng-dirty{background:var(--p-red-200)!important;border-bottom:1px solid var(--p-red-500)!important}:host ::ng-deep .p-select-open{border-bottom:1px solid var(--p-primary-color)}:host ::ng-deep .p-select-open .p-select-dropdown{display:flex}:host ::ng-deep .p-select-open .p-select-clear-icon{display:flex}:host ::ng-deep .p-select:hover{border-bottom:1px solid var(--p-primary-color)}:host ::ng-deep .p-select:hover .p-select-dropdown{display:flex}:host ::ng-deep .p-select:hover .p-select-clear-icon{display:flex}:host ::ng-deep .p-select.ng-hovered{border-bottom:1px solid var(--p-primary-color)}:host ::ng-deep .p-select.ng-hovered .p-select-dropdown{display:flex}:host ::ng-deep .p-select.ng-hovered .p-select-clear-icon{display:flex}:host ::ng-deep .p-multiselect-label{padding:0}:host ::ng-deep .p-multiselect{border-width:0;border-radius:0;background:#fff;box-shadow:none}:host ::ng-deep .p-multiselect .p-multiselect-dropdown{display:none}:host ::ng-deep .p-multiselect:not(.ng-valid).ng-dirty{background:var(--p-red-200)!important;border-bottom:1px solid var(--p-red-500)!important}:host ::ng-deep .p-multiselect-open{border-bottom:1px solid var(--p-primary-color)}:host ::ng-deep .p-multiselect-open .p-multiselect-dropdown{display:flex}:host ::ng-deep .p-multiselect:not(.p-disabled).p-focus{border-bottom:1px solid var(--p-primary-color)}:host ::ng-deep .p-multiselect:not(.p-disabled).p-focus .p-multiselect-dropdown{display:flex}:host ::ng-deep .p-multiselect:not(.p-disabled):hover{border-bottom:1px solid var(--p-primary-color)}:host ::ng-deep .p-multiselect:not(.p-disabled):hover .p-multiselect-dropdown{display:flex}:host ::ng-deep .p-multiselect:not(.p-disabled).ng-hovered{border-bottom:1px solid var(--p-primary-color)}:host ::ng-deep .p-multiselect:not(.p-disabled).ng-hovered .p-multiselect-dropdown{display:flex}:host ::ng-deep .p-textarea{border-radius:0;box-shadow:none;padding:0;background:#fff;resize:none}:host ::ng-deep .p-textarea:not(.ng-valid).ng-dirty{background:var(--p-red-200)!important;border:1px solid var(--p-red-500)!important}:host ::ng-deep .p-textarea:not(:disabled):hover{border:1px solid var(--p-primary-color);resize:vertical}:host ::ng-deep .p-textarea:not(:disabled).ng-hovered{border:1px solid var(--p-primary-color);resize:vertical}:host ::ng-deep .p-textarea:focus{border:1px solid var(--p-primary-color);resize:vertical}:host ::ng-deep .p-treeselect-label{padding:0}:host ::ng-deep .p-treeselect{border-width:0;border-radius:0;box-shadow:none;background:#fff}:host ::ng-deep .p-treeselect .p-treeselect-dropdown{display:none}:host ::ng-deep .ng-invalid.ng-dirty>.p-treeselect{background:var(--p-red-200)!important;border-bottom:1px solid var(--p-red-500)!important}:host ::ng-deep .p-treeselect-open{border-bottom:1px solid var(--p-primary-color)}:host ::ng-deep .p-treeselect-open .p-treeselect-dropdown{display:flex}:host ::ng-deep .p-treeselect:not(.p-disabled).p-focus{border-bottom:1px solid var(--p-primary-color)}:host ::ng-deep .p-treeselect:not(.p-disabled).p-focus .p-treeselect-dropdown{display:flex}:host ::ng-deep .p-treeselect:not(.p-disabled):hover{border-bottom:1px solid var(--p-primary-color)}:host ::ng-deep .p-treeselect:not(.p-disabled):hover .p-treeselect-dropdown{display:flex}:host ::ng-deep .ng-hovered>.p-treeselect:not(.p-disabled){border-bottom:1px solid var(--p-primary-color)}:host ::ng-deep .ng-hovered>.p-treeselect:not(.p-disabled) .p-treeselect-dropdown{display:flex}:host ::ng-deep .p-menubar{border-width:0;padding:0}:host ::ng-deep .p-menubar-submenu{z-index:3}:host ::ng-deep .p-fileupload-advanced{border-width:0;border-radius:0;background-color:#fff}:host ::ng-deep .p-fileupload-header{padding:0}:host ::ng-deep .p-fileupload-content{padding:0;display:block;border-width:0}:host ::ng-deep .p-inputnumber:not(.ng-valid).ng-dirty>.p-inputtext{background:var(--p-red-200)!important;border-bottom:1px solid var(--p-red-500)!important}:host ::ng-deep .p-inputnumber.ng-hovered:not(.p-disabled)>.p-inputtext{border-bottom:1px solid var(--p-primary-color)}:host ::ng-deep .ng-invalid.ng-dirty>.p-datepicker .p-inputtext{background:var(--p-red-200)!important;border-bottom:1px solid var(--p-red-500)!important}:host ::ng-deep .ng-hovered>.p-datepicker:not(.p-disabled) .p-inputtext{border-bottom:1px solid var(--p-primary-color)}:host ::ng-deep .cm-editor{border:1px solid #cbd5e1}:host ::ng-deep .cm-editor.cm-focused{outline:none!important;border:1px solid var(--p-primary-color)}:host ::ng-deep .cm-editor:hover{border:1px solid var(--p-primary-color)}:host ::ng-deep .cm-editor.ng-hovered{border:1px solid var(--p-primary-color)}:host ::ng-deep .cm-gutters{background-color:#fff;border:\"none\"}:host ::ng-deep .cm-activeLineGutter{background-color:#fff}\n", ".file-item{border-top:solid 1px #fff}.upload-btn{border:solid 1px transparent}.upload-btn.upload-disable:hover{cursor:default}.upload-btn:not(.upload-disable):hover{border:solid 1px var(--p-primary-color);background:var(--p-primary-50);cursor:pointer}.upload-btn:not(.upload-disable).ng-hovered{border:solid 1px var(--p-primary-color);background:var(--p-primary-50);cursor:pointer}.file-name{font-size:12px;cursor:pointer;color:var(--p-primary-color)!important}:is() .p-image-preview-mask{position:inherit;opacity:1;justify-content:left;color:#334155}:is() p-image .p-image{display:inline-block;color:var(--p-primary-color)!important}\n"], dependencies: [{ kind: "component", type: FileUpload, selector: "p-fileupload, p-fileUpload", inputs: ["name", "url", "method", "multiple", "accept", "disabled", "auto", "withCredentials", "maxFileSize", "invalidFileSizeMessageSummary", "invalidFileSizeMessageDetail", "invalidFileTypeMessageSummary", "invalidFileTypeMessageDetail", "invalidFileLimitMessageDetail", "invalidFileLimitMessageSummary", "style", "styleClass", "previewWidth", "chooseLabel", "uploadLabel", "cancelLabel", "chooseIcon", "uploadIcon", "cancelIcon", "showUploadButton", "showCancelButton", "mode", "headers", "customUpload", "fileLimit", "uploadStyleClass", "cancelStyleClass", "removeStyleClass", "chooseStyleClass", "chooseButtonProps", "uploadButtonProps", "cancelButtonProps", "files"], outputs: ["onBeforeUpload", "onSend", "onUpload", "onError", "onClear", "onRemove", "onSelect", "onProgress", "uploadHandler", "onImageError", "onRemoveUploadedFile"] }, { kind: "ngmodule", type: ButtonModule }, { kind: "component", type:
|
|
265
|
+
</p-fileUpload>`, isInline: true, styles: [":host ::ng-deep .p-disabled,:host ::ng-deep .p-component:disabled{opacity:1}:host ::ng-deep .p-inputtext{border-width:0;border-radius:0;box-shadow:none;background:#fff;padding:0}:host ::ng-deep .p-inputtext:not(.ng-valid).ng-dirty{background:var(--p-red-200)!important;border-bottom:1px solid var(--p-red-500)!important}:host ::ng-deep .p-inputtext:not(:disabled):hover{border-bottom:1px solid var(--p-primary-color)}:host ::ng-deep .p-inputtext:not(:disabled).ng-hovered{border-bottom:1px solid var(--p-primary-color)}:host ::ng-deep .p-inputtext:focus{border-bottom:1px solid var(--p-primary-color)}:host ::ng-deep .ng-hovered .p-autocomplete-input:not(.p-disabled){border-bottom:1px solid var(--p-primary-color)}:host ::ng-deep .p-select-label{padding:0}:host ::ng-deep .p-select{border-width:0;border-radius:0;box-shadow:none;background:#fff}:host ::ng-deep .p-select .p-select-dropdown{display:none}:host ::ng-deep .p-select .p-select-clear-icon{display:none}:host ::ng-deep .p-select:not(.ng-valid).ng-dirty{background:var(--p-red-200)!important;border-bottom:1px solid var(--p-red-500)!important}:host ::ng-deep .p-select-open{border-bottom:1px solid var(--p-primary-color)}:host ::ng-deep .p-select-open .p-select-dropdown{display:flex}:host ::ng-deep .p-select-open .p-select-clear-icon{display:flex}:host ::ng-deep .p-select:hover{border-bottom:1px solid var(--p-primary-color)}:host ::ng-deep .p-select:hover .p-select-dropdown{display:flex}:host ::ng-deep .p-select:hover .p-select-clear-icon{display:flex}:host ::ng-deep .p-select.ng-hovered{border-bottom:1px solid var(--p-primary-color)}:host ::ng-deep .p-select.ng-hovered .p-select-dropdown{display:flex}:host ::ng-deep .p-select.ng-hovered .p-select-clear-icon{display:flex}:host ::ng-deep .p-multiselect-label{padding:0}:host ::ng-deep .p-multiselect{border-width:0;border-radius:0;background:#fff;box-shadow:none}:host ::ng-deep .p-multiselect .p-multiselect-dropdown{display:none}:host ::ng-deep .p-multiselect:not(.ng-valid).ng-dirty{background:var(--p-red-200)!important;border-bottom:1px solid var(--p-red-500)!important}:host ::ng-deep .p-multiselect-open{border-bottom:1px solid var(--p-primary-color)}:host ::ng-deep .p-multiselect-open .p-multiselect-dropdown{display:flex}:host ::ng-deep .p-multiselect:not(.p-disabled).p-focus{border-bottom:1px solid var(--p-primary-color)}:host ::ng-deep .p-multiselect:not(.p-disabled).p-focus .p-multiselect-dropdown{display:flex}:host ::ng-deep .p-multiselect:not(.p-disabled):hover{border-bottom:1px solid var(--p-primary-color)}:host ::ng-deep .p-multiselect:not(.p-disabled):hover .p-multiselect-dropdown{display:flex}:host ::ng-deep .p-multiselect:not(.p-disabled).ng-hovered{border-bottom:1px solid var(--p-primary-color)}:host ::ng-deep .p-multiselect:not(.p-disabled).ng-hovered .p-multiselect-dropdown{display:flex}:host ::ng-deep .p-textarea{border-radius:0;box-shadow:none;padding:0;background:#fff;resize:none}:host ::ng-deep .p-textarea:not(.ng-valid).ng-dirty{background:var(--p-red-200)!important;border:1px solid var(--p-red-500)!important}:host ::ng-deep .p-textarea:not(:disabled):hover{border:1px solid var(--p-primary-color);resize:vertical}:host ::ng-deep .p-textarea:not(:disabled).ng-hovered{border:1px solid var(--p-primary-color);resize:vertical}:host ::ng-deep .p-textarea:focus{border:1px solid var(--p-primary-color);resize:vertical}:host ::ng-deep .p-treeselect-label{padding:0}:host ::ng-deep .p-treeselect{border-width:0;border-radius:0;box-shadow:none;background:#fff}:host ::ng-deep .p-treeselect .p-treeselect-dropdown{display:none}:host ::ng-deep .ng-invalid.ng-dirty>.p-treeselect{background:var(--p-red-200)!important;border-bottom:1px solid var(--p-red-500)!important}:host ::ng-deep .p-treeselect-open{border-bottom:1px solid var(--p-primary-color)}:host ::ng-deep .p-treeselect-open .p-treeselect-dropdown{display:flex}:host ::ng-deep .p-treeselect:not(.p-disabled).p-focus{border-bottom:1px solid var(--p-primary-color)}:host ::ng-deep .p-treeselect:not(.p-disabled).p-focus .p-treeselect-dropdown{display:flex}:host ::ng-deep .p-treeselect:not(.p-disabled):hover{border-bottom:1px solid var(--p-primary-color)}:host ::ng-deep .p-treeselect:not(.p-disabled):hover .p-treeselect-dropdown{display:flex}:host ::ng-deep .ng-hovered>.p-treeselect:not(.p-disabled){border-bottom:1px solid var(--p-primary-color)}:host ::ng-deep .ng-hovered>.p-treeselect:not(.p-disabled) .p-treeselect-dropdown{display:flex}:host ::ng-deep .p-menubar{border-width:0;padding:0}:host ::ng-deep .p-menubar-submenu{z-index:3}:host ::ng-deep .p-fileupload-advanced{border-width:0;border-radius:0;background-color:#fff}:host ::ng-deep .p-fileupload-header{padding:0}:host ::ng-deep .p-fileupload-content{padding:0;display:block;border-width:0}:host ::ng-deep .p-inputnumber:not(.ng-valid).ng-dirty>.p-inputtext{background:var(--p-red-200)!important;border-bottom:1px solid var(--p-red-500)!important}:host ::ng-deep .p-inputnumber.ng-hovered:not(.p-disabled)>.p-inputtext{border-bottom:1px solid var(--p-primary-color)}:host ::ng-deep .ng-invalid.ng-dirty>.p-datepicker .p-inputtext{background:var(--p-red-200)!important;border-bottom:1px solid var(--p-red-500)!important}:host ::ng-deep .ng-hovered>.p-datepicker:not(.p-disabled) .p-inputtext{border-bottom:1px solid var(--p-primary-color)}:host ::ng-deep .cm-editor{border:1px solid #cbd5e1}:host ::ng-deep .cm-editor.cm-focused{outline:none!important;border:1px solid var(--p-primary-color)}:host ::ng-deep .cm-editor:hover{border:1px solid var(--p-primary-color)}:host ::ng-deep .cm-editor.ng-hovered{border:1px solid var(--p-primary-color)}:host ::ng-deep .cm-gutters{background-color:#fff;border:\"none\"}:host ::ng-deep .cm-activeLineGutter{background-color:#fff}\n", ".file-item{border-top:solid 1px #fff}.upload-btn{border:solid 1px transparent}.upload-btn.upload-disable:hover{cursor:default}.upload-btn:not(.upload-disable):hover{border:solid 1px var(--p-primary-color);background:var(--p-primary-50);cursor:pointer}.upload-btn:not(.upload-disable).ng-hovered{border:solid 1px var(--p-primary-color);background:var(--p-primary-50);cursor:pointer}.file-name{font-size:12px;cursor:pointer;color:var(--p-primary-color)!important}:is() .p-image-preview-mask{position:inherit;opacity:1;justify-content:left;color:#334155}:is() p-image .p-image{display:inline-block;color:var(--p-primary-color)!important}\n"], dependencies: [{ kind: "component", type: FileUpload, selector: "p-fileupload, p-fileUpload", inputs: ["name", "url", "method", "multiple", "accept", "disabled", "auto", "withCredentials", "maxFileSize", "invalidFileSizeMessageSummary", "invalidFileSizeMessageDetail", "invalidFileTypeMessageSummary", "invalidFileTypeMessageDetail", "invalidFileLimitMessageDetail", "invalidFileLimitMessageSummary", "style", "styleClass", "previewWidth", "chooseLabel", "uploadLabel", "cancelLabel", "chooseIcon", "uploadIcon", "cancelIcon", "showUploadButton", "showCancelButton", "mode", "headers", "customUpload", "fileLimit", "uploadStyleClass", "cancelStyleClass", "removeStyleClass", "chooseStyleClass", "chooseButtonProps", "uploadButtonProps", "cancelButtonProps", "files"], outputs: ["onBeforeUpload", "onSend", "onUpload", "onError", "onClear", "onRemove", "onSelect", "onProgress", "uploadHandler", "onImageError", "onRemoveUploadedFile"] }, { kind: "ngmodule", type: ButtonModule }, { kind: "component", type: i4.Button, selector: "p-button", inputs: ["type", "iconPos", "icon", "badge", "label", "disabled", "loading", "loadingIcon", "raised", "rounded", "text", "plain", "severity", "outlined", "link", "tabindex", "size", "variant", "style", "styleClass", "badgeClass", "badgeSeverity", "ariaLabel", "autofocus", "fluid", "buttonProps"], outputs: ["onClick", "onFocus", "onBlur"] }, { kind: "component", type: Image, selector: "p-image", inputs: ["imageClass", "imageStyle", "styleClass", "style", "src", "srcSet", "sizes", "previewImageSrc", "previewImageSrcSet", "previewImageSizes", "alt", "width", "height", "loading", "appendTo", "preview", "showTransitionOptions", "hideTransitionOptions"], outputs: ["onShow", "onHide", "onImageError"] }, { kind: "ngmodule", type: ReactiveFormsModule }] }); }
|
|
214
266
|
}
|
|
215
267
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ImageComponent, decorators: [{
|
|
216
268
|
type: Component,
|
|
@@ -229,6 +281,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
229
281
|
[headers]="props.headers"
|
|
230
282
|
[fileLimit]="props.fileLimit"
|
|
231
283
|
[customUpload]="props.customUpload ?? true"
|
|
284
|
+
[multiple]="props.multiple ?? false"
|
|
232
285
|
(onBeforeUpload)="props.onBeforeUpload?.(field()!, $event)"
|
|
233
286
|
(onSend)="props.onSend?.(field()!, $event)"
|
|
234
287
|
(onUpload)="props.onUpload?.(field()!, $event)"
|
|
@@ -319,8 +372,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
319
372
|
</ng-template>
|
|
320
373
|
<ng-template #file> </ng-template>
|
|
321
374
|
</p-fileUpload>`, styles: [":host ::ng-deep .p-disabled,:host ::ng-deep .p-component:disabled{opacity:1}:host ::ng-deep .p-inputtext{border-width:0;border-radius:0;box-shadow:none;background:#fff;padding:0}:host ::ng-deep .p-inputtext:not(.ng-valid).ng-dirty{background:var(--p-red-200)!important;border-bottom:1px solid var(--p-red-500)!important}:host ::ng-deep .p-inputtext:not(:disabled):hover{border-bottom:1px solid var(--p-primary-color)}:host ::ng-deep .p-inputtext:not(:disabled).ng-hovered{border-bottom:1px solid var(--p-primary-color)}:host ::ng-deep .p-inputtext:focus{border-bottom:1px solid var(--p-primary-color)}:host ::ng-deep .ng-hovered .p-autocomplete-input:not(.p-disabled){border-bottom:1px solid var(--p-primary-color)}:host ::ng-deep .p-select-label{padding:0}:host ::ng-deep .p-select{border-width:0;border-radius:0;box-shadow:none;background:#fff}:host ::ng-deep .p-select .p-select-dropdown{display:none}:host ::ng-deep .p-select .p-select-clear-icon{display:none}:host ::ng-deep .p-select:not(.ng-valid).ng-dirty{background:var(--p-red-200)!important;border-bottom:1px solid var(--p-red-500)!important}:host ::ng-deep .p-select-open{border-bottom:1px solid var(--p-primary-color)}:host ::ng-deep .p-select-open .p-select-dropdown{display:flex}:host ::ng-deep .p-select-open .p-select-clear-icon{display:flex}:host ::ng-deep .p-select:hover{border-bottom:1px solid var(--p-primary-color)}:host ::ng-deep .p-select:hover .p-select-dropdown{display:flex}:host ::ng-deep .p-select:hover .p-select-clear-icon{display:flex}:host ::ng-deep .p-select.ng-hovered{border-bottom:1px solid var(--p-primary-color)}:host ::ng-deep .p-select.ng-hovered .p-select-dropdown{display:flex}:host ::ng-deep .p-select.ng-hovered .p-select-clear-icon{display:flex}:host ::ng-deep .p-multiselect-label{padding:0}:host ::ng-deep .p-multiselect{border-width:0;border-radius:0;background:#fff;box-shadow:none}:host ::ng-deep .p-multiselect .p-multiselect-dropdown{display:none}:host ::ng-deep .p-multiselect:not(.ng-valid).ng-dirty{background:var(--p-red-200)!important;border-bottom:1px solid var(--p-red-500)!important}:host ::ng-deep .p-multiselect-open{border-bottom:1px solid var(--p-primary-color)}:host ::ng-deep .p-multiselect-open .p-multiselect-dropdown{display:flex}:host ::ng-deep .p-multiselect:not(.p-disabled).p-focus{border-bottom:1px solid var(--p-primary-color)}:host ::ng-deep .p-multiselect:not(.p-disabled).p-focus .p-multiselect-dropdown{display:flex}:host ::ng-deep .p-multiselect:not(.p-disabled):hover{border-bottom:1px solid var(--p-primary-color)}:host ::ng-deep .p-multiselect:not(.p-disabled):hover .p-multiselect-dropdown{display:flex}:host ::ng-deep .p-multiselect:not(.p-disabled).ng-hovered{border-bottom:1px solid var(--p-primary-color)}:host ::ng-deep .p-multiselect:not(.p-disabled).ng-hovered .p-multiselect-dropdown{display:flex}:host ::ng-deep .p-textarea{border-radius:0;box-shadow:none;padding:0;background:#fff;resize:none}:host ::ng-deep .p-textarea:not(.ng-valid).ng-dirty{background:var(--p-red-200)!important;border:1px solid var(--p-red-500)!important}:host ::ng-deep .p-textarea:not(:disabled):hover{border:1px solid var(--p-primary-color);resize:vertical}:host ::ng-deep .p-textarea:not(:disabled).ng-hovered{border:1px solid var(--p-primary-color);resize:vertical}:host ::ng-deep .p-textarea:focus{border:1px solid var(--p-primary-color);resize:vertical}:host ::ng-deep .p-treeselect-label{padding:0}:host ::ng-deep .p-treeselect{border-width:0;border-radius:0;box-shadow:none;background:#fff}:host ::ng-deep .p-treeselect .p-treeselect-dropdown{display:none}:host ::ng-deep .ng-invalid.ng-dirty>.p-treeselect{background:var(--p-red-200)!important;border-bottom:1px solid var(--p-red-500)!important}:host ::ng-deep .p-treeselect-open{border-bottom:1px solid var(--p-primary-color)}:host ::ng-deep .p-treeselect-open .p-treeselect-dropdown{display:flex}:host ::ng-deep .p-treeselect:not(.p-disabled).p-focus{border-bottom:1px solid var(--p-primary-color)}:host ::ng-deep .p-treeselect:not(.p-disabled).p-focus .p-treeselect-dropdown{display:flex}:host ::ng-deep .p-treeselect:not(.p-disabled):hover{border-bottom:1px solid var(--p-primary-color)}:host ::ng-deep .p-treeselect:not(.p-disabled):hover .p-treeselect-dropdown{display:flex}:host ::ng-deep .ng-hovered>.p-treeselect:not(.p-disabled){border-bottom:1px solid var(--p-primary-color)}:host ::ng-deep .ng-hovered>.p-treeselect:not(.p-disabled) .p-treeselect-dropdown{display:flex}:host ::ng-deep .p-menubar{border-width:0;padding:0}:host ::ng-deep .p-menubar-submenu{z-index:3}:host ::ng-deep .p-fileupload-advanced{border-width:0;border-radius:0;background-color:#fff}:host ::ng-deep .p-fileupload-header{padding:0}:host ::ng-deep .p-fileupload-content{padding:0;display:block;border-width:0}:host ::ng-deep .p-inputnumber:not(.ng-valid).ng-dirty>.p-inputtext{background:var(--p-red-200)!important;border-bottom:1px solid var(--p-red-500)!important}:host ::ng-deep .p-inputnumber.ng-hovered:not(.p-disabled)>.p-inputtext{border-bottom:1px solid var(--p-primary-color)}:host ::ng-deep .ng-invalid.ng-dirty>.p-datepicker .p-inputtext{background:var(--p-red-200)!important;border-bottom:1px solid var(--p-red-500)!important}:host ::ng-deep .ng-hovered>.p-datepicker:not(.p-disabled) .p-inputtext{border-bottom:1px solid var(--p-primary-color)}:host ::ng-deep .cm-editor{border:1px solid #cbd5e1}:host ::ng-deep .cm-editor.cm-focused{outline:none!important;border:1px solid var(--p-primary-color)}:host ::ng-deep .cm-editor:hover{border:1px solid var(--p-primary-color)}:host ::ng-deep .cm-editor.ng-hovered{border:1px solid var(--p-primary-color)}:host ::ng-deep .cm-gutters{background-color:#fff;border:\"none\"}:host ::ng-deep .cm-activeLineGutter{background-color:#fff}\n", ".file-item{border-top:solid 1px #fff}.upload-btn{border:solid 1px transparent}.upload-btn.upload-disable:hover{cursor:default}.upload-btn:not(.upload-disable):hover{border:solid 1px var(--p-primary-color);background:var(--p-primary-50);cursor:pointer}.upload-btn:not(.upload-disable).ng-hovered{border:solid 1px var(--p-primary-color);background:var(--p-primary-50);cursor:pointer}.file-name{font-size:12px;cursor:pointer;color:var(--p-primary-color)!important}:is() .p-image-preview-mask{position:inherit;opacity:1;justify-content:left;color:#334155}:is() p-image .p-image{display:inline-block;color:var(--p-primary-color)!important}\n"] }]
|
|
322
|
-
}], ctorParameters: () => [{ type: i1.HttpClient }, { type: i2.ActionService }, { type: i0.Renderer2 }], propDecorators: { imageCompRef: [{
|
|
375
|
+
}], ctorParameters: () => [{ type: i1.HttpClient }, { type: i2.ActionService }, { type: i0.Renderer2 }, { type: i3.DatePipe }], propDecorators: { imageCompRef: [{
|
|
323
376
|
type: ViewChild,
|
|
324
377
|
args: ['imageComp', { read: ElementRef, static: false }]
|
|
325
378
|
}] } });
|
|
326
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"image.type.js","sourceRoot":"","sources":["../../../../../../projects/imm-element-ui/src/lib/form/form-type/image.type.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, input, effect, ViewChild, ElementRef, Renderer2 } from '@angular/core';\nimport { ReactiveFormsModule } from '@angular/forms';\nimport { FileUpload } from 'primeng/fileupload';\nimport { ButtonModule } from 'primeng/button';\nimport { Image } from 'primeng/image';\nimport { FormField, FieldProps, AttributeEvent } from '../form-field/form-field';\nimport { HttpClient, HttpEvent, HttpHeaders, HttpRequest, HttpEventType } from '@angular/common/http';\nimport { ActionService } from '../../service/action.service';\n\nimport { filter, forkJoin, Observable } from 'rxjs';\n\nexport interface ImageProps extends FieldProps {\n\turl?: string;\n\tmethod?: 'post' | 'put';\n\twithCredentials?: boolean;\n\tmaxFileSize?: number;\n\tpreviewWidth?: number;\n\tmode?: 'basic' | 'advanced';\n\theaders?: any;\n\tcustomUpload?: boolean;\n\tfileLimit?: number;\n\tuploadStyleClass?: string;\n\tcancelStyleClass?: string;\n\tremoveStyleClass?: string;\n\tchooseStyleClass?: string;\n\tadjustable?: boolean;\n\timageMode?: boolean;\n\n\tonBeforeUpload?: AttributeEvent;\n\tonSend?: AttributeEvent;\n\tonUpload?: AttributeEvent;\n\tonError?: AttributeEvent;\n\tonClear?: AttributeEvent;\n\tonRemove?: AttributeEvent;\n\tonSelect?: AttributeEvent;\n\tonProgress?: AttributeEvent;\n}\n\n@Component({\n\tselector: 'form-image',\n\tstandalone: true,\n\tstyles: `\n\t\t.file-item {\n\t\t\tborder-top: solid 1px #fff;\n\t\t}\n\t\t.upload-btn {\n\t\t\tborder: solid 1px transparent;\n\t\t}\n\t\t.upload-btn.upload-disable:hover {\n\t\t\tcursor: default;\n\t\t}\n\t\t.upload-btn:not(.upload-disable):hover {\n\t\t\tborder: solid 1px var(--p-primary-color);\n\t\t\tbackground: var(--p-primary-50);\n\t\t\tcursor: pointer;\n\t\t}\n\t\t.upload-btn:not(.upload-disable).ng-hovered {\n\t\t\tborder: solid 1px var(--p-primary-color);\n\t\t\tbackground: var(--p-primary-50);\n\t\t\tcursor: pointer;\n\t\t}\n\t\t.file-name {\n\t\t\tfont-size: 12px;\n\t\t\tcursor: pointer;\n\t\t\tcolor: var(--p-primary-color) !important;\n\t\t}\n\t\t:host ::ng-deep {\n\t\t\t.p-image-preview-mask {\n\t\t\t\tposition: inherit;\n\t\t\t\topacity: 1;\n\t\t\t\tjustify-content: left;\n\t\t\t\tcolor: #334155;\n\t\t\t}\n\t\t\tp-image {\n\t\t\t\t.p-image {\n\t\t\t\t\tdisplay: inline-block;\n\t\t\t\t\tcolor: var(--p-primary-color) !important;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t`,\n\timports: [FileUpload, ButtonModule, Image, ReactiveFormsModule],\n\ttemplate: `<p-fileUpload\n\t\t#fu\n\t\tauto\n\t\t[name]=\"props.name\"\n\t\t[url]=\"props.url\"\n\t\t[method]=\"props.method ?? 'post'\"\n\t\taccept=\"image/*\"\n\t\t[withCredentials]=\"props.withCredentials\"\n\t\t[maxFileSize]=\"props.maxFileSize\"\n\t\t[styleClass]=\"props.styleClass\"\n\t\t[previewWidth]=\"props.previewWidth ?? 50\"\n\t\t[mode]=\"props.mode ?? 'advanced'\"\n\t\t[headers]=\"props.headers\"\n\t\t[fileLimit]=\"props.fileLimit\"\n\t\t[customUpload]=\"props.customUpload ?? true\"\n\t\t(onBeforeUpload)=\"props.onBeforeUpload?.(field()!, $event)\"\n\t\t(onSend)=\"props.onSend?.(field()!, $event)\"\n\t\t(onUpload)=\"props.onUpload?.(field()!, $event)\"\n\t\t(onError)=\"props.onError?.(field()!, $event)\"\n\t\t(onClear)=\"props.onClear?.(field()!, $event)\"\n\t\t(onRemove)=\"props.onRemove?.(field()!, $event)\"\n\t\t(onSelect)=\"props.onSelect?.(field()!, $event)\"\n\t\t(onProgress)=\"props.onProgress?.(field()!, $event)\"\n\t\t(uploadHandler)=\"uploadHandler(field()!, $event, fu)\">\n\t\t<ng-template\n\t\t\t#header\n\t\t\tlet-chooseCallback=\"chooseCallback\">\n\t\t\t<div\n\t\t\t\t#imageComp\n\t\t\t\t[class]=\"'flex justify-center w-full upload-btn' + (field()?.fieldControl?.disabled ? ' upload-disable' : '')\"\n\t\t\t\t(click)=\"choose($event, chooseCallback)\">\n\t\t\t\t<span\n\t\t\t\t\t><span\n\t\t\t\t\t\tstyle=\"font-size: 12px; margin-right: 2.5px\"\n\t\t\t\t\t\tclass=\"pi pi-upload\"></span\n\t\t\t\t\t>上传</span\n\t\t\t\t>\n\t\t\t</div>\n\t\t</ng-template>\n\t\t<ng-template #content>\n\t\t\t@if (imageList.length > 0) {\n\t\t\t\t@if (!props.imageMode) {\n\t\t\t\t\t@for (image of imageList; track image; let index = $index) {\n\t\t\t\t\t\t<div class=\"flex justify-between items-center file-item\">\n\t\t\t\t\t\t\t<p-image\n\t\t\t\t\t\t\t\t[src]=\"'https://hrimage.myfoodiepet.com//' + image\"\n\t\t\t\t\t\t\t\t[preview]=\"true\"\n\t\t\t\t\t\t\t\t(onShow)=\"ajustedImage($event)\"\n\t\t\t\t\t\t\t\talt=\"Image\">\n\t\t\t\t\t\t\t\t<ng-template #indicator>\n\t\t\t\t\t\t\t\t\t<span class=\"file-name\">{{ image }}</span>\n\t\t\t\t\t\t\t\t</ng-template>\n\t\t\t\t\t\t\t\t<ng-template #image>\n\t\t\t\t\t\t\t\t\t<span class=\"file-name\">{{ image }}</span>\n\t\t\t\t\t\t\t\t</ng-template>\n\t\t\t\t\t\t\t</p-image>\n\t\t\t\t\t\t\t@if (!field()?.fieldControl?.disabled) {\n\t\t\t\t\t\t\t\t<p-button\n\t\t\t\t\t\t\t\t\ticon=\"pi pi-times\"\n\t\t\t\t\t\t\t\t\tseverity=\"danger\"\n\t\t\t\t\t\t\t\t\tsize=\"small\"\n\t\t\t\t\t\t\t\t\t(onClick)=\"deleteHandler(image, index)\"\n\t\t\t\t\t\t\t\t\t[text]=\"true\" />\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t</div>\n\t\t\t\t\t}\n\t\t\t\t} @else {\n\t\t\t\t\t<div class=\"flex gap-2 mt-2\">\n\t\t\t\t\t\t@for (image of imageList; track image; let index = $index) {\n\t\t\t\t\t\t\t<div class=\"border\">\n\t\t\t\t\t\t\t\t@if (!field()?.fieldControl?.disabled) {\n\t\t\t\t\t\t\t\t\t<div class=\"flex flex-row-reverse\">\n\t\t\t\t\t\t\t\t\t\t<p-button\n\t\t\t\t\t\t\t\t\t\t\ticon=\"pi pi-times\"\n\t\t\t\t\t\t\t\t\t\t\tseverity=\"danger\"\n\t\t\t\t\t\t\t\t\t\t\tsize=\"small\"\n\t\t\t\t\t\t\t\t\t\t\t(onClick)=\"deleteHandler(image, index)\"\n\t\t\t\t\t\t\t\t\t\t\t[text]=\"true\" />\n\t\t\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t<p-image\n\t\t\t\t\t\t\t\t\t[src]=\"'https://hrimage.myfoodiepet.com//' + image\"\n\t\t\t\t\t\t\t\t\t[preview]=\"true\"\n\t\t\t\t\t\t\t\t\t(onShow)=\"ajustedImage($event)\"\n\t\t\t\t\t\t\t\t\talt=\"Image\">\n\t\t\t\t\t\t\t\t\t<ng-template #indicator>\n\t\t\t\t\t\t\t\t\t\t<i class=\"pi pi-search\"></i>\n\t\t\t\t\t\t\t\t\t</ng-template>\n\t\t\t\t\t\t\t\t\t<ng-template #image>\n\t\t\t\t\t\t\t\t\t\t<div class=\"p-2\">\n\t\t\t\t\t\t\t\t\t\t\t<img\n\t\t\t\t\t\t\t\t\t\t\t\t[src]=\"'https://hrimage.myfoodiepet.com//' + image\"\n\t\t\t\t\t\t\t\t\t\t\t\talt=\"image\"\n\t\t\t\t\t\t\t\t\t\t\t\tstyle=\"width: 85px; height: 100px; object-fit: cover\" />\n\t\t\t\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t\t\t\t</ng-template>\n\t\t\t\t\t\t\t\t</p-image>\n\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t}\n\t\t\t\t\t</div>\n\t\t\t\t}\n\t\t\t}\n\t\t</ng-template>\n\t\t<ng-template #file> </ng-template>\n\t</p-fileUpload>`,\n\tstyleUrl: '../../styles/styles.scss',\n})\nexport class ImageComponent {\n\t@ViewChild('imageComp', { read: ElementRef, static: false }) imageCompRef!: ElementRef;\n\tfield = input<FormField>();\n\tprops: ImageProps = {};\n\timageList: string[] = [];\n\tdeleteHooks: Observable<any>[] = [];\n\n\tconstructor(\n\t\tprivate http: HttpClient,\n\t\tprivate action: ActionService,\n\t\tprivate renderer: Renderer2,\n\t) {\n\t\teffect(() => {\n\t\t\tif (this.field()) {\n\t\t\t\tthis.props = this.field()!.imageProps!;\n\t\t\t\tthis.handleDisabled();\n\t\t\t\tthis.handleHookChange();\n\t\t\t\tthis.afterSubmit();\n\t\t\t}\n\t\t});\n\t\teffect(() => {\n\t\t\tconst labelAction = this.action.getFieldLabelAction();\n\t\t\tif (!labelAction || labelAction?.key != this.field()?.uuid) {\n\t\t\t\treturn;\n\t\t\t}\n\t\t\tif (labelAction.type == 'mouseenter') {\n\t\t\t\tthis.renderer.addClass(this.imageCompRef.nativeElement, 'ng-hovered');\n\t\t\t} else if (labelAction.type == 'mouseleave') {\n\t\t\t\tthis.renderer.removeClass(this.imageCompRef.nativeElement, 'ng-hovered');\n\t\t\t} else if (labelAction.type == 'click') {\n\t\t\t\tthis.imageCompRef.nativeElement.click();\n\t\t\t}\n\t\t});\n\t}\n\n\tchoose(event: any, callback: any) {\n\t\tif (this.field()?.fieldControl?.disabled) {\n\t\t\treturn;\n\t\t}\n\t\tcallback();\n\t}\n\n\tuploadImage(file: File): Observable<any> {\n\t\tconst formData = new FormData();\n\t\tformData.append('file', file);\n\t\treturn this.http\n\t\t\t.request(\n\t\t\t\tnew HttpRequest('POST', 'imageUpload', formData, {\n\t\t\t\t\treportProgress: true,\n\t\t\t\t\twithCredentials: false,\n\t\t\t\t}),\n\t\t\t)\n\t\t\t.pipe(filter((response: HttpEvent<any>) => response.type == HttpEventType.Response));\n\t}\n\n\tdelImage(image: string): Observable<any> {\n\t\treturn this.http.post('imageDelete', { fid: image });\n\t}\n\n\tuploadHandler(field: any, event: any, fu: any) {\n\t\tthis.uploadImage(event.files[0]).subscribe((response) => {\n\t\t\tthis.imageList?.push(response.body.fid);\n\t\t\tthis.field()?.fieldControl?.setValue(this.imageList);\n\t\t});\n\t}\n\n\tdeleteHandler(image: string, index: number) {\n\t\tthis.deleteHooks.push(this.delImage(image));\n\t\tthis.imageList = this.imageList?.filter((value, i) => index != i);\n\t\tthis.field()?.fieldControl?.setValue(this.imageList);\n\t}\n\n\tafterSubmit() {\n\t\tthis.field()?.fieldControl?.submitChange.subscribe((value) => {\n\t\t\tif (Boolean(value)) {\n\t\t\t\tthis.deleteHooks.forEach((hook) => hook.subscribe());\n\t\t\t}\n\t\t});\n\t}\n\n\thandleHookChange() {\n\t\tthis.field()?.fieldControl?.hookChange.subscribe((value) => {\n\t\t\tif (value == null) {\n\t\t\t\treturn;\n\t\t\t}\n\t\t\tthis.props.onHookChange?.(this.field()!, { value });\n\t\t\tthis.imageList = [...value];\n\t\t});\n\t}\n\n\thandleDisabled() {\n\t\tif (this.props?.disabled) {\n\t\t\tthis.field()!.fieldControl!.disable({ emitEvent: false });\n\t\t}\n\t}\n\n\tajustedImage(event: any) {\n\t\tif (this.props?.adjustable) {\n\t\t\t// 解决图片查看时的操作按钮（旋转、放大、缩小、关闭）不在屏幕右上角显示的问题\n\t\t\tlet childDiv = document.getElementsByClassName('p-image-toolbar')[0];\n\t\t\tlet parentDiv = document.createElement('div');\n\t\t\tparentDiv.style.width = '100vw';\n\t\t\tparentDiv.style.height = '100vh';\n\t\t\tparentDiv.style.position = 'fixed';\n\t\t\tchildDiv?.parentNode?.insertBefore(parentDiv, childDiv);\n\t\t\tparentDiv.appendChild(childDiv);\n\t\t}\n\t}\n}\n"]}
|
|
379
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"image.type.js","sourceRoot":"","sources":["../../../../../../projects/imm-element-ui/src/lib/form/form-type/image.type.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,MAAM,EAAE,SAAS,EAAE,UAAU,EAAa,MAAM,eAAe,CAAC;AAC3F,OAAO,EAAE,mBAAmB,EAAE,MAAM,gBAAgB,CAAC;AACrD,OAAO,EAAE,UAAU,EAAE,MAAM,oBAAoB,CAAC;AAChD,OAAO,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC;AAC9C,OAAO,EAAE,KAAK,EAAE,MAAM,eAAe,CAAC;AAEtC,OAAO,EAAsC,WAAW,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAGtG,OAAO,EAAE,MAAM,EAAwB,MAAM,MAAM,CAAC;;;;;;AAwLpD,MAAM,OAAO,cAAc;IAO1B,YACS,IAAgB,EAChB,MAAqB,EACrB,QAAmB,EACnB,QAAkB;QAHlB,SAAI,GAAJ,IAAI,CAAY;QAChB,WAAM,GAAN,MAAM,CAAe;QACrB,aAAQ,GAAR,QAAQ,CAAW;QACnB,aAAQ,GAAR,QAAQ,CAAU;QAT3B,UAAK,GAAG,KAAK,EAAa,CAAC;QAC3B,UAAK,GAAe,EAAE,CAAC;QACvB,cAAS,GAAa,EAAE,CAAC;QACzB,gBAAW,GAAsB,EAAE,CAAC;QAQnC,MAAM,CAAC,GAAG,EAAE;YACX,IAAI,IAAI,CAAC,KAAK,EAAE,EAAE,CAAC;gBAClB,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,EAAG,CAAC,UAAW,CAAC;gBACvC,IAAI,CAAC,cAAc,EAAE,CAAC;gBACtB,IAAI,CAAC,gBAAgB,EAAE,CAAC;gBACxB,IAAI,CAAC,WAAW,EAAE,CAAC;YACpB,CAAC;QACF,CAAC,CAAC,CAAC;QACH,MAAM,CAAC,GAAG,EAAE;YACX,MAAM,WAAW,GAAG,IAAI,CAAC,MAAM,CAAC,mBAAmB,EAAE,CAAC;YACtD,IAAI,CAAC,WAAW,IAAI,WAAW,EAAE,GAAG,IAAI,IAAI,CAAC,KAAK,EAAE,EAAE,IAAI,EAAE,CAAC;gBAC5D,OAAO;YACR,CAAC;YACD,IAAI,WAAW,CAAC,IAAI,IAAI,YAAY,EAAE,CAAC;gBACtC,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,YAAY,CAAC,aAAa,EAAE,YAAY,CAAC,CAAC;YACvE,CAAC;iBAAM,IAAI,WAAW,CAAC,IAAI,IAAI,YAAY,EAAE,CAAC;gBAC7C,IAAI,CAAC,QAAQ,CAAC,WAAW,CAAC,IAAI,CAAC,YAAY,CAAC,aAAa,EAAE,YAAY,CAAC,CAAC;YAC1E,CAAC;iBAAM,IAAI,WAAW,CAAC,IAAI,IAAI,OAAO,EAAE,CAAC;gBACxC,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;YACzC,CAAC;QACF,CAAC,CAAC,CAAC;IACJ,CAAC;IAED,MAAM,CAAC,KAAU,EAAE,QAAa;QAC/B,IAAI,IAAI,CAAC,KAAK,EAAE,EAAE,YAAY,EAAE,QAAQ,EAAE,CAAC;YAC1C,OAAO;QACR,CAAC;QACD,QAAQ,EAAE,CAAC;IACZ,CAAC;IAED,WAAW,CAAC,IAAU;QACrB,MAAM,QAAQ,GAAG,IAAI,QAAQ,EAAE,CAAC;QAChC,QAAQ,CAAC,MAAM,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;QAC9B,OAAO,IAAI,CAAC,IAAI;aACd,OAAO,CACP,IAAI,WAAW,CAAC,MAAM,EAAE,aAAa,EAAE,QAAQ,EAAE;YAChD,cAAc,EAAE,IAAI;YACpB,eAAe,EAAE,KAAK;SACtB,CAAC,CACF;aACA,IAAI,CAAC,MAAM,CAAC,CAAC,QAAwB,EAAE,EAAE,CAAC,QAAQ,CAAC,IAAI,IAAI,aAAa,CAAC,QAAQ,CAAC,CAAC,CAAC;IACvF,CAAC;IAED,QAAQ,CAAC,KAAa;QACrB,OAAO,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,EAAE,GAAG,EAAE,KAAK,EAAE,CAAC,CAAC;IACtD,CAAC;IAED,aAAa,CAAC,KAAU,EAAE,KAAU,EAAE,EAAO;QAC5C,OAAO,CAAC,GAAG,CAAC,KAAK,EAAC,gBAAgB,CAAC,CAAA;QACnC,KAAK,CAAC,KAAK,CAAC,OAAO,CAAC,KAAK,EAAE,CAAK,EAAE,EAAE;YACnC,IAAG,IAAI,CAAC,KAAK,CAAC,SAAS,EAAC,CAAC;gBACxB,IAAI,IAAI,GAAG,MAAM,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;gBACtC,MAAM,OAAO,GAAG,IAAI,IAAI,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,IAAI,EAAE,EAAE,IAAI,EAAE,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC;gBAC3D,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC,SAAS,CAAC,CAAC,QAAQ,EAAE,EAAE;oBAChD,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;oBACxC,IAAI,CAAC,KAAK,EAAE,EAAE,YAAY,EAAE,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;gBACtD,CAAC,CAAC,CAAC;YACJ,CAAC;iBAAM,CAAC;gBACP,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,QAAQ,EAAE,EAAE;oBAC1C,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;oBACxC,IAAI,CAAC,KAAK,EAAE,EAAE,YAAY,EAAE,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;gBACtD,CAAC,CAAC,CAAC;YACJ,CAAC;QACF,CAAC,CAAC,CAAA;IAEH,CAAC;IACD,YAAY,CAAC,SAAe;QACzB,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;YACrC,MAAM,MAAM,GAAG,IAAI,UAAU,EAAE,CAAC;YAEhC,MAAM,CAAC,MAAM,GAAG,CAAC,KAAK,EAAE,EAAE;gBACxB,MAAM,GAAG,GAAG,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;gBAC1C,GAAG,CAAC,MAAM,GAAG,GAAG,EAAE;oBAChB,MAAM,MAAM,GAAG,QAAQ,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC;oBAChD,MAAM,GAAG,GAAG,MAAM,CAAC,UAAU,CAAC,IAAI,CAAE,CAAC;oBAErC,cAAc;oBACd,MAAM,CAAC,KAAK,GAAG,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;oBACjC,MAAM,CAAC,MAAM,GAAG,MAAM,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;oBAEnC,SAAS;oBACT,GAAG,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;oBAEzB,OAAO;oBACP,GAAG,CAAC,IAAI,GAAG,0BAA0B,CAAC;oBACtC,GAAG,CAAC,SAAS,GAAG,KAAK,CAAC;oBACtB,GAAG,CAAC,SAAS,GAAG,QAAQ,CAAC;oBACzB,GAAG,CAAC,YAAY,GAAG,QAAQ,CAAC;oBACjC,MAAM,WAAW,GAAG,IAAI,CAAC,QAAQ,CAAC,SAAS,CAAC,IAAI,IAAI,EAAE,EAAE,qBAAqB,CAAC,IAAI,EAAE,CAAA;oBAC/E,GAAG,CAAC,QAAQ,CAAC,WAAW,EAAE,MAAM,CAAC,KAAK,GAAG,CAAC,EAAE,MAAM,CAAC,MAAM,GAAG,EAAE,CAAC,CAAC;oBAEhE,UAAU;oBACV,MAAM,CAAC,MAAM,CAAC,CAAC,IAAI,EAAE,EAAE;wBACrB,IAAI,IAAI,EAAE,CAAC;4BACT,OAAO,CAAC,IAAI,CAAC,CAAC;wBAChB,CAAC;6BAAM,CAAC;4BACN,MAAM,CAAC,IAAI,KAAK,CAAC,kCAAkC,CAAC,CAAC,CAAC;wBACxD,CAAC;oBACH,CAAC,EAAE,YAAY,EAAE,GAAG,CAAC,CAAC;gBACxB,CAAC,CAAC;gBAEF,GAAG,CAAC,GAAG,GAAG,KAAK,CAAC,MAAM,EAAE,MAAgB,CAAC;YAC3C,CAAC,CAAC;YAEF,MAAM,CAAC,OAAO,GAAG,CAAC,KAAK,EAAE,EAAE,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;YAC1C,MAAM,CAAC,aAAa,CAAC,SAAS,CAAC,CAAC;QAClC,CAAC,CAAC,CAAC;IACN,CAAC;IACD,aAAa,CAAC,KAAa,EAAE,KAAa;QACzC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC;QAC5C,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,SAAS,EAAE,MAAM,CAAC,CAAC,KAAK,EAAE,CAAC,EAAE,EAAE,CAAC,KAAK,IAAI,CAAC,CAAC,CAAC;QAClE,IAAI,CAAC,KAAK,EAAE,EAAE,YAAY,EAAE,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;IACtD,CAAC;IAED,WAAW;QACV,IAAI,CAAC,KAAK,EAAE,EAAE,YAAY,EAAE,YAAY,CAAC,SAAS,CAAC,CAAC,KAAK,EAAE,EAAE;YAC5D,IAAI,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC;gBACpB,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,SAAS,EAAE,CAAC,CAAC;YACtD,CAAC;QACF,CAAC,CAAC,CAAC;IACJ,CAAC;IAED,gBAAgB;QACf,IAAI,CAAC,KAAK,EAAE,EAAE,YAAY,EAAE,UAAU,CAAC,SAAS,CAAC,CAAC,KAAK,EAAE,EAAE;YAC1D,IAAI,KAAK,IAAI,IAAI,EAAE,CAAC;gBACnB,OAAO;YACR,CAAC;YACD,IAAI,CAAC,KAAK,CAAC,YAAY,EAAE,CAAC,IAAI,CAAC,KAAK,EAAG,EAAE,EAAE,KAAK,EAAE,CAAC,CAAC;YACpD,IAAI,CAAC,SAAS,GAAG,CAAC,GAAG,KAAK,CAAC,CAAC;QAC7B,CAAC,CAAC,CAAC;IACJ,CAAC;IAED,cAAc;QACb,IAAI,IAAI,CAAC,KAAK,EAAE,QAAQ,EAAE,CAAC;YAC1B,IAAI,CAAC,KAAK,EAAG,CAAC,YAAa,CAAC,OAAO,CAAC,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAC;QAC3D,CAAC;IACF,CAAC;IAED,YAAY,CAAC,KAAU;QACtB,IAAI,IAAI,CAAC,KAAK,EAAE,UAAU,EAAE,CAAC;YAC5B,wCAAwC;YACxC,IAAI,QAAQ,GAAG,QAAQ,CAAC,sBAAsB,CAAC,iBAAiB,CAAC,CAAC,CAAC,CAAC,CAAC;YACrE,IAAI,SAAS,GAAG,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;YAC9C,SAAS,CAAC,KAAK,CAAC,KAAK,GAAG,OAAO,CAAC;YAChC,SAAS,CAAC,KAAK,CAAC,MAAM,GAAG,OAAO,CAAC;YACjC,SAAS,CAAC,KAAK,CAAC,QAAQ,GAAG,OAAO,CAAC;YACnC,QAAQ,EAAE,UAAU,EAAE,YAAY,CAAC,SAAS,EAAE,QAAQ,CAAC,CAAC;YACxD,SAAS,CAAC,WAAW,CAAC,QAAQ,CAAC,CAAC;QACjC,CAAC;IACF,CAAC;+GAlKW,cAAc;mGAAd,cAAc,gSACM,UAAU,6BA7GhC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;iBAyGM,i0MA1GN,UAAU,g5BAAE,YAAY,kbAAE,KAAK,qWAAE,mBAAmB;;4FA6GlD,cAAc;kBAxJ1B,SAAS;+BACC,YAAY,cACV,IAAI,WAyCP,CAAC,UAAU,EAAE,YAAY,EAAE,KAAK,EAAE,mBAAmB,CAAC,YACrD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;iBAyGM;0JAI6C,YAAY;sBAAxE,SAAS;uBAAC,WAAW,EAAE,EAAE,IAAI,EAAE,UAAU,EAAE,MAAM,EAAE,KAAK,EAAE","sourcesContent":["import { Component, input, effect, ViewChild, ElementRef, Renderer2 } from '@angular/core';\nimport { ReactiveFormsModule } from '@angular/forms';\nimport { FileUpload } from 'primeng/fileupload';\nimport { ButtonModule } from 'primeng/button';\nimport { Image } from 'primeng/image';\nimport { FormField, FieldProps, AttributeEvent } from '../form-field/form-field';\nimport { HttpClient, HttpEvent, HttpHeaders, HttpRequest, HttpEventType } from '@angular/common/http';\nimport { ActionService } from '../../service/action.service';\n\nimport { filter, forkJoin, Observable } from 'rxjs';\nimport { DatePipe } from '@angular/common';\n\nexport interface ImageProps extends FieldProps {\n\turl?: string;\n\tmethod?: 'post' | 'put';\n\twithCredentials?: boolean;\n\tmaxFileSize?: number;\n\tpreviewWidth?: number;\n\tmode?: 'basic' | 'advanced';\n\theaders?: any;\n\tcustomUpload?: boolean;\n\tfileLimit?: number;\n\tuploadStyleClass?: string;\n\tcancelStyleClass?: string;\n\tremoveStyleClass?: string;\n\tchooseStyleClass?: string;\n\tadjustable?: boolean;\n\timageMode?: boolean;\n\tmultiple?:boolean;\n\twatermark?:boolean;\n\n\tonBeforeUpload?: AttributeEvent;\n\tonSend?: AttributeEvent;\n\tonUpload?: AttributeEvent;\n\tonError?: AttributeEvent;\n\tonClear?: AttributeEvent;\n\tonRemove?: AttributeEvent;\n\tonSelect?: AttributeEvent;\n\tonProgress?: AttributeEvent;\n}\n\n@Component({\n\tselector: 'form-image',\n\tstandalone: true,\n\tstyles: `\n\t\t.file-item {\n\t\t\tborder-top: solid 1px #fff;\n\t\t}\n\t\t.upload-btn {\n\t\t\tborder: solid 1px transparent;\n\t\t}\n\t\t.upload-btn.upload-disable:hover {\n\t\t\tcursor: default;\n\t\t}\n\t\t.upload-btn:not(.upload-disable):hover {\n\t\t\tborder: solid 1px var(--p-primary-color);\n\t\t\tbackground: var(--p-primary-50);\n\t\t\tcursor: pointer;\n\t\t}\n\t\t.upload-btn:not(.upload-disable).ng-hovered {\n\t\t\tborder: solid 1px var(--p-primary-color);\n\t\t\tbackground: var(--p-primary-50);\n\t\t\tcursor: pointer;\n\t\t}\n\t\t.file-name {\n\t\t\tfont-size: 12px;\n\t\t\tcursor: pointer;\n\t\t\tcolor: var(--p-primary-color) !important;\n\t\t}\n\t\t:host ::ng-deep {\n\t\t\t.p-image-preview-mask {\n\t\t\t\tposition: inherit;\n\t\t\t\topacity: 1;\n\t\t\t\tjustify-content: left;\n\t\t\t\tcolor: #334155;\n\t\t\t}\n\t\t\tp-image {\n\t\t\t\t.p-image {\n\t\t\t\t\tdisplay: inline-block;\n\t\t\t\t\tcolor: var(--p-primary-color) !important;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t`,\n\timports: [FileUpload, ButtonModule, Image, ReactiveFormsModule],\n\ttemplate: `<p-fileUpload\n\t\t#fu\n\t\tauto\n\t\t[name]=\"props.name\"\n\t\t[url]=\"props.url\"\n\t\t[method]=\"props.method ?? 'post'\"\n\t\taccept=\"image/*\"\n\t\t[withCredentials]=\"props.withCredentials\"\n\t\t[maxFileSize]=\"props.maxFileSize\"\n\t\t[styleClass]=\"props.styleClass\"\n\t\t[previewWidth]=\"props.previewWidth ?? 50\"\n\t\t[mode]=\"props.mode ?? 'advanced'\"\n\t\t[headers]=\"props.headers\"\n\t\t[fileLimit]=\"props.fileLimit\"\n\t\t[customUpload]=\"props.customUpload ?? true\"\n\t\t[multiple]=\"props.multiple ?? false\"\n\t\t(onBeforeUpload)=\"props.onBeforeUpload?.(field()!, $event)\"\n\t\t(onSend)=\"props.onSend?.(field()!, $event)\"\n\t\t(onUpload)=\"props.onUpload?.(field()!, $event)\"\n\t\t(onError)=\"props.onError?.(field()!, $event)\"\n\t\t(onClear)=\"props.onClear?.(field()!, $event)\"\n\t\t(onRemove)=\"props.onRemove?.(field()!, $event)\"\n\t\t(onSelect)=\"props.onSelect?.(field()!, $event)\"\n\t\t(onProgress)=\"props.onProgress?.(field()!, $event)\"\n\t\t(uploadHandler)=\"uploadHandler(field()!, $event, fu)\">\n\t\t<ng-template\n\t\t\t#header\n\t\t\tlet-chooseCallback=\"chooseCallback\">\n\t\t\t<div\n\t\t\t\t#imageComp\n\t\t\t\t[class]=\"'flex justify-center w-full upload-btn' + (field()?.fieldControl?.disabled ? ' upload-disable' : '')\"\n\t\t\t\t(click)=\"choose($event, chooseCallback)\">\n\t\t\t\t<span\n\t\t\t\t\t><span\n\t\t\t\t\t\tstyle=\"font-size: 12px; margin-right: 2.5px\"\n\t\t\t\t\t\tclass=\"pi pi-upload\"></span\n\t\t\t\t\t>上传</span\n\t\t\t\t>\n\t\t\t</div>\n\t\t</ng-template>\n\t\t<ng-template #content>\n\t\t\t@if (imageList.length > 0) {\n\t\t\t\t@if (!props.imageMode) {\n\t\t\t\t\t@for (image of imageList; track image; let index = $index) {\n\t\t\t\t\t\t<div class=\"flex justify-between items-center file-item\">\n\t\t\t\t\t\t\t<p-image\n\t\t\t\t\t\t\t\t[src]=\"'https://hrimage.myfoodiepet.com//' + image\"\n\t\t\t\t\t\t\t\t[preview]=\"true\"\n\t\t\t\t\t\t\t\t(onShow)=\"ajustedImage($event)\"\n\t\t\t\t\t\t\t\talt=\"Image\">\n\t\t\t\t\t\t\t\t<ng-template #indicator>\n\t\t\t\t\t\t\t\t\t<span class=\"file-name\">{{ image }}</span>\n\t\t\t\t\t\t\t\t</ng-template>\n\t\t\t\t\t\t\t\t<ng-template #image>\n\t\t\t\t\t\t\t\t\t<span class=\"file-name\">{{ image }}</span>\n\t\t\t\t\t\t\t\t</ng-template>\n\t\t\t\t\t\t\t</p-image>\n\t\t\t\t\t\t\t@if (!field()?.fieldControl?.disabled) {\n\t\t\t\t\t\t\t\t<p-button\n\t\t\t\t\t\t\t\t\ticon=\"pi pi-times\"\n\t\t\t\t\t\t\t\t\tseverity=\"danger\"\n\t\t\t\t\t\t\t\t\tsize=\"small\"\n\t\t\t\t\t\t\t\t\t(onClick)=\"deleteHandler(image, index)\"\n\t\t\t\t\t\t\t\t\t[text]=\"true\" />\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t</div>\n\t\t\t\t\t}\n\t\t\t\t} @else {\n\t\t\t\t\t<div class=\"flex gap-2 mt-2\">\n\t\t\t\t\t\t@for (image of imageList; track image; let index = $index) {\n\t\t\t\t\t\t\t<div class=\"border\">\n\t\t\t\t\t\t\t\t@if (!field()?.fieldControl?.disabled) {\n\t\t\t\t\t\t\t\t\t<div class=\"flex flex-row-reverse\">\n\t\t\t\t\t\t\t\t\t\t<p-button\n\t\t\t\t\t\t\t\t\t\t\ticon=\"pi pi-times\"\n\t\t\t\t\t\t\t\t\t\t\tseverity=\"danger\"\n\t\t\t\t\t\t\t\t\t\t\tsize=\"small\"\n\t\t\t\t\t\t\t\t\t\t\t(onClick)=\"deleteHandler(image, index)\"\n\t\t\t\t\t\t\t\t\t\t\t[text]=\"true\" />\n\t\t\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t\t<p-image\n\t\t\t\t\t\t\t\t\t[src]=\"'https://hrimage.myfoodiepet.com//' + image\"\n\t\t\t\t\t\t\t\t\t[preview]=\"true\"\n\t\t\t\t\t\t\t\t\t(onShow)=\"ajustedImage($event)\"\n\t\t\t\t\t\t\t\t\talt=\"Image\">\n\t\t\t\t\t\t\t\t\t<ng-template #indicator>\n\t\t\t\t\t\t\t\t\t\t<i class=\"pi pi-search\"></i>\n\t\t\t\t\t\t\t\t\t</ng-template>\n\t\t\t\t\t\t\t\t\t<ng-template #image>\n\t\t\t\t\t\t\t\t\t\t<div class=\"p-2\">\n\t\t\t\t\t\t\t\t\t\t\t<img\n\t\t\t\t\t\t\t\t\t\t\t\t[src]=\"'https://hrimage.myfoodiepet.com//' + image\"\n\t\t\t\t\t\t\t\t\t\t\t\talt=\"image\"\n\t\t\t\t\t\t\t\t\t\t\t\tstyle=\"width: 85px; height: 100px; object-fit: cover\" />\n\t\t\t\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t\t\t\t</ng-template>\n\t\t\t\t\t\t\t\t</p-image>\n\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t}\n\t\t\t\t\t</div>\n\t\t\t\t}\n\t\t\t}\n\t\t</ng-template>\n\t\t<ng-template #file> </ng-template>\n\t</p-fileUpload>`,\n\tstyleUrl: '../../styles/styles.scss',\n})\nexport class ImageComponent {\n\t@ViewChild('imageComp', { read: ElementRef, static: false }) imageCompRef!: ElementRef;\n\tfield = input<FormField>();\n\tprops: ImageProps = {};\n\timageList: string[] = [];\n\tdeleteHooks: Observable<any>[] = [];\n\n\tconstructor(\n\t\tprivate http: HttpClient,\n\t\tprivate action: ActionService,\n\t\tprivate renderer: Renderer2,\n\t\tprivate datePipe: DatePipe\n\t) {\n\t\teffect(() => {\n\t\t\tif (this.field()) {\n\t\t\t\tthis.props = this.field()!.imageProps!;\n\t\t\t\tthis.handleDisabled();\n\t\t\t\tthis.handleHookChange();\n\t\t\t\tthis.afterSubmit();\n\t\t\t}\n\t\t});\n\t\teffect(() => {\n\t\t\tconst labelAction = this.action.getFieldLabelAction();\n\t\t\tif (!labelAction || labelAction?.key != this.field()?.uuid) {\n\t\t\t\treturn;\n\t\t\t}\n\t\t\tif (labelAction.type == 'mouseenter') {\n\t\t\t\tthis.renderer.addClass(this.imageCompRef.nativeElement, 'ng-hovered');\n\t\t\t} else if (labelAction.type == 'mouseleave') {\n\t\t\t\tthis.renderer.removeClass(this.imageCompRef.nativeElement, 'ng-hovered');\n\t\t\t} else if (labelAction.type == 'click') {\n\t\t\t\tthis.imageCompRef.nativeElement.click();\n\t\t\t}\n\t\t});\n\t}\n\n\tchoose(event: any, callback: any) {\n\t\tif (this.field()?.fieldControl?.disabled) {\n\t\t\treturn;\n\t\t}\n\t\tcallback();\n\t}\n\n\tuploadImage(file: File): Observable<any> {\n\t\tconst formData = new FormData();\n\t\tformData.append('file', file);\n\t\treturn this.http\n\t\t\t.request(\n\t\t\t\tnew HttpRequest('POST', 'imageUpload', formData, {\n\t\t\t\t\treportProgress: true,\n\t\t\t\t\twithCredentials: false,\n\t\t\t\t}),\n\t\t\t)\n\t\t\t.pipe(filter((response: HttpEvent<any>) => response.type == HttpEventType.Response));\n\t}\n\n\tdelImage(image: string): Observable<any> {\n\t\treturn this.http.post('imageDelete', { fid: image });\n\t}\n\n\tuploadHandler(field: any, event: any, fu: any) {\n\t\tconsole.log(event,'file----events')\n\t\tevent.files.forEach(async (v:any) => {\n\t\t\tif(this.props.watermark){\n\t\t\t\tlet blob = await this.addWatermark(v);\n\t\t\t\tconst newFile = new File([blob], v.name, { type: v.type });\n\t\t\t\tthis.uploadImage(newFile).subscribe((response) => {\n\t\t\t\t\tthis.imageList?.push(response.body.fid);\n\t\t\t\t\tthis.field()?.fieldControl?.setValue(this.imageList);\n\t\t\t\t});\n\t\t\t} else {\n\t\t\t\tthis.uploadImage(v).subscribe((response) => {\n\t\t\t\t\tthis.imageList?.push(response.body.fid);\n\t\t\t\t\tthis.field()?.fieldControl?.setValue(this.imageList);\n\t\t\t\t});\n\t\t\t}\n\t\t})\n\t\t\n\t}\n\taddWatermark(imageFile: File): Promise<Blob> {\n    return new Promise((resolve, reject) => {\n      const reader = new FileReader();\n      \n      reader.onload = (event) => {\n        const img = document.createElement('img');\n        img.onload = () => {\n          const canvas = document.createElement('canvas');\n          const ctx = canvas.getContext('2d')!;\n          \n          // 设置画布大小为图片大小\n          canvas.width = Number(img.width);\n          canvas.height = Number(img.height);\n          \n          // 绘制原始图片\n          ctx.drawImage(img, 0, 0);\n          \n          // 添加水印\n          ctx.font = `italic bold 30px Courier`;\n          ctx.fillStyle = 'red';\n          ctx.textAlign = 'center';\n          ctx.textBaseline = 'middle';\n\t\t\t\t\tconst currentTime = this.datePipe.transform(new Date(), 'yyyy-MM-dd HH:mm:ss') || ''\n          ctx.fillText(currentTime, canvas.width / 2, canvas.height - 50);\n          \n          // 转换为Blob\n          canvas.toBlob((blob) => {\n            if (blob) {\n              resolve(blob);\n            } else {\n              reject(new Error('Canvas to Blob conversion failed'));\n            }\n          }, 'image/jpeg', 0.8);\n        };\n        \n        img.src = event.target?.result as string;\n      };\n      \n      reader.onerror = (error) => reject(error);\n      reader.readAsDataURL(imageFile);\n    });\n\t}\n\tdeleteHandler(image: string, index: number) {\n\t\tthis.deleteHooks.push(this.delImage(image));\n\t\tthis.imageList = this.imageList?.filter((value, i) => index != i);\n\t\tthis.field()?.fieldControl?.setValue(this.imageList);\n\t}\n\n\tafterSubmit() {\n\t\tthis.field()?.fieldControl?.submitChange.subscribe((value) => {\n\t\t\tif (Boolean(value)) {\n\t\t\t\tthis.deleteHooks.forEach((hook) => hook.subscribe());\n\t\t\t}\n\t\t});\n\t}\n\n\thandleHookChange() {\n\t\tthis.field()?.fieldControl?.hookChange.subscribe((value) => {\n\t\t\tif (value == null) {\n\t\t\t\treturn;\n\t\t\t}\n\t\t\tthis.props.onHookChange?.(this.field()!, { value });\n\t\t\tthis.imageList = [...value];\n\t\t});\n\t}\n\n\thandleDisabled() {\n\t\tif (this.props?.disabled) {\n\t\t\tthis.field()!.fieldControl!.disable({ emitEvent: false });\n\t\t}\n\t}\n\n\tajustedImage(event: any) {\n\t\tif (this.props?.adjustable) {\n\t\t\t// 解决图片查看时的操作按钮（旋转、放大、缩小、关闭）不在屏幕右上角显示的问题\n\t\t\tlet childDiv = document.getElementsByClassName('p-image-toolbar')[0];\n\t\t\tlet parentDiv = document.createElement('div');\n\t\t\tparentDiv.style.width = '100vw';\n\t\t\tparentDiv.style.height = '100vh';\n\t\t\tparentDiv.style.position = 'fixed';\n\t\t\tchildDiv?.parentNode?.insertBefore(parentDiv, childDiv);\n\t\t\tparentDiv.appendChild(childDiv);\n\t\t}\n\t}\n}\n"]}
|