imm-element-ui 1.1.1 → 1.1.3
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
|
-
|
|
182
|
-
<
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
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
|
-
|
|
288
|
-
<
|
|
289
|
-
|
|
290
|
-
|
|
291
|
-
|
|
292
|
-
|
|
293
|
-
|
|
294
|
-
|
|
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
|
|
33
|
-
this.color = item
|
|
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,
|
|
62
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hpcC1yZW5kZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9pbW0tZWxlbWVudC11aS9zcmMvbGliL2dyaWQvY2VsbC1yZW5kZXIvY2hpcC1yZW5kZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQzVDLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDMUMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDOztBQUUvQyxNQUFNLFFBQVEsR0FBUTtJQUNyQixPQUFPLEVBQUUsU0FBUztJQUNsQixLQUFLLEVBQUUsU0FBUztJQUNoQixJQUFJLEVBQUUsU0FBUztJQUNmLE1BQU0sRUFBRSxTQUFTO0lBQ2pCLEtBQUssRUFBRSxTQUFTO0lBQ2hCLEdBQUcsRUFBRSxTQUFTO0lBQ2QsSUFBSSxFQUFFLFNBQVM7SUFDZixNQUFNLEVBQUUsU0FBUztJQUNqQixJQUFJLEVBQUUsU0FBUztJQUNmLE1BQU0sRUFBRSxTQUFTO0lBQ2pCLEdBQUcsRUFBRSxTQUFTO0lBQ2QsTUFBTSxFQUFFLFNBQVM7SUFDakIsSUFBSSxFQUFFLFNBQVM7SUFDZixJQUFJLEVBQUUsU0FBUztJQUNmLElBQUksRUFBRSxTQUFTO0lBQ2YsTUFBTSxFQUFFLFNBQVM7SUFDakIsT0FBTyxFQUFFLFNBQVM7Q0FDbEIsQ0FBQztBQTBCRixNQUFNLE9BQU8sWUFBWTtJQXhCekI7UUF5QkMsVUFBSyxHQUFXLEVBQUUsQ0FBQztRQUNuQixVQUFLLEdBQVcsRUFBRSxDQUFDO0tBUW5CO0lBTkEsTUFBTSxDQUFDLE1BQVc7UUFDakIsTUFBTSxPQUFPLEdBQVUsTUFBTSxDQUFDLE9BQU8sQ0FBQztRQUN0QyxNQUFNLElBQUksR0FBRyxPQUFPLEVBQUUsSUFBSSxDQUFDLENBQUMsSUFBUyxFQUFFLEVBQUUsQ0FBQyxJQUFJLENBQUMsS0FBSyxLQUFLLE1BQU0sQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUN2RSxJQUFJLENBQUMsS0FBSyxHQUFHLElBQUksRUFBRSxLQUFLLElBQUksRUFBRSxDQUFDO1FBQy9CLElBQUksQ0FBQyxLQUFLLEdBQUcsSUFBSSxFQUFFLElBQUksQ0FBQyxDQUFDLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxJQUFLLENBQUMsQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDO0lBQ3JELENBQUM7K0dBVFcsWUFBWTttR0FBWixZQUFZLDJEQXJCYixDQUFDLFNBQVMsQ0FBQywwQkFTWjs7Ozs7Ozs7OztFQVVULGtKQXBCUyxZQUFZOzs0RkFzQlYsWUFBWTtrQkF4QnhCLFNBQVM7aUNBQ0csSUFBSSxXQUNQLENBQUMsWUFBWSxDQUFDLGFBQ1osQ0FBQyxTQUFTLENBQUMsWUFTWjs7Ozs7Ozs7OztFQVVUIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQXN5bmNQaXBlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IENvbXBvbmVudCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcblxuY29uc3QgQ29sb3JNYXA6IGFueSA9IHtcblx0ZW1lcmFsZDogJyMxMEI5ODEnLFxuXHRncmVlbjogJyMyMmM1NWUnLFxuXHRsaW1lOiAnIzg0Q0MxNicsXG5cdG9yYW5nZTogJyNmOTczMTYnLFxuXHRhbWJlcjogJyNGNTlFMEInLFxuXHRza3k6ICcjMEVBNUU5Jyxcblx0Ymx1ZTogJyMwZWE1ZTknLFxuXHR2aW9sZXQ6ICcjNkIyNkMxJyxcblx0cGluazogJyNFQzQ4OTknLFxuXHRwdXJwbGU6ICcjZjk3MzE2Jyxcblx0cmVkOiAnI0VGNDQ0NCcsXG5cdHllbGxvdzogJyNGNTlFMEInLFxuXHRncmF5OiAnIzRCNTU2MycsXG5cdHRlYWw6ICcjMTZBMzRBJyxcblx0Y3lhbjogJyMyNUQzNjYnLFxuXHRpbmRpZ286ICcjNjU3NENEJyxcblx0ZnVzaHNpYTogJyNFMTAwOTgnLFxufTtcblxuQENvbXBvbmVudCh7XG5cdHN0YW5kYWxvbmU6IHRydWUsXG5cdGltcG9ydHM6IFtDb21tb25Nb2R1bGVdLFxuXHRwcm92aWRlcnM6IFtBc3luY1BpcGVdLFxuXHRzdHlsZXM6IGBcblx0XHQuY2VsbC1jaGlwIHtcblx0XHRcdHBhZGRpbmc6IDJweCA1cHg7XG5cdFx0XHRjb2xvcjogI2ZmZjtcblx0XHRcdGJvcmRlci1yYWRpdXM6IDJweDtcblx0XHRcdGZvbnQtc2l6ZTogMTJweDtcblx0XHR9XG5cdGAsXG5cdHRlbXBsYXRlOiBgXG5cdFx0QGlmIChjb2xvcikge1xuXHRcdFx0PHNwYW5cblx0XHRcdFx0Y2xhc3M9XCJjZWxsLWNoaXBcIlxuXHRcdFx0XHRbc3R5bGVdPVwieyBiYWNrZ3JvdW5kOiBjb2xvciB9XCJcblx0XHRcdFx0Pnt7IGxhYmVsIH19PC9zcGFuXG5cdFx0XHQ+XG5cdFx0fSBAZWxzZSB7XG5cdFx0XHQ8c3Bhbj57eyBsYWJlbCB9fTwvc3Bhbj5cblx0XHR9XG5cdGAsXG59KVxuZXhwb3J0IGNsYXNzIENoaXBSZW5kZXJlciB7XG5cdGxhYmVsOiBzdHJpbmcgPSAnJztcblx0Y29sb3I6IHN0cmluZyA9ICcnO1xuXG5cdGFnSW5pdChwYXJhbXM6IGFueSk6IHZvaWQge1xuXHRcdGNvbnN0IG9wdGlvbnM6IGFueVtdID0gcGFyYW1zLm9wdGlvbnM7XG5cdFx0Y29uc3QgaXRlbSA9IG9wdGlvbnM/LmZpbmQoKGl0ZW06IGFueSkgPT4gaXRlbS52YWx1ZSA9PT0gcGFyYW1zLnZhbHVlKTtcblx0XHR0aGlzLmxhYmVsID0gaXRlbT8ubGFiZWwgfHwgJyc7XG5cdFx0dGhpcy5jb2xvciA9IGl0ZW0/LmNoaXAgPyBDb2xvck1hcFtpdGVtLmNoaXAhXSA6ICcnO1xuXHR9XG59XG4iXX0=
|
|
@@ -126,9 +126,9 @@ const _gridUtils = {
|
|
|
126
126
|
else if (gridOptions.selectionMode === 'single') {
|
|
127
127
|
gridOptions.rowSelection = { mode: 'singleRow' };
|
|
128
128
|
}
|
|
129
|
-
if
|
|
130
|
-
|
|
131
|
-
}
|
|
129
|
+
// if(gridOptions.isRowSelectable) {
|
|
130
|
+
// (gridOptions.rowSelection as any).isRowSelectable = gridOptions.isRowSelectable
|
|
131
|
+
// }
|
|
132
132
|
return { ...gridOptions };
|
|
133
133
|
},
|
|
134
134
|
};
|
|
@@ -141,4 +141,4 @@ export const gridUtils = {
|
|
|
141
141
|
handleI18nKey: _gridUtils.handleI18nKey,
|
|
142
142
|
mergeOptions: _gridUtils.mergeOptions,
|
|
143
143
|
};
|
|
144
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"grid-utils.js","sourceRoot":"","sources":["../../../../../projects/imm-element-ui/src/lib/grid/grid-utils.ts"],"names":[],"mappings":"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","sourcesContent":["import { $dt } from '@primeng/themes';\nimport { themeQuartz } from 'ag-grid-enterprise';\nimport { ThemeConfigService } from '../service/themeConfig.service';\nimport { AG_GRID_LOCALE_CN, AG_GRID_LOCALE_EN } from '@ag-grid-community/locale';\nimport { filterObjectByKeys } from '../share/utils';\nimport { I18nService } from '../service/i18n.service';\nimport { GridOptions } from './grid/grid.component';\nimport { ActionService } from '../service/action.service';\n\nconst _gridUtils = {\n\tcalcRowIds: (api: any, isServerSide: boolean): any[] => {\n\t\tconst result: any[] = [];\n\t\tapi.forEachNode((node: any) => {\n\t\t\tnode.isSelected() && result.push(node.data);\n\t\t});\n\t\treturn result;\n\t},\n\tselectionHandler: (api: any, selectionKeys: any[], startRow: number) => {\n\t\tfor (let i = startRow; i < api.getDisplayedRowCount(); i++) {\n\t\t\tconst node = api.getDisplayedRowAtIndex(i);\n\t\t\tif (selectionKeys?.includes(node.data.id)) {\n\t\t\t\tnode.setSelected(true, false);\n\t\t\t}\n\t\t}\n\t},\n\tcalcGridHeight(rowCount: number, margin: number) {\n\t\tconst headerHeight = 49;\n\t\tconst rowHeight = 42;\n\t\tconst totalHeight = headerHeight + rowCount * rowHeight + margin;\n\t\treturn Math.max(totalHeight, headerHeight + rowHeight + margin);\n\t},\n\tgetTheme(themeConfig: ThemeConfigService) {\n\t\tconst primary = themeConfig.appState()?.primary as string;\n\t\treturn themeQuartz.withParams({\n\t\t\taccentColor: primary,\n\t\t\tselectedRowBackgroundColor: $dt(`${primary}.50`).value,\n\t\t\tcheckboxCheckedBackgroundColor: $dt(`${primary}.500`).value,\n\t\t\trowHoverColor: $dt(`${primary}.50`).value,\n\t\t\trangeSelectionBackgroundColor: $dt(`${primary}.100`).value,\n\t\t\trangeSelectionBorderColor: $dt(`${primary}.100`).value,\n\t\t\twrapperBorderRadius: 0,\n\t\t});\n\t},\n\t// ag-grid 本地国际化 官方无泰文翻译包 目前暂用英文 后续需要再翻译\n\tgetLocalText(local: string) {\n\t\tlet localeText;\n\t\tswitch (local) {\n\t\t\tcase 'zh-CN':\n\t\t\t\tlocaleText = AG_GRID_LOCALE_CN;\n\t\t\t\tbreak;\n\t\t\tcase 'en-US':\n\t\t\t\tlocaleText = AG_GRID_LOCALE_EN;\n\t\t\t\tbreak;\n\t\t\tcase 'th-TH':\n\t\t\t\tlocaleText = AG_GRID_LOCALE_EN;\n\t\t\t\tbreak;\n\t\t\tdefault:\n\t\t\t\t'';\n\t\t}\n\t\treturn localeText;\n\t},\n\thandleI18nKey(cols: any[], i18n: I18nService) {\n\t\tconst columnDefs: any[] = [];\n\t\tcols.forEach((item: any) => {\n\t\t\tlet cols: any;\n\t\t\tif (item.hasOwnProperty('i18nKey')) {\n\t\t\t\tlet headerName = i18n.fanyi(item.i18nKey);\n\t\t\t\tcols = { ...item, headerName };\n\t\t\t\tdelete cols.i18nKey;\n\t\t\t} else {\n\t\t\t\tcols = { ...item };\n\t\t\t}\n\t\t\tcolumnDefs.push(cols);\n\t\t});\n\t\treturn columnDefs;\n\t},\n\tgetTreeOptions(columnDef: any): any {\n\t\tconst treeOptions = {\n\t\t\ttreeData: true,\n\t\t\ttreeDataChildrenField: 'children',\n\t\t\trowSelection: {\n\t\t\t\tmode: 'multiRow',\n\t\t\t},\n\t\t\tautoGroupColumnDef: {\n\t\t\t\tcellStyle: { color: 'var(--p-form-field-focus-border-color)' },\n\t\t\t\tcellRenderer: 'agGroupCellRenderer',\n\t\t\t\tcellRendererParams: {\n\t\t\t\t\t...columnDef.cellRendererParams,\n\t\t\t\t\tinnerRenderer: 'linkRenderer',\n\t\t\t\t\tsuppressCount: true,\n\t\t\t\t},\n\t\t\t\t...filterObjectByKeys(columnDef, ['headerName', 'field', 'minWidth']),\n\t\t\t},\n\t\t\tisServerSideGroup: (dataItem: any) => {\n\t\t\t\treturn !!dataItem.children;\n\t\t\t},\n\t\t\tgetServerSideGroupKey: (dataItem: any) => {\n\t\t\t\treturn dataItem.id;\n\t\t\t},\n\t\t\tonRowSelected: (event: any, x: any) => {\n\t\t\t\tconst node = event.node;\n\t\t\t\tif (!node.group) return;\n\t\t\t\tnode.childrenAfterGroup.forEach((child: any) => {\n\t\t\t\t\tchild.setSelected(node.isSelected(), false);\n\t\t\t\t});\n\t\t\t},\n\t\t};\n\t\treturn treeOptions;\n\t},\n\tmergeOptions(gridOptions: GridOptions, cacheBlockSize: any, action: ActionService): any {\n\t\tgridOptions.cacheBlockSize = cacheBlockSize ?? 50;\n\t\tif (gridOptions.treeDataField) {\n\t\t\tlet columnDef: any = gridOptions.columnDefs?.find((col: any) => col.field == gridOptions.treeDataField);\n\t\t\tcolumnDef.hide = true;\n\t\t\treturn { ...gridOptions, ..._gridUtils.getTreeOptions(columnDef) };\n\t\t}\n\t\tif (gridOptions.showIndex) {\n\t\t\tgridOptions.columnDefs?.unshift({\n\t\t\t\theaderName: '#',\n\t\t\t\tvalueGetter: (params) => (params.node?.rowIndex || 0) + 1,\n\t\t\t\twidth: 80,\n\t\t\t\tminWidth: 80,\n\t\t\t\tmaxWidth: 80,\n\t\t\t});\n\t\t}\n\t\tif (gridOptions.selectionMode === 'none') {\n\t\t\tgridOptions.rowSelection = undefined;\n\t\t} else if (gridOptions.selectionMode === 'single') {\n\t\t\tgridOptions.rowSelection = { mode: 'singleRow' };\n\t\t}\n\t\tif(gridOptions.isRowSelectable) {\n\t\t\t(gridOptions.rowSelection as any).isRowSelectable = gridOptions.isRowSelectable\n\t\t}\n\t\treturn { ...gridOptions };\n\t},\n};\nexport const gridUtils = {\n\tcalcRowIds: _gridUtils.calcRowIds,\n\tselectionHandler: _gridUtils.selectionHandler,\n\tcalcGridHeight: _gridUtils.calcGridHeight,\n\tgetTheme: _gridUtils.getTheme,\n\tgetLocalText: _gridUtils.getLocalText,\n\thandleI18nKey: _gridUtils.handleI18nKey,\n\tmergeOptions: _gridUtils.mergeOptions,\n};\n"]}
|
|
144
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"grid-utils.js","sourceRoot":"","sources":["../../../../../projects/imm-element-ui/src/lib/grid/grid-utils.ts"],"names":[],"mappings":"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","sourcesContent":["import { $dt } from '@primeng/themes';\nimport { themeQuartz } from 'ag-grid-enterprise';\nimport { ThemeConfigService } from '../service/themeConfig.service';\nimport { AG_GRID_LOCALE_CN, AG_GRID_LOCALE_EN } from '@ag-grid-community/locale';\nimport { filterObjectByKeys } from '../share/utils';\nimport { I18nService } from '../service/i18n.service';\nimport { GridOptions } from './grid/grid.component';\nimport { ActionService } from '../service/action.service';\n\nconst _gridUtils = {\n\tcalcRowIds: (api: any, isServerSide: boolean): any[] => {\n\t\tconst result: any[] = [];\n\t\tapi.forEachNode((node: any) => {\n\t\t\tnode.isSelected() && result.push(node.data);\n\t\t});\n\t\treturn result;\n\t},\n\tselectionHandler: (api: any, selectionKeys: any[], startRow: number) => {\n\t\tfor (let i = startRow; i < api.getDisplayedRowCount(); i++) {\n\t\t\tconst node = api.getDisplayedRowAtIndex(i);\n\t\t\tif (selectionKeys?.includes(node.data.id)) {\n\t\t\t\tnode.setSelected(true, false);\n\t\t\t}\n\t\t}\n\t},\n\tcalcGridHeight(rowCount: number, margin: number) {\n\t\tconst headerHeight = 49;\n\t\tconst rowHeight = 42;\n\t\tconst totalHeight = headerHeight + rowCount * rowHeight + margin;\n\t\treturn Math.max(totalHeight, headerHeight + rowHeight + margin);\n\t},\n\tgetTheme(themeConfig: ThemeConfigService) {\n\t\tconst primary = themeConfig.appState()?.primary as string;\n\t\treturn themeQuartz.withParams({\n\t\t\taccentColor: primary,\n\t\t\tselectedRowBackgroundColor: $dt(`${primary}.50`).value,\n\t\t\tcheckboxCheckedBackgroundColor: $dt(`${primary}.500`).value,\n\t\t\trowHoverColor: $dt(`${primary}.50`).value,\n\t\t\trangeSelectionBackgroundColor: $dt(`${primary}.100`).value,\n\t\t\trangeSelectionBorderColor: $dt(`${primary}.100`).value,\n\t\t\twrapperBorderRadius: 0,\n\t\t});\n\t},\n\t// ag-grid 本地国际化 官方无泰文翻译包 目前暂用英文 后续需要再翻译\n\tgetLocalText(local: string) {\n\t\tlet localeText;\n\t\tswitch (local) {\n\t\t\tcase 'zh-CN':\n\t\t\t\tlocaleText = AG_GRID_LOCALE_CN;\n\t\t\t\tbreak;\n\t\t\tcase 'en-US':\n\t\t\t\tlocaleText = AG_GRID_LOCALE_EN;\n\t\t\t\tbreak;\n\t\t\tcase 'th-TH':\n\t\t\t\tlocaleText = AG_GRID_LOCALE_EN;\n\t\t\t\tbreak;\n\t\t\tdefault:\n\t\t\t\t'';\n\t\t}\n\t\treturn localeText;\n\t},\n\thandleI18nKey(cols: any[], i18n: I18nService) {\n\t\tconst columnDefs: any[] = [];\n\t\tcols.forEach((item: any) => {\n\t\t\tlet cols: any;\n\t\t\tif (item.hasOwnProperty('i18nKey')) {\n\t\t\t\tlet headerName = i18n.fanyi(item.i18nKey);\n\t\t\t\tcols = { ...item, headerName };\n\t\t\t\tdelete cols.i18nKey;\n\t\t\t} else {\n\t\t\t\tcols = { ...item };\n\t\t\t}\n\t\t\tcolumnDefs.push(cols);\n\t\t});\n\t\treturn columnDefs;\n\t},\n\tgetTreeOptions(columnDef: any): any {\n\t\tconst treeOptions = {\n\t\t\ttreeData: true,\n\t\t\ttreeDataChildrenField: 'children',\n\t\t\trowSelection: {\n\t\t\t\tmode: 'multiRow',\n\t\t\t},\n\t\t\tautoGroupColumnDef: {\n\t\t\t\tcellStyle: { color: 'var(--p-form-field-focus-border-color)' },\n\t\t\t\tcellRenderer: 'agGroupCellRenderer',\n\t\t\t\tcellRendererParams: {\n\t\t\t\t\t...columnDef.cellRendererParams,\n\t\t\t\t\tinnerRenderer: 'linkRenderer',\n\t\t\t\t\tsuppressCount: true,\n\t\t\t\t},\n\t\t\t\t...filterObjectByKeys(columnDef, ['headerName', 'field', 'minWidth']),\n\t\t\t},\n\t\t\tisServerSideGroup: (dataItem: any) => {\n\t\t\t\treturn !!dataItem.children;\n\t\t\t},\n\t\t\tgetServerSideGroupKey: (dataItem: any) => {\n\t\t\t\treturn dataItem.id;\n\t\t\t},\n\t\t\tonRowSelected: (event: any, x: any) => {\n\t\t\t\tconst node = event.node;\n\t\t\t\tif (!node.group) return;\n\t\t\t\tnode.childrenAfterGroup.forEach((child: any) => {\n\t\t\t\t\tchild.setSelected(node.isSelected(), false);\n\t\t\t\t});\n\t\t\t},\n\t\t};\n\t\treturn treeOptions;\n\t},\n\tmergeOptions(gridOptions: GridOptions, cacheBlockSize: any, action: ActionService): any {\n\t\tgridOptions.cacheBlockSize = cacheBlockSize ?? 50;\n\t\tif (gridOptions.treeDataField) {\n\t\t\tlet columnDef: any = gridOptions.columnDefs?.find((col: any) => col.field == gridOptions.treeDataField);\n\t\t\tcolumnDef.hide = true;\n\t\t\treturn { ...gridOptions, ..._gridUtils.getTreeOptions(columnDef) };\n\t\t}\n\t\tif (gridOptions.showIndex) {\n\t\t\tgridOptions.columnDefs?.unshift({\n\t\t\t\theaderName: '#',\n\t\t\t\tvalueGetter: (params) => (params.node?.rowIndex || 0) + 1,\n\t\t\t\twidth: 80,\n\t\t\t\tminWidth: 80,\n\t\t\t\tmaxWidth: 80,\n\t\t\t});\n\t\t}\n\t\tif (gridOptions.selectionMode === 'none') {\n\t\t\tgridOptions.rowSelection = undefined;\n\t\t} else if (gridOptions.selectionMode === 'single') {\n\t\t\tgridOptions.rowSelection = { mode: 'singleRow' };\n\t\t}\n\t\t// if(gridOptions.isRowSelectable) {\n\t\t// \t(gridOptions.rowSelection as any).isRowSelectable = gridOptions.isRowSelectable\n\t\t// }\n\t\treturn { ...gridOptions };\n\t},\n};\nexport const gridUtils = {\n\tcalcRowIds: _gridUtils.calcRowIds,\n\tselectionHandler: _gridUtils.selectionHandler,\n\tcalcGridHeight: _gridUtils.calcGridHeight,\n\tgetTheme: _gridUtils.getTheme,\n\tgetLocalText: _gridUtils.getLocalText,\n\thandleI18nKey: _gridUtils.handleI18nKey,\n\tmergeOptions: _gridUtils.mergeOptions,\n};\n"]}
|
|
@@ -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
|
-
|
|
3376
|
-
<
|
|
3377
|
-
|
|
3378
|
-
|
|
3379
|
-
|
|
3380
|
-
|
|
3381
|
-
|
|
3382
|
-
|
|
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
|
-
|
|
3482
|
-
<
|
|
3483
|
-
|
|
3484
|
-
|
|
3485
|
-
|
|
3486
|
-
|
|
3487
|
-
|
|
3488
|
-
|
|
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"
|
|
@@ -4370,9 +4374,9 @@ const _gridUtils = {
|
|
|
4370
4374
|
else if (gridOptions.selectionMode === 'single') {
|
|
4371
4375
|
gridOptions.rowSelection = { mode: 'singleRow' };
|
|
4372
4376
|
}
|
|
4373
|
-
if
|
|
4374
|
-
|
|
4375
|
-
}
|
|
4377
|
+
// if(gridOptions.isRowSelectable) {
|
|
4378
|
+
// (gridOptions.rowSelection as any).isRowSelectable = gridOptions.isRowSelectable
|
|
4379
|
+
// }
|
|
4376
4380
|
return { ...gridOptions };
|
|
4377
4381
|
},
|
|
4378
4382
|
};
|
|
@@ -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
|
|
5098
|
-
this.color = item
|
|
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
|
|