imm-element-ui 1.1.1 → 1.1.2

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.
@@ -178,14 +178,16 @@ export class ImageComponent {
178
178
  <div class="flex gap-2 mt-2">
179
179
  @for (image of imageList; track image; let index = $index) {
180
180
  <div class="border">
181
- <div class="flex flex-row-reverse">
182
- <p-button
183
- icon="pi pi-times"
184
- severity="danger"
185
- size="small"
186
- (onClick)="deleteHandler(image, index)"
187
- [text]="true" />
188
- </div>
181
+ @if (!field()?.fieldControl?.disabled) {
182
+ <div class="flex flex-row-reverse">
183
+ <p-button
184
+ icon="pi pi-times"
185
+ severity="danger"
186
+ size="small"
187
+ (onClick)="deleteHandler(image, index)"
188
+ [text]="true" />
189
+ </div>
190
+ }
189
191
  <p-image
190
192
  [src]="'https://hrimage.myfoodiepet.com//' + image"
191
193
  [preview]="true"
@@ -284,14 +286,16 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
284
286
  <div class="flex gap-2 mt-2">
285
287
  @for (image of imageList; track image; let index = $index) {
286
288
  <div class="border">
287
- <div class="flex flex-row-reverse">
288
- <p-button
289
- icon="pi pi-times"
290
- severity="danger"
291
- size="small"
292
- (onClick)="deleteHandler(image, index)"
293
- [text]="true" />
294
- </div>
289
+ @if (!field()?.fieldControl?.disabled) {
290
+ <div class="flex flex-row-reverse">
291
+ <p-button
292
+ icon="pi pi-times"
293
+ severity="danger"
294
+ size="small"
295
+ (onClick)="deleteHandler(image, index)"
296
+ [text]="true" />
297
+ </div>
298
+ }
295
299
  <p-image
296
300
  [src]="'https://hrimage.myfoodiepet.com//' + image"
297
301
  [preview]="true"
@@ -321,4 +325,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
321
325
  type: ViewChild,
322
326
  args: ['imageComp', { read: ElementRef, static: false }]
323
327
  }] } });
324
- //# 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<div class=\"flex flex-row-reverse\">\n\t\t\t\t\t\t\t\t\t<p-button\n\t\t\t\t\t\t\t\t\t\ticon=\"pi pi-times\"\n\t\t\t\t\t\t\t\t\t\tseverity=\"danger\"\n\t\t\t\t\t\t\t\t\t\tsize=\"small\"\n\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[text]=\"true\" />\n\t\t\t\t\t\t\t\t</div>\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"]}
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"]}
@@ -29,34 +29,34 @@ export class ChipRenderer {
29
29
  agInit(params) {
30
30
  const options = params.options;
31
31
  const item = options?.find((item) => item.value === params.value);
32
- this.label = item.label || '';
33
- this.color = item.chip ? ColorMap[item.chip] : '';
32
+ this.label = item?.label || '';
33
+ this.color = item?.chip ? ColorMap[item.chip] : '';
34
34
  }
35
35
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ChipRenderer, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
36
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: ChipRenderer, isStandalone: true, selector: "ng-component", providers: [AsyncPipe], ngImport: i0, template: `
37
- @if (color) {
38
- <span
39
- class="cell-chip"
40
- [style]="{ background: color }"
41
- >{{ label }}</span
42
- >
43
- } @else {
44
- <span>{{ label }}</span>
45
- }
36
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: ChipRenderer, isStandalone: true, selector: "ng-component", providers: [AsyncPipe], ngImport: i0, template: `
37
+ @if (color) {
38
+ <span
39
+ class="cell-chip"
40
+ [style]="{ background: color }"
41
+ >{{ label }}</span
42
+ >
43
+ } @else {
44
+ <span>{{ label }}</span>
45
+ }
46
46
  `, isInline: true, styles: [".cell-chip{padding:2px 5px;color:#fff;border-radius:2px;font-size:12px}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }] }); }
47
47
  }
48
48
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ChipRenderer, decorators: [{
49
49
  type: Component,
50
- args: [{ standalone: true, imports: [CommonModule], providers: [AsyncPipe], template: `
51
- @if (color) {
52
- <span
53
- class="cell-chip"
54
- [style]="{ background: color }"
55
- >{{ label }}</span
56
- >
57
- } @else {
58
- <span>{{ label }}</span>
59
- }
50
+ args: [{ standalone: true, imports: [CommonModule], providers: [AsyncPipe], template: `
51
+ @if (color) {
52
+ <span
53
+ class="cell-chip"
54
+ [style]="{ background: color }"
55
+ >{{ label }}</span
56
+ >
57
+ } @else {
58
+ <span>{{ label }}</span>
59
+ }
60
60
  `, styles: [".cell-chip{padding:2px 5px;color:#fff;border-radius:2px;font-size:12px}\n"] }]
61
61
  }] });
62
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hpcC1yZW5kZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9pbW0tZWxlbWVudC11aS9zcmMvbGliL2dyaWQvY2VsbC1yZW5kZXIvY2hpcC1yZW5kZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQzVDLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDMUMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDOztBQUUvQyxNQUFNLFFBQVEsR0FBUTtJQUNyQixPQUFPLEVBQUUsU0FBUztJQUNsQixLQUFLLEVBQUUsU0FBUztJQUNoQixJQUFJLEVBQUUsU0FBUztJQUNmLE1BQU0sRUFBRSxTQUFTO0lBQ2pCLEtBQUssRUFBRSxTQUFTO0lBQ2hCLEdBQUcsRUFBRSxTQUFTO0lBQ2QsSUFBSSxFQUFFLFNBQVM7SUFDZixNQUFNLEVBQUUsU0FBUztJQUNqQixJQUFJLEVBQUUsU0FBUztJQUNmLE1BQU0sRUFBRSxTQUFTO0lBQ2pCLEdBQUcsRUFBRSxTQUFTO0lBQ2QsTUFBTSxFQUFFLFNBQVM7SUFDakIsSUFBSSxFQUFFLFNBQVM7SUFDZixJQUFJLEVBQUUsU0FBUztJQUNmLElBQUksRUFBRSxTQUFTO0lBQ2YsTUFBTSxFQUFFLFNBQVM7SUFDakIsT0FBTyxFQUFFLFNBQVM7Q0FDbEIsQ0FBQztBQTBCRixNQUFNLE9BQU8sWUFBWTtJQXhCekI7UUF5QkMsVUFBSyxHQUFXLEVBQUUsQ0FBQztRQUNuQixVQUFLLEdBQVcsRUFBRSxDQUFDO0tBUW5CO0lBTkEsTUFBTSxDQUFDLE1BQVc7UUFDakIsTUFBTSxPQUFPLEdBQVUsTUFBTSxDQUFDLE9BQU8sQ0FBQztRQUN0QyxNQUFNLElBQUksR0FBRyxPQUFPLEVBQUUsSUFBSSxDQUFDLENBQUMsSUFBUyxFQUFFLEVBQUUsQ0FBQyxJQUFJLENBQUMsS0FBSyxLQUFLLE1BQU0sQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUN2RSxJQUFJLENBQUMsS0FBSyxHQUFHLElBQUksQ0FBQyxLQUFLLElBQUksRUFBRSxDQUFDO1FBQzlCLElBQUksQ0FBQyxLQUFLLEdBQUcsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxJQUFLLENBQUMsQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDO0lBQ3BELENBQUM7K0dBVFcsWUFBWTttR0FBWixZQUFZLDJEQXJCYixDQUFDLFNBQVMsQ0FBQywwQkFTWjs7Ozs7Ozs7OztFQVVULGtKQXBCUyxZQUFZOzs0RkFzQlYsWUFBWTtrQkF4QnhCLFNBQVM7aUNBQ0csSUFBSSxXQUNQLENBQUMsWUFBWSxDQUFDLGFBQ1osQ0FBQyxTQUFTLENBQUMsWUFTWjs7Ozs7Ozs7OztFQVVUIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQXN5bmNQaXBlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcclxuaW1wb3J0IHsgQ29tcG9uZW50IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XHJcblxyXG5jb25zdCBDb2xvck1hcDogYW55ID0ge1xyXG5cdGVtZXJhbGQ6ICcjMTBCOTgxJyxcclxuXHRncmVlbjogJyMyMmM1NWUnLFxyXG5cdGxpbWU6ICcjODRDQzE2JyxcclxuXHRvcmFuZ2U6ICcjZjk3MzE2JyxcclxuXHRhbWJlcjogJyNGNTlFMEInLFxyXG5cdHNreTogJyMwRUE1RTknLFxyXG5cdGJsdWU6ICcjMGVhNWU5JyxcclxuXHR2aW9sZXQ6ICcjNkIyNkMxJyxcclxuXHRwaW5rOiAnI0VDNDg5OScsXHJcblx0cHVycGxlOiAnI2Y5NzMxNicsXHJcblx0cmVkOiAnI0VGNDQ0NCcsXHJcblx0eWVsbG93OiAnI0Y1OUUwQicsXHJcblx0Z3JheTogJyM0QjU1NjMnLFxyXG5cdHRlYWw6ICcjMTZBMzRBJyxcclxuXHRjeWFuOiAnIzI1RDM2NicsXHJcblx0aW5kaWdvOiAnIzY1NzRDRCcsXHJcblx0ZnVzaHNpYTogJyNFMTAwOTgnLFxyXG59O1xyXG5cclxuQENvbXBvbmVudCh7XHJcblx0c3RhbmRhbG9uZTogdHJ1ZSxcclxuXHRpbXBvcnRzOiBbQ29tbW9uTW9kdWxlXSxcclxuXHRwcm92aWRlcnM6IFtBc3luY1BpcGVdLFxyXG5cdHN0eWxlczogYFxyXG5cdFx0LmNlbGwtY2hpcCB7XHJcblx0XHRcdHBhZGRpbmc6IDJweCA1cHg7XHJcblx0XHRcdGNvbG9yOiAjZmZmO1xyXG5cdFx0XHRib3JkZXItcmFkaXVzOiAycHg7XHJcblx0XHRcdGZvbnQtc2l6ZTogMTJweDtcclxuXHRcdH1cclxuXHRgLFxyXG5cdHRlbXBsYXRlOiBgXHJcblx0XHRAaWYgKGNvbG9yKSB7XHJcblx0XHRcdDxzcGFuXHJcblx0XHRcdFx0Y2xhc3M9XCJjZWxsLWNoaXBcIlxyXG5cdFx0XHRcdFtzdHlsZV09XCJ7IGJhY2tncm91bmQ6IGNvbG9yIH1cIlxyXG5cdFx0XHRcdD57eyBsYWJlbCB9fTwvc3BhblxyXG5cdFx0XHQ+XHJcblx0XHR9IEBlbHNlIHtcclxuXHRcdFx0PHNwYW4+e3sgbGFiZWwgfX08L3NwYW4+XHJcblx0XHR9XHJcblx0YCxcclxufSlcclxuZXhwb3J0IGNsYXNzIENoaXBSZW5kZXJlciB7XHJcblx0bGFiZWw6IHN0cmluZyA9ICcnO1xyXG5cdGNvbG9yOiBzdHJpbmcgPSAnJztcclxuXHJcblx0YWdJbml0KHBhcmFtczogYW55KTogdm9pZCB7XHJcblx0XHRjb25zdCBvcHRpb25zOiBhbnlbXSA9IHBhcmFtcy5vcHRpb25zO1xyXG5cdFx0Y29uc3QgaXRlbSA9IG9wdGlvbnM/LmZpbmQoKGl0ZW06IGFueSkgPT4gaXRlbS52YWx1ZSA9PT0gcGFyYW1zLnZhbHVlKTtcclxuXHRcdHRoaXMubGFiZWwgPSBpdGVtLmxhYmVsIHx8ICcnO1xyXG5cdFx0dGhpcy5jb2xvciA9IGl0ZW0uY2hpcCA/IENvbG9yTWFwW2l0ZW0uY2hpcCFdIDogJyc7XHJcblx0fVxyXG59XHJcbiJdfQ==
62
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hpcC1yZW5kZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9pbW0tZWxlbWVudC11aS9zcmMvbGliL2dyaWQvY2VsbC1yZW5kZXIvY2hpcC1yZW5kZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQzVDLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDMUMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDOztBQUUvQyxNQUFNLFFBQVEsR0FBUTtJQUNyQixPQUFPLEVBQUUsU0FBUztJQUNsQixLQUFLLEVBQUUsU0FBUztJQUNoQixJQUFJLEVBQUUsU0FBUztJQUNmLE1BQU0sRUFBRSxTQUFTO0lBQ2pCLEtBQUssRUFBRSxTQUFTO0lBQ2hCLEdBQUcsRUFBRSxTQUFTO0lBQ2QsSUFBSSxFQUFFLFNBQVM7SUFDZixNQUFNLEVBQUUsU0FBUztJQUNqQixJQUFJLEVBQUUsU0FBUztJQUNmLE1BQU0sRUFBRSxTQUFTO0lBQ2pCLEdBQUcsRUFBRSxTQUFTO0lBQ2QsTUFBTSxFQUFFLFNBQVM7SUFDakIsSUFBSSxFQUFFLFNBQVM7SUFDZixJQUFJLEVBQUUsU0FBUztJQUNmLElBQUksRUFBRSxTQUFTO0lBQ2YsTUFBTSxFQUFFLFNBQVM7SUFDakIsT0FBTyxFQUFFLFNBQVM7Q0FDbEIsQ0FBQztBQTBCRixNQUFNLE9BQU8sWUFBWTtJQXhCekI7UUF5QkMsVUFBSyxHQUFXLEVBQUUsQ0FBQztRQUNuQixVQUFLLEdBQVcsRUFBRSxDQUFDO0tBUW5CO0lBTkEsTUFBTSxDQUFDLE1BQVc7UUFDakIsTUFBTSxPQUFPLEdBQVUsTUFBTSxDQUFDLE9BQU8sQ0FBQztRQUN0QyxNQUFNLElBQUksR0FBRyxPQUFPLEVBQUUsSUFBSSxDQUFDLENBQUMsSUFBUyxFQUFFLEVBQUUsQ0FBQyxJQUFJLENBQUMsS0FBSyxLQUFLLE1BQU0sQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUN2RSxJQUFJLENBQUMsS0FBSyxHQUFHLElBQUksRUFBRSxLQUFLLElBQUksRUFBRSxDQUFDO1FBQy9CLElBQUksQ0FBQyxLQUFLLEdBQUcsSUFBSSxFQUFFLElBQUksQ0FBQyxDQUFDLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxJQUFLLENBQUMsQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDO0lBQ3JELENBQUM7K0dBVFcsWUFBWTttR0FBWixZQUFZLDJEQXJCYixDQUFDLFNBQVMsQ0FBQywwQkFTWjs7Ozs7Ozs7OztFQVVULGtKQXBCUyxZQUFZOzs0RkFzQlYsWUFBWTtrQkF4QnhCLFNBQVM7aUNBQ0csSUFBSSxXQUNQLENBQUMsWUFBWSxDQUFDLGFBQ1osQ0FBQyxTQUFTLENBQUMsWUFTWjs7Ozs7Ozs7OztFQVVUIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQXN5bmNQaXBlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IENvbXBvbmVudCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcblxuY29uc3QgQ29sb3JNYXA6IGFueSA9IHtcblx0ZW1lcmFsZDogJyMxMEI5ODEnLFxuXHRncmVlbjogJyMyMmM1NWUnLFxuXHRsaW1lOiAnIzg0Q0MxNicsXG5cdG9yYW5nZTogJyNmOTczMTYnLFxuXHRhbWJlcjogJyNGNTlFMEInLFxuXHRza3k6ICcjMEVBNUU5Jyxcblx0Ymx1ZTogJyMwZWE1ZTknLFxuXHR2aW9sZXQ6ICcjNkIyNkMxJyxcblx0cGluazogJyNFQzQ4OTknLFxuXHRwdXJwbGU6ICcjZjk3MzE2Jyxcblx0cmVkOiAnI0VGNDQ0NCcsXG5cdHllbGxvdzogJyNGNTlFMEInLFxuXHRncmF5OiAnIzRCNTU2MycsXG5cdHRlYWw6ICcjMTZBMzRBJyxcblx0Y3lhbjogJyMyNUQzNjYnLFxuXHRpbmRpZ286ICcjNjU3NENEJyxcblx0ZnVzaHNpYTogJyNFMTAwOTgnLFxufTtcblxuQENvbXBvbmVudCh7XG5cdHN0YW5kYWxvbmU6IHRydWUsXG5cdGltcG9ydHM6IFtDb21tb25Nb2R1bGVdLFxuXHRwcm92aWRlcnM6IFtBc3luY1BpcGVdLFxuXHRzdHlsZXM6IGBcblx0XHQuY2VsbC1jaGlwIHtcblx0XHRcdHBhZGRpbmc6IDJweCA1cHg7XG5cdFx0XHRjb2xvcjogI2ZmZjtcblx0XHRcdGJvcmRlci1yYWRpdXM6IDJweDtcblx0XHRcdGZvbnQtc2l6ZTogMTJweDtcblx0XHR9XG5cdGAsXG5cdHRlbXBsYXRlOiBgXG5cdFx0QGlmIChjb2xvcikge1xuXHRcdFx0PHNwYW5cblx0XHRcdFx0Y2xhc3M9XCJjZWxsLWNoaXBcIlxuXHRcdFx0XHRbc3R5bGVdPVwieyBiYWNrZ3JvdW5kOiBjb2xvciB9XCJcblx0XHRcdFx0Pnt7IGxhYmVsIH19PC9zcGFuXG5cdFx0XHQ+XG5cdFx0fSBAZWxzZSB7XG5cdFx0XHQ8c3Bhbj57eyBsYWJlbCB9fTwvc3Bhbj5cblx0XHR9XG5cdGAsXG59KVxuZXhwb3J0IGNsYXNzIENoaXBSZW5kZXJlciB7XG5cdGxhYmVsOiBzdHJpbmcgPSAnJztcblx0Y29sb3I6IHN0cmluZyA9ICcnO1xuXG5cdGFnSW5pdChwYXJhbXM6IGFueSk6IHZvaWQge1xuXHRcdGNvbnN0IG9wdGlvbnM6IGFueVtdID0gcGFyYW1zLm9wdGlvbnM7XG5cdFx0Y29uc3QgaXRlbSA9IG9wdGlvbnM/LmZpbmQoKGl0ZW06IGFueSkgPT4gaXRlbS52YWx1ZSA9PT0gcGFyYW1zLnZhbHVlKTtcblx0XHR0aGlzLmxhYmVsID0gaXRlbT8ubGFiZWwgfHwgJyc7XG5cdFx0dGhpcy5jb2xvciA9IGl0ZW0/LmNoaXAgPyBDb2xvck1hcFtpdGVtLmNoaXAhXSA6ICcnO1xuXHR9XG59XG4iXX0=
@@ -3372,14 +3372,16 @@ class ImageComponent {
3372
3372
  <div class="flex gap-2 mt-2">
3373
3373
  @for (image of imageList; track image; let index = $index) {
3374
3374
  <div class="border">
3375
- <div class="flex flex-row-reverse">
3376
- <p-button
3377
- icon="pi pi-times"
3378
- severity="danger"
3379
- size="small"
3380
- (onClick)="deleteHandler(image, index)"
3381
- [text]="true" />
3382
- </div>
3375
+ @if (!field()?.fieldControl?.disabled) {
3376
+ <div class="flex flex-row-reverse">
3377
+ <p-button
3378
+ icon="pi pi-times"
3379
+ severity="danger"
3380
+ size="small"
3381
+ (onClick)="deleteHandler(image, index)"
3382
+ [text]="true" />
3383
+ </div>
3384
+ }
3383
3385
  <p-image
3384
3386
  [src]="'https://hrimage.myfoodiepet.com//' + image"
3385
3387
  [preview]="true"
@@ -3478,14 +3480,16 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
3478
3480
  <div class="flex gap-2 mt-2">
3479
3481
  @for (image of imageList; track image; let index = $index) {
3480
3482
  <div class="border">
3481
- <div class="flex flex-row-reverse">
3482
- <p-button
3483
- icon="pi pi-times"
3484
- severity="danger"
3485
- size="small"
3486
- (onClick)="deleteHandler(image, index)"
3487
- [text]="true" />
3488
- </div>
3483
+ @if (!field()?.fieldControl?.disabled) {
3484
+ <div class="flex flex-row-reverse">
3485
+ <p-button
3486
+ icon="pi pi-times"
3487
+ severity="danger"
3488
+ size="small"
3489
+ (onClick)="deleteHandler(image, index)"
3490
+ [text]="true" />
3491
+ </div>
3492
+ }
3489
3493
  <p-image
3490
3494
  [src]="'https://hrimage.myfoodiepet.com//' + image"
3491
3495
  [preview]="true"
@@ -5094,34 +5098,34 @@ class ChipRenderer {
5094
5098
  agInit(params) {
5095
5099
  const options = params.options;
5096
5100
  const item = options?.find((item) => item.value === params.value);
5097
- this.label = item.label || '';
5098
- this.color = item.chip ? ColorMap[item.chip] : '';
5101
+ this.label = item?.label || '';
5102
+ this.color = item?.chip ? ColorMap[item.chip] : '';
5099
5103
  }
5100
5104
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ChipRenderer, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
5101
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: ChipRenderer, isStandalone: true, selector: "ng-component", providers: [AsyncPipe], ngImport: i0, template: `
5102
- @if (color) {
5103
- <span
5104
- class="cell-chip"
5105
- [style]="{ background: color }"
5106
- >{{ label }}</span
5107
- >
5108
- } @else {
5109
- <span>{{ label }}</span>
5110
- }
5105
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: ChipRenderer, isStandalone: true, selector: "ng-component", providers: [AsyncPipe], ngImport: i0, template: `
5106
+ @if (color) {
5107
+ <span
5108
+ class="cell-chip"
5109
+ [style]="{ background: color }"
5110
+ >{{ label }}</span
5111
+ >
5112
+ } @else {
5113
+ <span>{{ label }}</span>
5114
+ }
5111
5115
  `, isInline: true, styles: [".cell-chip{padding:2px 5px;color:#fff;border-radius:2px;font-size:12px}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }] }); }
5112
5116
  }
5113
5117
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: ChipRenderer, decorators: [{
5114
5118
  type: Component,
5115
- args: [{ standalone: true, imports: [CommonModule], providers: [AsyncPipe], template: `
5116
- @if (color) {
5117
- <span
5118
- class="cell-chip"
5119
- [style]="{ background: color }"
5120
- >{{ label }}</span
5121
- >
5122
- } @else {
5123
- <span>{{ label }}</span>
5124
- }
5119
+ args: [{ standalone: true, imports: [CommonModule], providers: [AsyncPipe], template: `
5120
+ @if (color) {
5121
+ <span
5122
+ class="cell-chip"
5123
+ [style]="{ background: color }"
5124
+ >{{ label }}</span
5125
+ >
5126
+ } @else {
5127
+ <span>{{ label }}</span>
5128
+ }
5125
5129
  `, styles: [".cell-chip{padding:2px 5px;color:#fff;border-radius:2px;font-size:12px}\n"] }]
5126
5130
  }] });
5127
5131