imm-element-ui 1.0.6 → 1.0.8

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (42) hide show
  1. package/esm2022/lib/form/form/form.component.mjs +9 -6
  2. package/esm2022/lib/form/form-field/field-control.mjs +5 -5
  3. package/esm2022/lib/form/form-field/field-utils.mjs +4 -5
  4. package/esm2022/lib/form/form-field/form-field.mjs +107 -107
  5. package/esm2022/lib/form/form-type/autocomplete.type.mjs +160 -151
  6. package/esm2022/lib/form/form-type/codemirror.type.mjs +5 -4
  7. package/esm2022/lib/form/form-type/datepicker.type.mjs +10 -1
  8. package/esm2022/lib/form/form-type/image.type.mjs +147 -146
  9. package/esm2022/lib/form/form-type/inputnumber.type.mjs +100 -91
  10. package/esm2022/lib/form/form-type/inputtext.type.mjs +28 -19
  11. package/esm2022/lib/form/form-type/multiselect.type.mjs +172 -163
  12. package/esm2022/lib/form/form-type/radio.type.mjs +81 -80
  13. package/esm2022/lib/form/form-type/rowselector.type.mjs +29 -28
  14. package/esm2022/lib/form/form-type/select.type.mjs +136 -136
  15. package/esm2022/lib/form/form-type/textarea.type.mjs +10 -1
  16. package/esm2022/lib/form/form-type/treeselect.type.mjs +4 -4
  17. package/esm2022/lib/form/form-type/upload.type.mjs +135 -134
  18. package/esm2022/lib/grid/actions/actions.component.mjs +3 -3
  19. package/esm2022/lib/page-form/page-form.component.mjs +12 -3
  20. package/esm2022/lib/share/utils.mjs +10 -1
  21. package/fesm2022/imm-element-ui.mjs +1147 -1068
  22. package/fesm2022/imm-element-ui.mjs.map +1 -1
  23. package/lib/crumb-action/crumb-action.component.d.ts +1 -1
  24. package/lib/form/form/form.component.d.ts +3 -1
  25. package/lib/form/form-field/field-control.d.ts +2 -2
  26. package/lib/form/form-field/field-utils.d.ts +1 -1
  27. package/lib/form/form-field/form-field.d.ts +2 -0
  28. package/lib/form/form-type/autocomplete.type.d.ts +1 -0
  29. package/lib/form/form-type/codemirror.type.d.ts +1 -1
  30. package/lib/form/form-type/datepicker.type.d.ts +2 -0
  31. package/lib/form/form-type/image.type.d.ts +1 -1
  32. package/lib/form/form-type/inputnumber.type.d.ts +1 -0
  33. package/lib/form/form-type/inputtext.type.d.ts +1 -0
  34. package/lib/form/form-type/multiselect.type.d.ts +1 -0
  35. package/lib/form/form-type/radio.type.d.ts +1 -1
  36. package/lib/form/form-type/rowselector.type.d.ts +1 -1
  37. package/lib/form/form-type/select.type.d.ts +1 -2
  38. package/lib/form/form-type/textarea.type.d.ts +1 -0
  39. package/lib/form/form-type/treeselect.type.d.ts +1 -1
  40. package/lib/form/form-type/upload.type.d.ts +1 -1
  41. package/lib/grid/grid/grid.component.d.ts +1 -1
  42. package/package.json +1 -1
@@ -32,116 +32,116 @@ export class FormFieldComponent {
32
32
  return this.fieldLabel;
33
33
  }
34
34
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FormFieldComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
35
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: FormFieldComponent, isStandalone: true, selector: "form-field", inputs: { field: { classPropertyName: "field", publicName: "field", isSignal: true, isRequired: false, transformFunction: null } }, viewQueries: [{ propertyName: "fieldLabel", first: true, predicate: ["fieldLabelRef"], descendants: true }, { propertyName: "fieldComponents", predicate: FormFieldComponent, descendants: true }], ngImport: i0, template: `
36
- @if (field()?.group) {
37
- <div [class]="field()?.groupClass">
38
- @for (fchild of field()!.group; track fchild) {
39
- @if (!fchild.hide) {
40
- <div [class]="fchild.groupClass || fchild.class">
41
- <form-field
42
- class="w-full"
43
- [field]="fchild">
44
- </form-field>
45
- </div>
46
- }
47
- }
48
- </div>
49
- } @else {
50
- <div [class]="field()?.innerClass || 'px-4 my-1'">
51
- <div class="flex flex-row flex-nowrap items-start">
52
- <div
53
- class="flex-none p-field field-label min-h-8 pt-[1.5px] flex items-center"
54
- [style]="getStyle()">
55
- <label
56
- #label
57
- [class]="labelClass()"
58
- fieldLabel
59
- [field]="field()!"
60
- [contextMenu]="contextMenu">
61
- <span
62
- style="user-select: none"
63
- #fieldLabelRef
64
- >{{ props(field()!).i18nKey ? (props(field()!).i18nKey! | translate) : props(field()!).label! }}</span
65
- >
66
- @if (props(field()!).required) {
67
- <span class="field-required">*</span>
68
- }
69
- @if (!field()?.fieldControl?.disabled) {
70
- <span class="iconfont icon-edit-flag field-editable"></span>
71
- }
72
- </label>
73
- </div>
74
- <div class="flex-1 min-h-8 pt-1 w-0 flex flex-row-reverse">
75
- <div
76
- #fieldTypeRef
77
- class="w-full">
78
- <form-type [field]="field()!"></form-type>
79
- </div>
80
- </div>
81
- </div>
82
- </div>
83
- <app-context-menu
84
- #contextMenu
85
- [target]="label"
86
- [field]="field()!"></app-context-menu>
87
- }
35
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: FormFieldComponent, isStandalone: true, selector: "form-field", inputs: { field: { classPropertyName: "field", publicName: "field", isSignal: true, isRequired: false, transformFunction: null } }, viewQueries: [{ propertyName: "fieldLabel", first: true, predicate: ["fieldLabelRef"], descendants: true }, { propertyName: "fieldComponents", predicate: FormFieldComponent, descendants: true }], ngImport: i0, template: `
36
+ @if (field()?.group) {
37
+ <div [class]="field()?.groupClass">
38
+ @for (fchild of field()!.group; track fchild) {
39
+ @if (!fchild.hide) {
40
+ <div [class]="fchild.groupClass || fchild.class">
41
+ <form-field
42
+ class="w-full"
43
+ [field]="fchild">
44
+ </form-field>
45
+ </div>
46
+ }
47
+ }
48
+ </div>
49
+ } @else {
50
+ <div [class]="field()?.innerClass || 'px-4 my-1'">
51
+ <div class="flex flex-row flex-nowrap items-start">
52
+ <div
53
+ class="flex-none p-field field-label min-h-8 pt-[1.5px] flex items-center"
54
+ [style]="getStyle()">
55
+ <label
56
+ #label
57
+ [class]="labelClass()"
58
+ fieldLabel
59
+ [field]="field()!"
60
+ [contextMenu]="contextMenu">
61
+ <span
62
+ style="user-select: none"
63
+ #fieldLabelRef
64
+ >{{ props(field()!).i18nKey ? (props(field()!).i18nKey! | translate) : props(field()!).label! }}</span
65
+ >
66
+ @if (props(field()!).required) {
67
+ <span class="field-required">*</span>
68
+ }
69
+ @if (!field()?.fieldControl?.disabled) {
70
+ <span class="iconfont icon-edit-flag field-editable"></span>
71
+ }
72
+ </label>
73
+ </div>
74
+ <div class="flex-1 min-h-8 pt-1 w-0 flex flex-row-reverse">
75
+ <div
76
+ #fieldTypeRef
77
+ class="w-full">
78
+ <form-type [field]="field()!"></form-type>
79
+ </div>
80
+ </div>
81
+ </div>
82
+ </div>
83
+ <app-context-menu
84
+ #contextMenu
85
+ [target]="label"
86
+ [field]="field()!"></app-context-menu>
87
+ }
88
88
  `, isInline: true, styles: [".p-field>label{margin:2px;text-overflow:ellipsis;display:block;color:#1e293b}.p-field>label:not(.ng-valid).ng-dirty{color:var(--p-red-500)!important}.p-field>label:not(.ng-valid).ng-dirty>.field-required{color:var(--p-red-500)!important}.field-required{padding-left:2.5px;color:var(--p-primary-color)}.p-field>label:not(.ng-valid).ng-dirty>.field-editable{color:var(--p-red-500)!important}.field-editable{padding-left:1px;font-size:6px;color:var(--p-primary-color)}.field-label{display:inline-block;overflow-wrap:break-word;word-break:break-word;white-space:normal}\n"], dependencies: [{ kind: "component", type: FormFieldComponent, selector: "form-field", inputs: ["field"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "component", type: FormTypeComponent, selector: "form-type", inputs: ["field"] }, { kind: "pipe", type: TranslatePipe, name: "translate" }, { kind: "directive", type: LabelDirective, selector: "[fieldLabel], [fieldLabel][field], [fieldLabel][contextMenu]", inputs: ["field", "contextMenu"] }, { kind: "component", type: ContextMenuComponent, selector: "app-context-menu", inputs: ["target", "field"] }] }); }
89
89
  }
90
90
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FormFieldComponent, decorators: [{
91
91
  type: Component,
92
- args: [{ selector: 'form-field', standalone: true, imports: [ReactiveFormsModule, FormTypeComponent, TranslatePipe, LabelDirective, ContextMenuComponent], template: `
93
- @if (field()?.group) {
94
- <div [class]="field()?.groupClass">
95
- @for (fchild of field()!.group; track fchild) {
96
- @if (!fchild.hide) {
97
- <div [class]="fchild.groupClass || fchild.class">
98
- <form-field
99
- class="w-full"
100
- [field]="fchild">
101
- </form-field>
102
- </div>
103
- }
104
- }
105
- </div>
106
- } @else {
107
- <div [class]="field()?.innerClass || 'px-4 my-1'">
108
- <div class="flex flex-row flex-nowrap items-start">
109
- <div
110
- class="flex-none p-field field-label min-h-8 pt-[1.5px] flex items-center"
111
- [style]="getStyle()">
112
- <label
113
- #label
114
- [class]="labelClass()"
115
- fieldLabel
116
- [field]="field()!"
117
- [contextMenu]="contextMenu">
118
- <span
119
- style="user-select: none"
120
- #fieldLabelRef
121
- >{{ props(field()!).i18nKey ? (props(field()!).i18nKey! | translate) : props(field()!).label! }}</span
122
- >
123
- @if (props(field()!).required) {
124
- <span class="field-required">*</span>
125
- }
126
- @if (!field()?.fieldControl?.disabled) {
127
- <span class="iconfont icon-edit-flag field-editable"></span>
128
- }
129
- </label>
130
- </div>
131
- <div class="flex-1 min-h-8 pt-1 w-0 flex flex-row-reverse">
132
- <div
133
- #fieldTypeRef
134
- class="w-full">
135
- <form-type [field]="field()!"></form-type>
136
- </div>
137
- </div>
138
- </div>
139
- </div>
140
- <app-context-menu
141
- #contextMenu
142
- [target]="label"
143
- [field]="field()!"></app-context-menu>
144
- }
92
+ args: [{ selector: 'form-field', standalone: true, imports: [ReactiveFormsModule, FormTypeComponent, TranslatePipe, LabelDirective, ContextMenuComponent], template: `
93
+ @if (field()?.group) {
94
+ <div [class]="field()?.groupClass">
95
+ @for (fchild of field()!.group; track fchild) {
96
+ @if (!fchild.hide) {
97
+ <div [class]="fchild.groupClass || fchild.class">
98
+ <form-field
99
+ class="w-full"
100
+ [field]="fchild">
101
+ </form-field>
102
+ </div>
103
+ }
104
+ }
105
+ </div>
106
+ } @else {
107
+ <div [class]="field()?.innerClass || 'px-4 my-1'">
108
+ <div class="flex flex-row flex-nowrap items-start">
109
+ <div
110
+ class="flex-none p-field field-label min-h-8 pt-[1.5px] flex items-center"
111
+ [style]="getStyle()">
112
+ <label
113
+ #label
114
+ [class]="labelClass()"
115
+ fieldLabel
116
+ [field]="field()!"
117
+ [contextMenu]="contextMenu">
118
+ <span
119
+ style="user-select: none"
120
+ #fieldLabelRef
121
+ >{{ props(field()!).i18nKey ? (props(field()!).i18nKey! | translate) : props(field()!).label! }}</span
122
+ >
123
+ @if (props(field()!).required) {
124
+ <span class="field-required">*</span>
125
+ }
126
+ @if (!field()?.fieldControl?.disabled) {
127
+ <span class="iconfont icon-edit-flag field-editable"></span>
128
+ }
129
+ </label>
130
+ </div>
131
+ <div class="flex-1 min-h-8 pt-1 w-0 flex flex-row-reverse">
132
+ <div
133
+ #fieldTypeRef
134
+ class="w-full">
135
+ <form-type [field]="field()!"></form-type>
136
+ </div>
137
+ </div>
138
+ </div>
139
+ </div>
140
+ <app-context-menu
141
+ #contextMenu
142
+ [target]="label"
143
+ [field]="field()!"></app-context-menu>
144
+ }
145
145
  `, styles: [".p-field>label{margin:2px;text-overflow:ellipsis;display:block;color:#1e293b}.p-field>label:not(.ng-valid).ng-dirty{color:var(--p-red-500)!important}.p-field>label:not(.ng-valid).ng-dirty>.field-required{color:var(--p-red-500)!important}.field-required{padding-left:2.5px;color:var(--p-primary-color)}.p-field>label:not(.ng-valid).ng-dirty>.field-editable{color:var(--p-red-500)!important}.field-editable{padding-left:1px;font-size:6px;color:var(--p-primary-color)}.field-label{display:inline-block;overflow-wrap:break-word;word-break:break-word;white-space:normal}\n"] }]
146
146
  }], ctorParameters: () => [], propDecorators: { fieldComponents: [{
147
147
  type: ViewChildren,
@@ -150,4 +150,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
150
150
  type: ViewChild,
151
151
  args: ['fieldLabelRef', { static: false }]
152
152
  }] } });
153
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-field.js","sourceRoot":"","sources":["../../../../../../projects/imm-element-ui/src/lib/form/form-field/form-field.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,SAAS,EAAc,YAAY,EAAqC,MAAM,eAAe,CAAC;AACzH,OAAO,EAAE,mBAAmB,EAAE,MAAM,gBAAgB,CAAC;AACrD,OAAO,EAAE,cAAc,EAAE,MAAM,mBAAmB,CAAC;AACnD,OAAO,EAAE,oBAAoB,EAAE,MAAM,gBAAgB,CAAC;AACtD,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AACpD,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAE3C,OAAO,EACN,iBAAiB,GAajB,MAAM,aAAa,CAAC;;AAoLrB,MAAM,OAAO,kBAAkB;IAM9B;QAHA,UAAK,GAAG,KAAK,EAAa,CAAC;QAC3B,UAAK,GAAG,UAAU,CAAC,KAAK,CAAC;IAEV,CAAC;IAEhB,QAAQ,KAAU,CAAC;IAEnB,UAAU;QACT,MAAM,EAAE,GAAG,EAAE,CAAC;QACd,IAAI,IAAI,CAAC,KAAK,EAAE,EAAE,YAAY,EAAE,KAAK,EAAE,CAAC;YACvC,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QACrB,CAAC;QACD,IAAI,IAAI,CAAC,KAAK,EAAE,EAAE,YAAY,EAAE,KAAK,KAAK,SAAS,IAAI,IAAI,CAAC,KAAK,EAAE,EAAE,YAAY,EAAE,KAAK,KAAK,KAAK,EAAE,CAAC;YACpG,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QACrB,CAAC;QACD,OAAO,EAAE,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IACrB,CAAC;IACD,QAAQ;QACP,OAAO,EAAE,KAAK,EAAE,IAAI,CAAC,KAAK,EAAG,CAAC,aAAc,EAAE,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC;IACnE,CAAC;IACD,kBAAkB;QACjB,OAAO,IAAI,CAAC,eAAe,CAAC;IAC7B,CAAC;IAED,aAAa;QACZ,OAAO,IAAI,CAAC,UAAU,CAAC;IACxB,CAAC;+GA7BW,kBAAkB;mGAAlB,kBAAkB,4UAChB,kBAAkB,gDAxDtB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAqDT,ioBAEW,kBAAkB,yEAxFpB,mBAAmB,+BAAE,iBAAiB,oEAAE,aAAa,kDAAE,cAAc,2IAAE,oBAAoB;;4FAwFzF,kBAAkB;kBA3F9B,SAAS;+BACC,YAAY,cACV,IAAI,WACP,CAAC,mBAAmB,EAAE,iBAAiB,EAAE,aAAa,EAAE,cAAc,EAAE,oBAAoB,CAAC,YAiC5F;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAqDT;wDAGiC,eAAe;sBAAhD,YAAY;uBAAC,kBAAkB;gBACe,UAAU;sBAAxD,SAAS;uBAAC,eAAe,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE","sourcesContent":["import { Component, input, ViewChild, ElementRef, ViewChildren, QueryList, effect, WritableSignal } from '@angular/core';\r\nimport { ReactiveFormsModule } from '@angular/forms';\r\nimport { LabelDirective } from './label.directive';\r\nimport { ContextMenuComponent } from './context-menu';\r\nimport { TranslatePipe } from '@ngx-translate/core';\r\nimport { fieldUtils } from './field-utils';\r\nimport { Observable } from 'rxjs';\r\nimport {\r\n\tFormTypeComponent,\r\n\tInputTextProps,\r\n\tInputNumberProps,\r\n\tSelectProps,\r\n\tTreeSelectProps,\r\n\tDatePickerProps,\r\n\tAutoCompleteProps,\r\n\tMultiSelectProps,\r\n\tRadioProps,\r\n\tTextAreaProps,\r\n\tUploadProps,\r\n\tImageProps,\r\n\tCodeMirrorProps,\r\n} from './form-type';\r\nimport { FieldControl } from './field-control';\r\nimport { FormComponent } from '../form/form.component';\r\n\r\nexport interface FormField {\r\n\tkey?: string;\r\n\ttype?:\r\n\t\t| 'inputtext'\r\n\t\t| 'inputnumber'\r\n\t\t| 'select'\r\n\t\t| 'treeselect'\r\n\t\t| 'datepicker'\r\n\t\t| 'autocomplete'\r\n\t\t| 'multiselect'\r\n\t\t| 'radio'\r\n\t\t| 'textarea'\r\n\t\t| 'upload'\r\n\t\t| 'image'\r\n\t\t| 'codemirror'\r\n\t\t| 'rowselector';\r\n\tdefault?: any;\r\n\tid?: string;\r\n\tname?: string;\r\n\tgroup?: FormField[];\r\n\tgroupClass?: string;\r\n\tclass?: string;\r\n\tinnerClass?: string;\r\n\tfieldControl?: FieldControl;\r\n\tinputTextProps?: InputTextProps;\r\n\tinputNumberProps?: InputNumberProps;\r\n\tselectProps?: SelectProps;\r\n\ttreeSelectProps?: TreeSelectProps;\r\n\tdatePickerProps?: DatePickerProps;\r\n\tautoCompleteProps?: AutoCompleteProps;\r\n\tmultiSelectProps?: MultiSelectProps;\r\n\tradioProps?: RadioProps;\r\n\ttextAreaProps?: TextAreaProps;\r\n\tuploadProps?: UploadProps;\r\n\timageProps?: ImageProps;\r\n\tcodeMirrorProps?: CodeMirrorProps;\r\n\trowSelectorProps?: any;\r\n\thide?: boolean;\r\n\thideExpression?: (model: any, field?: FormField) => boolean;\r\n\thook?: Observable<(field?: FormField) => void>;\r\n\tvalidators?: any;\r\n\tinvalid?: boolean;\r\n\textra?: any;\r\n\tuuid?: string;\r\n\tlabelMinWidth?: WritableSignal<string | undefined>;\r\n\tinteractiveLabel?: boolean;\r\n\tform?: FormComponent;\r\n}\r\n\r\nexport interface FieldProps {\r\n\ttype?: string;\r\n\tlabel?: string;\r\n\ti18nKey?: string;\r\n\tlabelClass?: string;\r\n\tlabelVariant?: 'in' | 'over' | 'on';\r\n\tvariant?: any;\r\n\tclass?: string;\r\n\tname?: string;\r\n\tplaceholder?: string;\r\n\tdisabled?: boolean;\r\n\thidden?: boolean;\r\n\trequired?: boolean;\r\n\tsize?: any;\r\n\tstyleClass?: string;\r\n\tstyle?: any;\r\n\tautofocus?: boolean;\r\n\tmin?: number;\r\n\tmax?: number;\r\n\tinputStyle?: any;\r\n\tinputStyleClass?: string;\r\n\tfluid?: boolean;\r\n\tariaLabel?: string;\r\n\tariaLabelledBy?: string;\r\n\tfocus?: FocusEvent;\r\n\tblur?: FocusEvent;\r\n\tkeyup?: KeyboardEvent;\r\n\tkeydown?: KeyboardEvent;\r\n\tclick?: MouseEvent;\r\n\tinput?: Event;\r\n\tchange?: Event;\r\n\tkeypress?: KeyboardEvent;\r\n}\r\n\r\nexport declare type AttributeEvent = (field: FormField, event?: any) => void;\r\n\r\n@Component({\r\n\tselector: 'form-field',\r\n\tstandalone: true,\r\n\timports: [ReactiveFormsModule, FormTypeComponent, TranslatePipe, LabelDirective, ContextMenuComponent],\r\n\tstyles: `\r\n\t\t.p-field > label {\r\n\t\t\tmargin: 2px;\r\n\t\t\ttext-overflow: ellipsis;\r\n\t\t\tdisplay: block;\r\n\t\t\tcolor: #1e293b;\r\n\t\t}\r\n\t\t.p-field > label:not(.ng-valid).ng-dirty {\r\n\t\t\tcolor: var(--p-red-500) !important;\r\n\t\t}\r\n\t\t.p-field > label:not(.ng-valid).ng-dirty > .field-required {\r\n\t\t\tcolor: var(--p-red-500) !important;\r\n\t\t}\r\n\t\t.field-required {\r\n\t\t\tpadding-left: 2.5px;\r\n\t\t\tcolor: var(--p-primary-color);\r\n\t\t}\r\n\t\t.p-field > label:not(.ng-valid).ng-dirty > .field-editable {\r\n\t\t\tcolor: var(--p-red-500) !important;\r\n\t\t}\r\n\t\t.field-editable {\r\n\t\t\tpadding-left: 1px;\r\n\t\t\tfont-size: 6px;\r\n\t\t\tcolor: var(--p-primary-color);\r\n\t\t}\r\n\t\t.field-label {\r\n\t\t\tdisplay: inline-block;\r\n\t\t\toverflow-wrap: break-word;\r\n\t\t\tword-break: break-word;\r\n\t\t\twhite-space: normal;\r\n\t\t}\r\n\t`,\r\n\ttemplate: `\r\n\t\t@if (field()?.group) {\r\n\t\t\t<div [class]=\"field()?.groupClass\">\r\n\t\t\t\t@for (fchild of field()!.group; track fchild) {\r\n\t\t\t\t\t@if (!fchild.hide) {\r\n\t\t\t\t\t\t<div [class]=\"fchild.groupClass || fchild.class\">\r\n\t\t\t\t\t\t\t<form-field\r\n\t\t\t\t\t\t\t\tclass=\"w-full\"\r\n\t\t\t\t\t\t\t\t[field]=\"fchild\">\r\n\t\t\t\t\t\t\t</form-field>\r\n\t\t\t\t\t\t</div>\r\n\t\t\t\t\t}\r\n\t\t\t\t}\r\n\t\t\t</div>\r\n\t\t} @else {\r\n\t\t\t<div [class]=\"field()?.innerClass || 'px-4 my-1'\">\r\n\t\t\t\t<div class=\"flex flex-row flex-nowrap items-start\">\r\n\t\t\t\t\t<div\r\n\t\t\t\t\t\tclass=\"flex-none p-field field-label min-h-8 pt-[1.5px] flex items-center\"\r\n\t\t\t\t\t\t[style]=\"getStyle()\">\r\n\t\t\t\t\t\t<label\r\n\t\t\t\t\t\t\t#label\r\n\t\t\t\t\t\t\t[class]=\"labelClass()\"\r\n\t\t\t\t\t\t\tfieldLabel\r\n\t\t\t\t\t\t\t[field]=\"field()!\"\r\n\t\t\t\t\t\t\t[contextMenu]=\"contextMenu\">\r\n\t\t\t\t\t\t\t<span\r\n\t\t\t\t\t\t\t\tstyle=\"user-select: none\"\r\n\t\t\t\t\t\t\t\t#fieldLabelRef\r\n\t\t\t\t\t\t\t\t>{{ props(field()!).i18nKey ? (props(field()!).i18nKey! | translate) : props(field()!).label! }}</span\r\n\t\t\t\t\t\t\t>\r\n\t\t\t\t\t\t\t@if (props(field()!).required) {\r\n\t\t\t\t\t\t\t\t<span class=\"field-required\">*</span>\r\n\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t\t@if (!field()?.fieldControl?.disabled) {\r\n\t\t\t\t\t\t\t\t<span class=\"iconfont icon-edit-flag field-editable\"></span>\r\n\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t</label>\r\n\t\t\t\t\t</div>\r\n\t\t\t\t\t<div class=\"flex-1 min-h-8 pt-1 w-0 flex flex-row-reverse\">\r\n\t\t\t\t\t\t<div\r\n\t\t\t\t\t\t\t#fieldTypeRef\r\n\t\t\t\t\t\t\tclass=\"w-full\">\r\n\t\t\t\t\t\t\t<form-type [field]=\"field()!\"></form-type>\r\n\t\t\t\t\t\t</div>\r\n\t\t\t\t\t</div>\r\n\t\t\t\t</div>\r\n\t\t\t</div>\r\n\t\t\t<app-context-menu\r\n\t\t\t\t#contextMenu\r\n\t\t\t\t[target]=\"label\"\r\n\t\t\t\t[field]=\"field()!\"></app-context-menu>\r\n\t\t}\r\n\t`,\r\n})\r\nexport class FormFieldComponent {\r\n\t@ViewChildren(FormFieldComponent) fieldComponents?: QueryList<FormFieldComponent>;\r\n\t@ViewChild('fieldLabelRef', { static: false }) fieldLabel?: ElementRef;\r\n\tfield = input<FormField>();\r\n\tprops = fieldUtils.props;\r\n\r\n\tconstructor() {}\r\n\r\n\tngOnInit(): void {}\r\n\r\n\tlabelClass() {\r\n\t\tconst lc = [];\r\n\t\tif (this.field()?.fieldControl?.dirty) {\r\n\t\t\tlc.push('ng-dirty');\r\n\t\t}\r\n\t\tif (this.field()?.fieldControl?.valid !== undefined && this.field()?.fieldControl?.valid !== false) {\r\n\t\t\tlc.push('ng-valid');\r\n\t\t}\r\n\t\treturn lc.join(' ');\r\n\t}\r\n\tgetStyle() {\r\n\t\treturn { width: this.field()!.labelMinWidth!(), maxWidth: '40%' };\r\n\t}\r\n\tgetFieldComponents(): QueryList<FormFieldComponent> | undefined {\r\n\t\treturn this.fieldComponents;\r\n\t}\r\n\r\n\tgetFieldLabel() {\r\n\t\treturn this.fieldLabel;\r\n\t}\r\n}\r\n"]}
153
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-field.js","sourceRoot":"","sources":["../../../../../../projects/imm-element-ui/src/lib/form/form-field/form-field.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,SAAS,EAAc,YAAY,EAAqC,MAAM,eAAe,CAAC;AACzH,OAAO,EAAE,mBAAmB,EAAE,MAAM,gBAAgB,CAAC;AACrD,OAAO,EAAE,cAAc,EAAE,MAAM,mBAAmB,CAAC;AACnD,OAAO,EAAE,oBAAoB,EAAE,MAAM,gBAAgB,CAAC;AACtD,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AACpD,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAE3C,OAAO,EACN,iBAAiB,GAajB,MAAM,aAAa,CAAC;;AAsLrB,MAAM,OAAO,kBAAkB;IAM9B;QAHA,UAAK,GAAG,KAAK,EAAa,CAAC;QAC3B,UAAK,GAAG,UAAU,CAAC,KAAK,CAAC;IAEV,CAAC;IAEhB,QAAQ,KAAU,CAAC;IAEnB,UAAU;QACT,MAAM,EAAE,GAAG,EAAE,CAAC;QACd,IAAI,IAAI,CAAC,KAAK,EAAE,EAAE,YAAY,EAAE,KAAK,EAAE,CAAC;YACvC,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QACrB,CAAC;QACD,IAAI,IAAI,CAAC,KAAK,EAAE,EAAE,YAAY,EAAE,KAAK,KAAK,SAAS,IAAI,IAAI,CAAC,KAAK,EAAE,EAAE,YAAY,EAAE,KAAK,KAAK,KAAK,EAAE,CAAC;YACpG,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QACrB,CAAC;QACD,OAAO,EAAE,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IACrB,CAAC;IACD,QAAQ;QACP,OAAO,EAAE,KAAK,EAAE,IAAI,CAAC,KAAK,EAAG,CAAC,aAAc,EAAE,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC;IACnE,CAAC;IACD,kBAAkB;QACjB,OAAO,IAAI,CAAC,eAAe,CAAC;IAC7B,CAAC;IAED,aAAa;QACZ,OAAO,IAAI,CAAC,UAAU,CAAC;IACxB,CAAC;+GA7BW,kBAAkB;mGAAlB,kBAAkB,4UAChB,kBAAkB,gDAxDtB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAqDT,ioBAEW,kBAAkB,yEAxFpB,mBAAmB,+BAAE,iBAAiB,oEAAE,aAAa,kDAAE,cAAc,2IAAE,oBAAoB;;4FAwFzF,kBAAkB;kBA3F9B,SAAS;+BACC,YAAY,cACV,IAAI,WACP,CAAC,mBAAmB,EAAE,iBAAiB,EAAE,aAAa,EAAE,cAAc,EAAE,oBAAoB,CAAC,YAiC5F;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAqDT;wDAGiC,eAAe;sBAAhD,YAAY;uBAAC,kBAAkB;gBACe,UAAU;sBAAxD,SAAS;uBAAC,eAAe,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE","sourcesContent":["import { Component, input, ViewChild, ElementRef, ViewChildren, QueryList, effect, WritableSignal } from '@angular/core';\nimport { ReactiveFormsModule } from '@angular/forms';\nimport { LabelDirective } from './label.directive';\nimport { ContextMenuComponent } from './context-menu';\nimport { TranslatePipe } from '@ngx-translate/core';\nimport { fieldUtils } from './field-utils';\nimport { Observable } from 'rxjs';\nimport {\n\tFormTypeComponent,\n\tInputTextProps,\n\tInputNumberProps,\n\tSelectProps,\n\tTreeSelectProps,\n\tDatePickerProps,\n\tAutoCompleteProps,\n\tMultiSelectProps,\n\tRadioProps,\n\tTextAreaProps,\n\tUploadProps,\n\tImageProps,\n\tCodeMirrorProps,\n} from './form-type';\nimport { FieldControl } from './field-control';\nimport { FormComponent } from '../form/form.component';\n\nexport interface FormField {\n\tkey?: string;\n\ttype?:\n\t\t| 'inputtext'\n\t\t| 'inputnumber'\n\t\t| 'select'\n\t\t| 'treeselect'\n\t\t| 'datepicker'\n\t\t| 'autocomplete'\n\t\t| 'multiselect'\n\t\t| 'radio'\n\t\t| 'textarea'\n\t\t| 'upload'\n\t\t| 'image'\n\t\t| 'codemirror'\n\t\t| 'rowselector';\n\tdefault?: any;\n\tid?: string;\n\tname?: string;\n\tgroup?: FormField[];\n\tgroupClass?: string;\n\tclass?: string;\n\tinnerClass?: string;\n\tfieldControl?: FieldControl;\n\tinputTextProps?: InputTextProps;\n\tinputNumberProps?: InputNumberProps;\n\tselectProps?: SelectProps;\n\ttreeSelectProps?: TreeSelectProps;\n\tdatePickerProps?: DatePickerProps;\n\tautoCompleteProps?: AutoCompleteProps;\n\tmultiSelectProps?: MultiSelectProps;\n\tradioProps?: RadioProps;\n\ttextAreaProps?: TextAreaProps;\n\tuploadProps?: UploadProps;\n\timageProps?: ImageProps;\n\tcodeMirrorProps?: CodeMirrorProps;\n\trowSelectorProps?: any;\n\thide?: boolean;\n\thideExpression?: (model: any, field?: FormField) => boolean;\n\thook?: Observable<(field?: FormField) => void>;\n\tvalidators?: any;\n\tinvalid?: boolean;\n\textra?: any;\n\tuuid?: string;\n\tlabelMinWidth?: WritableSignal<string | undefined>;\n\tinteractiveLabel?: boolean;\n\tform?: FormComponent;\n}\n\nexport interface FieldProps {\n\ttype?: string;\n\tlabel?: string;\n\ti18nKey?: string;\n\tlabelClass?: string;\n\tlabelVariant?: 'in' | 'over' | 'on';\n\tvariant?: any;\n\tclass?: string;\n\tname?: string;\n\tplaceholder?: string;\n\tdisabled?: boolean;\n\thidden?: boolean;\n\trequired?: boolean;\n\tsize?: any;\n\tstyleClass?: string;\n\tstyle?: any;\n\tautofocus?: boolean;\n\tmin?: number;\n\tmax?: number;\n\tinputStyle?: any;\n\tinputStyleClass?: string;\n\tfluid?: boolean;\n\tariaLabel?: string;\n\tariaLabelledBy?: string;\n\tfocus?: FocusEvent;\n\tblur?: FocusEvent;\n\tkeyup?: KeyboardEvent;\n\tkeydown?: KeyboardEvent;\n\tclick?: MouseEvent;\n\tinput?: Event;\n\tchange?: Event;\n\tkeypress?: KeyboardEvent;\n\tonModelChange?: AttributeEvent;\n\tonHookChange?: AttributeEvent;\n}\n\nexport declare type AttributeEvent = (field: FormField, event?: any) => void;\n\n@Component({\n\tselector: 'form-field',\n\tstandalone: true,\n\timports: [ReactiveFormsModule, FormTypeComponent, TranslatePipe, LabelDirective, ContextMenuComponent],\n\tstyles: `\n\t\t.p-field > label {\n\t\t\tmargin: 2px;\n\t\t\ttext-overflow: ellipsis;\n\t\t\tdisplay: block;\n\t\t\tcolor: #1e293b;\n\t\t}\n\t\t.p-field > label:not(.ng-valid).ng-dirty {\n\t\t\tcolor: var(--p-red-500) !important;\n\t\t}\n\t\t.p-field > label:not(.ng-valid).ng-dirty > .field-required {\n\t\t\tcolor: var(--p-red-500) !important;\n\t\t}\n\t\t.field-required {\n\t\t\tpadding-left: 2.5px;\n\t\t\tcolor: var(--p-primary-color);\n\t\t}\n\t\t.p-field > label:not(.ng-valid).ng-dirty > .field-editable {\n\t\t\tcolor: var(--p-red-500) !important;\n\t\t}\n\t\t.field-editable {\n\t\t\tpadding-left: 1px;\n\t\t\tfont-size: 6px;\n\t\t\tcolor: var(--p-primary-color);\n\t\t}\n\t\t.field-label {\n\t\t\tdisplay: inline-block;\n\t\t\toverflow-wrap: break-word;\n\t\t\tword-break: break-word;\n\t\t\twhite-space: normal;\n\t\t}\n\t`,\n\ttemplate: `\n\t\t@if (field()?.group) {\n\t\t\t<div [class]=\"field()?.groupClass\">\n\t\t\t\t@for (fchild of field()!.group; track fchild) {\n\t\t\t\t\t@if (!fchild.hide) {\n\t\t\t\t\t\t<div [class]=\"fchild.groupClass || fchild.class\">\n\t\t\t\t\t\t\t<form-field\n\t\t\t\t\t\t\t\tclass=\"w-full\"\n\t\t\t\t\t\t\t\t[field]=\"fchild\">\n\t\t\t\t\t\t\t</form-field>\n\t\t\t\t\t\t</div>\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t</div>\n\t\t} @else {\n\t\t\t<div [class]=\"field()?.innerClass || 'px-4 my-1'\">\n\t\t\t\t<div class=\"flex flex-row flex-nowrap items-start\">\n\t\t\t\t\t<div\n\t\t\t\t\t\tclass=\"flex-none p-field field-label min-h-8 pt-[1.5px] flex items-center\"\n\t\t\t\t\t\t[style]=\"getStyle()\">\n\t\t\t\t\t\t<label\n\t\t\t\t\t\t\t#label\n\t\t\t\t\t\t\t[class]=\"labelClass()\"\n\t\t\t\t\t\t\tfieldLabel\n\t\t\t\t\t\t\t[field]=\"field()!\"\n\t\t\t\t\t\t\t[contextMenu]=\"contextMenu\">\n\t\t\t\t\t\t\t<span\n\t\t\t\t\t\t\t\tstyle=\"user-select: none\"\n\t\t\t\t\t\t\t\t#fieldLabelRef\n\t\t\t\t\t\t\t\t>{{ props(field()!).i18nKey ? (props(field()!).i18nKey! | translate) : props(field()!).label! }}</span\n\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t@if (props(field()!).required) {\n\t\t\t\t\t\t\t\t<span class=\"field-required\">*</span>\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t\t@if (!field()?.fieldControl?.disabled) {\n\t\t\t\t\t\t\t\t<span class=\"iconfont icon-edit-flag field-editable\"></span>\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t</label>\n\t\t\t\t\t</div>\n\t\t\t\t\t<div class=\"flex-1 min-h-8 pt-1 w-0 flex flex-row-reverse\">\n\t\t\t\t\t\t<div\n\t\t\t\t\t\t\t#fieldTypeRef\n\t\t\t\t\t\t\tclass=\"w-full\">\n\t\t\t\t\t\t\t<form-type [field]=\"field()!\"></form-type>\n\t\t\t\t\t\t</div>\n\t\t\t\t\t</div>\n\t\t\t\t</div>\n\t\t\t</div>\n\t\t\t<app-context-menu\n\t\t\t\t#contextMenu\n\t\t\t\t[target]=\"label\"\n\t\t\t\t[field]=\"field()!\"></app-context-menu>\n\t\t}\n\t`,\n})\nexport class FormFieldComponent {\n\t@ViewChildren(FormFieldComponent) fieldComponents?: QueryList<FormFieldComponent>;\n\t@ViewChild('fieldLabelRef', { static: false }) fieldLabel?: ElementRef;\n\tfield = input<FormField>();\n\tprops = fieldUtils.props;\n\n\tconstructor() {}\n\n\tngOnInit(): void {}\n\n\tlabelClass() {\n\t\tconst lc = [];\n\t\tif (this.field()?.fieldControl?.dirty) {\n\t\t\tlc.push('ng-dirty');\n\t\t}\n\t\tif (this.field()?.fieldControl?.valid !== undefined && this.field()?.fieldControl?.valid !== false) {\n\t\t\tlc.push('ng-valid');\n\t\t}\n\t\treturn lc.join(' ');\n\t}\n\tgetStyle() {\n\t\treturn { width: this.field()!.labelMinWidth!(), maxWidth: '40%' };\n\t}\n\tgetFieldComponents(): QueryList<FormFieldComponent> | undefined {\n\t\treturn this.fieldComponents;\n\t}\n\n\tgetFieldLabel() {\n\t\treturn this.fieldLabel;\n\t}\n}\n"]}