imm-element-ui 1.2.4 → 1.2.6

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.
@@ -1,11 +1,15 @@
1
- import { Component, effect, input, ViewChild } from '@angular/core';
1
+ import { Component, effect, HostListener, input, ViewChild } from '@angular/core';
2
2
  import { ContextMenu } from 'primeng/contextmenu';
3
3
  import { fieldUtils } from './field-utils';
4
4
  import * as i0 from "@angular/core";
5
5
  import * as i1 from "@angular/cdk/clipboard";
6
6
  export class ContextMenuComponent {
7
+ onResize() {
8
+ this.updVisible();
9
+ }
7
10
  constructor(clipboard) {
8
11
  this.clipboard = clipboard;
12
+ this.visible = true;
9
13
  this.target = input({});
10
14
  this.field = input();
11
15
  this.commonItems = [
@@ -25,6 +29,7 @@ export class ContextMenuComponent {
25
29
  },
26
30
  },
27
31
  ];
32
+ this.updVisible();
28
33
  effect(() => {
29
34
  if (this.field()) {
30
35
  if (this.field()?.type === 'select') {
@@ -103,44 +108,54 @@ export class ContextMenuComponent {
103
108
  }
104
109
  return undefined;
105
110
  }
111
+ updVisible() {
112
+ this.visible = window.innerWidth > 1024;
113
+ }
106
114
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ContextMenuComponent, deps: [{ token: i1.Clipboard }], target: i0.ɵɵFactoryTarget.Component }); }
107
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.13", type: ContextMenuComponent, isStandalone: true, selector: "app-context-menu", inputs: { target: { classPropertyName: "target", publicName: "target", isSignal: true, isRequired: false, transformFunction: null }, field: { classPropertyName: "field", publicName: "field", isSignal: true, isRequired: false, transformFunction: null } }, viewQueries: [{ propertyName: "cm", first: true, predicate: ["cm"], descendants: true }], ngImport: i0, template: `
108
- <p-contextMenu
109
- #cm
110
- [target]="target()"
111
- [appendTo]="'body'"
112
- [model]="items">
113
- <ng-template
114
- #item
115
- let-item>
116
- <div class="px-[0.5rem] py-[0.5rem]">
117
- <i [class]="item.icon"></i>
118
- <span class="ml-2 cursor-pointer">{{ item.label }}</span>
119
- </div>
120
- </ng-template>
121
- </p-contextMenu>
115
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: ContextMenuComponent, isStandalone: true, selector: "app-context-menu", inputs: { target: { classPropertyName: "target", publicName: "target", isSignal: true, isRequired: false, transformFunction: null }, field: { classPropertyName: "field", publicName: "field", isSignal: true, isRequired: false, transformFunction: null } }, host: { listeners: { "window:resize": "onResize($event)" } }, viewQueries: [{ propertyName: "cm", first: true, predicate: ["cm"], descendants: true }], ngImport: i0, template: `
116
+ @if (visible) {
117
+ <p-contextMenu
118
+ #cm
119
+ [target]="target()"
120
+ [appendTo]="'body'"
121
+ [model]="items">
122
+ <ng-template
123
+ #item
124
+ let-item>
125
+ <div class="px-[0.5rem] py-[0.5rem]">
126
+ <i [class]="item.icon"></i>
127
+ <span class="ml-2 cursor-pointer">{{ item.label }}</span>
128
+ </div>
129
+ </ng-template>
130
+ </p-contextMenu>
131
+ }
122
132
  `, isInline: true, styles: [""], dependencies: [{ kind: "component", type: ContextMenu, selector: "p-contextMenu, p-contextmenu, p-context-menu", inputs: ["model", "triggerEvent", "target", "global", "style", "styleClass", "appendTo", "autoZIndex", "baseZIndex", "id", "breakpoint", "ariaLabel", "ariaLabelledBy", "pressDelay"], outputs: ["onShow", "onHide"] }] }); }
123
133
  }
124
134
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ContextMenuComponent, decorators: [{
125
135
  type: Component,
126
136
  args: [{ selector: 'app-context-menu', standalone: true, imports: [ContextMenu], template: `
127
- <p-contextMenu
128
- #cm
129
- [target]="target()"
130
- [appendTo]="'body'"
131
- [model]="items">
132
- <ng-template
133
- #item
134
- let-item>
135
- <div class="px-[0.5rem] py-[0.5rem]">
136
- <i [class]="item.icon"></i>
137
- <span class="ml-2 cursor-pointer">{{ item.label }}</span>
138
- </div>
139
- </ng-template>
140
- </p-contextMenu>
137
+ @if (visible) {
138
+ <p-contextMenu
139
+ #cm
140
+ [target]="target()"
141
+ [appendTo]="'body'"
142
+ [model]="items">
143
+ <ng-template
144
+ #item
145
+ let-item>
146
+ <div class="px-[0.5rem] py-[0.5rem]">
147
+ <i [class]="item.icon"></i>
148
+ <span class="ml-2 cursor-pointer">{{ item.label }}</span>
149
+ </div>
150
+ </ng-template>
151
+ </p-contextMenu>
152
+ }
141
153
  ` }]
142
154
  }], ctorParameters: () => [{ type: i1.Clipboard }], propDecorators: { cm: [{
143
155
  type: ViewChild,
144
156
  args: ['cm']
157
+ }], onResize: [{
158
+ type: HostListener,
159
+ args: ['window:resize', ['$event']]
145
160
  }] } });
146
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"context-menu.js","sourceRoot":"","sources":["../../../../../../projects/imm-element-ui/src/lib/form/form-field/context-menu.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, effect, input, ViewChild } from '@angular/core';\nimport { MenuItem } from 'primeng/api';\nimport { ContextMenu } from 'primeng/contextmenu';\nimport { Clipboard } from '@angular/cdk/clipboard';\nimport { FormField } from './form-field';\nimport { fieldUtils } from './field-utils';\n\n@Component({\n\tselector: 'app-context-menu',\n\tstandalone: true,\n\timports: [ContextMenu],\n\ttemplate: `\n\t\t<p-contextMenu\n\t\t\t#cm\n\t\t\t[target]=\"target()\"\n\t\t\t[appendTo]=\"'body'\"\n\t\t\t[model]=\"items\">\n\t\t\t<ng-template\n\t\t\t\t#item\n\t\t\t\tlet-item>\n\t\t\t\t<div class=\"px-[0.5rem] py-[0.5rem]\">\n\t\t\t\t\t<i [class]=\"item.icon\"></i>\n\t\t\t\t\t<span class=\"ml-2 cursor-pointer\">{{ item.label }}</span>\n\t\t\t\t</div>\n\t\t\t</ng-template>\n\t\t</p-contextMenu>\n\t`,\n\tstyles: [``],\n})\nexport class ContextMenuComponent {\n\t@ViewChild('cm') cm?: ContextMenu;\n\ttarget = input<any>({});\n\tfield = input<FormField>();\n\titems?: MenuItem[];\n\tcommonItems: MenuItem[] = [\n\t\t{\n\t\t\tlabel: '复制标题【Label】',\n\t\t\ticon: 'pi pi-clone',\n\t\t\tcommand: () => {\n\t\t\t\tconst label = fieldUtils.props(this.field()!).label || '';\n\t\t\t\tthis.clipboard.copy(label);\n\t\t\t},\n\t\t},\n\t\t{\n\t\t\tlabel: '复制键名【Key】',\n\t\t\ticon: 'pi pi-clone',\n\t\t\tcommand: () => {\n\t\t\t\tthis.clipboard.copy(this.field()?.key || '');\n\t\t\t},\n\t\t},\n\t];\n\tconstructor(private clipboard: Clipboard) {\n\t\teffect(() => {\n\t\t\tif (this.field()) {\n\t\t\t\tif (this.field()?.type === 'select') {\n\t\t\t\t\tthis.items = [\n\t\t\t\t\t\t...this.commonItems,\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tlabel: '复制项值【OptionValue】',\n\t\t\t\t\t\t\ticon: 'pi pi-clone',\n\t\t\t\t\t\t\tcommand: () => {\n\t\t\t\t\t\t\t\tconst value = this.field()?.form?.model()?.[this.field()?.key!];\n\t\t\t\t\t\t\t\tthis.clipboard.copy(value);\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t},\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tlabel: '复制项名称【OptionLabel】',\n\t\t\t\t\t\t\ticon: 'pi pi-clone',\n\t\t\t\t\t\t\tcommand: () => {\n\t\t\t\t\t\t\t\tconst value = this.field()?.form?.model()?.[this.field()?.key!];\n\t\t\t\t\t\t\t\tconst optionValue = this.field()?.selectProps?.optionValue || 'value';\n\t\t\t\t\t\t\t\tconst optionLabel = this.field()?.selectProps?.optionLabel || 'label';\n\t\t\t\t\t\t\t\tconst result = this.field()?.selectProps?.options?.find((item) => item[optionValue] === value)?.[optionLabel];\n\t\t\t\t\t\t\t\tthis.clipboard.copy(result);\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t},\n\t\t\t\t\t];\n\t\t\t\t} else if (this.field()?.type === 'treeselect') {\n\t\t\t\t\tthis.items = [\n\t\t\t\t\t\t...this.commonItems,\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tlabel: '复制项值【OptionValue】',\n\t\t\t\t\t\t\ticon: 'pi pi-clone',\n\t\t\t\t\t\t\tcommand: () => {\n\t\t\t\t\t\t\t\tconst value = this.field()?.form?.model()?.[this.field()?.key!];\n\t\t\t\t\t\t\t\tthis.clipboard.copy(value);\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t},\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tlabel: '复制项名称【OptionLabel】',\n\t\t\t\t\t\t\ticon: 'pi pi-clone',\n\t\t\t\t\t\t\tcommand: () => {\n\t\t\t\t\t\t\t\tconst value = this.field()?.form?.model()?.[this.field()?.key!];\n\t\t\t\t\t\t\t\tconst options: any[] = this.field()?.treeSelectProps?.options!;\n\t\t\t\t\t\t\t\tconst result = this.findLabelByTreeValue(options, value) || '';\n\t\t\t\t\t\t\t\tthis.clipboard.copy(result);\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t},\n\t\t\t\t\t];\n\t\t\t\t} else {\n\t\t\t\t\tthis.items = [\n\t\t\t\t\t\t...this.commonItems,\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tlabel: '复制值【Value】',\n\t\t\t\t\t\t\ticon: 'pi pi-clone',\n\t\t\t\t\t\t\tcommand: () => {\n\t\t\t\t\t\t\t\tconst value = this.field()?.form?.model()?.[this.field()?.key!];\n\t\t\t\t\t\t\t\tthis.clipboard.copy(value);\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t},\n\t\t\t\t\t];\n\t\t\t\t}\n\t\t\t}\n\t\t});\n\t}\n\n\tfindLabelByTreeValue(options: any[], value: any): string | undefined {\n\t\tfor (const option of options) {\n\t\t\tif (option.key === value) {\n\t\t\t\treturn option.label;\n\t\t\t}\n\t\t\tif (option.children) {\n\t\t\t\tconst foundInChildren = this.findLabelByTreeValue(option.children, value);\n\t\t\t\tif (foundInChildren) return foundInChildren;\n\t\t\t}\n\t\t}\n\t\treturn undefined;\n\t}\n}\n"]}
161
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"context-menu.js","sourceRoot":"","sources":["../../../../../../projects/imm-element-ui/src/lib/form/form-field/context-menu.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,EAAE,YAAY,EAAE,KAAK,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AAElF,OAAO,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAGlD,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;;;AA0B3C,MAAM,OAAO,oBAAoB;IAwBhC,QAAQ;QACP,IAAI,CAAC,UAAU,EAAE,CAAC;IACnB,CAAC;IAED,YAAoB,SAAoB;QAApB,cAAS,GAAT,SAAS,CAAW;QA1BxC,YAAO,GAAG,IAAI,CAAC;QACf,WAAM,GAAG,KAAK,CAAM,EAAE,CAAC,CAAC;QACxB,UAAK,GAAG,KAAK,EAAa,CAAC;QAE3B,gBAAW,GAAe;YACzB;gBACC,KAAK,EAAE,aAAa;gBACpB,IAAI,EAAE,aAAa;gBACnB,OAAO,EAAE,GAAG,EAAE;oBACb,MAAM,KAAK,GAAG,UAAU,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,EAAG,CAAC,CAAC,KAAK,IAAI,EAAE,CAAC;oBAC1D,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;gBAC5B,CAAC;aACD;YACD;gBACC,KAAK,EAAE,WAAW;gBAClB,IAAI,EAAE,aAAa;gBACnB,OAAO,EAAE,GAAG,EAAE;oBACb,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE,EAAE,GAAG,IAAI,EAAE,CAAC,CAAC;gBAC9C,CAAC;aACD;SACD,CAAC;QAOD,IAAI,CAAC,UAAU,EAAE,CAAC;QAClB,MAAM,CAAC,GAAG,EAAE;YACX,IAAI,IAAI,CAAC,KAAK,EAAE,EAAE,CAAC;gBAClB,IAAI,IAAI,CAAC,KAAK,EAAE,EAAE,IAAI,KAAK,QAAQ,EAAE,CAAC;oBACrC,IAAI,CAAC,KAAK,GAAG;wBACZ,GAAG,IAAI,CAAC,WAAW;wBACnB;4BACC,KAAK,EAAE,mBAAmB;4BAC1B,IAAI,EAAE,aAAa;4BACnB,OAAO,EAAE,GAAG,EAAE;gCACb,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,EAAE,EAAE,IAAI,EAAE,KAAK,EAAE,EAAE,CAAC,IAAI,CAAC,KAAK,EAAE,EAAE,GAAI,CAAC,CAAC;gCAChE,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;4BAC5B,CAAC;yBACD;wBACD;4BACC,KAAK,EAAE,oBAAoB;4BAC3B,IAAI,EAAE,aAAa;4BACnB,OAAO,EAAE,GAAG,EAAE;gCACb,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,EAAE,EAAE,IAAI,EAAE,KAAK,EAAE,EAAE,CAAC,IAAI,CAAC,KAAK,EAAE,EAAE,GAAI,CAAC,CAAC;gCAChE,MAAM,WAAW,GAAG,IAAI,CAAC,KAAK,EAAE,EAAE,WAAW,EAAE,WAAW,IAAI,OAAO,CAAC;gCACtE,MAAM,WAAW,GAAG,IAAI,CAAC,KAAK,EAAE,EAAE,WAAW,EAAE,WAAW,IAAI,OAAO,CAAC;gCACtE,MAAM,MAAM,GAAG,IAAI,CAAC,KAAK,EAAE,EAAE,WAAW,EAAE,OAAO,EAAE,IAAI,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,WAAW,CAAC,KAAK,KAAK,CAAC,EAAE,CAAC,WAAW,CAAC,CAAC;gCAC9G,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;4BAC7B,CAAC;yBACD;qBACD,CAAC;gBACH,CAAC;qBAAM,IAAI,IAAI,CAAC,KAAK,EAAE,EAAE,IAAI,KAAK,YAAY,EAAE,CAAC;oBAChD,IAAI,CAAC,KAAK,GAAG;wBACZ,GAAG,IAAI,CAAC,WAAW;wBACnB;4BACC,KAAK,EAAE,mBAAmB;4BAC1B,IAAI,EAAE,aAAa;4BACnB,OAAO,EAAE,GAAG,EAAE;gCACb,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,EAAE,EAAE,IAAI,EAAE,KAAK,EAAE,EAAE,CAAC,IAAI,CAAC,KAAK,EAAE,EAAE,GAAI,CAAC,CAAC;gCAChE,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;4BAC5B,CAAC;yBACD;wBACD;4BACC,KAAK,EAAE,oBAAoB;4BAC3B,IAAI,EAAE,aAAa;4BACnB,OAAO,EAAE,GAAG,EAAE;gCACb,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,EAAE,EAAE,IAAI,EAAE,KAAK,EAAE,EAAE,CAAC,IAAI,CAAC,KAAK,EAAE,EAAE,GAAI,CAAC,CAAC;gCAChE,MAAM,OAAO,GAAU,IAAI,CAAC,KAAK,EAAE,EAAE,eAAe,EAAE,OAAQ,CAAC;gCAC/D,MAAM,MAAM,GAAG,IAAI,CAAC,oBAAoB,CAAC,OAAO,EAAE,KAAK,CAAC,IAAI,EAAE,CAAC;gCAC/D,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;4BAC7B,CAAC;yBACD;qBACD,CAAC;gBACH,CAAC;qBAAM,CAAC;oBACP,IAAI,CAAC,KAAK,GAAG;wBACZ,GAAG,IAAI,CAAC,WAAW;wBACnB;4BACC,KAAK,EAAE,YAAY;4BACnB,IAAI,EAAE,aAAa;4BACnB,OAAO,EAAE,GAAG,EAAE;gCACb,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,EAAE,EAAE,IAAI,EAAE,KAAK,EAAE,EAAE,CAAC,IAAI,CAAC,KAAK,EAAE,EAAE,GAAI,CAAC,CAAC;gCAChE,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;4BAC5B,CAAC;yBACD;qBACD,CAAC;gBACH,CAAC;YACF,CAAC;QACF,CAAC,CAAC,CAAC;IACJ,CAAC;IAED,oBAAoB,CAAC,OAAc,EAAE,KAAU;QAC9C,KAAK,MAAM,MAAM,IAAI,OAAO,EAAE,CAAC;YAC9B,IAAI,MAAM,CAAC,GAAG,KAAK,KAAK,EAAE,CAAC;gBAC1B,OAAO,MAAM,CAAC,KAAK,CAAC;YACrB,CAAC;YACD,IAAI,MAAM,CAAC,QAAQ,EAAE,CAAC;gBACrB,MAAM,eAAe,GAAG,IAAI,CAAC,oBAAoB,CAAC,MAAM,CAAC,QAAQ,EAAE,KAAK,CAAC,CAAC;gBAC1E,IAAI,eAAe;oBAAE,OAAO,eAAe,CAAC;YAC7C,CAAC;QACF,CAAC;QACD,OAAO,SAAS,CAAC;IAClB,CAAC;IAED,UAAU;QACT,IAAI,CAAC,OAAO,GAAG,MAAM,CAAC,UAAU,GAAG,IAAI,CAAC;IACzC,CAAC;+GA7GW,oBAAoB;mGAApB,oBAAoB,meApBtB;;;;;;;;;;;;;;;;;EAiBT,0EAlBS,WAAW;;4FAqBT,oBAAoB;kBAxBhC,SAAS;+BACC,kBAAkB,cAChB,IAAI,WACP,CAAC,WAAW,CAAC,YACZ;;;;;;;;;;;;;;;;;EAiBT;8EAIgB,EAAE;sBAAlB,SAAS;uBAAC,IAAI;gBAuBf,QAAQ;sBADP,YAAY;uBAAC,eAAe,EAAE,CAAC,QAAQ,CAAC","sourcesContent":["import { Component, effect, HostListener, input, ViewChild } from '@angular/core';\nimport { MenuItem } from 'primeng/api';\nimport { ContextMenu } from 'primeng/contextmenu';\nimport { Clipboard } from '@angular/cdk/clipboard';\nimport { FormField } from './form-field';\nimport { fieldUtils } from './field-utils';\n\n@Component({\n\tselector: 'app-context-menu',\n\tstandalone: true,\n\timports: [ContextMenu],\n\ttemplate: `\n\t\t@if (visible) {\n\t\t\t<p-contextMenu\n\t\t\t\t#cm\n\t\t\t\t[target]=\"target()\"\n\t\t\t\t[appendTo]=\"'body'\"\n\t\t\t\t[model]=\"items\">\n\t\t\t\t<ng-template\n\t\t\t\t\t#item\n\t\t\t\t\tlet-item>\n\t\t\t\t\t<div class=\"px-[0.5rem] py-[0.5rem]\">\n\t\t\t\t\t\t<i [class]=\"item.icon\"></i>\n\t\t\t\t\t\t<span class=\"ml-2 cursor-pointer\">{{ item.label }}</span>\n\t\t\t\t\t</div>\n\t\t\t\t</ng-template>\n\t\t\t</p-contextMenu>\n\t\t}\n\t`,\n\tstyles: [``],\n})\nexport class ContextMenuComponent {\n\t@ViewChild('cm') cm?: ContextMenu;\n\tvisible = true;\n\ttarget = input<any>({});\n\tfield = input<FormField>();\n\titems?: MenuItem[];\n\tcommonItems: MenuItem[] = [\n\t\t{\n\t\t\tlabel: '复制标题【Label】',\n\t\t\ticon: 'pi pi-clone',\n\t\t\tcommand: () => {\n\t\t\t\tconst label = fieldUtils.props(this.field()!).label || '';\n\t\t\t\tthis.clipboard.copy(label);\n\t\t\t},\n\t\t},\n\t\t{\n\t\t\tlabel: '复制键名【Key】',\n\t\t\ticon: 'pi pi-clone',\n\t\t\tcommand: () => {\n\t\t\t\tthis.clipboard.copy(this.field()?.key || '');\n\t\t\t},\n\t\t},\n\t];\n\t@HostListener('window:resize', ['$event'])\n\tonResize() {\n\t\tthis.updVisible();\n\t}\n\n\tconstructor(private clipboard: Clipboard) {\n\t\tthis.updVisible();\n\t\teffect(() => {\n\t\t\tif (this.field()) {\n\t\t\t\tif (this.field()?.type === 'select') {\n\t\t\t\t\tthis.items = [\n\t\t\t\t\t\t...this.commonItems,\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tlabel: '复制项值【OptionValue】',\n\t\t\t\t\t\t\ticon: 'pi pi-clone',\n\t\t\t\t\t\t\tcommand: () => {\n\t\t\t\t\t\t\t\tconst value = this.field()?.form?.model()?.[this.field()?.key!];\n\t\t\t\t\t\t\t\tthis.clipboard.copy(value);\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t},\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tlabel: '复制项名称【OptionLabel】',\n\t\t\t\t\t\t\ticon: 'pi pi-clone',\n\t\t\t\t\t\t\tcommand: () => {\n\t\t\t\t\t\t\t\tconst value = this.field()?.form?.model()?.[this.field()?.key!];\n\t\t\t\t\t\t\t\tconst optionValue = this.field()?.selectProps?.optionValue || 'value';\n\t\t\t\t\t\t\t\tconst optionLabel = this.field()?.selectProps?.optionLabel || 'label';\n\t\t\t\t\t\t\t\tconst result = this.field()?.selectProps?.options?.find((item) => item[optionValue] === value)?.[optionLabel];\n\t\t\t\t\t\t\t\tthis.clipboard.copy(result);\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t},\n\t\t\t\t\t];\n\t\t\t\t} else if (this.field()?.type === 'treeselect') {\n\t\t\t\t\tthis.items = [\n\t\t\t\t\t\t...this.commonItems,\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tlabel: '复制项值【OptionValue】',\n\t\t\t\t\t\t\ticon: 'pi pi-clone',\n\t\t\t\t\t\t\tcommand: () => {\n\t\t\t\t\t\t\t\tconst value = this.field()?.form?.model()?.[this.field()?.key!];\n\t\t\t\t\t\t\t\tthis.clipboard.copy(value);\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t},\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tlabel: '复制项名称【OptionLabel】',\n\t\t\t\t\t\t\ticon: 'pi pi-clone',\n\t\t\t\t\t\t\tcommand: () => {\n\t\t\t\t\t\t\t\tconst value = this.field()?.form?.model()?.[this.field()?.key!];\n\t\t\t\t\t\t\t\tconst options: any[] = this.field()?.treeSelectProps?.options!;\n\t\t\t\t\t\t\t\tconst result = this.findLabelByTreeValue(options, value) || '';\n\t\t\t\t\t\t\t\tthis.clipboard.copy(result);\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t},\n\t\t\t\t\t];\n\t\t\t\t} else {\n\t\t\t\t\tthis.items = [\n\t\t\t\t\t\t...this.commonItems,\n\t\t\t\t\t\t{\n\t\t\t\t\t\t\tlabel: '复制值【Value】',\n\t\t\t\t\t\t\ticon: 'pi pi-clone',\n\t\t\t\t\t\t\tcommand: () => {\n\t\t\t\t\t\t\t\tconst value = this.field()?.form?.model()?.[this.field()?.key!];\n\t\t\t\t\t\t\t\tthis.clipboard.copy(value);\n\t\t\t\t\t\t\t},\n\t\t\t\t\t\t},\n\t\t\t\t\t];\n\t\t\t\t}\n\t\t\t}\n\t\t});\n\t}\n\n\tfindLabelByTreeValue(options: any[], value: any): string | undefined {\n\t\tfor (const option of options) {\n\t\t\tif (option.key === value) {\n\t\t\t\treturn option.label;\n\t\t\t}\n\t\t\tif (option.children) {\n\t\t\t\tconst foundInChildren = this.findLabelByTreeValue(option.children, value);\n\t\t\t\tif (foundInChildren) return foundInChildren;\n\t\t\t}\n\t\t}\n\t\treturn undefined;\n\t}\n\n\tupdVisible() {\n\t\tthis.visible = window.innerWidth > 1024;\n\t}\n}\n"]}
@@ -48,8 +48,16 @@ export class LabelDirective {
48
48
  extra.preContextMenu = this.contextMenu();
49
49
  }, 100);
50
50
  }
51
+ onTouchStart(event) {
52
+ event.preventDefault();
53
+ event.stopPropagation();
54
+ }
55
+ onTouchend(event) {
56
+ event.preventDefault();
57
+ event.stopPropagation();
58
+ }
51
59
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: LabelDirective, deps: [{ token: i1.ActionService }], target: i0.ɵɵFactoryTarget.Directive }); }
52
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "18.2.13", type: LabelDirective, isStandalone: true, selector: "[fieldLabel], [fieldLabel][field], [fieldLabel][contextMenu]", inputs: { field: { classPropertyName: "field", publicName: "field", isSignal: true, isRequired: false, transformFunction: null }, contextMenu: { classPropertyName: "contextMenu", publicName: "contextMenu", isSignal: true, isRequired: false, transformFunction: null } }, host: { listeners: { "mouseenter": "onMouseEnter()", "mouseleave": "onMouseLeave()", "click": "onClick()", "dblclick": "onDoubleClick()", "contextmenu": "onRightClick($event)" } }, viewQueries: [{ propertyName: "container", first: true, predicate: ["container"], descendants: true, read: ViewContainerRef }], ngImport: i0 }); }
60
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "18.2.13", type: LabelDirective, isStandalone: true, selector: "[fieldLabel], [fieldLabel][field], [fieldLabel][contextMenu]", inputs: { field: { classPropertyName: "field", publicName: "field", isSignal: true, isRequired: false, transformFunction: null }, contextMenu: { classPropertyName: "contextMenu", publicName: "contextMenu", isSignal: true, isRequired: false, transformFunction: null } }, host: { listeners: { "mouseenter": "onMouseEnter()", "mouseleave": "onMouseLeave()", "click": "onClick()", "dblclick": "onDoubleClick()", "contextmenu": "onRightClick($event)", "touchstart": "onTouchStart($event)", "touchend": "onTouchend($event)" } }, viewQueries: [{ propertyName: "container", first: true, predicate: ["container"], descendants: true, read: ViewContainerRef }], ngImport: i0 }); }
53
61
  }
54
62
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: LabelDirective, decorators: [{
55
63
  type: Directive,
@@ -75,5 +83,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
75
83
  }], onRightClick: [{
76
84
  type: HostListener,
77
85
  args: ['contextmenu', ['$event']]
86
+ }], onTouchStart: [{
87
+ type: HostListener,
88
+ args: ['touchstart', ['$event']]
89
+ }], onTouchend: [{
90
+ type: HostListener,
91
+ args: ['touchend', ['$event']]
78
92
  }] } });
79
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGFiZWwuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvaW1tLWVsZW1lbnQtdWkvc3JjL2xpYi9mb3JtL2Zvcm0tZmllbGQvbGFiZWwuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsWUFBWSxFQUFFLEtBQUssRUFBVSxTQUFTLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxlQUFlLENBQUM7OztBQVFwRyxNQUFNLE9BQU8sY0FBYztJQUkxQixZQUFvQixNQUFxQjtRQUFyQixXQUFNLEdBQU4sTUFBTSxDQUFlO1FBRnpDLFVBQUssR0FBRyxLQUFLLEVBQWEsQ0FBQztRQUMzQixnQkFBVyxHQUFHLEtBQUssRUFBTyxDQUFDO0lBQ2lCLENBQUM7SUFFakIsWUFBWTtRQUN2QyxJQUFJLENBQUMsSUFBSSxDQUFDLEtBQUssRUFBRSxFQUFFLGdCQUFnQjtZQUFFLE9BQU87UUFDNUMsSUFBSSxJQUFJLENBQUMsS0FBSyxFQUFFLEVBQUUsWUFBWSxFQUFFLFFBQVE7WUFBRSxPQUFPO1FBQ2pELElBQUksQ0FBQyxNQUFNLENBQUMsbUJBQW1CLENBQUMsSUFBSSxDQUFDLEtBQUssRUFBRyxDQUFDLElBQUssRUFBRSxZQUFZLENBQUMsQ0FBQztJQUNwRSxDQUFDO0lBRTJCLFlBQVk7UUFDdkMsSUFBSSxDQUFDLElBQUksQ0FBQyxLQUFLLEVBQUUsRUFBRSxnQkFBZ0I7WUFBRSxPQUFPO1FBQzVDLElBQUksSUFBSSxDQUFDLEtBQUssRUFBRSxFQUFFLFlBQVksRUFBRSxRQUFRO1lBQUUsT0FBTztRQUNqRCxJQUFJLENBQUMsS0FBSyxFQUFFLEVBQUUsZ0JBQWdCLElBQUksSUFBSSxDQUFDLE1BQU0sQ0FBQyxtQkFBbUIsQ0FBQyxJQUFJLENBQUMsS0FBSyxFQUFHLENBQUMsSUFBSyxFQUFFLFlBQVksQ0FBQyxDQUFDO0lBQ3RHLENBQUM7SUFFc0IsT0FBTztRQUM3QixJQUFJLElBQUksQ0FBQyxLQUFLLEVBQUUsRUFBRSxnQkFBZ0IsRUFBRSxDQUFDO1lBQ3BDLElBQUksSUFBSSxDQUFDLEtBQUssRUFBRSxFQUFFLFlBQVksRUFBRSxRQUFRO2dCQUFFLE9BQU87WUFDakQsSUFBSSxDQUFDLE1BQU0sQ0FBQyxtQkFBbUIsQ0FBQyxJQUFJLENBQUMsS0FBSyxFQUFHLENBQUMsSUFBSyxFQUFFLE9BQU8sQ0FBQyxDQUFDO1FBQy9ELENBQUM7YUFBTSxDQUFDO1lBQ1AsSUFBSSxDQUFDLE1BQU0sQ0FBQyxjQUFjLENBQUMsSUFBSSxDQUFDLEtBQUssRUFBRyxDQUFDLENBQUM7UUFDM0MsQ0FBQztJQUNGLENBQUM7SUFFeUIsYUFBYTtRQUN0QyxJQUFJLENBQUMsV0FBVyxFQUFFLFVBQVUsRUFBRSxZQUFZLENBQUMsQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLEtBQUssRUFBRSxFQUFFLElBQUssQ0FBQyxFQUFFLENBQUM7WUFDM0UsSUFBSSxDQUFDLE1BQU0sQ0FBQyxtQkFBbUIsQ0FBQyxJQUFJLENBQUMsS0FBSyxFQUFHLENBQUMsSUFBSyxFQUFFLFVBQVUsQ0FBQyxDQUFDO1FBQ2xFLENBQUM7SUFDRixDQUFDO0lBR0QsWUFBWSxDQUFDLEtBQWlCO1FBQzdCLEtBQUssQ0FBQyxjQUFjLEVBQUUsQ0FBQztRQUN2QixLQUFLLENBQUMsZUFBZSxFQUFFLENBQUM7UUFDeEIsTUFBTSxLQUFLLEdBQVEsSUFBSSxDQUFDLEtBQUssRUFBRSxFQUFFLElBQUksRUFBRSxLQUFLLENBQUM7UUFDN0MsSUFBSSxLQUFLLENBQUMsY0FBYyxFQUFFLENBQUM7WUFDMUIsS0FBSyxDQUFDLGNBQWMsRUFBRSxFQUFFLEVBQUUsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQ3ZDLENBQUM7UUFDRCxVQUFVLENBQUMsR0FBRyxFQUFFO1lBQ2YsSUFBSSxDQUFDLFdBQVcsRUFBRSxFQUFFLEVBQUUsRUFBRSxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7WUFDcEMsS0FBSyxDQUFDLGNBQWMsR0FBRyxJQUFJLENBQUMsV0FBVyxFQUFFLENBQUM7UUFDM0MsQ0FBQyxFQUFFLEdBQUcsQ0FBQyxDQUFDO0lBQ1QsQ0FBQzsrR0E3Q1csY0FBYzttR0FBZCxjQUFjLDhvQkFDTSxnQkFBZ0I7OzRGQURwQyxjQUFjO2tCQUoxQixTQUFTO21CQUFDO29CQUNWLFFBQVEsRUFBRSw4REFBOEQ7b0JBQ3hFLFVBQVUsRUFBRSxJQUFJO2lCQUNoQjtrRkFFb0QsU0FBUztzQkFBNUQsU0FBUzt1QkFBQyxXQUFXLEVBQUUsRUFBRSxJQUFJLEVBQUUsZ0JBQWdCLEVBQUU7Z0JBS3RCLFlBQVk7c0JBQXZDLFlBQVk7dUJBQUMsWUFBWTtnQkFNRSxZQUFZO3NCQUF2QyxZQUFZO3VCQUFDLFlBQVk7Z0JBTUgsT0FBTztzQkFBN0IsWUFBWTt1QkFBQyxPQUFPO2dCQVNLLGFBQWE7c0JBQXRDLFlBQVk7dUJBQUMsVUFBVTtnQkFPeEIsWUFBWTtzQkFEWCxZQUFZO3VCQUFDLGFBQWEsRUFBRSxDQUFDLFFBQVEsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpcmVjdGl2ZSwgSG9zdExpc3RlbmVyLCBpbnB1dCwgZWZmZWN0LCBWaWV3Q2hpbGQsIFZpZXdDb250YWluZXJSZWYgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgQWN0aW9uU2VydmljZSB9IGZyb20gJy4uLy4uL3NlcnZpY2UvYWN0aW9uLnNlcnZpY2UnO1xyXG5pbXBvcnQgeyBGb3JtRmllbGQgfSBmcm9tICcuL2Zvcm0tZmllbGQnO1xyXG5cclxuQERpcmVjdGl2ZSh7XHJcblx0c2VsZWN0b3I6ICdbZmllbGRMYWJlbF0sIFtmaWVsZExhYmVsXVtmaWVsZF0sIFtmaWVsZExhYmVsXVtjb250ZXh0TWVudV0nLFxyXG5cdHN0YW5kYWxvbmU6IHRydWUsXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBMYWJlbERpcmVjdGl2ZSB7XHJcblx0QFZpZXdDaGlsZCgnY29udGFpbmVyJywgeyByZWFkOiBWaWV3Q29udGFpbmVyUmVmIH0pIGNvbnRhaW5lcj86IFZpZXdDb250YWluZXJSZWY7XHJcblx0ZmllbGQgPSBpbnB1dDxGb3JtRmllbGQ+KCk7XHJcblx0Y29udGV4dE1lbnUgPSBpbnB1dDxhbnk+KCk7XHJcblx0Y29uc3RydWN0b3IocHJpdmF0ZSBhY3Rpb246IEFjdGlvblNlcnZpY2UpIHt9XHJcblxyXG5cdEBIb3N0TGlzdGVuZXIoJ21vdXNlZW50ZXInKSBvbk1vdXNlRW50ZXIoKSB7XHJcblx0XHRpZiAoIXRoaXMuZmllbGQoKT8uaW50ZXJhY3RpdmVMYWJlbCkgcmV0dXJuO1xyXG5cdFx0aWYgKHRoaXMuZmllbGQoKT8uZmllbGRDb250cm9sPy5kaXNhYmxlZCkgcmV0dXJuO1xyXG5cdFx0dGhpcy5hY3Rpb24uc2V0RmllbGRMYWJlbEFjdGlvbih0aGlzLmZpZWxkKCkhLnV1aWQhLCAnbW91c2VlbnRlcicpO1xyXG5cdH1cclxuXHJcblx0QEhvc3RMaXN0ZW5lcignbW91c2VsZWF2ZScpIG9uTW91c2VMZWF2ZSgpIHtcclxuXHRcdGlmICghdGhpcy5maWVsZCgpPy5pbnRlcmFjdGl2ZUxhYmVsKSByZXR1cm47XHJcblx0XHRpZiAodGhpcy5maWVsZCgpPy5maWVsZENvbnRyb2w/LmRpc2FibGVkKSByZXR1cm47XHJcblx0XHR0aGlzLmZpZWxkKCk/LmludGVyYWN0aXZlTGFiZWwgJiYgdGhpcy5hY3Rpb24uc2V0RmllbGRMYWJlbEFjdGlvbih0aGlzLmZpZWxkKCkhLnV1aWQhLCAnbW91c2VsZWF2ZScpO1xyXG5cdH1cclxuXHJcblx0QEhvc3RMaXN0ZW5lcignY2xpY2snKSBvbkNsaWNrKCkge1xyXG5cdFx0aWYgKHRoaXMuZmllbGQoKT8uaW50ZXJhY3RpdmVMYWJlbCkge1xyXG5cdFx0XHRpZiAodGhpcy5maWVsZCgpPy5maWVsZENvbnRyb2w/LmRpc2FibGVkKSByZXR1cm47XHJcblx0XHRcdHRoaXMuYWN0aW9uLnNldEZpZWxkTGFiZWxBY3Rpb24odGhpcy5maWVsZCgpIS51dWlkISwgJ2NsaWNrJyk7XHJcblx0XHR9IGVsc2Uge1xyXG5cdFx0XHR0aGlzLmFjdGlvbi5zZXRGaWVsZEFjdGlvbih0aGlzLmZpZWxkKCkhKTtcclxuXHRcdH1cclxuXHR9XHJcblxyXG5cdEBIb3N0TGlzdGVuZXIoJ2RibGNsaWNrJykgb25Eb3VibGVDbGljaygpIHtcclxuXHRcdGlmIChbJ2lucHV0dGV4dCcsICd0ZXh0YXJlYScsICdjb2RlbWlycm9yJ10uaW5jbHVkZXModGhpcy5maWVsZCgpPy50eXBlISkpIHtcclxuXHRcdFx0dGhpcy5hY3Rpb24uc2V0RmllbGRMYWJlbEFjdGlvbih0aGlzLmZpZWxkKCkhLnV1aWQhLCAnZGJsY2xpY2snKTtcclxuXHRcdH1cclxuXHR9XHJcblxyXG5cdEBIb3N0TGlzdGVuZXIoJ2NvbnRleHRtZW51JywgWyckZXZlbnQnXSlcclxuXHRvblJpZ2h0Q2xpY2soZXZlbnQ6IE1vdXNlRXZlbnQpOiB2b2lkIHtcclxuXHRcdGV2ZW50LnByZXZlbnREZWZhdWx0KCk7XHJcblx0XHRldmVudC5zdG9wUHJvcGFnYXRpb24oKTtcclxuXHRcdGNvbnN0IGV4dHJhOiBhbnkgPSB0aGlzLmZpZWxkKCk/LmZvcm0/LmV4dHJhO1xyXG5cdFx0aWYgKGV4dHJhLnByZUNvbnRleHRNZW51KSB7XHJcblx0XHRcdGV4dHJhLnByZUNvbnRleHRNZW51Py5jbT8uaGlkZShldmVudCk7XHJcblx0XHR9XHJcblx0XHRzZXRUaW1lb3V0KCgpID0+IHtcclxuXHRcdFx0dGhpcy5jb250ZXh0TWVudSgpPy5jbT8uc2hvdyhldmVudCk7XHJcblx0XHRcdGV4dHJhLnByZUNvbnRleHRNZW51ID0gdGhpcy5jb250ZXh0TWVudSgpO1xyXG5cdFx0fSwgMTAwKTtcclxuXHR9XHJcbn1cclxuIl19
93
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGFiZWwuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvaW1tLWVsZW1lbnQtdWkvc3JjL2xpYi9mb3JtL2Zvcm0tZmllbGQvbGFiZWwuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsWUFBWSxFQUFFLEtBQUssRUFBVSxTQUFTLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxlQUFlLENBQUM7OztBQVFwRyxNQUFNLE9BQU8sY0FBYztJQUkxQixZQUFvQixNQUFxQjtRQUFyQixXQUFNLEdBQU4sTUFBTSxDQUFlO1FBRnpDLFVBQUssR0FBRyxLQUFLLEVBQWEsQ0FBQztRQUMzQixnQkFBVyxHQUFHLEtBQUssRUFBTyxDQUFDO0lBQ2lCLENBQUM7SUFFakIsWUFBWTtRQUN2QyxJQUFJLENBQUMsSUFBSSxDQUFDLEtBQUssRUFBRSxFQUFFLGdCQUFnQjtZQUFFLE9BQU87UUFDNUMsSUFBSSxJQUFJLENBQUMsS0FBSyxFQUFFLEVBQUUsWUFBWSxFQUFFLFFBQVE7WUFBRSxPQUFPO1FBQ2pELElBQUksQ0FBQyxNQUFNLENBQUMsbUJBQW1CLENBQUMsSUFBSSxDQUFDLEtBQUssRUFBRyxDQUFDLElBQUssRUFBRSxZQUFZLENBQUMsQ0FBQztJQUNwRSxDQUFDO0lBRTJCLFlBQVk7UUFDdkMsSUFBSSxDQUFDLElBQUksQ0FBQyxLQUFLLEVBQUUsRUFBRSxnQkFBZ0I7WUFBRSxPQUFPO1FBQzVDLElBQUksSUFBSSxDQUFDLEtBQUssRUFBRSxFQUFFLFlBQVksRUFBRSxRQUFRO1lBQUUsT0FBTztRQUNqRCxJQUFJLENBQUMsS0FBSyxFQUFFLEVBQUUsZ0JBQWdCLElBQUksSUFBSSxDQUFDLE1BQU0sQ0FBQyxtQkFBbUIsQ0FBQyxJQUFJLENBQUMsS0FBSyxFQUFHLENBQUMsSUFBSyxFQUFFLFlBQVksQ0FBQyxDQUFDO0lBQ3RHLENBQUM7SUFFc0IsT0FBTztRQUM3QixJQUFJLElBQUksQ0FBQyxLQUFLLEVBQUUsRUFBRSxnQkFBZ0IsRUFBRSxDQUFDO1lBQ3BDLElBQUksSUFBSSxDQUFDLEtBQUssRUFBRSxFQUFFLFlBQVksRUFBRSxRQUFRO2dCQUFFLE9BQU87WUFDakQsSUFBSSxDQUFDLE1BQU0sQ0FBQyxtQkFBbUIsQ0FBQyxJQUFJLENBQUMsS0FBSyxFQUFHLENBQUMsSUFBSyxFQUFFLE9BQU8sQ0FBQyxDQUFDO1FBQy9ELENBQUM7YUFBTSxDQUFDO1lBQ1AsSUFBSSxDQUFDLE1BQU0sQ0FBQyxjQUFjLENBQUMsSUFBSSxDQUFDLEtBQUssRUFBRyxDQUFDLENBQUM7UUFDM0MsQ0FBQztJQUNGLENBQUM7SUFFeUIsYUFBYTtRQUN0QyxJQUFJLENBQUMsV0FBVyxFQUFFLFVBQVUsRUFBRSxZQUFZLENBQUMsQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLEtBQUssRUFBRSxFQUFFLElBQUssQ0FBQyxFQUFFLENBQUM7WUFDM0UsSUFBSSxDQUFDLE1BQU0sQ0FBQyxtQkFBbUIsQ0FBQyxJQUFJLENBQUMsS0FBSyxFQUFHLENBQUMsSUFBSyxFQUFFLFVBQVUsQ0FBQyxDQUFDO1FBQ2xFLENBQUM7SUFDRixDQUFDO0lBR0QsWUFBWSxDQUFDLEtBQWlCO1FBQzdCLEtBQUssQ0FBQyxjQUFjLEVBQUUsQ0FBQztRQUN2QixLQUFLLENBQUMsZUFBZSxFQUFFLENBQUM7UUFDeEIsTUFBTSxLQUFLLEdBQVEsSUFBSSxDQUFDLEtBQUssRUFBRSxFQUFFLElBQUksRUFBRSxLQUFLLENBQUM7UUFDN0MsSUFBSSxLQUFLLENBQUMsY0FBYyxFQUFFLENBQUM7WUFDMUIsS0FBSyxDQUFDLGNBQWMsRUFBRSxFQUFFLEVBQUUsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQ3ZDLENBQUM7UUFDRCxVQUFVLENBQUMsR0FBRyxFQUFFO1lBQ2YsSUFBSSxDQUFDLFdBQVcsRUFBRSxFQUFFLEVBQUUsRUFBRSxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7WUFDcEMsS0FBSyxDQUFDLGNBQWMsR0FBRyxJQUFJLENBQUMsV0FBVyxFQUFFLENBQUM7UUFDM0MsQ0FBQyxFQUFFLEdBQUcsQ0FBQyxDQUFDO0lBQ1QsQ0FBQztJQUdELFlBQVksQ0FBQyxLQUFpQjtRQUM3QixLQUFLLENBQUMsY0FBYyxFQUFFLENBQUM7UUFDdkIsS0FBSyxDQUFDLGVBQWUsRUFBRSxDQUFDO0lBQ3pCLENBQUM7SUFHRCxVQUFVLENBQUMsS0FBaUI7UUFDM0IsS0FBSyxDQUFDLGNBQWMsRUFBRSxDQUFDO1FBQ3ZCLEtBQUssQ0FBQyxlQUFlLEVBQUUsQ0FBQztJQUN6QixDQUFDOytHQXpEVyxjQUFjO21HQUFkLGNBQWMsc3RCQUNNLGdCQUFnQjs7NEZBRHBDLGNBQWM7a0JBSjFCLFNBQVM7bUJBQUM7b0JBQ1YsUUFBUSxFQUFFLDhEQUE4RDtvQkFDeEUsVUFBVSxFQUFFLElBQUk7aUJBQ2hCO2tGQUVvRCxTQUFTO3NCQUE1RCxTQUFTO3VCQUFDLFdBQVcsRUFBRSxFQUFFLElBQUksRUFBRSxnQkFBZ0IsRUFBRTtnQkFLdEIsWUFBWTtzQkFBdkMsWUFBWTt1QkFBQyxZQUFZO2dCQU1FLFlBQVk7c0JBQXZDLFlBQVk7dUJBQUMsWUFBWTtnQkFNSCxPQUFPO3NCQUE3QixZQUFZO3VCQUFDLE9BQU87Z0JBU0ssYUFBYTtzQkFBdEMsWUFBWTt1QkFBQyxVQUFVO2dCQU94QixZQUFZO3NCQURYLFlBQVk7dUJBQUMsYUFBYSxFQUFFLENBQUMsUUFBUSxDQUFDO2dCQWV2QyxZQUFZO3NCQURYLFlBQVk7dUJBQUMsWUFBWSxFQUFFLENBQUMsUUFBUSxDQUFDO2dCQU90QyxVQUFVO3NCQURULFlBQVk7dUJBQUMsVUFBVSxFQUFFLENBQUMsUUFBUSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlLCBIb3N0TGlzdGVuZXIsIGlucHV0LCBlZmZlY3QsIFZpZXdDaGlsZCwgVmlld0NvbnRhaW5lclJlZiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQWN0aW9uU2VydmljZSB9IGZyb20gJy4uLy4uL3NlcnZpY2UvYWN0aW9uLnNlcnZpY2UnO1xuaW1wb3J0IHsgRm9ybUZpZWxkIH0gZnJvbSAnLi9mb3JtLWZpZWxkJztcblxuQERpcmVjdGl2ZSh7XG5cdHNlbGVjdG9yOiAnW2ZpZWxkTGFiZWxdLCBbZmllbGRMYWJlbF1bZmllbGRdLCBbZmllbGRMYWJlbF1bY29udGV4dE1lbnVdJyxcblx0c3RhbmRhbG9uZTogdHJ1ZSxcbn0pXG5leHBvcnQgY2xhc3MgTGFiZWxEaXJlY3RpdmUge1xuXHRAVmlld0NoaWxkKCdjb250YWluZXInLCB7IHJlYWQ6IFZpZXdDb250YWluZXJSZWYgfSkgY29udGFpbmVyPzogVmlld0NvbnRhaW5lclJlZjtcblx0ZmllbGQgPSBpbnB1dDxGb3JtRmllbGQ+KCk7XG5cdGNvbnRleHRNZW51ID0gaW5wdXQ8YW55PigpO1xuXHRjb25zdHJ1Y3Rvcihwcml2YXRlIGFjdGlvbjogQWN0aW9uU2VydmljZSkge31cblxuXHRASG9zdExpc3RlbmVyKCdtb3VzZWVudGVyJykgb25Nb3VzZUVudGVyKCkge1xuXHRcdGlmICghdGhpcy5maWVsZCgpPy5pbnRlcmFjdGl2ZUxhYmVsKSByZXR1cm47XG5cdFx0aWYgKHRoaXMuZmllbGQoKT8uZmllbGRDb250cm9sPy5kaXNhYmxlZCkgcmV0dXJuO1xuXHRcdHRoaXMuYWN0aW9uLnNldEZpZWxkTGFiZWxBY3Rpb24odGhpcy5maWVsZCgpIS51dWlkISwgJ21vdXNlZW50ZXInKTtcblx0fVxuXG5cdEBIb3N0TGlzdGVuZXIoJ21vdXNlbGVhdmUnKSBvbk1vdXNlTGVhdmUoKSB7XG5cdFx0aWYgKCF0aGlzLmZpZWxkKCk/LmludGVyYWN0aXZlTGFiZWwpIHJldHVybjtcblx0XHRpZiAodGhpcy5maWVsZCgpPy5maWVsZENvbnRyb2w/LmRpc2FibGVkKSByZXR1cm47XG5cdFx0dGhpcy5maWVsZCgpPy5pbnRlcmFjdGl2ZUxhYmVsICYmIHRoaXMuYWN0aW9uLnNldEZpZWxkTGFiZWxBY3Rpb24odGhpcy5maWVsZCgpIS51dWlkISwgJ21vdXNlbGVhdmUnKTtcblx0fVxuXG5cdEBIb3N0TGlzdGVuZXIoJ2NsaWNrJykgb25DbGljaygpIHtcblx0XHRpZiAodGhpcy5maWVsZCgpPy5pbnRlcmFjdGl2ZUxhYmVsKSB7XG5cdFx0XHRpZiAodGhpcy5maWVsZCgpPy5maWVsZENvbnRyb2w/LmRpc2FibGVkKSByZXR1cm47XG5cdFx0XHR0aGlzLmFjdGlvbi5zZXRGaWVsZExhYmVsQWN0aW9uKHRoaXMuZmllbGQoKSEudXVpZCEsICdjbGljaycpO1xuXHRcdH0gZWxzZSB7XG5cdFx0XHR0aGlzLmFjdGlvbi5zZXRGaWVsZEFjdGlvbih0aGlzLmZpZWxkKCkhKTtcblx0XHR9XG5cdH1cblxuXHRASG9zdExpc3RlbmVyKCdkYmxjbGljaycpIG9uRG91YmxlQ2xpY2soKSB7XG5cdFx0aWYgKFsnaW5wdXR0ZXh0JywgJ3RleHRhcmVhJywgJ2NvZGVtaXJyb3InXS5pbmNsdWRlcyh0aGlzLmZpZWxkKCk/LnR5cGUhKSkge1xuXHRcdFx0dGhpcy5hY3Rpb24uc2V0RmllbGRMYWJlbEFjdGlvbih0aGlzLmZpZWxkKCkhLnV1aWQhLCAnZGJsY2xpY2snKTtcblx0XHR9XG5cdH1cblxuXHRASG9zdExpc3RlbmVyKCdjb250ZXh0bWVudScsIFsnJGV2ZW50J10pXG5cdG9uUmlnaHRDbGljayhldmVudDogTW91c2VFdmVudCk6IHZvaWQge1xuXHRcdGV2ZW50LnByZXZlbnREZWZhdWx0KCk7XG5cdFx0ZXZlbnQuc3RvcFByb3BhZ2F0aW9uKCk7XG5cdFx0Y29uc3QgZXh0cmE6IGFueSA9IHRoaXMuZmllbGQoKT8uZm9ybT8uZXh0cmE7XG5cdFx0aWYgKGV4dHJhLnByZUNvbnRleHRNZW51KSB7XG5cdFx0XHRleHRyYS5wcmVDb250ZXh0TWVudT8uY20/LmhpZGUoZXZlbnQpO1xuXHRcdH1cblx0XHRzZXRUaW1lb3V0KCgpID0+IHtcblx0XHRcdHRoaXMuY29udGV4dE1lbnUoKT8uY20/LnNob3coZXZlbnQpO1xuXHRcdFx0ZXh0cmEucHJlQ29udGV4dE1lbnUgPSB0aGlzLmNvbnRleHRNZW51KCk7XG5cdFx0fSwgMTAwKTtcblx0fVxuXG5cdEBIb3N0TGlzdGVuZXIoJ3RvdWNoc3RhcnQnLCBbJyRldmVudCddKVxuXHRvblRvdWNoU3RhcnQoZXZlbnQ6IFRvdWNoRXZlbnQpIHtcblx0XHRldmVudC5wcmV2ZW50RGVmYXVsdCgpO1xuXHRcdGV2ZW50LnN0b3BQcm9wYWdhdGlvbigpO1xuXHR9XG5cblx0QEhvc3RMaXN0ZW5lcigndG91Y2hlbmQnLCBbJyRldmVudCddKVxuXHRvblRvdWNoZW5kKGV2ZW50OiBUb3VjaEV2ZW50KTogdm9pZCB7XG5cdFx0ZXZlbnQucHJldmVudERlZmF1bHQoKTtcblx0XHRldmVudC5zdG9wUHJvcGFnYXRpb24oKTtcblx0fVxufVxuIl19
@@ -63,9 +63,7 @@ export class ImageComponent {
63
63
  }
64
64
  uploadHandler(field, event, fu) {
65
65
  this.uploadImage(event.files[0]).subscribe((response) => {
66
- console.log('response.body----', response.body);
67
66
  this.imageList?.push(response.body.fid);
68
- console.log('this.imageList----', this.imageList);
69
67
  this.field()?.fieldControl?.setValue(this.imageList);
70
68
  });
71
69
  }
@@ -325,4 +323,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
325
323
  type: ViewChild,
326
324
  args: ['imageComp', { read: ElementRef, static: false }]
327
325
  }] } });
328
- //# 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\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"]}
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":"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;;;;;AAoLpD,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,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;YACxC,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;+GA3GW,cAAc;mGAAd,cAAc,gSACM,UAAU,6BA5GhC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;iBAwGM,i0MAzGN,UAAU,g5BAAE,YAAY,kbAAE,KAAK,qWAAE,mBAAmB;;4FA4GlD,cAAc;kBAvJ1B,SAAS;+BACC,YAAY,cACV,IAAI,WAyCP,CAAC,UAAU,EAAE,YAAY,EAAE,KAAK,EAAE,mBAAmB,CAAC,YACrD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;iBAwGM;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\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"]}