imm-element-ui 1.0.7 → 1.0.8

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (40) hide show
  1. package/esm2022/lib/form/form/form.component.mjs +9 -6
  2. package/esm2022/lib/form/form-field/field-control.mjs +5 -5
  3. package/esm2022/lib/form/form-field/field-utils.mjs +4 -5
  4. package/esm2022/lib/form/form-field/form-field.mjs +107 -107
  5. package/esm2022/lib/form/form-type/autocomplete.type.mjs +160 -151
  6. package/esm2022/lib/form/form-type/codemirror.type.mjs +5 -4
  7. package/esm2022/lib/form/form-type/datepicker.type.mjs +4 -4
  8. package/esm2022/lib/form/form-type/image.type.mjs +147 -146
  9. package/esm2022/lib/form/form-type/inputnumber.type.mjs +100 -91
  10. package/esm2022/lib/form/form-type/inputtext.type.mjs +28 -19
  11. package/esm2022/lib/form/form-type/multiselect.type.mjs +172 -163
  12. package/esm2022/lib/form/form-type/radio.type.mjs +81 -80
  13. package/esm2022/lib/form/form-type/rowselector.type.mjs +29 -28
  14. package/esm2022/lib/form/form-type/select.type.mjs +136 -136
  15. package/esm2022/lib/form/form-type/textarea.type.mjs +10 -1
  16. package/esm2022/lib/form/form-type/treeselect.type.mjs +4 -4
  17. package/esm2022/lib/form/form-type/upload.type.mjs +135 -134
  18. package/esm2022/lib/grid/actions/actions.component.mjs +3 -3
  19. package/esm2022/lib/page-form/page-form.component.mjs +12 -3
  20. package/esm2022/lib/share/utils.mjs +10 -1
  21. package/fesm2022/imm-element-ui.mjs +1141 -1071
  22. package/fesm2022/imm-element-ui.mjs.map +1 -1
  23. package/lib/form/form/form.component.d.ts +3 -1
  24. package/lib/form/form-field/field-control.d.ts +2 -2
  25. package/lib/form/form-field/field-utils.d.ts +1 -1
  26. package/lib/form/form-field/form-field.d.ts +2 -0
  27. package/lib/form/form-type/autocomplete.type.d.ts +1 -0
  28. package/lib/form/form-type/codemirror.type.d.ts +1 -1
  29. package/lib/form/form-type/datepicker.type.d.ts +1 -1
  30. package/lib/form/form-type/image.type.d.ts +1 -1
  31. package/lib/form/form-type/inputnumber.type.d.ts +1 -0
  32. package/lib/form/form-type/inputtext.type.d.ts +1 -0
  33. package/lib/form/form-type/multiselect.type.d.ts +1 -0
  34. package/lib/form/form-type/radio.type.d.ts +1 -1
  35. package/lib/form/form-type/rowselector.type.d.ts +1 -1
  36. package/lib/form/form-type/select.type.d.ts +1 -2
  37. package/lib/form/form-type/textarea.type.d.ts +1 -0
  38. package/lib/form/form-type/treeselect.type.d.ts +1 -1
  39. package/lib/form/form-type/upload.type.d.ts +1 -1
  40. package/package.json +1 -1
@@ -16,7 +16,7 @@ export class DatePickerComponent {
16
16
  effect(() => {
17
17
  if (this.field()) {
18
18
  this.props = this.field().datePickerProps;
19
- this.handleModelChange();
19
+ this.handleHookChange();
20
20
  this.handleDisabled();
21
21
  }
22
22
  });
@@ -39,8 +39,8 @@ export class DatePickerComponent {
39
39
  }, { allowSignalWrites: true });
40
40
  }
41
41
  ngOnInit() { }
42
- handleModelChange() {
43
- this.field()?.fieldControl?.modelChange.subscribe((value) => {
42
+ handleHookChange() {
43
+ this.field()?.fieldControl?.hookChange.subscribe((value) => {
44
44
  if (!value) {
45
45
  return;
46
46
  }
@@ -263,4 +263,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
263
263
  type: ViewChild,
264
264
  args: [DatePicker, { read: ElementRef, static: false }]
265
265
  }] } });
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.handleModelChange();\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\thandleModelChange() {\n\t\tthis.field()?.fieldControl?.modelChange.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"]}
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"]}
@@ -22,7 +22,7 @@ export class ImageComponent {
22
22
  if (this.field()) {
23
23
  this.props = this.field().imageProps;
24
24
  this.handleDisabled();
25
- this.handleModelChange();
25
+ this.handleHookChange();
26
26
  this.afterSubmit();
27
27
  }
28
28
  });
@@ -74,14 +74,6 @@ export class ImageComponent {
74
74
  this.imageList = this.imageList?.filter((value, i) => index != i);
75
75
  this.field()?.fieldControl?.setValue(this.imageList);
76
76
  }
77
- handleModelChange() {
78
- this.field()?.fieldControl?.modelChange.subscribe((value) => {
79
- if (value == null) {
80
- return;
81
- }
82
- this.imageList = [...value];
83
- });
84
- }
85
77
  afterSubmit() {
86
78
  this.field()?.fieldControl?.submitChange.subscribe((value) => {
87
79
  if (Boolean(value)) {
@@ -89,6 +81,15 @@ export class ImageComponent {
89
81
  }
90
82
  });
91
83
  }
84
+ handleHookChange() {
85
+ this.field()?.fieldControl?.hookChange.subscribe((value) => {
86
+ if (value == null) {
87
+ return;
88
+ }
89
+ this.props.onHookChange?.(this.field(), { value });
90
+ this.imageList = [...value];
91
+ });
92
+ }
92
93
  handleDisabled() {
93
94
  if (this.props?.disabled) {
94
95
  this.field().fieldControl.disable({ emitEvent: false });
@@ -107,149 +108,149 @@ export class ImageComponent {
107
108
  }
108
109
  }
109
110
  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 }); }
110
- 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
111
- #fu
112
- auto
113
- [name]="props.name"
114
- [url]="props.url"
115
- [method]="props.method ?? 'post'"
116
- accept="image/*"
117
- [withCredentials]="props.withCredentials"
118
- [maxFileSize]="props.maxFileSize"
119
- [styleClass]="props.styleClass"
120
- [previewWidth]="props.previewWidth ?? 50"
121
- [mode]="props.mode ?? 'advanced'"
122
- [headers]="props.headers"
123
- [fileLimit]="props.fileLimit"
124
- [customUpload]="props.customUpload ?? true"
125
- (onBeforeUpload)="props.onBeforeUpload?.(field()!, $event)"
126
- (onSend)="props.onSend?.(field()!, $event)"
127
- (onUpload)="props.onUpload?.(field()!, $event)"
128
- (onError)="props.onError?.(field()!, $event)"
129
- (onClear)="props.onClear?.(field()!, $event)"
130
- (onRemove)="props.onRemove?.(field()!, $event)"
131
- (onSelect)="props.onSelect?.(field()!, $event)"
132
- (onProgress)="props.onProgress?.(field()!, $event)"
133
- (uploadHandler)="uploadHandler(field()!, $event, fu)">
134
- <ng-template
135
- #header
136
- let-chooseCallback="chooseCallback">
137
- <div
138
- #imageComp
139
- [class]="'flex justify-center w-full upload-btn' + (field()?.fieldControl?.disabled ? ' upload-disable' : '')"
140
- (click)="choose($event, chooseCallback)">
141
- <span
142
- ><span
143
- style="font-size: 12px; margin-right: 2.5px"
144
- class="pi pi-upload"></span
145
- >上传</span
146
- >
147
- </div>
148
- </ng-template>
149
- <ng-template #content>
150
- @if (imageList.length > 0) {
151
- @for (image of imageList; track image; let index = $index) {
152
- <div class="flex justify-between items-center file-item">
153
- <p-image
154
- [src]="'https://hrimage.myfoodiepet.com//' + image"
155
- [preview]="true"
156
- (onShow)="ajustedImage($event)"
157
- alt="Image">
158
- <ng-template #indicator>
159
- <span class="file-name">{{ image }}</span>
160
- </ng-template>
161
- <ng-template #image>
162
- <span class="file-name">{{ image }}</span>
163
- </ng-template>
164
- </p-image>
165
- @if (!field()?.fieldControl?.disabled) {
166
- <p-button
167
- icon="pi pi-times"
168
- severity="danger"
169
- size="small"
170
- (onClick)="deleteHandler(image, index)"
171
- [text]="true" />
172
- }
173
- </div>
174
- }
175
- }
176
- </ng-template>
177
- <ng-template #file> </ng-template>
111
+ 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
112
+ #fu
113
+ auto
114
+ [name]="props.name"
115
+ [url]="props.url"
116
+ [method]="props.method ?? 'post'"
117
+ accept="image/*"
118
+ [withCredentials]="props.withCredentials"
119
+ [maxFileSize]="props.maxFileSize"
120
+ [styleClass]="props.styleClass"
121
+ [previewWidth]="props.previewWidth ?? 50"
122
+ [mode]="props.mode ?? 'advanced'"
123
+ [headers]="props.headers"
124
+ [fileLimit]="props.fileLimit"
125
+ [customUpload]="props.customUpload ?? true"
126
+ (onBeforeUpload)="props.onBeforeUpload?.(field()!, $event)"
127
+ (onSend)="props.onSend?.(field()!, $event)"
128
+ (onUpload)="props.onUpload?.(field()!, $event)"
129
+ (onError)="props.onError?.(field()!, $event)"
130
+ (onClear)="props.onClear?.(field()!, $event)"
131
+ (onRemove)="props.onRemove?.(field()!, $event)"
132
+ (onSelect)="props.onSelect?.(field()!, $event)"
133
+ (onProgress)="props.onProgress?.(field()!, $event)"
134
+ (uploadHandler)="uploadHandler(field()!, $event, fu)">
135
+ <ng-template
136
+ #header
137
+ let-chooseCallback="chooseCallback">
138
+ <div
139
+ #imageComp
140
+ [class]="'flex justify-center w-full upload-btn' + (field()?.fieldControl?.disabled ? ' upload-disable' : '')"
141
+ (click)="choose($event, chooseCallback)">
142
+ <span
143
+ ><span
144
+ style="font-size: 12px; margin-right: 2.5px"
145
+ class="pi pi-upload"></span
146
+ >上传</span
147
+ >
148
+ </div>
149
+ </ng-template>
150
+ <ng-template #content>
151
+ @if (imageList.length > 0) {
152
+ @for (image of imageList; track image; let index = $index) {
153
+ <div class="flex justify-between items-center file-item">
154
+ <p-image
155
+ [src]="'https://hrimage.myfoodiepet.com//' + image"
156
+ [preview]="true"
157
+ (onShow)="ajustedImage($event)"
158
+ alt="Image">
159
+ <ng-template #indicator>
160
+ <span class="file-name">{{ image }}</span>
161
+ </ng-template>
162
+ <ng-template #image>
163
+ <span class="file-name">{{ image }}</span>
164
+ </ng-template>
165
+ </p-image>
166
+ @if (!field()?.fieldControl?.disabled) {
167
+ <p-button
168
+ icon="pi pi-times"
169
+ severity="danger"
170
+ size="small"
171
+ (onClick)="deleteHandler(image, index)"
172
+ [text]="true" />
173
+ }
174
+ </div>
175
+ }
176
+ }
177
+ </ng-template>
178
+ <ng-template #file> </ng-template>
178
179
  </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}// .file-name:hover{// cursor: pointer;// color: var(--p-primary-color);//}: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: i3.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 }] }); }
179
180
  }
180
181
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ImageComponent, decorators: [{
181
182
  type: Component,
182
- args: [{ selector: 'form-image', standalone: true, imports: [FileUpload, ButtonModule, Image, ReactiveFormsModule], template: `<p-fileUpload
183
- #fu
184
- auto
185
- [name]="props.name"
186
- [url]="props.url"
187
- [method]="props.method ?? 'post'"
188
- accept="image/*"
189
- [withCredentials]="props.withCredentials"
190
- [maxFileSize]="props.maxFileSize"
191
- [styleClass]="props.styleClass"
192
- [previewWidth]="props.previewWidth ?? 50"
193
- [mode]="props.mode ?? 'advanced'"
194
- [headers]="props.headers"
195
- [fileLimit]="props.fileLimit"
196
- [customUpload]="props.customUpload ?? true"
197
- (onBeforeUpload)="props.onBeforeUpload?.(field()!, $event)"
198
- (onSend)="props.onSend?.(field()!, $event)"
199
- (onUpload)="props.onUpload?.(field()!, $event)"
200
- (onError)="props.onError?.(field()!, $event)"
201
- (onClear)="props.onClear?.(field()!, $event)"
202
- (onRemove)="props.onRemove?.(field()!, $event)"
203
- (onSelect)="props.onSelect?.(field()!, $event)"
204
- (onProgress)="props.onProgress?.(field()!, $event)"
205
- (uploadHandler)="uploadHandler(field()!, $event, fu)">
206
- <ng-template
207
- #header
208
- let-chooseCallback="chooseCallback">
209
- <div
210
- #imageComp
211
- [class]="'flex justify-center w-full upload-btn' + (field()?.fieldControl?.disabled ? ' upload-disable' : '')"
212
- (click)="choose($event, chooseCallback)">
213
- <span
214
- ><span
215
- style="font-size: 12px; margin-right: 2.5px"
216
- class="pi pi-upload"></span
217
- >上传</span
218
- >
219
- </div>
220
- </ng-template>
221
- <ng-template #content>
222
- @if (imageList.length > 0) {
223
- @for (image of imageList; track image; let index = $index) {
224
- <div class="flex justify-between items-center file-item">
225
- <p-image
226
- [src]="'https://hrimage.myfoodiepet.com//' + image"
227
- [preview]="true"
228
- (onShow)="ajustedImage($event)"
229
- alt="Image">
230
- <ng-template #indicator>
231
- <span class="file-name">{{ image }}</span>
232
- </ng-template>
233
- <ng-template #image>
234
- <span class="file-name">{{ image }}</span>
235
- </ng-template>
236
- </p-image>
237
- @if (!field()?.fieldControl?.disabled) {
238
- <p-button
239
- icon="pi pi-times"
240
- severity="danger"
241
- size="small"
242
- (onClick)="deleteHandler(image, index)"
243
- [text]="true" />
244
- }
245
- </div>
246
- }
247
- }
248
- </ng-template>
249
- <ng-template #file> </ng-template>
183
+ args: [{ selector: 'form-image', standalone: true, imports: [FileUpload, ButtonModule, Image, ReactiveFormsModule], template: `<p-fileUpload
184
+ #fu
185
+ auto
186
+ [name]="props.name"
187
+ [url]="props.url"
188
+ [method]="props.method ?? 'post'"
189
+ accept="image/*"
190
+ [withCredentials]="props.withCredentials"
191
+ [maxFileSize]="props.maxFileSize"
192
+ [styleClass]="props.styleClass"
193
+ [previewWidth]="props.previewWidth ?? 50"
194
+ [mode]="props.mode ?? 'advanced'"
195
+ [headers]="props.headers"
196
+ [fileLimit]="props.fileLimit"
197
+ [customUpload]="props.customUpload ?? true"
198
+ (onBeforeUpload)="props.onBeforeUpload?.(field()!, $event)"
199
+ (onSend)="props.onSend?.(field()!, $event)"
200
+ (onUpload)="props.onUpload?.(field()!, $event)"
201
+ (onError)="props.onError?.(field()!, $event)"
202
+ (onClear)="props.onClear?.(field()!, $event)"
203
+ (onRemove)="props.onRemove?.(field()!, $event)"
204
+ (onSelect)="props.onSelect?.(field()!, $event)"
205
+ (onProgress)="props.onProgress?.(field()!, $event)"
206
+ (uploadHandler)="uploadHandler(field()!, $event, fu)">
207
+ <ng-template
208
+ #header
209
+ let-chooseCallback="chooseCallback">
210
+ <div
211
+ #imageComp
212
+ [class]="'flex justify-center w-full upload-btn' + (field()?.fieldControl?.disabled ? ' upload-disable' : '')"
213
+ (click)="choose($event, chooseCallback)">
214
+ <span
215
+ ><span
216
+ style="font-size: 12px; margin-right: 2.5px"
217
+ class="pi pi-upload"></span
218
+ >上传</span
219
+ >
220
+ </div>
221
+ </ng-template>
222
+ <ng-template #content>
223
+ @if (imageList.length > 0) {
224
+ @for (image of imageList; track image; let index = $index) {
225
+ <div class="flex justify-between items-center file-item">
226
+ <p-image
227
+ [src]="'https://hrimage.myfoodiepet.com//' + image"
228
+ [preview]="true"
229
+ (onShow)="ajustedImage($event)"
230
+ alt="Image">
231
+ <ng-template #indicator>
232
+ <span class="file-name">{{ image }}</span>
233
+ </ng-template>
234
+ <ng-template #image>
235
+ <span class="file-name">{{ image }}</span>
236
+ </ng-template>
237
+ </p-image>
238
+ @if (!field()?.fieldControl?.disabled) {
239
+ <p-button
240
+ icon="pi pi-times"
241
+ severity="danger"
242
+ size="small"
243
+ (onClick)="deleteHandler(image, index)"
244
+ [text]="true" />
245
+ }
246
+ </div>
247
+ }
248
+ }
249
+ </ng-template>
250
+ <ng-template #file> </ng-template>
250
251
  </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}// .file-name:hover{// cursor: pointer;// color: var(--p-primary-color);//}: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"] }]
251
252
  }], ctorParameters: () => [{ type: i1.HttpClient }, { type: i2.ActionService }, { type: i0.Renderer2 }], propDecorators: { imageCompRef: [{
252
253
  type: ViewChild,
253
254
  args: ['imageComp', { read: ElementRef, static: false }]
254
255
  }] } });
255
- //# 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';\r\nimport { ReactiveFormsModule } from '@angular/forms';\r\nimport { FileUpload } from 'primeng/fileupload';\r\nimport { ButtonModule } from 'primeng/button';\r\nimport { Image } from 'primeng/image';\r\nimport { FormField, FieldProps, AttributeEvent } from '../form-field/form-field';\r\nimport { HttpClient, HttpEvent, HttpHeaders, HttpRequest, HttpEventType } from '@angular/common/http';\r\nimport { ActionService } from '../../service/action.service';\r\n\r\nimport { filter, forkJoin, Observable } from 'rxjs';\r\n\r\nexport interface ImageProps extends FieldProps {\r\n\turl?: string;\r\n\tmethod?: 'post' | 'put';\r\n\twithCredentials?: boolean;\r\n\tmaxFileSize?: number;\r\n\tpreviewWidth?: number;\r\n\tmode?: 'basic' | 'advanced';\r\n\theaders?: any;\r\n\tcustomUpload?: boolean;\r\n\tfileLimit?: number;\r\n\tuploadStyleClass?: string;\r\n\tcancelStyleClass?: string;\r\n\tremoveStyleClass?: string;\r\n\tchooseStyleClass?: string;\r\n\tadjustable?: boolean;\r\n\r\n\tonBeforeUpload?: AttributeEvent;\r\n\tonSend?: AttributeEvent;\r\n\tonUpload?: AttributeEvent;\r\n\tonError?: AttributeEvent;\r\n\tonClear?: AttributeEvent;\r\n\tonRemove?: AttributeEvent;\r\n\tonSelect?: AttributeEvent;\r\n\tonProgress?: AttributeEvent;\r\n}\r\n\r\n@Component({\r\n\tselector: 'form-image',\r\n\tstandalone: true,\r\n\tstyles: `\r\n\t\t.file-item {\r\n\t\t\tborder-top: solid 1px #fff;\r\n\t\t}\r\n\t\t.upload-btn {\r\n\t\t\tborder: solid 1px transparent;\r\n\t\t}\r\n\t\t.upload-btn.upload-disable:hover {\r\n\t\t\tcursor: default;\r\n\t\t}\r\n\t\t.upload-btn:not(.upload-disable):hover {\r\n\t\t\tborder: solid 1px var(--p-primary-color);\r\n\t\t\tbackground: var(--p-primary-50);\r\n\t\t\tcursor: pointer;\r\n\t\t}\r\n\t\t.upload-btn:not(.upload-disable).ng-hovered {\r\n\t\t\tborder: solid 1px var(--p-primary-color);\r\n\t\t\tbackground: var(--p-primary-50);\r\n\t\t\tcursor: pointer;\r\n\t\t}\r\n\t\t.file-name {\r\n\t\t\tfont-size: 12px;\r\n\t\t\tcursor: pointer;\r\n\t\t\tcolor: var(--p-primary-color) !important;\r\n\t\t}\r\n\t\t// .file-name:hover {\r\n\t\t// \tcursor: pointer;\r\n\t\t// \tcolor: var(--p-primary-color);\r\n\t\t// }\r\n\t\t:host ::ng-deep {\r\n\t\t\t.p-image-preview-mask {\r\n\t\t\t\tposition: inherit;\r\n\t\t\t\topacity: 1;\r\n\t\t\t\tjustify-content: left;\r\n\t\t\t\tcolor: #334155;\r\n\t\t\t}\r\n\t\t\tp-image {\r\n\t\t\t\t.p-image {\r\n\t\t\t\t\tdisplay: inline-block;\r\n\t\t\t\t\tcolor: var(--p-primary-color) !important;\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t}\r\n\t`,\r\n\timports: [FileUpload, ButtonModule, Image, ReactiveFormsModule],\r\n\ttemplate: `<p-fileUpload\r\n\t\t#fu\r\n\t\tauto\r\n\t\t[name]=\"props.name\"\r\n\t\t[url]=\"props.url\"\r\n\t\t[method]=\"props.method ?? 'post'\"\r\n\t\taccept=\"image/*\"\r\n\t\t[withCredentials]=\"props.withCredentials\"\r\n\t\t[maxFileSize]=\"props.maxFileSize\"\r\n\t\t[styleClass]=\"props.styleClass\"\r\n\t\t[previewWidth]=\"props.previewWidth ?? 50\"\r\n\t\t[mode]=\"props.mode ?? 'advanced'\"\r\n\t\t[headers]=\"props.headers\"\r\n\t\t[fileLimit]=\"props.fileLimit\"\r\n\t\t[customUpload]=\"props.customUpload ?? true\"\r\n\t\t(onBeforeUpload)=\"props.onBeforeUpload?.(field()!, $event)\"\r\n\t\t(onSend)=\"props.onSend?.(field()!, $event)\"\r\n\t\t(onUpload)=\"props.onUpload?.(field()!, $event)\"\r\n\t\t(onError)=\"props.onError?.(field()!, $event)\"\r\n\t\t(onClear)=\"props.onClear?.(field()!, $event)\"\r\n\t\t(onRemove)=\"props.onRemove?.(field()!, $event)\"\r\n\t\t(onSelect)=\"props.onSelect?.(field()!, $event)\"\r\n\t\t(onProgress)=\"props.onProgress?.(field()!, $event)\"\r\n\t\t(uploadHandler)=\"uploadHandler(field()!, $event, fu)\">\r\n\t\t<ng-template\r\n\t\t\t#header\r\n\t\t\tlet-chooseCallback=\"chooseCallback\">\r\n\t\t\t<div\r\n\t\t\t\t#imageComp\r\n\t\t\t\t[class]=\"'flex justify-center w-full upload-btn' + (field()?.fieldControl?.disabled ? ' upload-disable' : '')\"\r\n\t\t\t\t(click)=\"choose($event, chooseCallback)\">\r\n\t\t\t\t<span\r\n\t\t\t\t\t><span\r\n\t\t\t\t\t\tstyle=\"font-size: 12px; margin-right: 2.5px\"\r\n\t\t\t\t\t\tclass=\"pi pi-upload\"></span\r\n\t\t\t\t\t>上传</span\r\n\t\t\t\t>\r\n\t\t\t</div>\r\n\t\t</ng-template>\r\n\t\t<ng-template #content>\r\n\t\t\t@if (imageList.length > 0) {\r\n\t\t\t\t@for (image of imageList; track image; let index = $index) {\r\n\t\t\t\t\t<div class=\"flex justify-between items-center file-item\">\r\n\t\t\t\t\t\t<p-image\r\n\t\t\t\t\t\t\t[src]=\"'https://hrimage.myfoodiepet.com//' + image\"\r\n\t\t\t\t\t\t\t[preview]=\"true\"\r\n\t\t\t\t\t\t\t(onShow)=\"ajustedImage($event)\"\r\n\t\t\t\t\t\t\talt=\"Image\">\r\n\t\t\t\t\t\t\t<ng-template #indicator>\r\n\t\t\t\t\t\t\t\t<span class=\"file-name\">{{ image }}</span>\r\n\t\t\t\t\t\t\t</ng-template>\r\n\t\t\t\t\t\t\t<ng-template #image>\r\n\t\t\t\t\t\t\t\t<span class=\"file-name\">{{ image }}</span>\r\n\t\t\t\t\t\t\t</ng-template>\r\n\t\t\t\t\t\t</p-image>\r\n\t\t\t\t\t\t@if (!field()?.fieldControl?.disabled) {\r\n\t\t\t\t\t\t\t<p-button\r\n\t\t\t\t\t\t\t\ticon=\"pi pi-times\"\r\n\t\t\t\t\t\t\t\tseverity=\"danger\"\r\n\t\t\t\t\t\t\t\tsize=\"small\"\r\n\t\t\t\t\t\t\t\t(onClick)=\"deleteHandler(image, index)\"\r\n\t\t\t\t\t\t\t\t[text]=\"true\" />\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t</div>\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t</ng-template>\r\n\t\t<ng-template #file> </ng-template>\r\n\t</p-fileUpload>`,\r\n\tstyleUrl: '../../styles/styles.scss',\r\n})\r\nexport class ImageComponent {\r\n\t@ViewChild('imageComp', { read: ElementRef, static: false }) imageCompRef!: ElementRef;\r\n\tfield = input<FormField>();\r\n\tprops: ImageProps = {};\r\n\timageList: string[] = [];\r\n\tdeleteHooks: Observable<any>[] = [];\r\n\r\n\tconstructor(\r\n\t\tprivate http: HttpClient,\r\n\t\tprivate action: ActionService,\r\n\t\tprivate renderer: Renderer2,\r\n\t) {\r\n\t\teffect(() => {\r\n\t\t\tif (this.field()) {\r\n\t\t\t\tthis.props = this.field()!.imageProps!;\r\n\t\t\t\tthis.handleDisabled();\r\n\t\t\t\tthis.handleModelChange();\r\n\t\t\t\tthis.afterSubmit();\r\n\t\t\t}\r\n\t\t});\r\n\t\teffect(() => {\r\n\t\t\tconst labelAction = this.action.getFieldLabelAction();\r\n\t\t\tif (!labelAction || labelAction?.key != this.field()?.uuid) {\r\n\t\t\t\treturn;\r\n\t\t\t}\r\n\t\t\tif (labelAction.type == 'mouseenter') {\r\n\t\t\t\tthis.renderer.addClass(this.imageCompRef.nativeElement, 'ng-hovered');\r\n\t\t\t} else if (labelAction.type == 'mouseleave') {\r\n\t\t\t\tthis.renderer.removeClass(this.imageCompRef.nativeElement, 'ng-hovered');\r\n\t\t\t} else if (labelAction.type == 'click') {\r\n\t\t\t\tthis.imageCompRef.nativeElement.click();\r\n\t\t\t}\r\n\t\t});\r\n\t}\r\n\r\n\tchoose(event: any, callback: any) {\r\n\t\tif (this.field()?.fieldControl?.disabled) {\r\n\t\t\treturn;\r\n\t\t}\r\n\t\tcallback();\r\n\t}\r\n\r\n\tuploadImage(file: File): Observable<any> {\r\n\t\tconst formData = new FormData();\r\n\t\tformData.append('file', file);\r\n\t\treturn this.http\r\n\t\t\t.request(\r\n\t\t\t\tnew HttpRequest('POST', 'imageUpload', formData, {\r\n\t\t\t\t\treportProgress: true,\r\n\t\t\t\t\twithCredentials: false,\r\n\t\t\t\t}),\r\n\t\t\t)\r\n\t\t\t.pipe(filter((response: HttpEvent<any>) => response.type == HttpEventType.Response));\r\n\t}\r\n\r\n\tdelImage(image: string): Observable<any> {\r\n\t\treturn this.http.post('imageDelete', { fid: image });\r\n\t}\r\n\r\n\tuploadHandler(field: any, event: any, fu: any) {\r\n\t\tthis.uploadImage(event.files[0]).subscribe((response) => {\r\n\t\t\tconsole.log('response.body----', response.body);\r\n\t\t\tthis.imageList?.push(response.body.fid);\r\n\t\t\tconsole.log('this.imageList----', this.imageList);\r\n\t\t\tthis.field()?.fieldControl?.setValue(this.imageList);\r\n\t\t});\r\n\t}\r\n\r\n\tdeleteHandler(image: string, index: number) {\r\n\t\tthis.deleteHooks.push(this.delImage(image));\r\n\t\tthis.imageList = this.imageList?.filter((value, i) => index != i);\r\n\t\tthis.field()?.fieldControl?.setValue(this.imageList);\r\n\t}\r\n\r\n\thandleModelChange() {\r\n\t\tthis.field()?.fieldControl?.modelChange.subscribe((value) => {\r\n\t\t\tif (value == null) {\r\n\t\t\t\treturn;\r\n\t\t\t}\r\n\t\t\tthis.imageList = [...value];\r\n\t\t});\r\n\t}\r\n\r\n\tafterSubmit() {\r\n\t\tthis.field()?.fieldControl?.submitChange.subscribe((value) => {\r\n\t\t\tif (Boolean(value)) {\r\n\t\t\t\tthis.deleteHooks.forEach((hook) => hook.subscribe());\r\n\t\t\t}\r\n\t\t});\r\n\t}\r\n\r\n\thandleDisabled() {\r\n\t\tif (this.props?.disabled) {\r\n\t\t\tthis.field()!.fieldControl!.disable({ emitEvent: false });\r\n\t\t}\r\n\t}\r\n\r\n\tajustedImage(event: any) {\r\n\t\tif (this.props?.adjustable) {\r\n\t\t\t// 解决图片查看时的操作按钮（旋转、放大、缩小、关闭）不在屏幕右上角显示的问题\r\n\t\t\tlet childDiv = document.getElementsByClassName('p-image-toolbar')[0];\r\n\t\t\tlet parentDiv = document.createElement('div');\r\n\t\t\tparentDiv.style.width = '100vw';\r\n\t\t\tparentDiv.style.height = '100vh';\r\n\t\t\tparentDiv.style.position = 'fixed';\r\n\t\t\tchildDiv?.parentNode?.insertBefore(parentDiv, childDiv);\r\n\t\t\tparentDiv.appendChild(childDiv);\r\n\t\t}\r\n\t}\r\n}\r\n"]}
256
+ //# 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;;;;;AAmJpD,MAAM,OAAO,cAAc;IAO1B,YACS,IAAgB,EAChB,MAAqB,EACrB,QAAmB;QAFnB,SAAI,GAAJ,IAAI,CAAY;QAChB,WAAM,GAAN,MAAM,CAAe;QACrB,aAAQ,GAAR,QAAQ,CAAW;QAR5B,UAAK,GAAG,KAAK,EAAa,CAAC;QAC3B,UAAK,GAAe,EAAE,CAAC;QACvB,cAAS,GAAa,EAAE,CAAC;QACzB,gBAAW,GAAsB,EAAE,CAAC;QAOnC,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,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,QAAQ,EAAE,EAAE;YACvD,OAAO,CAAC,GAAG,CAAC,mBAAmB,EAAE,QAAQ,CAAC,IAAI,CAAC,CAAC;YAChD,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;YACxC,OAAO,CAAC,GAAG,CAAC,oBAAoB,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC;YAClD,IAAI,CAAC,KAAK,EAAE,EAAE,YAAY,EAAE,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QACtD,CAAC,CAAC,CAAC;IACJ,CAAC;IAED,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;+GA7GW,cAAc;mGAAd,cAAc,gSACM,UAAU,6BAxEhC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;iBAoEM,44MArEN,UAAU,g5BAAE,YAAY,kbAAE,KAAK,qWAAE,mBAAmB;;4FAwElD,cAAc;kBAvH1B,SAAS;+BACC,YAAY,cACV,IAAI,WA6CP,CAAC,UAAU,EAAE,YAAY,EAAE,KAAK,EAAE,mBAAmB,CAAC,YACrD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;iBAoEM;mIAI6C,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';\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\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// .file-name:hover {\n\t\t// \tcursor: pointer;\n\t\t// \tcolor: var(--p-primary-color);\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@for (image of imageList; track image; let index = $index) {\n\t\t\t\t\t<div class=\"flex justify-between items-center file-item\">\n\t\t\t\t\t\t<p-image\n\t\t\t\t\t\t\t[src]=\"'https://hrimage.myfoodiepet.com//' + image\"\n\t\t\t\t\t\t\t[preview]=\"true\"\n\t\t\t\t\t\t\t(onShow)=\"ajustedImage($event)\"\n\t\t\t\t\t\t\talt=\"Image\">\n\t\t\t\t\t\t\t<ng-template #indicator>\n\t\t\t\t\t\t\t\t<span class=\"file-name\">{{ image }}</span>\n\t\t\t\t\t\t\t</ng-template>\n\t\t\t\t\t\t\t<ng-template #image>\n\t\t\t\t\t\t\t\t<span class=\"file-name\">{{ image }}</span>\n\t\t\t\t\t\t\t</ng-template>\n\t\t\t\t\t\t</p-image>\n\t\t\t\t\t\t@if (!field()?.fieldControl?.disabled) {\n\t\t\t\t\t\t\t<p-button\n\t\t\t\t\t\t\t\ticon=\"pi pi-times\"\n\t\t\t\t\t\t\t\tseverity=\"danger\"\n\t\t\t\t\t\t\t\tsize=\"small\"\n\t\t\t\t\t\t\t\t(onClick)=\"deleteHandler(image, index)\"\n\t\t\t\t\t\t\t\t[text]=\"true\" />\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\tconsole.log('response.body----', response.body);\n\t\t\tthis.imageList?.push(response.body.fid);\n\t\t\tconsole.log('this.imageList----', this.imageList);\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"]}