imm-element-ui 0.2.8 → 0.3.0
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.
- package/esm2022/lib/form/form/form.component.mjs +5 -3
- package/esm2022/lib/page-form/page-form.component.mjs +15 -7
- package/esm2022/lib/steps/steps.component.mjs +12 -7
- package/fesm2022/imm-element-ui.mjs +28 -13
- package/fesm2022/imm-element-ui.mjs.map +1 -1
- package/lib/page-form/page-form.component.d.ts +1 -1
- package/lib/steps/steps.component.d.ts +1 -0
- package/package.json +1 -1
|
@@ -8,7 +8,7 @@ import { I18nService } from '../../service/i18n.service';
|
|
|
8
8
|
import { fieldUtils } from '../form-field/field-utils';
|
|
9
9
|
import { generateUniqueId } from '../../share/utils';
|
|
10
10
|
import { Router } from '@angular/router';
|
|
11
|
-
import { shareReplay } from 'rxjs';
|
|
11
|
+
import { isObservable, shareReplay } from 'rxjs';
|
|
12
12
|
import * as i0 from "@angular/core";
|
|
13
13
|
import * as i1 from "@angular/common";
|
|
14
14
|
export class FormComponent {
|
|
@@ -84,7 +84,9 @@ export class FormComponent {
|
|
|
84
84
|
field.labelMinWidth = this.labelMinWidth;
|
|
85
85
|
field.interactiveLabel = this.options().interactiveLabel ?? true;
|
|
86
86
|
field.form = this;
|
|
87
|
-
|
|
87
|
+
if (isObservable(field.hook)) {
|
|
88
|
+
this.uniqueHook(field, field.hook);
|
|
89
|
+
}
|
|
88
90
|
this.handleFieldControl(field);
|
|
89
91
|
});
|
|
90
92
|
}
|
|
@@ -218,4 +220,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
218
220
|
type: HostListener,
|
|
219
221
|
args: ['window:resize', ['$event']]
|
|
220
222
|
}] } });
|
|
221
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form.component.js","sourceRoot":"","sources":["../../../../../../projects/imm-element-ui/src/lib/form/form/form.component.ts","../../../../../../projects/imm-element-ui/src/lib/form/form/form.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n\tComponent,\r\n\teffect,\r\n\tinput,\r\n\tcomputed,\r\n\tViewChildren,\r\n\tQueryList,\r\n\tElementRef,\r\n\tChangeDetectorRef,\r\n\tinject,\r\n\tHostListener,\r\n\tuntracked,\r\n\tsignal,\r\n} from '@angular/core';\r\nimport { CommonModule } from '@angular/common';\r\nimport { FormGroup, Validators, ReactiveFormsModule, FormSubmittedEvent } from '@angular/forms';\r\nimport { FieldControl } from '../form-field/field-control';\r\nimport { FormField, FormFieldComponent } from '../form-field/form-field';\r\nimport { DatePipe } from '@angular/common';\r\nimport { I18nService } from '../../service/i18n.service';\r\nimport { fieldUtils } from '../form-field/field-utils';\r\nimport { Upsert } from '../../am/am.component';\r\nimport { generateUniqueId } from '../../share/utils';\r\nimport { Router } from '@angular/router';\r\nimport { Observable, shareReplay } from 'rxjs';\r\nexport interface FormOptions {\r\n\tfields?: FormField[];\r\n\tform?: FormGroup;\r\n\tmainField?: string;\r\n\tlabelWidth?: string;\r\n\tinteractiveLabel?: boolean;\r\n\textra?: any;\r\n}\r\n\r\n@Component({\r\n\tselector: 'custom-form',\r\n\tstandalone: true,\r\n\timports: [CommonModule, ReactiveFormsModule, FormFieldComponent],\r\n\tproviders: [DatePipe],\r\n\ttemplateUrl: './form.component.html',\r\n\tstyleUrl: './form.component.scss',\r\n})\r\nexport class FormComponent {\r\n\t@ViewChildren(FormFieldComponent) fieldComponents?: QueryList<FormFieldComponent>;\r\n\trouter: Router = inject(Router);\r\n\tisNew: boolean = false;\r\n\toptions = input<FormOptions>({});\r\n\tfields = computed(() => {\r\n\t\tuntracked(() => {\r\n\t\t\tthis.initForm();\r\n\t\t\tsetTimeout(() => {\r\n\t\t\t\tthis.reCalcLabelSize();\r\n\t\t\t});\r\n\t\t});\r\n\t\treturn this.options().fields;\r\n\t});\r\n\r\n\ti18nService = inject(I18nService);\r\n\tmodel = input<any>();\r\n\tupsert = input<Upsert>();\r\n\trawModel: any = {};\r\n\tchangedModel: any = {};\r\n\tfieldList!: FormField[];\r\n\thookObservers: Function[] = [];\r\n\tlabelMinWidth = signal<string | undefined>(undefined);\r\n\r\n\t@HostListener('window:resize', ['$event'])\r\n\tonResize() {\r\n\t\tthis.reCalcLabelSize();\r\n\t}\r\n\r\n\tconstructor(\r\n\t\tprivate cdr: ChangeDetectorRef,\r\n\t\tprivate datePipe: DatePipe,\r\n\t) {\r\n\t\tthis.router.url.split('/').pop() == 'new' && (this.isNew = true);\r\n\t\teffect(\r\n\t\t\t() => {\r\n\t\t\t\tif (!this.model()) {\r\n\t\t\t\t\treturn;\r\n\t\t\t\t}\r\n\t\t\t\t// 默认值仅在表单新建时生效\r\n\t\t\t\tif (this.isNew) {\r\n\t\t\t\t\tthis.fieldList.forEach((field) => {\r\n\t\t\t\t\t\tif (!field.default) return;\r\n\t\t\t\t\t\tif (this.model()[field.key!] !== undefined) return;\r\n\t\t\t\t\t\tuntracked(() => {\r\n\t\t\t\t\t\t\tthis.handleValueChange(field.default, field);\r\n\t\t\t\t\t\t});\r\n\t\t\t\t\t});\r\n\t\t\t\t}\r\n\t\t\t\tthis.rawModel = { ...this.model() };\r\n\t\t\t\tthis.changedModel = {};\r\n\t\t\t\tuntracked(() => this.triggerHook());\r\n\t\t\t},\r\n\t\t\t{ allowSignalWrites: true },\r\n\t\t);\r\n\t}\r\n\r\n\tngAfterViewInit(): void {\r\n\t\tsetTimeout(() => {\r\n\t\t\tthis.reCalcLabelSize();\r\n\t\t});\r\n\t\tthis.i18nService.change.subscribe((res) => {\r\n\t\t\tthis.reCalcLabelSize();\r\n\t\t});\r\n\t}\r\n\r\n\tngOnDestroy() {\r\n\t\tthis.hookObservers.forEach((unsubscribe) => unsubscribe());\r\n\t}\r\n\r\n\tinitForm() {\r\n\t\tif (!this.options().extra) {\r\n\t\t\tthis.options().extra = {};\r\n\t\t}\r\n\t\tif (!this.options().form) {\r\n\t\t\tthis.options().form = new FormGroup({});\r\n\t\t}\r\n\t\tthis.fieldList = [];\r\n\t\tthis.parseFields(this.options().fields || []);\r\n\t\tthis.fieldList.forEach((field) => {\r\n\t\t\tfield.uuid = generateUniqueId();\r\n\t\t\tfield.labelMinWidth = this.labelMinWidth;\r\n\t\t\tfield.interactiveLabel = this.options().interactiveLabel ?? true;\r\n\t\t\tfield.form = this;\r\n\t\t\tfield.hook && this.uniqueHook(field, field.hook);\r\n\t\t\tthis.handleFieldControl(field);\r\n\t\t});\r\n\t}\r\n\r\n\tgetField(key: string) {\r\n\t\treturn this.fieldList.find((field) => field.key === key);\r\n\t}\r\n\r\n\tparseFields(fields: FormField[]) {\r\n\t\tfields.forEach((field) => {\r\n\t\t\tif (field.group) {\r\n\t\t\t\tthis.parseFields(field.group);\r\n\t\t\t} else {\r\n\t\t\t\tthis.fieldList.push(field);\r\n\t\t\t}\r\n\t\t});\r\n\t}\r\n\r\n\thandleFieldControl(field: FormField) {\r\n\t\tconst fieldControl = fieldUtils.props(field).required\r\n\t\t\t? new FieldControl(null, field.validators ? field.validators : Validators.required)\r\n\t\t\t: new FieldControl(null);\r\n\t\tthis.options().form?.addControl(field.key || '', fieldControl);\r\n\t\tfield.fieldControl = fieldControl;\r\n\t\tfield.fieldControl?.valueChanges.subscribe((value) => {\r\n\t\t\tconst targetValue = fieldUtils.fromFieldValue(field, value, this.datePipe);\r\n\t\t\tif (fieldUtils.isFakedChange(targetValue, this.model()[field.key!], field)) {\r\n\t\t\t\treturn;\r\n\t\t\t}\r\n\t\t\tthis.handleValueChange(targetValue, field);\r\n\t\t});\r\n\t}\r\n\r\n\thandleValueChange(value: any, field: FormField) {\r\n\t\tthis.model()[field.key!] = value;\r\n\t\tthis.changedModel[field.key!] = { name: fieldUtils.label(field, this.i18nService), value: value, type: field.type };\r\n\t\tthis.handleUpsert(field.key!, value);\r\n\t\tconsole.log('-----handleValueChange', this.upsert());\r\n\t\tthis.handleHideExpression();\r\n\t}\r\n\r\n\thandleUpsert(key: string, value: any) {\r\n\t\tif (this.isNew) {\r\n\t\t\tthis.upsert()!.addData![key] = value;\r\n\t\t} else {\r\n\t\t\tthis.upsert()!.updData![key] = value;\r\n\t\t}\r\n\t\tthis.upsert()!.log!.content = fieldUtils.transLog(\r\n\t\t\tthis.rawModel,\r\n\t\t\tthis.changedModel,\r\n\t\t\tthis.model()[this.options().mainField!],\r\n\t\t\tthis.isNew,\r\n\t\t);\r\n\t}\r\n\r\n\thandleHideExpression() {\r\n\t\tthis.fieldList.forEach((field) => {\r\n\t\t\tif (field.hideExpression) {\r\n\t\t\t\tfield.hide = field.hideExpression(this.model(), field);\r\n\t\t\t\tif (field.hide) {\r\n\t\t\t\t\tthis.options().form?.controls[field.key!].disable({ emitEvent: false });\r\n\t\t\t\t} else {\r\n\t\t\t\t\tthis.options().form?.controls[field.key!].enable({ emitEvent: false });\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t});\r\n\t}\r\n\r\n\tvalidate() {\r\n\t\tfor (let key in this.options().form?.controls) {\r\n\t\t\t!this.options().form?.controls[key]['disabled'] && this.options().form?.controls[key].markAsDirty();\r\n\t\t}\r\n\t\treturn this.options().form?.valid;\r\n\t}\r\n\r\n\tuniqueHook(field: FormField, hook: Observable<(field?: FormField) => void>) {\r\n\t\tfield.hook = hook.pipe(shareReplay(1));\r\n\t}\r\n\r\n\ttriggerHook() {\r\n\t\tthis.fieldList.forEach((field) => {\r\n\t\t\tfieldUtils.triggerHookAndSetValue(\r\n\t\t\t\tfield,\r\n\t\t\t\tthis.model()?.[field.key!],\r\n\t\t\t\t['upload', 'image', 'codemirror', 'radio', 'select'].includes(field.type!),\r\n\t\t\t\tthis.hookObservers,\r\n\t\t\t\t() => {\r\n\t\t\t\t\tthis.handleHideExpression();\r\n\t\t\t\t},\r\n\t\t\t\tthis.datePipe,\r\n\t\t\t);\r\n\t\t});\r\n\t}\r\n\r\n\treCalcLabelSize() {\r\n\t\tif (this.options().labelWidth) {\r\n\t\t\tthis.labelMinWidth.set(this.options().labelWidth);\r\n\t\t\treturn;\r\n\t\t}\r\n\t\tthis.labelMinWidth.set(undefined);\r\n\t\tthis.cdr.detectChanges();\r\n\t\tthis.handleFieldLabels();\r\n\t\tthis.cdr.detectChanges();\r\n\t}\r\n\r\n\thandleFieldLabels() {\r\n\t\tconst fieldLabels: ElementRef[] = [];\r\n\t\tthis.getFieldLabels(this.fieldComponents, fieldLabels);\r\n\t\tconst offsetWidths = fieldLabels.map((fieldLabel) => fieldLabel.nativeElement.offsetWidth);\r\n\t\tthis.labelMinWidth.set(Math.max(...offsetWidths) + 18 + 'px');\r\n\t}\r\n\r\n\tgetFieldLabels(fieldComponents: QueryList<FormFieldComponent> | undefined, fieldLabels: ElementRef[]) {\r\n\t\tif (!fieldComponents) {\r\n\t\t\treturn;\r\n\t\t}\r\n\t\tfieldComponents?.forEach((component) => {\r\n\t\t\tconst fieldLabel = component.getFieldLabel();\r\n\t\t\tif (fieldLabel) {\r\n\t\t\t\tfieldLabels.push(fieldLabel);\r\n\t\t\t}\r\n\t\t\tthis.getFieldLabels(component.getFieldComponents(), fieldLabels);\r\n\t\t});\r\n\t}\r\n\r\n\ttriggerModelEffect(model: any) {\r\n\t\tObject.keys(model).forEach((key) => {\r\n\t\t\tconst field = this.getField(key)!;\r\n\t\t\tif (!field) return;\r\n\t\t\tfieldUtils.triggerHookAndSetValue(\r\n\t\t\t\tfield,\r\n\t\t\t\tmodel[key],\r\n\t\t\t\t['upload', 'image', 'codemirror', 'radio', 'select'].includes(field.type!),\r\n\t\t\t\tthis.hookObservers,\r\n\t\t\t\t() => {\r\n\t\t\t\t\tthis.handleHideExpression();\r\n\t\t\t\t},\r\n\t\t\t\tthis.datePipe,\r\n\t\t\t);\r\n\t\t});\r\n\t}\r\n\r\n\tfinalize() {\r\n\t\tthis.fieldList.forEach((field) => {\r\n\t\t\tif (['image', 'upload'].includes(field.type!)) {\r\n\t\t\t\tfield.fieldControl?.afterSubmit();\r\n\t\t\t}\r\n\t\t});\r\n\t}\r\n}\r\n","@for (field of fields(); track field) {\r\n\t<form-field\r\n\t\tclass=\"w-full\"\r\n\t\t[field]=\"field\">\r\n\t</form-field>\r\n}\r\n"]}
|
|
223
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form.component.js","sourceRoot":"","sources":["../../../../../../projects/imm-element-ui/src/lib/form/form/form.component.ts","../../../../../../projects/imm-element-ui/src/lib/form/form/form.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n\tComponent,\r\n\teffect,\r\n\tinput,\r\n\tcomputed,\r\n\tViewChildren,\r\n\tQueryList,\r\n\tElementRef,\r\n\tChangeDetectorRef,\r\n\tinject,\r\n\tHostListener,\r\n\tuntracked,\r\n\tsignal,\r\n} from '@angular/core';\r\nimport { CommonModule } from '@angular/common';\r\nimport { FormGroup, Validators, ReactiveFormsModule, FormSubmittedEvent } from '@angular/forms';\r\nimport { FieldControl } from '../form-field/field-control';\r\nimport { FormField, FormFieldComponent } from '../form-field/form-field';\r\nimport { DatePipe } from '@angular/common';\r\nimport { I18nService } from '../../service/i18n.service';\r\nimport { fieldUtils } from '../form-field/field-utils';\r\nimport { Upsert } from '../../am/am.component';\r\nimport { generateUniqueId } from '../../share/utils';\r\nimport { Router } from '@angular/router';\r\nimport { isObservable, Observable, shareReplay } from 'rxjs';\r\nexport interface FormOptions {\r\n\tfields?: FormField[];\r\n\tform?: FormGroup;\r\n\tmainField?: string;\r\n\tlabelWidth?: string;\r\n\tinteractiveLabel?: boolean;\r\n\textra?: any;\r\n}\r\n\r\n@Component({\r\n\tselector: 'custom-form',\r\n\tstandalone: true,\r\n\timports: [CommonModule, ReactiveFormsModule, FormFieldComponent],\r\n\tproviders: [DatePipe],\r\n\ttemplateUrl: './form.component.html',\r\n\tstyleUrl: './form.component.scss',\r\n})\r\nexport class FormComponent {\r\n\t@ViewChildren(FormFieldComponent) fieldComponents?: QueryList<FormFieldComponent>;\r\n\trouter: Router = inject(Router);\r\n\tisNew: boolean = false;\r\n\toptions = input<FormOptions>({});\r\n\tfields = computed(() => {\r\n\t\tuntracked(() => {\r\n\t\t\tthis.initForm();\r\n\t\t\tsetTimeout(() => {\r\n\t\t\t\tthis.reCalcLabelSize();\r\n\t\t\t});\r\n\t\t});\r\n\t\treturn this.options().fields;\r\n\t});\r\n\r\n\ti18nService = inject(I18nService);\r\n\tmodel = input<any>();\r\n\tupsert = input<Upsert>();\r\n\trawModel: any = {};\r\n\tchangedModel: any = {};\r\n\tfieldList!: FormField[];\r\n\thookObservers: Function[] = [];\r\n\tlabelMinWidth = signal<string | undefined>(undefined);\r\n\r\n\t@HostListener('window:resize', ['$event'])\r\n\tonResize() {\r\n\t\tthis.reCalcLabelSize();\r\n\t}\r\n\r\n\tconstructor(\r\n\t\tprivate cdr: ChangeDetectorRef,\r\n\t\tprivate datePipe: DatePipe,\r\n\t) {\r\n\t\tthis.router.url.split('/').pop() == 'new' && (this.isNew = true);\r\n\t\teffect(\r\n\t\t\t() => {\r\n\t\t\t\tif (!this.model()) {\r\n\t\t\t\t\treturn;\r\n\t\t\t\t}\r\n\t\t\t\t// 默认值仅在表单新建时生效\r\n\t\t\t\tif (this.isNew) {\r\n\t\t\t\t\tthis.fieldList.forEach((field) => {\r\n\t\t\t\t\t\tif (!field.default) return;\r\n\t\t\t\t\t\tif (this.model()[field.key!] !== undefined) return;\r\n\t\t\t\t\t\tuntracked(() => {\r\n\t\t\t\t\t\t\tthis.handleValueChange(field.default, field);\r\n\t\t\t\t\t\t});\r\n\t\t\t\t\t});\r\n\t\t\t\t}\r\n\t\t\t\tthis.rawModel = { ...this.model() };\r\n\t\t\t\tthis.changedModel = {};\r\n\t\t\t\tuntracked(() => this.triggerHook());\r\n\t\t\t},\r\n\t\t\t{ allowSignalWrites: true },\r\n\t\t);\r\n\t}\r\n\r\n\tngAfterViewInit(): void {\r\n\t\tsetTimeout(() => {\r\n\t\t\tthis.reCalcLabelSize();\r\n\t\t});\r\n\t\tthis.i18nService.change.subscribe((res) => {\r\n\t\t\tthis.reCalcLabelSize();\r\n\t\t});\r\n\t}\r\n\r\n\tngOnDestroy() {\r\n\t\tthis.hookObservers.forEach((unsubscribe) => unsubscribe());\r\n\t}\r\n\r\n\tinitForm() {\r\n\t\tif (!this.options().extra) {\r\n\t\t\tthis.options().extra = {};\r\n\t\t}\r\n\t\tif (!this.options().form) {\r\n\t\t\tthis.options().form = new FormGroup({});\r\n\t\t}\r\n\t\tthis.fieldList = [];\r\n\t\tthis.parseFields(this.options().fields || []);\r\n\t\tthis.fieldList.forEach((field) => {\r\n\t\t\tfield.uuid = generateUniqueId();\r\n\t\t\tfield.labelMinWidth = this.labelMinWidth;\r\n\t\t\tfield.interactiveLabel = this.options().interactiveLabel ?? true;\r\n\t\t\tfield.form = this;\r\n\t\t\tif(isObservable(field.hook) ){\r\n\t\t\t\tthis.uniqueHook(field, field.hook);\r\n\t\t\t}\r\n\t\t\tthis.handleFieldControl(field);\r\n\t\t});\r\n\t}\r\n\r\n\tgetField(key: string) {\r\n\t\treturn this.fieldList.find((field) => field.key === key);\r\n\t}\r\n\r\n\tparseFields(fields: FormField[]) {\r\n\t\tfields.forEach((field) => {\r\n\t\t\tif (field.group) {\r\n\t\t\t\tthis.parseFields(field.group);\r\n\t\t\t} else {\r\n\t\t\t\tthis.fieldList.push(field);\r\n\t\t\t}\r\n\t\t});\r\n\t}\r\n\r\n\thandleFieldControl(field: FormField) {\r\n\t\tconst fieldControl = fieldUtils.props(field).required\r\n\t\t\t? new FieldControl(null, field.validators ? field.validators : Validators.required)\r\n\t\t\t: new FieldControl(null);\r\n\t\tthis.options().form?.addControl(field.key || '', fieldControl);\r\n\t\tfield.fieldControl = fieldControl;\r\n\t\tfield.fieldControl?.valueChanges.subscribe((value) => {\r\n\t\t\tconst targetValue = fieldUtils.fromFieldValue(field, value, this.datePipe);\r\n\t\t\tif (fieldUtils.isFakedChange(targetValue, this.model()[field.key!], field)) {\r\n\t\t\t\treturn;\r\n\t\t\t}\r\n\t\t\tthis.handleValueChange(targetValue, field);\r\n\t\t});\r\n\t}\r\n\r\n\thandleValueChange(value: any, field: FormField) {\r\n\t\tthis.model()[field.key!] = value;\r\n\t\tthis.changedModel[field.key!] = { name: fieldUtils.label(field, this.i18nService), value: value, type: field.type };\r\n\t\tthis.handleUpsert(field.key!, value);\r\n\t\tconsole.log('-----handleValueChange', this.upsert());\r\n\t\tthis.handleHideExpression();\r\n\t}\r\n\r\n\thandleUpsert(key: string, value: any) {\r\n\t\tif (this.isNew) {\r\n\t\t\tthis.upsert()!.addData![key] = value;\r\n\t\t} else {\r\n\t\t\tthis.upsert()!.updData![key] = value;\r\n\t\t}\r\n\t\tthis.upsert()!.log!.content = fieldUtils.transLog(\r\n\t\t\tthis.rawModel,\r\n\t\t\tthis.changedModel,\r\n\t\t\tthis.model()[this.options().mainField!],\r\n\t\t\tthis.isNew,\r\n\t\t);\r\n\t}\r\n\r\n\thandleHideExpression() {\r\n\t\tthis.fieldList.forEach((field) => {\r\n\t\t\tif (field.hideExpression) {\r\n\t\t\t\tfield.hide = field.hideExpression(this.model(), field);\r\n\t\t\t\tif (field.hide) {\r\n\t\t\t\t\tthis.options().form?.controls[field.key!].disable({ emitEvent: false });\r\n\t\t\t\t} else {\r\n\t\t\t\t\tthis.options().form?.controls[field.key!].enable({ emitEvent: false });\r\n\t\t\t\t}\r\n\t\t\t}\r\n\t\t});\r\n\t}\r\n\r\n\tvalidate() {\r\n\t\tfor (let key in this.options().form?.controls) {\r\n\t\t\t!this.options().form?.controls[key]['disabled'] && this.options().form?.controls[key].markAsDirty();\r\n\t\t}\r\n\t\treturn this.options().form?.valid;\r\n\t}\r\n\r\n\tuniqueHook(field: FormField, hook: Observable<(field?: FormField) => void>) {\r\n\t\tfield.hook = hook.pipe(shareReplay(1));\r\n\t}\r\n\r\n\ttriggerHook() {\r\n\t\tthis.fieldList.forEach((field) => {\r\n\t\t\tfieldUtils.triggerHookAndSetValue(\r\n\t\t\t\tfield,\r\n\t\t\t\tthis.model()?.[field.key!],\r\n\t\t\t\t['upload', 'image', 'codemirror', 'radio', 'select'].includes(field.type!),\r\n\t\t\t\tthis.hookObservers,\r\n\t\t\t\t() => {\r\n\t\t\t\t\tthis.handleHideExpression();\r\n\t\t\t\t},\r\n\t\t\t\tthis.datePipe,\r\n\t\t\t);\r\n\t\t});\r\n\t}\r\n\r\n\treCalcLabelSize() {\r\n\t\tif (this.options().labelWidth) {\r\n\t\t\tthis.labelMinWidth.set(this.options().labelWidth);\r\n\t\t\treturn;\r\n\t\t}\r\n\t\tthis.labelMinWidth.set(undefined);\r\n\t\tthis.cdr.detectChanges();\r\n\t\tthis.handleFieldLabels();\r\n\t\tthis.cdr.detectChanges();\r\n\t}\r\n\r\n\thandleFieldLabels() {\r\n\t\tconst fieldLabels: ElementRef[] = [];\r\n\t\tthis.getFieldLabels(this.fieldComponents, fieldLabels);\r\n\t\tconst offsetWidths = fieldLabels.map((fieldLabel) => fieldLabel.nativeElement.offsetWidth);\r\n\t\tthis.labelMinWidth.set(Math.max(...offsetWidths) + 18 + 'px');\r\n\t}\r\n\r\n\tgetFieldLabels(fieldComponents: QueryList<FormFieldComponent> | undefined, fieldLabels: ElementRef[]) {\r\n\t\tif (!fieldComponents) {\r\n\t\t\treturn;\r\n\t\t}\r\n\t\tfieldComponents?.forEach((component) => {\r\n\t\t\tconst fieldLabel = component.getFieldLabel();\r\n\t\t\tif (fieldLabel) {\r\n\t\t\t\tfieldLabels.push(fieldLabel);\r\n\t\t\t}\r\n\t\t\tthis.getFieldLabels(component.getFieldComponents(), fieldLabels);\r\n\t\t});\r\n\t}\r\n\r\n\ttriggerModelEffect(model: any) {\r\n\t\tObject.keys(model).forEach((key) => {\r\n\t\t\tconst field = this.getField(key)!;\r\n\t\t\tif (!field) return;\r\n\t\t\tfieldUtils.triggerHookAndSetValue(\r\n\t\t\t\tfield,\r\n\t\t\t\tmodel[key],\r\n\t\t\t\t['upload', 'image', 'codemirror', 'radio', 'select'].includes(field.type!),\r\n\t\t\t\tthis.hookObservers,\r\n\t\t\t\t() => {\r\n\t\t\t\t\tthis.handleHideExpression();\r\n\t\t\t\t},\r\n\t\t\t\tthis.datePipe,\r\n\t\t\t);\r\n\t\t});\r\n\t}\r\n\r\n\tfinalize() {\r\n\t\tthis.fieldList.forEach((field) => {\r\n\t\t\tif (['image', 'upload'].includes(field.type!)) {\r\n\t\t\t\tfield.fieldControl?.afterSubmit();\r\n\t\t\t}\r\n\t\t});\r\n\t}\r\n}\r\n","@for (field of fields(); track field) {\r\n\t<form-field\r\n\t\tclass=\"w-full\"\r\n\t\t[field]=\"field\">\r\n\t</form-field>\r\n}\r\n"]}
|
|
@@ -55,6 +55,14 @@ export class PageFormComponent extends AmComponent {
|
|
|
55
55
|
this.isLog = this.modelLog();
|
|
56
56
|
console.log('model-----', this.isLog, this.modelLog());
|
|
57
57
|
}, { allowSignalWrites: true });
|
|
58
|
+
effect(() => {
|
|
59
|
+
if (this.statusSteps().length > 0 && !this.id) {
|
|
60
|
+
this.upsertPrm.addData[this.statusKey()] = this.statusSteps()[0]['value'];
|
|
61
|
+
this.getPrm.data = Object.assign(this.getPrm.data || {}, {
|
|
62
|
+
[this.statusKey()]: this.statusSteps()[0]['value']
|
|
63
|
+
});
|
|
64
|
+
}
|
|
65
|
+
}, { allowSignalWrites: true });
|
|
58
66
|
}
|
|
59
67
|
ngOnInit() {
|
|
60
68
|
this.upCb = this.upCb.bind(this);
|
|
@@ -107,10 +115,11 @@ export class PageFormComponent extends AmComponent {
|
|
|
107
115
|
});
|
|
108
116
|
}
|
|
109
117
|
}
|
|
110
|
-
getDetail() {
|
|
118
|
+
getDetail(customSteps) {
|
|
111
119
|
this.web_get(this.getPrm).subscribe(res => {
|
|
112
120
|
this.updateTitle(res);
|
|
113
121
|
this.formDisabled() && this.formDisFunc();
|
|
122
|
+
// customSteps && customSteps.refreshSteps()
|
|
114
123
|
});
|
|
115
124
|
}
|
|
116
125
|
updateTitle(res) {
|
|
@@ -158,8 +167,7 @@ export class PageFormComponent extends AmComponent {
|
|
|
158
167
|
};
|
|
159
168
|
}
|
|
160
169
|
this.web_write(param).subscribe(res => {
|
|
161
|
-
this.getDetail();
|
|
162
|
-
customSteps.refreshSteps();
|
|
170
|
+
this.getDetail(customSteps);
|
|
163
171
|
});
|
|
164
172
|
}
|
|
165
173
|
else {
|
|
@@ -168,7 +176,7 @@ export class PageFormComponent extends AmComponent {
|
|
|
168
176
|
});
|
|
169
177
|
this.upsertPrm.addData[this.statusKey()] = value;
|
|
170
178
|
this.cForm.triggerModelEffect({ [this.statusKey()]: value });
|
|
171
|
-
customSteps.refreshSteps()
|
|
179
|
+
// customSteps.refreshSteps()
|
|
172
180
|
}
|
|
173
181
|
}
|
|
174
182
|
formDisFunc() {
|
|
@@ -185,7 +193,7 @@ export class PageFormComponent extends AmComponent {
|
|
|
185
193
|
});
|
|
186
194
|
}
|
|
187
195
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: PageFormComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
188
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: PageFormComponent, isStandalone: true, selector: "app-page-form", inputs: { addVisible: { classPropertyName: "addVisible", publicName: "addVisible", isSignal: true, isRequired: false, transformFunction: null }, gridList: { classPropertyName: "gridList", publicName: "gridList", isSignal: true, isRequired: false, transformFunction: null }, form: { classPropertyName: "form", publicName: "form", isSignal: true, isRequired: true, transformFunction: null }, getPrmInput: { classPropertyName: "getPrmInput", publicName: "getPrmInput", isSignal: true, isRequired: true, transformFunction: null }, statusSteps: { classPropertyName: "statusSteps", publicName: "statusSteps", isSignal: true, isRequired: false, transformFunction: null }, statusKey: { classPropertyName: "statusKey", publicName: "statusKey", isSignal: true, isRequired: false, transformFunction: null }, hrefBtnList: { classPropertyName: "hrefBtnList", publicName: "hrefBtnList", isSignal: true, isRequired: false, transformFunction: null }, setTitle: { classPropertyName: "setTitle", publicName: "setTitle", isSignal: true, isRequired: false, transformFunction: null }, actionList: { classPropertyName: "actionList", publicName: "actionList", isSignal: true, isRequired: false, transformFunction: null }, modelLog: { classPropertyName: "modelLog", publicName: "modelLog", isSignal: true, isRequired: false, transformFunction: null }, formDisabled: { classPropertyName: "formDisabled", publicName: "formDisabled", isSignal: true, isRequired: false, transformFunction: null }, authLevel: { classPropertyName: "authLevel", publicName: "authLevel", isSignal: true, isRequired: false, transformFunction: null } }, providers: [], viewQueries: [{ propertyName: "customGrid", first: true, predicate: ["customGrid"], descendants: true }, { propertyName: "cForm", first: true, predicate: ["cForm"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<div class=\"overflow-hidden\">\r\n <div class=\"flex items-center justify-between py-1 px-1 border-b-[1px] border-[#dbdbdb] bg-white\">\r\n <app-crumb-action\r\n [addVisible]=\"addVisible()\"\r\n [newUrl]=\"newUrl\"\r\n [isShowCog]=\"true\"\r\n [outlined]=\"true\"\r\n [authLevel]=\"authLevel()\"\r\n [actionList]=\"actionList()\"\r\n (actionEvent)=\"authClick($event)\"\r\n (saveEvent)=\"submitForm()\">\r\n </app-crumb-action>\r\n <div class=\"hrefBtnList\">\r\n @if(id){\r\n @for(btn of hrefBtnList();track btn){\r\n <p-button \r\n [variant]=\"btn?.variant\" \r\n [severity]=\"btn?.severity\" \r\n class=\"mr-[6px]\"\r\n [icon]=\"btn?.icon\"\r\n label=\"{{btn.i18nKey? i18n.fanyi(btn.i18nKey) : btn.label}}\"\r\n (click)=\"goRun(btn)\"\r\n >\r\n </p-button>\r\n }\r\n }\r\n \r\n </div>\r\n <div></div>\r\n \r\n </div>\r\n <div class=\"flex\">\r\n <div class=\"px-2 flex flex-wrap items-center md:basis-2/3 basis-full\">\r\n <div class=\"hidden md:basis-1/3 py-1 basis-full md:flex items-center gap-2 flex-row order-1\">\r\n @for (btn of actionList();let i = $index; track btn) {\r\n <p-button\r\n [variant]=\"btn?.variant\"\r\n [severity]=\"btn?.severity\"\r\n class=\"mr-[4px]\"\r\n size=\"small\"\r\n [icon]=\"btn?.icon\"\r\n label=\"{{ btn.i18nKey ? (btn.i18nKey | translate) : btn.label }}\"\r\n (click)=\"authClick(btn)\"\r\n [disabled]=\"btn.btnDisabled ? btn.btnDisabled(getPrm.data) : false\"\r\n >\r\n </p-button>\r\n }\r\n </div>\r\n \r\n <div class=\"md:basis-2/3 basis-full flex md:flex-row-reverse flex-row md:order-2 order-first w-full\">\r\n <custom-steps\r\n #customSteps\r\n class=\"w-full\"\r\n [steps]=\"statusSteps()\"\r\n [current]=\"getPrm.data && getPrm.data[statusKey()] !== undefined ? getPrm.data[statusKey()] : 0\"\r\n [authLevel]=\"authLevel()\"\r\n (change)=\"statusChange($event, customSteps)\">\r\n </custom-steps>\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"main flex flex-wrap overflow-y-hidden\">\r\n <div class=\"md:basis-2/3 basis-full h-full overflow-y-auto\">\r\n <div class=\"bg-white mx-2 form-panel\">\r\n <div class=\"p-2 flex-1\">\r\n <form\r\n [formGroup]=\"form().form!\">\r\n <custom-form\r\n #cForm\r\n [options]=\"formOptions\"\r\n [upsert]=\"upsertPrm\"\r\n [model]=\"getPrm.data??{}\"></custom-form>\r\n </form>\r\n </div>\r\n @if(gridList() && gridList().length > 1){\r\n <div class=\"relative mb-2\">\r\n <p-tabs [(value)]=\"indexValue\">\r\n <p-tablist>\r\n @for (fchild of gridList();let i = $index; track fchild) {\r\n <p-tab [value]=\"i\">\r\n {{fchild.i18nKey ? i18n.fanyi(fchild.i18nKey) : fchild.title}}\r\n </p-tab>\r\n }\r\n </p-tablist>\r\n </p-tabs>\r\n </div>\r\n }\r\n @for (grid of gridList(); let i = $index;track grid) {\r\n <custom-grid\r\n #customGrid\r\n [hidden]=\"indexValue !=i \"\r\n [rowData]=\"getPrm.data?.[grid.subDataKey!]|| []\"\r\n [upsert]=\"upsertPrm\"\r\n (deleteEmit)=\"delRows($event)\"\r\n [addType]=\"grid.subTableSource\"\r\n (addEmit)=\"dataSourceShow()\"\r\n [gridOptions]=\"grid.gridOptions\"\r\n [authLevel]=\"authLevel()\"\r\n [selectData]=\"grid.selectData\">\r\n </custom-grid>\r\n } \r\n </div>\r\n </div>\r\n <div class=\"md:basis-1/3 basis-full h-full overflow-y-auto\">\r\n <custom-log [logs]=\"getPrm.data?.log??[]\"></custom-log>\r\n </div>\r\n </div>\r\n</div>\r\n<row-selector\r\n\t[(visible)]=\"visible\"\r\n\t[searchPrm]=\"dialogSearchPrm\"\r\n\t[gridOptions]=\"selectOptions\"\r\n\t(onOk)=\"onOk($event)\">\r\n</row-selector>", styles: ["@charset \"UTF-8\";.main{height:calc(100vh - 140px)}:host ::ng-deep .main .ag-root-wrapper{border-left:none!important;border-right:none!important;border-bottom:none!important}.form-panel{border:solid 1px #dbdbdb}\n"], dependencies: [{ kind: "ngmodule", type: ButtonModule }, { kind: "component", type: i1.Button, selector: "p-button", inputs: ["type", "iconPos", "icon", "badge", "label", "disabled", "loading", "loadingIcon", "raised", "rounded", "text", "plain", "severity", "outlined", "link", "tabindex", "size", "variant", "style", "styleClass", "badgeClass", "badgeSeverity", "ariaLabel", "autofocus", "fluid", "buttonProps"], outputs: ["onClick", "onFocus", "onBlur"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i2.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i2.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "component", type: FormComponent, selector: "custom-form", inputs: ["options", "model", "upsert"] }, { kind: "component", type: LogComponent, selector: "custom-log", inputs: ["logs", "id"] }, { kind: "component", type: CrumbActionComponent, selector: "app-crumb-action", inputs: ["isShowCog", "addVisible", "newUrl", "onExport", "outlined", "isList", "authLevel", "actionList"], outputs: ["saveEvent", "cancelEvent", "actionEvent"] }, { kind: "component", type: StepsComponent, selector: "custom-steps", inputs: ["steps", "current", "authLevel"], outputs: ["change"] }, { kind: "component", type: GridComponent, selector: "custom-grid", inputs: ["gridOptions", "upsert", "rowData", "searchPrm", "addType", "selectData", "showAct", "actPos", "authLevel"], outputs: ["searchPrmChange", "deleteEmit", "addEmit"] }, { kind: "ngmodule", type: TabsModule }, { kind: "component", type: i3.Tabs, selector: "p-tabs", inputs: ["value", "scrollable", "lazy", "selectOnFocus", "showNavigators", "tabindex"], outputs: ["valueChange"] }, { kind: "component", type: i3.TabList, selector: "p-tablist" }, { kind: "component", type: i3.Tab, selector: "p-tab", inputs: ["value", "disabled"], outputs: ["valueChange"] }, { kind: "component", type: RowSelectorComponent, selector: "row-selector", inputs: ["title", "gridOptions", "searchPrm", "visible"], outputs: ["onOk", "visibleChange"] }, { kind: "pipe", type: TranslatePipe, name: "translate" }] }); }
|
|
196
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: PageFormComponent, isStandalone: true, selector: "app-page-form", inputs: { addVisible: { classPropertyName: "addVisible", publicName: "addVisible", isSignal: true, isRequired: false, transformFunction: null }, gridList: { classPropertyName: "gridList", publicName: "gridList", isSignal: true, isRequired: false, transformFunction: null }, form: { classPropertyName: "form", publicName: "form", isSignal: true, isRequired: true, transformFunction: null }, getPrmInput: { classPropertyName: "getPrmInput", publicName: "getPrmInput", isSignal: true, isRequired: true, transformFunction: null }, statusSteps: { classPropertyName: "statusSteps", publicName: "statusSteps", isSignal: true, isRequired: false, transformFunction: null }, statusKey: { classPropertyName: "statusKey", publicName: "statusKey", isSignal: true, isRequired: false, transformFunction: null }, hrefBtnList: { classPropertyName: "hrefBtnList", publicName: "hrefBtnList", isSignal: true, isRequired: false, transformFunction: null }, setTitle: { classPropertyName: "setTitle", publicName: "setTitle", isSignal: true, isRequired: false, transformFunction: null }, actionList: { classPropertyName: "actionList", publicName: "actionList", isSignal: true, isRequired: false, transformFunction: null }, modelLog: { classPropertyName: "modelLog", publicName: "modelLog", isSignal: true, isRequired: false, transformFunction: null }, formDisabled: { classPropertyName: "formDisabled", publicName: "formDisabled", isSignal: true, isRequired: false, transformFunction: null }, authLevel: { classPropertyName: "authLevel", publicName: "authLevel", isSignal: true, isRequired: false, transformFunction: null } }, providers: [], viewQueries: [{ propertyName: "customGrid", first: true, predicate: ["customGrid"], descendants: true }, { propertyName: "cForm", first: true, predicate: ["cForm"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<div class=\"md:overflow-hidden\">\r\n <div class=\"flex items-center justify-between py-1 px-1 border-b-[1px] border-[#dbdbdb] bg-white\">\r\n <app-crumb-action\r\n [addVisible]=\"addVisible()\"\r\n [newUrl]=\"newUrl\"\r\n [isShowCog]=\"true\"\r\n [outlined]=\"true\"\r\n [authLevel]=\"authLevel()\"\r\n [actionList]=\"actionList()\"\r\n (actionEvent)=\"authClick($event)\"\r\n (saveEvent)=\"submitForm()\">\r\n </app-crumb-action>\r\n <div class=\"hrefBtnList\">\r\n @if(id){\r\n @for(btn of hrefBtnList();track btn){\r\n <p-button \r\n [variant]=\"btn?.variant\" \r\n [severity]=\"btn?.severity\" \r\n class=\"mr-[6px]\"\r\n [icon]=\"btn?.icon\"\r\n label=\"{{btn.i18nKey? i18n.fanyi(btn.i18nKey) : btn.label}}\"\r\n (click)=\"goRun(btn)\"\r\n >\r\n </p-button>\r\n }\r\n }\r\n \r\n </div>\r\n <div></div>\r\n \r\n </div>\r\n <div class=\"flex\">\r\n <div class=\"px-2 flex flex-wrap items-center md:basis-2/3 basis-full\">\r\n <div class=\"hidden md:basis-1/3 py-1 basis-full md:flex items-center gap-2 flex-row order-1\">\r\n @for (btn of actionList();let i = $index; track btn) {\r\n <p-button\r\n [variant]=\"btn?.variant\"\r\n [severity]=\"btn?.severity\"\r\n class=\"mr-[4px]\"\r\n size=\"small\"\r\n [icon]=\"btn?.icon\"\r\n label=\"{{ btn.i18nKey ? (btn.i18nKey | translate) : btn.label }}\"\r\n (click)=\"authClick(btn)\"\r\n [disabled]=\"btn.btnDisabled ? btn.btnDisabled(getPrm.data) : false\"\r\n >\r\n </p-button>\r\n }\r\n </div>\r\n \r\n <div class=\"md:basis-2/3 basis-full flex md:flex-row-reverse flex-row md:order-2 order-first w-full\">\r\n <custom-steps\r\n #customSteps\r\n class=\"w-full\"\r\n [steps]=\"statusSteps()\"\r\n [current]=\"getPrm.data && getPrm.data[statusKey()] !== undefined ? getPrm.data[statusKey()] : 0\"\r\n [authLevel]=\"authLevel()\"\r\n (change)=\"statusChange($event, customSteps)\">\r\n </custom-steps>\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"main flex flex-wrap md:overflow-y-hidden\">\r\n <div class=\"md:basis-2/3 basis-full h-full overflow-y-auto\">\r\n <div class=\"bg-white mx-2 form-panel\">\r\n <div class=\"p-2 flex-1\">\r\n <form\r\n [formGroup]=\"form().form!\">\r\n <custom-form\r\n #cForm\r\n [options]=\"formOptions\"\r\n [upsert]=\"upsertPrm\"\r\n [model]=\"getPrm.data??{}\"></custom-form>\r\n </form>\r\n </div>\r\n @if(gridList() && gridList().length > 1){\r\n <div class=\"relative mb-2\">\r\n <p-tabs [(value)]=\"indexValue\">\r\n <p-tablist>\r\n @for (fchild of gridList();let i = $index; track fchild) {\r\n <p-tab [value]=\"i\">\r\n {{fchild.i18nKey ? i18n.fanyi(fchild.i18nKey) : fchild.title}}\r\n </p-tab>\r\n }\r\n </p-tablist>\r\n </p-tabs>\r\n </div>\r\n }\r\n @for (grid of gridList(); let i = $index;track grid) {\r\n <custom-grid\r\n #customGrid\r\n [hidden]=\"indexValue !=i \"\r\n [rowData]=\"getPrm.data?.[grid.subDataKey!]|| []\"\r\n [upsert]=\"upsertPrm\"\r\n (deleteEmit)=\"delRows($event)\"\r\n [addType]=\"grid.subTableSource\"\r\n (addEmit)=\"dataSourceShow()\"\r\n [gridOptions]=\"grid.gridOptions\"\r\n [authLevel]=\"authLevel()\"\r\n [selectData]=\"grid.selectData\">\r\n </custom-grid>\r\n } \r\n </div>\r\n </div>\r\n <div class=\"md:basis-1/3 basis-full h-full overflow-y-auto\">\r\n <custom-log [logs]=\"getPrm.data?.log??[]\"></custom-log>\r\n </div>\r\n </div>\r\n</div>\r\n<row-selector\r\n\t[(visible)]=\"visible\"\r\n\t[searchPrm]=\"dialogSearchPrm\"\r\n\t[gridOptions]=\"selectOptions\"\r\n\t(onOk)=\"onOk($event)\">\r\n</row-selector>", styles: ["@charset \"UTF-8\";.main{height:calc(100vh - 140px)}:host ::ng-deep .main .ag-root-wrapper{border-left:none!important;border-right:none!important;border-bottom:none!important}.form-panel{border:solid 1px #dbdbdb}\n"], dependencies: [{ kind: "ngmodule", type: ButtonModule }, { kind: "component", type: i1.Button, selector: "p-button", inputs: ["type", "iconPos", "icon", "badge", "label", "disabled", "loading", "loadingIcon", "raised", "rounded", "text", "plain", "severity", "outlined", "link", "tabindex", "size", "variant", "style", "styleClass", "badgeClass", "badgeSeverity", "ariaLabel", "autofocus", "fluid", "buttonProps"], outputs: ["onClick", "onFocus", "onBlur"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i2.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i2.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "component", type: FormComponent, selector: "custom-form", inputs: ["options", "model", "upsert"] }, { kind: "component", type: LogComponent, selector: "custom-log", inputs: ["logs", "id"] }, { kind: "component", type: CrumbActionComponent, selector: "app-crumb-action", inputs: ["isShowCog", "addVisible", "newUrl", "onExport", "outlined", "isList", "authLevel", "actionList"], outputs: ["saveEvent", "cancelEvent", "actionEvent"] }, { kind: "component", type: StepsComponent, selector: "custom-steps", inputs: ["steps", "current", "authLevel"], outputs: ["change"] }, { kind: "component", type: GridComponent, selector: "custom-grid", inputs: ["gridOptions", "upsert", "rowData", "searchPrm", "addType", "selectData", "showAct", "actPos", "authLevel"], outputs: ["searchPrmChange", "deleteEmit", "addEmit"] }, { kind: "ngmodule", type: TabsModule }, { kind: "component", type: i3.Tabs, selector: "p-tabs", inputs: ["value", "scrollable", "lazy", "selectOnFocus", "showNavigators", "tabindex"], outputs: ["valueChange"] }, { kind: "component", type: i3.TabList, selector: "p-tablist" }, { kind: "component", type: i3.Tab, selector: "p-tab", inputs: ["value", "disabled"], outputs: ["valueChange"] }, { kind: "component", type: RowSelectorComponent, selector: "row-selector", inputs: ["title", "gridOptions", "searchPrm", "visible"], outputs: ["onOk", "visibleChange"] }, { kind: "pipe", type: TranslatePipe, name: "translate" }] }); }
|
|
189
197
|
}
|
|
190
198
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: PageFormComponent, decorators: [{
|
|
191
199
|
type: Component,
|
|
@@ -200,7 +208,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
200
208
|
TabsModule,
|
|
201
209
|
RowSelectorComponent,
|
|
202
210
|
TranslatePipe,
|
|
203
|
-
], providers: [], template: "<div class=\"overflow-hidden\">\r\n <div class=\"flex items-center justify-between py-1 px-1 border-b-[1px] border-[#dbdbdb] bg-white\">\r\n <app-crumb-action\r\n [addVisible]=\"addVisible()\"\r\n [newUrl]=\"newUrl\"\r\n [isShowCog]=\"true\"\r\n [outlined]=\"true\"\r\n [authLevel]=\"authLevel()\"\r\n [actionList]=\"actionList()\"\r\n (actionEvent)=\"authClick($event)\"\r\n (saveEvent)=\"submitForm()\">\r\n </app-crumb-action>\r\n <div class=\"hrefBtnList\">\r\n @if(id){\r\n @for(btn of hrefBtnList();track btn){\r\n <p-button \r\n [variant]=\"btn?.variant\" \r\n [severity]=\"btn?.severity\" \r\n class=\"mr-[6px]\"\r\n [icon]=\"btn?.icon\"\r\n label=\"{{btn.i18nKey? i18n.fanyi(btn.i18nKey) : btn.label}}\"\r\n (click)=\"goRun(btn)\"\r\n >\r\n </p-button>\r\n }\r\n }\r\n \r\n </div>\r\n <div></div>\r\n \r\n </div>\r\n <div class=\"flex\">\r\n <div class=\"px-2 flex flex-wrap items-center md:basis-2/3 basis-full\">\r\n <div class=\"hidden md:basis-1/3 py-1 basis-full md:flex items-center gap-2 flex-row order-1\">\r\n @for (btn of actionList();let i = $index; track btn) {\r\n <p-button\r\n [variant]=\"btn?.variant\"\r\n [severity]=\"btn?.severity\"\r\n class=\"mr-[4px]\"\r\n size=\"small\"\r\n [icon]=\"btn?.icon\"\r\n label=\"{{ btn.i18nKey ? (btn.i18nKey | translate) : btn.label }}\"\r\n (click)=\"authClick(btn)\"\r\n [disabled]=\"btn.btnDisabled ? btn.btnDisabled(getPrm.data) : false\"\r\n >\r\n </p-button>\r\n }\r\n </div>\r\n \r\n <div class=\"md:basis-2/3 basis-full flex md:flex-row-reverse flex-row md:order-2 order-first w-full\">\r\n <custom-steps\r\n #customSteps\r\n class=\"w-full\"\r\n [steps]=\"statusSteps()\"\r\n [current]=\"getPrm.data && getPrm.data[statusKey()] !== undefined ? getPrm.data[statusKey()] : 0\"\r\n [authLevel]=\"authLevel()\"\r\n (change)=\"statusChange($event, customSteps)\">\r\n </custom-steps>\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"main flex flex-wrap overflow-y-hidden\">\r\n <div class=\"md:basis-2/3 basis-full h-full overflow-y-auto\">\r\n <div class=\"bg-white mx-2 form-panel\">\r\n <div class=\"p-2 flex-1\">\r\n <form\r\n [formGroup]=\"form().form!\">\r\n <custom-form\r\n #cForm\r\n [options]=\"formOptions\"\r\n [upsert]=\"upsertPrm\"\r\n [model]=\"getPrm.data??{}\"></custom-form>\r\n </form>\r\n </div>\r\n @if(gridList() && gridList().length > 1){\r\n <div class=\"relative mb-2\">\r\n <p-tabs [(value)]=\"indexValue\">\r\n <p-tablist>\r\n @for (fchild of gridList();let i = $index; track fchild) {\r\n <p-tab [value]=\"i\">\r\n {{fchild.i18nKey ? i18n.fanyi(fchild.i18nKey) : fchild.title}}\r\n </p-tab>\r\n }\r\n </p-tablist>\r\n </p-tabs>\r\n </div>\r\n }\r\n @for (grid of gridList(); let i = $index;track grid) {\r\n <custom-grid\r\n #customGrid\r\n [hidden]=\"indexValue !=i \"\r\n [rowData]=\"getPrm.data?.[grid.subDataKey!]|| []\"\r\n [upsert]=\"upsertPrm\"\r\n (deleteEmit)=\"delRows($event)\"\r\n [addType]=\"grid.subTableSource\"\r\n (addEmit)=\"dataSourceShow()\"\r\n [gridOptions]=\"grid.gridOptions\"\r\n [authLevel]=\"authLevel()\"\r\n [selectData]=\"grid.selectData\">\r\n </custom-grid>\r\n } \r\n </div>\r\n </div>\r\n <div class=\"md:basis-1/3 basis-full h-full overflow-y-auto\">\r\n <custom-log [logs]=\"getPrm.data?.log??[]\"></custom-log>\r\n </div>\r\n </div>\r\n</div>\r\n<row-selector\r\n\t[(visible)]=\"visible\"\r\n\t[searchPrm]=\"dialogSearchPrm\"\r\n\t[gridOptions]=\"selectOptions\"\r\n\t(onOk)=\"onOk($event)\">\r\n</row-selector>", styles: ["@charset \"UTF-8\";.main{height:calc(100vh - 140px)}:host ::ng-deep .main .ag-root-wrapper{border-left:none!important;border-right:none!important;border-bottom:none!important}.form-panel{border:solid 1px #dbdbdb}\n"] }]
|
|
211
|
+
], providers: [], template: "<div class=\"md:overflow-hidden\">\r\n <div class=\"flex items-center justify-between py-1 px-1 border-b-[1px] border-[#dbdbdb] bg-white\">\r\n <app-crumb-action\r\n [addVisible]=\"addVisible()\"\r\n [newUrl]=\"newUrl\"\r\n [isShowCog]=\"true\"\r\n [outlined]=\"true\"\r\n [authLevel]=\"authLevel()\"\r\n [actionList]=\"actionList()\"\r\n (actionEvent)=\"authClick($event)\"\r\n (saveEvent)=\"submitForm()\">\r\n </app-crumb-action>\r\n <div class=\"hrefBtnList\">\r\n @if(id){\r\n @for(btn of hrefBtnList();track btn){\r\n <p-button \r\n [variant]=\"btn?.variant\" \r\n [severity]=\"btn?.severity\" \r\n class=\"mr-[6px]\"\r\n [icon]=\"btn?.icon\"\r\n label=\"{{btn.i18nKey? i18n.fanyi(btn.i18nKey) : btn.label}}\"\r\n (click)=\"goRun(btn)\"\r\n >\r\n </p-button>\r\n }\r\n }\r\n \r\n </div>\r\n <div></div>\r\n \r\n </div>\r\n <div class=\"flex\">\r\n <div class=\"px-2 flex flex-wrap items-center md:basis-2/3 basis-full\">\r\n <div class=\"hidden md:basis-1/3 py-1 basis-full md:flex items-center gap-2 flex-row order-1\">\r\n @for (btn of actionList();let i = $index; track btn) {\r\n <p-button\r\n [variant]=\"btn?.variant\"\r\n [severity]=\"btn?.severity\"\r\n class=\"mr-[4px]\"\r\n size=\"small\"\r\n [icon]=\"btn?.icon\"\r\n label=\"{{ btn.i18nKey ? (btn.i18nKey | translate) : btn.label }}\"\r\n (click)=\"authClick(btn)\"\r\n [disabled]=\"btn.btnDisabled ? btn.btnDisabled(getPrm.data) : false\"\r\n >\r\n </p-button>\r\n }\r\n </div>\r\n \r\n <div class=\"md:basis-2/3 basis-full flex md:flex-row-reverse flex-row md:order-2 order-first w-full\">\r\n <custom-steps\r\n #customSteps\r\n class=\"w-full\"\r\n [steps]=\"statusSteps()\"\r\n [current]=\"getPrm.data && getPrm.data[statusKey()] !== undefined ? getPrm.data[statusKey()] : 0\"\r\n [authLevel]=\"authLevel()\"\r\n (change)=\"statusChange($event, customSteps)\">\r\n </custom-steps>\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"main flex flex-wrap md:overflow-y-hidden\">\r\n <div class=\"md:basis-2/3 basis-full h-full overflow-y-auto\">\r\n <div class=\"bg-white mx-2 form-panel\">\r\n <div class=\"p-2 flex-1\">\r\n <form\r\n [formGroup]=\"form().form!\">\r\n <custom-form\r\n #cForm\r\n [options]=\"formOptions\"\r\n [upsert]=\"upsertPrm\"\r\n [model]=\"getPrm.data??{}\"></custom-form>\r\n </form>\r\n </div>\r\n @if(gridList() && gridList().length > 1){\r\n <div class=\"relative mb-2\">\r\n <p-tabs [(value)]=\"indexValue\">\r\n <p-tablist>\r\n @for (fchild of gridList();let i = $index; track fchild) {\r\n <p-tab [value]=\"i\">\r\n {{fchild.i18nKey ? i18n.fanyi(fchild.i18nKey) : fchild.title}}\r\n </p-tab>\r\n }\r\n </p-tablist>\r\n </p-tabs>\r\n </div>\r\n }\r\n @for (grid of gridList(); let i = $index;track grid) {\r\n <custom-grid\r\n #customGrid\r\n [hidden]=\"indexValue !=i \"\r\n [rowData]=\"getPrm.data?.[grid.subDataKey!]|| []\"\r\n [upsert]=\"upsertPrm\"\r\n (deleteEmit)=\"delRows($event)\"\r\n [addType]=\"grid.subTableSource\"\r\n (addEmit)=\"dataSourceShow()\"\r\n [gridOptions]=\"grid.gridOptions\"\r\n [authLevel]=\"authLevel()\"\r\n [selectData]=\"grid.selectData\">\r\n </custom-grid>\r\n } \r\n </div>\r\n </div>\r\n <div class=\"md:basis-1/3 basis-full h-full overflow-y-auto\">\r\n <custom-log [logs]=\"getPrm.data?.log??[]\"></custom-log>\r\n </div>\r\n </div>\r\n</div>\r\n<row-selector\r\n\t[(visible)]=\"visible\"\r\n\t[searchPrm]=\"dialogSearchPrm\"\r\n\t[gridOptions]=\"selectOptions\"\r\n\t(onOk)=\"onOk($event)\">\r\n</row-selector>", styles: ["@charset \"UTF-8\";.main{height:calc(100vh - 140px)}:host ::ng-deep .main .ag-root-wrapper{border-left:none!important;border-right:none!important;border-bottom:none!important}.form-panel{border:solid 1px #dbdbdb}\n"] }]
|
|
204
212
|
}], ctorParameters: () => [], propDecorators: { customGrid: [{
|
|
205
213
|
type: ViewChild,
|
|
206
214
|
args: ['customGrid']
|
|
@@ -208,4 +216,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
208
216
|
type: ViewChild,
|
|
209
217
|
args: ['cForm']
|
|
210
218
|
}] } });
|
|
211
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"page-form.component.js","sourceRoot":"","sources":["../../../../../projects/imm-element-ui/src/lib/page-form/page-form.component.ts","../../../../../projects/imm-element-ui/src/lib/page-form/page-form.component.html"],"names":[],"mappings":"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","sourcesContent":["import { UserHistoryService } from '../service/userHistory.service';\r\nimport { Component, inject, OnInit, ViewChild, input, effect, computed, Input } from '@angular/core';\r\nimport { ReactiveFormsModule } from '@angular/forms';\r\nimport { FormComponent,FormOptions } from '../form/form/form.component';\r\nimport { RowSelectorComponent } from '../row-selector/row-selector.component'\r\nimport { LogComponent } from '../log/log.component';\r\nimport { ButtonModule } from 'primeng/button';\r\nimport { CrumbActionComponent } from '../crumb-action/crumb-action.component';\r\nimport { StepsComponent,Step } from '../steps/steps.component';\r\nimport { GridComponent, GridOptions } from '../grid/grid/grid.component';\r\nimport { TabsModule } from 'primeng/tabs';\r\nimport { AmComponent, Get, } from '../am/am.component';\r\nimport { Search } from '../am/am.component'\r\nimport { HrefBtnList,GridList } from './page-form.interface';\r\nimport { TranslatePipe } from '@ngx-translate/core';\r\nimport { I18nService } from '../service/i18n.service';\r\nimport { PermissionBtn } from './page-form.interface';\r\nimport { formTypeToProps } from './page-form.interface'\r\n@Component({\r\n  selector: 'app-page-form',\r\n  standalone: true,\r\n  imports: [\r\n    ButtonModule,\r\n    ReactiveFormsModule,\r\n    FormComponent,\r\n    LogComponent,\r\n    CrumbActionComponent,\r\n    StepsComponent,\r\n    GridComponent,\r\n    TabsModule,\r\n    RowSelectorComponent,\r\n    TranslatePipe,\r\n  ],\r\n  templateUrl: './page-form.component.html',\r\n  styleUrl: './page-form.component.scss',\r\n  providers:[]\r\n})\r\nexport class PageFormComponent extends AmComponent implements OnInit{\r\n  addVisible = input<boolean>()\r\n  gridList = input<GridList[]>([])\r\n  form = input.required<FormOptions>({})\r\n  getPrmInput = input.required<Get>({})\r\n  statusSteps = input<Step[]>([])\r\n  statusKey = input('status')\r\n  hrefBtnList = input<HrefBtnList[]>([])\r\n  setTitle = input<string>()\r\n  actionList = input<PermissionBtn[]>([])\r\n  modelLog = input<boolean>(false)\r\n  formDisabled = input<Function>()\r\n\r\n  @ViewChild('customGrid') customGrid!: GridComponent;\r\n  @ViewChild('cForm') cForm!: FormComponent\r\n  userHistoryService =  inject(UserHistoryService)\r\n  indexValue = 0\r\n  visible = false\r\n  dialogSearchPrm!: Search\r\n  selectOptions!:GridOptions\r\n  selectData :any[]= []\r\n  pageUrl = ''\r\n  newUrl = ''\r\n  i18n = inject(I18nService)\r\n  authLevel = input<number>(-1)\r\n  constructor(){\r\n    super()\r\n    this.id = Number(this.route.snapshot.paramMap.get('id'))\r\n    this.pageUrl = this.route.snapshot.url.map(segment => segment.path).join('/').replace(/([^\\/]*)$/, \"\")\r\n    this.newUrl = `${this.pageUrl}new`\r\n    effect(() => {\r\n      this.modelName = this.getPrmInput().modelName!\r\n      this.getPrm = {...this.getPrmInput()}\r\n      this.id && (this.getPrm.id = this.id)\r\n      this.id && this.getDetail()\r\n    },{ allowSignalWrites: true })\r\n\r\n    effect(() => {\r\n      this.formOptions = {...this.form()}\r\n    })\r\n    effect(() => {\r\n      this.isLog = this.modelLog()\r\n      console.log('model-----',this.isLog,this.modelLog())\r\n    },{allowSignalWrites:true})\r\n  }\r\n  ngOnInit(): void {\r\n    this.upCb = this.upCb.bind(this)\r\n  }\r\n\r\n  submitForm() :any{\r\n    if(this.cForm.validate()){\r\n      let cb:any = this.id === 0 ? null : this.upCb\r\n      this.upsert(null,cb)\r\n    }\r\n  }\r\n\r\n  delRows(e:any) {\r\n    const gridTab = this.gridList()[this.indexValue]\r\n    const deleteFunc = gridTab.deleteFunc\r\n    const subTable = gridTab.gridOptions.modelName;\r\n\r\n    let prm = { \r\n      modelName: subTable, \r\n      ids:e \r\n    };\r\n    if(!deleteFunc){\r\n      this.web_remove(prm).subscribe((res) => {\r\n        this.get();\r\n      });\r\n    } else {\r\n      deleteFunc().subscribe(() => {\r\n        this.get()\r\n      })\r\n    }\r\n    \r\n  }\r\n  upCb(res?:any){\r\n    if(res.id == 0){\r\n      this.getDetail()\r\n    }else {\r\n      setTimeout(() => {\r\n        let editUrl = `${this.pageUrl}${res.id}`\r\n        this.router.navigate([editUrl])\r\n      }, 1500)\r\n    }\r\n    this.cForm.finalize()\r\n  }\r\n  // TODO 是否需要数据转换回调函数\r\n  onOk(e:any){\r\n    this.gridList()[this.indexValue].selectData = []\r\n    if(e.length > 0){\r\n      let { selectDataCb } = this.gridList()[this.indexValue]\r\n      e.forEach((item:any) => {\r\n        let obj = selectDataCb ? selectDataCb(item): {...item}\r\n        this.gridList()[this.indexValue].selectData!.push(obj)\r\n      })\r\n    } \r\n  }\r\n  getDetail(){\r\n    this.web_get(this.getPrm).subscribe(res => {\r\n      this.updateTitle(res)\r\n      this.formDisabled() && this.formDisFunc()\r\n    })\r\n  }\r\n  updateTitle(res:any){\r\n    // let title = this.setTitle() ? this.setTitle() : ''\r\n    // title !== '' && this.userHistoryService.setLastTitle(title)\r\n    let mainField = this.form().mainField\r\n    let title = res[mainField!]\r\n    this.userHistoryService.setLastTitle(title)\r\n  }\r\n  dataSourceShow(){\r\n    this.dialogSearchPrm = {...this.gridList()[this.indexValue]['searchPrm']!}\r\n    this.selectOptions = this.gridList()[this.indexValue]['selectOptions']!\r\n    console.log('seletc-----',this.selectOptions)\r\n    this.dialogSearchPrm.modelName = this.selectOptions.modelName\r\n    this.visible = true\r\n  }\r\n\r\n  goRun(data:any){\r\n    if(data.idKey){\r\n      let id = this.getPrm.data[data.idKey]\r\n      this.router.navigate([`${data.url}/${id}`])\r\n    } else {\r\n      this.router.navigate([data.url])\r\n    }\r\n  }\r\n\r\n  authClick(btn:any){\r\n    console.log('authClick',btn)\r\n    if(btn.hasOwnProperty('onClick')){\r\n      btn.onClick(this.getPrm.data)\r\n    }\r\n  }\r\n  statusChange(value:any, customSteps: StepsComponent){\r\n    if(this.authLevel() < 4) return;\r\n    if(this.id){\r\n      let param :any= {\r\n        modelName: this.modelName,\r\n        data:{id: this.id, [this.statusKey()]: value}\r\n      }\r\n      if(this.isLog){\r\n        param.logModel = `${this.modelName}Log`\r\n        param.log = {\r\n          pid:this.id,\r\n          content:`[状态] ${this.getPrm.data![this.statusKey()]} -> ${value}`\r\n        }\r\n      }\r\n      this.web_write(param).subscribe(res => {\r\n        this.getDetail()\r\n        customSteps.refreshSteps()\r\n      })\r\n    } else {\r\n      this.getPrm.data = Object.assign(this.getPrm.data||{},{\r\n        [this.statusKey()]:value\r\n      })\r\n      this.upsertPrm.addData![this.statusKey()] = value\r\n      this.cForm.triggerModelEffect({[this.statusKey()]:value})\r\n      customSteps.refreshSteps()\r\n    }\r\n  }\r\n\r\n  formDisFunc(){\r\n    this.formOptions.fields?.forEach((v) => {\r\n      v.group?.forEach((g:any) => {\r\n        let fieldDisabled = g[formTypeToProps[g.type]].disabled || false\r\n        if(this.formDisabled()!(this.getPrm.data) ){\r\n          this.cForm.getField(g.key)?.fieldControl!.disable({emitEvent: false}) \r\n        } else {\r\n          !fieldDisabled && this.cForm.getField(g.key)?.fieldControl!.enable({emitEvent: false}) \r\n        }\r\n      })\r\n    })\r\n  }\r\n}","<div class=\"overflow-hidden\">\r\n  <div class=\"flex items-center justify-between py-1 px-1 border-b-[1px] border-[#dbdbdb] bg-white\">\r\n    <app-crumb-action\r\n      [addVisible]=\"addVisible()\"\r\n      [newUrl]=\"newUrl\"\r\n      [isShowCog]=\"true\"\r\n      [outlined]=\"true\"\r\n      [authLevel]=\"authLevel()\"\r\n      [actionList]=\"actionList()\"\r\n      (actionEvent)=\"authClick($event)\"\r\n      (saveEvent)=\"submitForm()\">\r\n    </app-crumb-action>\r\n    <div class=\"hrefBtnList\">\r\n      @if(id){\r\n        @for(btn of hrefBtnList();track btn){\r\n          <p-button \r\n            [variant]=\"btn?.variant\" \r\n            [severity]=\"btn?.severity\" \r\n            class=\"mr-[6px]\"\r\n            [icon]=\"btn?.icon\"\r\n            label=\"{{btn.i18nKey? i18n.fanyi(btn.i18nKey) : btn.label}}\"\r\n            (click)=\"goRun(btn)\"\r\n          >\r\n        </p-button>\r\n        }\r\n      }\r\n      \r\n    </div>\r\n    <div></div>\r\n    \r\n  </div>\r\n  <div class=\"flex\">\r\n    <div class=\"px-2 flex flex-wrap items-center md:basis-2/3 basis-full\">\r\n      <div class=\"hidden md:basis-1/3 py-1 basis-full md:flex items-center gap-2 flex-row order-1\">\r\n        @for (btn of actionList();let i = $index; track btn) {\r\n          <p-button\r\n            [variant]=\"btn?.variant\"\r\n            [severity]=\"btn?.severity\"\r\n            class=\"mr-[4px]\"\r\n            size=\"small\"\r\n            [icon]=\"btn?.icon\"\r\n            label=\"{{ btn.i18nKey ? (btn.i18nKey | translate) : btn.label }}\"\r\n            (click)=\"authClick(btn)\"\r\n            [disabled]=\"btn.btnDisabled ? btn.btnDisabled(getPrm.data) : false\"\r\n            >\r\n          </p-button>\r\n        }\r\n      </div>\r\n  \r\n      <div class=\"md:basis-2/3 basis-full flex md:flex-row-reverse flex-row md:order-2 order-first w-full\">\r\n        <custom-steps\r\n          #customSteps\r\n          class=\"w-full\"\r\n          [steps]=\"statusSteps()\"\r\n          [current]=\"getPrm.data && getPrm.data[statusKey()] !== undefined ? getPrm.data[statusKey()] : 0\"\r\n          [authLevel]=\"authLevel()\"\r\n          (change)=\"statusChange($event, customSteps)\">\r\n        </custom-steps>\r\n      </div>\r\n    </div>\r\n  </div>\r\n  <div class=\"main flex flex-wrap overflow-y-hidden\">\r\n    <div class=\"md:basis-2/3 basis-full h-full overflow-y-auto\">\r\n      <div class=\"bg-white mx-2 form-panel\">\r\n        <div class=\"p-2 flex-1\">\r\n          <form\r\n            [formGroup]=\"form().form!\">\r\n            <custom-form\r\n              #cForm\r\n              [options]=\"formOptions\"\r\n              [upsert]=\"upsertPrm\"\r\n              [model]=\"getPrm.data??{}\"></custom-form>\r\n          </form>\r\n        </div>\r\n        @if(gridList() && gridList().length > 1){\r\n          <div class=\"relative mb-2\">\r\n            <p-tabs [(value)]=\"indexValue\">\r\n              <p-tablist>\r\n                @for (fchild of gridList();let i = $index; track fchild) {\r\n                  <p-tab [value]=\"i\">\r\n                    {{fchild.i18nKey ? i18n.fanyi(fchild.i18nKey) : fchild.title}}\r\n                  </p-tab>\r\n                }\r\n              </p-tablist>\r\n            </p-tabs>\r\n          </div>\r\n        }\r\n        @for (grid of gridList(); let i = $index;track grid) {\r\n          <custom-grid\r\n            #customGrid\r\n            [hidden]=\"indexValue !=i \"\r\n            [rowData]=\"getPrm.data?.[grid.subDataKey!]|| []\"\r\n            [upsert]=\"upsertPrm\"\r\n            (deleteEmit)=\"delRows($event)\"\r\n            [addType]=\"grid.subTableSource\"\r\n            (addEmit)=\"dataSourceShow()\"\r\n            [gridOptions]=\"grid.gridOptions\"\r\n            [authLevel]=\"authLevel()\"\r\n            [selectData]=\"grid.selectData\">\r\n          </custom-grid>\r\n        }       \r\n      </div>\r\n    </div>\r\n    <div class=\"md:basis-1/3 basis-full h-full overflow-y-auto\">\r\n      <custom-log [logs]=\"getPrm.data?.log??[]\"></custom-log>\r\n    </div>\r\n  </div>\r\n</div>\r\n<row-selector\r\n\t[(visible)]=\"visible\"\r\n\t[searchPrm]=\"dialogSearchPrm\"\r\n\t[gridOptions]=\"selectOptions\"\r\n\t(onOk)=\"onOk($event)\">\r\n</row-selector>"]}
|
|
219
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"page-form.component.js","sourceRoot":"","sources":["../../../../../projects/imm-element-ui/src/lib/page-form/page-form.component.ts","../../../../../projects/imm-element-ui/src/lib/page-form/page-form.component.html"],"names":[],"mappings":"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","sourcesContent":["import { UserHistoryService } from '../service/userHistory.service';\r\nimport { Component, inject, OnInit, ViewChild, input, effect, computed, Input } from '@angular/core';\r\nimport { ReactiveFormsModule } from '@angular/forms';\r\nimport { FormComponent,FormOptions } from '../form/form/form.component';\r\nimport { RowSelectorComponent } from '../row-selector/row-selector.component'\r\nimport { LogComponent } from '../log/log.component';\r\nimport { ButtonModule } from 'primeng/button';\r\nimport { CrumbActionComponent } from '../crumb-action/crumb-action.component';\r\nimport { StepsComponent,Step } from '../steps/steps.component';\r\nimport { GridComponent, GridOptions } from '../grid/grid/grid.component';\r\nimport { TabsModule } from 'primeng/tabs';\r\nimport { AmComponent, Get, } from '../am/am.component';\r\nimport { Search } from '../am/am.component'\r\nimport { HrefBtnList,GridList } from './page-form.interface';\r\nimport { TranslatePipe } from '@ngx-translate/core';\r\nimport { I18nService } from '../service/i18n.service';\r\nimport { PermissionBtn } from './page-form.interface';\r\nimport { formTypeToProps } from './page-form.interface'\r\n@Component({\r\n  selector: 'app-page-form',\r\n  standalone: true,\r\n  imports: [\r\n    ButtonModule,\r\n    ReactiveFormsModule,\r\n    FormComponent,\r\n    LogComponent,\r\n    CrumbActionComponent,\r\n    StepsComponent,\r\n    GridComponent,\r\n    TabsModule,\r\n    RowSelectorComponent,\r\n    TranslatePipe,\r\n  ],\r\n  templateUrl: './page-form.component.html',\r\n  styleUrl: './page-form.component.scss',\r\n  providers:[]\r\n})\r\nexport class PageFormComponent extends AmComponent implements OnInit{\r\n  addVisible = input<boolean>()\r\n  gridList = input<GridList[]>([])\r\n  form = input.required<FormOptions>({})\r\n  getPrmInput = input.required<Get>({})\r\n  statusSteps = input<Step[]>([])\r\n  statusKey = input('status')\r\n  hrefBtnList = input<HrefBtnList[]>([])\r\n  setTitle = input<string>()\r\n  actionList = input<PermissionBtn[]>([])\r\n  modelLog = input<boolean>(false)\r\n  formDisabled = input<Function>()\r\n\r\n  @ViewChild('customGrid') customGrid!: GridComponent;\r\n  @ViewChild('cForm') cForm!: FormComponent\r\n  userHistoryService =  inject(UserHistoryService)\r\n  indexValue = 0\r\n  visible = false\r\n  dialogSearchPrm!: Search\r\n  selectOptions!:GridOptions\r\n  selectData :any[]= []\r\n  pageUrl = ''\r\n  newUrl = ''\r\n  i18n = inject(I18nService)\r\n  authLevel = input<number>(-1)\r\n  constructor(){\r\n    super()\r\n    this.id = Number(this.route.snapshot.paramMap.get('id'))\r\n    this.pageUrl = this.route.snapshot.url.map(segment => segment.path).join('/').replace(/([^\\/]*)$/, \"\")\r\n    this.newUrl = `${this.pageUrl}new`\r\n    effect(() => {\r\n      this.modelName = this.getPrmInput().modelName!\r\n      this.getPrm = {...this.getPrmInput()}\r\n      this.id && (this.getPrm.id = this.id)\r\n      this.id && this.getDetail()\r\n    },{ allowSignalWrites: true })\r\n\r\n    effect(() => {\r\n      this.formOptions = {...this.form()}\r\n    })\r\n    effect(() => {\r\n      this.isLog = this.modelLog()\r\n      console.log('model-----',this.isLog,this.modelLog())\r\n    },{allowSignalWrites:true})\r\n    effect(() => {\r\n      if(this.statusSteps().length > 0 && !this.id){\r\n        this.upsertPrm.addData![this.statusKey()] = this.statusSteps()[0]['value']\r\n        this.getPrm.data = Object.assign(this.getPrm.data||{},{\r\n          [this.statusKey()]:this.statusSteps()[0]['value']\r\n        })\r\n      }\r\n    },{allowSignalWrites:true})\r\n  }\r\n  ngOnInit(): void {\r\n    this.upCb = this.upCb.bind(this)\r\n  }\r\n\r\n  submitForm() :any{\r\n    if(this.cForm.validate()){\r\n      let cb:any = this.id === 0 ? null : this.upCb\r\n      this.upsert(null,cb)\r\n    }\r\n  }\r\n\r\n  delRows(e:any) {\r\n    const gridTab = this.gridList()[this.indexValue]\r\n    const deleteFunc = gridTab.deleteFunc\r\n    const subTable = gridTab.gridOptions.modelName;\r\n\r\n    let prm = { \r\n      modelName: subTable, \r\n      ids:e \r\n    };\r\n    if(!deleteFunc){\r\n      this.web_remove(prm).subscribe((res) => {\r\n        this.get();\r\n      });\r\n    } else {\r\n      deleteFunc().subscribe(() => {\r\n        this.get()\r\n      })\r\n    }\r\n    \r\n  }\r\n  upCb(res?:any){\r\n    if(res.id == 0){\r\n      this.getDetail()\r\n    }else {\r\n      setTimeout(() => {\r\n        let editUrl = `${this.pageUrl}${res.id}`\r\n        this.router.navigate([editUrl])\r\n      }, 1500)\r\n    }\r\n    this.cForm.finalize()\r\n  }\r\n  // TODO 是否需要数据转换回调函数\r\n  onOk(e:any){\r\n    this.gridList()[this.indexValue].selectData = []\r\n    if(e.length > 0){\r\n      let { selectDataCb } = this.gridList()[this.indexValue]\r\n      e.forEach((item:any) => {\r\n        let obj = selectDataCb ? selectDataCb(item): {...item}\r\n        this.gridList()[this.indexValue].selectData!.push(obj)\r\n      })\r\n    } \r\n  }\r\n  getDetail(customSteps?: StepsComponent){\r\n    this.web_get(this.getPrm).subscribe(res => {\r\n      this.updateTitle(res)\r\n      this.formDisabled() && this.formDisFunc()\r\n      // customSteps && customSteps.refreshSteps()\r\n    })\r\n  }\r\n  updateTitle(res:any){\r\n    // let title = this.setTitle() ? this.setTitle() : ''\r\n    // title !== '' && this.userHistoryService.setLastTitle(title)\r\n    let mainField = this.form().mainField\r\n    let title = res[mainField!]\r\n    this.userHistoryService.setLastTitle(title)\r\n  }\r\n  dataSourceShow(){\r\n    this.dialogSearchPrm = {...this.gridList()[this.indexValue]['searchPrm']!}\r\n    this.selectOptions = this.gridList()[this.indexValue]['selectOptions']!\r\n    console.log('seletc-----',this.selectOptions)\r\n    this.dialogSearchPrm.modelName = this.selectOptions.modelName\r\n    this.visible = true\r\n  }\r\n\r\n  goRun(data:any){\r\n    if(data.idKey){\r\n      let id = this.getPrm.data[data.idKey]\r\n      this.router.navigate([`${data.url}/${id}`])\r\n    } else {\r\n      this.router.navigate([data.url])\r\n    }\r\n  }\r\n\r\n  authClick(btn:any){\r\n    console.log('authClick',btn)\r\n    if(btn.hasOwnProperty('onClick')){\r\n      btn.onClick(this.getPrm.data)\r\n    }\r\n  }\r\n  statusChange(value:any, customSteps: StepsComponent){\r\n    if(this.authLevel() < 4) return;\r\n    if(this.id){\r\n      let param :any= {\r\n        modelName: this.modelName,\r\n        data:{id: this.id, [this.statusKey()]: value}\r\n      }\r\n      if(this.isLog){\r\n        param.logModel = `${this.modelName}Log`\r\n        param.log = {\r\n          pid:this.id,\r\n          content:`[状态] ${this.getPrm.data![this.statusKey()]} -> ${value}`\r\n        }\r\n      }\r\n      this.web_write(param).subscribe(res => {\r\n        this.getDetail(customSteps)\r\n      })\r\n    } else {\r\n      this.getPrm.data = Object.assign(this.getPrm.data||{},{\r\n        [this.statusKey()]:value\r\n      })\r\n      this.upsertPrm.addData![this.statusKey()] = value\r\n      this.cForm.triggerModelEffect({[this.statusKey()]:value})\r\n      // customSteps.refreshSteps()\r\n    }\r\n  }\r\n\r\n  formDisFunc(){\r\n    this.formOptions.fields?.forEach((v) => {\r\n      v.group?.forEach((g:any) => {\r\n        let fieldDisabled = g[formTypeToProps[g.type]].disabled || false\r\n        if(this.formDisabled()!(this.getPrm.data) ){\r\n          this.cForm.getField(g.key)?.fieldControl!.disable({emitEvent: false}) \r\n        } else {\r\n          !fieldDisabled && this.cForm.getField(g.key)?.fieldControl!.enable({emitEvent: false}) \r\n        }\r\n      })\r\n    })\r\n  }\r\n}","<div class=\"md:overflow-hidden\">\r\n  <div class=\"flex items-center justify-between py-1 px-1 border-b-[1px] border-[#dbdbdb] bg-white\">\r\n    <app-crumb-action\r\n      [addVisible]=\"addVisible()\"\r\n      [newUrl]=\"newUrl\"\r\n      [isShowCog]=\"true\"\r\n      [outlined]=\"true\"\r\n      [authLevel]=\"authLevel()\"\r\n      [actionList]=\"actionList()\"\r\n      (actionEvent)=\"authClick($event)\"\r\n      (saveEvent)=\"submitForm()\">\r\n    </app-crumb-action>\r\n    <div class=\"hrefBtnList\">\r\n      @if(id){\r\n        @for(btn of hrefBtnList();track btn){\r\n          <p-button \r\n            [variant]=\"btn?.variant\" \r\n            [severity]=\"btn?.severity\" \r\n            class=\"mr-[6px]\"\r\n            [icon]=\"btn?.icon\"\r\n            label=\"{{btn.i18nKey? i18n.fanyi(btn.i18nKey) : btn.label}}\"\r\n            (click)=\"goRun(btn)\"\r\n          >\r\n        </p-button>\r\n        }\r\n      }\r\n      \r\n    </div>\r\n    <div></div>\r\n    \r\n  </div>\r\n  <div class=\"flex\">\r\n    <div class=\"px-2 flex flex-wrap items-center md:basis-2/3 basis-full\">\r\n      <div class=\"hidden md:basis-1/3 py-1 basis-full md:flex items-center gap-2 flex-row order-1\">\r\n        @for (btn of actionList();let i = $index; track btn) {\r\n          <p-button\r\n            [variant]=\"btn?.variant\"\r\n            [severity]=\"btn?.severity\"\r\n            class=\"mr-[4px]\"\r\n            size=\"small\"\r\n            [icon]=\"btn?.icon\"\r\n            label=\"{{ btn.i18nKey ? (btn.i18nKey | translate) : btn.label }}\"\r\n            (click)=\"authClick(btn)\"\r\n            [disabled]=\"btn.btnDisabled ? btn.btnDisabled(getPrm.data) : false\"\r\n            >\r\n          </p-button>\r\n        }\r\n      </div>\r\n  \r\n      <div class=\"md:basis-2/3 basis-full flex md:flex-row-reverse flex-row md:order-2 order-first w-full\">\r\n        <custom-steps\r\n          #customSteps\r\n          class=\"w-full\"\r\n          [steps]=\"statusSteps()\"\r\n          [current]=\"getPrm.data && getPrm.data[statusKey()] !== undefined ? getPrm.data[statusKey()] : 0\"\r\n          [authLevel]=\"authLevel()\"\r\n          (change)=\"statusChange($event, customSteps)\">\r\n        </custom-steps>\r\n      </div>\r\n    </div>\r\n  </div>\r\n  <div class=\"main flex flex-wrap md:overflow-y-hidden\">\r\n    <div class=\"md:basis-2/3 basis-full h-full overflow-y-auto\">\r\n      <div class=\"bg-white mx-2 form-panel\">\r\n        <div class=\"p-2 flex-1\">\r\n          <form\r\n            [formGroup]=\"form().form!\">\r\n            <custom-form\r\n              #cForm\r\n              [options]=\"formOptions\"\r\n              [upsert]=\"upsertPrm\"\r\n              [model]=\"getPrm.data??{}\"></custom-form>\r\n          </form>\r\n        </div>\r\n        @if(gridList() && gridList().length > 1){\r\n          <div class=\"relative mb-2\">\r\n            <p-tabs [(value)]=\"indexValue\">\r\n              <p-tablist>\r\n                @for (fchild of gridList();let i = $index; track fchild) {\r\n                  <p-tab [value]=\"i\">\r\n                    {{fchild.i18nKey ? i18n.fanyi(fchild.i18nKey) : fchild.title}}\r\n                  </p-tab>\r\n                }\r\n              </p-tablist>\r\n            </p-tabs>\r\n          </div>\r\n        }\r\n        @for (grid of gridList(); let i = $index;track grid) {\r\n          <custom-grid\r\n            #customGrid\r\n            [hidden]=\"indexValue !=i \"\r\n            [rowData]=\"getPrm.data?.[grid.subDataKey!]|| []\"\r\n            [upsert]=\"upsertPrm\"\r\n            (deleteEmit)=\"delRows($event)\"\r\n            [addType]=\"grid.subTableSource\"\r\n            (addEmit)=\"dataSourceShow()\"\r\n            [gridOptions]=\"grid.gridOptions\"\r\n            [authLevel]=\"authLevel()\"\r\n            [selectData]=\"grid.selectData\">\r\n          </custom-grid>\r\n        }       \r\n      </div>\r\n    </div>\r\n    <div class=\"md:basis-1/3 basis-full h-full overflow-y-auto\">\r\n      <custom-log [logs]=\"getPrm.data?.log??[]\"></custom-log>\r\n    </div>\r\n  </div>\r\n</div>\r\n<row-selector\r\n\t[(visible)]=\"visible\"\r\n\t[searchPrm]=\"dialogSearchPrm\"\r\n\t[gridOptions]=\"selectOptions\"\r\n\t(onOk)=\"onOk($event)\">\r\n</row-selector>"]}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Component, computed, HostListener, inject, input, output, signal, ViewChild } from '@angular/core';
|
|
1
|
+
import { Component, computed, effect, HostListener, inject, input, output, signal, ViewChild } from '@angular/core';
|
|
2
2
|
import { I18nService } from '../service/i18n.service';
|
|
3
3
|
import { FormsModule } from '@angular/forms';
|
|
4
4
|
import { ListboxModule } from 'primeng/listbox';
|
|
@@ -28,11 +28,18 @@ export class StepsComponent {
|
|
|
28
28
|
this.widthList = [];
|
|
29
29
|
this.START_BUTTON_WIDTH = 32;
|
|
30
30
|
this.END_BUTTON_WIDTH = 47;
|
|
31
|
+
this.STEP_ITEM_MARGIN = 2;
|
|
31
32
|
this.startIndex = 0;
|
|
32
33
|
this.endIndex = 0;
|
|
33
34
|
this.startSteps = [];
|
|
34
35
|
this.endSteps = [];
|
|
35
36
|
this.maxWidth = 0;
|
|
37
|
+
effect(() => {
|
|
38
|
+
let current = this.current();
|
|
39
|
+
if (current != 0 && this.steps().length > 0) {
|
|
40
|
+
this.refreshSteps();
|
|
41
|
+
}
|
|
42
|
+
}, { allowSignalWrites: true });
|
|
36
43
|
}
|
|
37
44
|
ngAfterViewInit() {
|
|
38
45
|
this.calcMaxWidth();
|
|
@@ -52,7 +59,7 @@ export class StepsComponent {
|
|
|
52
59
|
if (children[i].classList.contains('end-item')) {
|
|
53
60
|
continue;
|
|
54
61
|
}
|
|
55
|
-
this.widthList.push(children[i].offsetWidth || 0);
|
|
62
|
+
this.widthList.push((children[i].offsetWidth || 0) + this.STEP_ITEM_MARGIN);
|
|
56
63
|
}
|
|
57
64
|
}
|
|
58
65
|
calcMaxWidth() {
|
|
@@ -165,10 +172,8 @@ export class StepsComponent {
|
|
|
165
172
|
this.excludeValues.set(excludeValues);
|
|
166
173
|
}
|
|
167
174
|
refreshSteps() {
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
this.handleSteps();
|
|
171
|
-
});
|
|
175
|
+
this.alternateWidthList();
|
|
176
|
+
this.handleSteps();
|
|
172
177
|
}
|
|
173
178
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: StepsComponent, deps: [{ token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
174
179
|
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: StepsComponent, isStandalone: true, selector: "custom-steps", inputs: { steps: { classPropertyName: "steps", publicName: "steps", isSignal: true, isRequired: false, transformFunction: null }, current: { classPropertyName: "current", publicName: "current", isSignal: true, isRequired: false, transformFunction: null }, authLevel: { classPropertyName: "authLevel", publicName: "authLevel", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { change: "change" }, host: { listeners: { "window:resize": "onResize($event)" } }, viewQueries: [{ propertyName: "containerRef", first: true, predicate: ["container"], descendants: true }, { propertyName: "endBtn", first: true, predicate: ["endBtn"], descendants: true }], ngImport: i0, template: "<div\r\n\t#container\r\n\tclass=\"flex my-1 w-full justify-end\">\r\n\t@for (st of displaySteps(); track st; let i = $index) {\r\n\t\t@if (st.value === 'start') {\r\n\t\t\t<div\r\n\t\t\t\t#startItem\r\n\t\t\t\t[class]=\"getClass(i, ['start-item'])\"\r\n\t\t\t\t(click)=\"showStartSteps($event, startOp)\">\r\n\t\t\t\t<span>...</span>\r\n\t\t\t</div>\r\n\t\t\t<p-popover\r\n\t\t\t\t#startOp\r\n\t\t\t\t[styleClass]=\"'pop-steps start-steps'\"\r\n\t\t\t\t[appendTo]=\"startItem\">\r\n\t\t\t\t<p-listbox\r\n\t\t\t\t\t[options]=\"startSteps\"\r\n\t\t\t\t\t(onChange)=\"onStartStepsChange($event)\"\r\n\t\t\t\t\toptionLabel=\"label\"\r\n\t\t\t\t\tclass=\"w-full md:w-56\" />\r\n\t\t\t</p-popover>\r\n\t\t} @else if (st.value === 'end') {\r\n\t\t\t<div\r\n\t\t\t\t#endItem\r\n\t\t\t\t[class]=\"getClass(i, ['end-item'])\"\r\n\t\t\t\t(click)=\"showEndSteps($event, endOp)\">\r\n\t\t\t\t<span>...</span>\r\n\t\t\t</div>\r\n\t\t\t<p-popover\r\n\t\t\t\t#endOp\r\n\t\t\t\t[styleClass]=\"'pop-steps end-steps'\"\r\n\t\t\t\t[appendTo]=\"endItem\">\r\n\t\t\t\t<p-listbox\r\n\t\t\t\t\t[options]=\"endSteps\"\r\n\t\t\t\t\t(onChange)=\"onEndStepsChange($event)\"\r\n\t\t\t\t\toptionLabel=\"label\"\r\n\t\t\t\t\tclass=\"w-full md:w-56\" />\r\n\t\t\t</p-popover>\r\n\t\t} @else {\r\n\t\t\t<div\r\n\t\t\t\t[class]=\"getClass(i, [])\"\r\n\t\t\t\t(click)=\"changeStatus(st)\">\r\n\t\t\t\t<span>{{ st.i18nKey ? i18n.fanyi(st.i18nKey) : st.label }}</span>\r\n\t\t\t</div>\r\n\t\t}\r\n\t}\r\n</div>\r\n", styles: ["::ng-deep .pop-steps.p-popover.p-popover-flipped:before{display:none}::ng-deep .pop-steps.p-popover.p-popover-flipped:after{display:none}::ng-deep .pop-steps.p-popover:before{display:none}::ng-deep .pop-steps.p-popover:after{display:none}::ng-deep .pop-steps.p-popover-flipped{margin-top:-5px}::ng-deep .pop-steps .p-popover-content{padding:0}::ng-deep .end-steps.p-popover{margin-top:2.5px;z-index:999;position:absolute!important;left:auto!important;right:0!important;top:100%!important;min-width:125px}::ng-deep .start-steps.p-popover{margin-top:2.5px;z-index:999;position:absolute!important;left:0!important;right:auto!important;top:100%!important;min-width:125px}.step-item{position:relative;height:32px;padding:0 5px;background-color:#e7e9ed}.step-item span{color:#334155c2;white-space:nowrap}.step-item.step-first{padding-left:15px}.step-item.step-last{padding-right:15px}.step-item:not(.step-first){border-left:15px solid transparent;margin-left:2px}.step-item:not(.step-first):before{content:\"\";position:absolute;top:0;left:-15px;width:0;height:0;border-top:15px solid transparent;border-bottom:15px solid transparent;border-left:12px solid white}.step-item:not(.step-last):after{content:\"\";position:absolute;top:0;right:-12px;width:0;height:0;border-top:15px solid transparent;border-bottom:15px solid transparent;border-left:12px solid #e7e9ed;z-index:2}.step-item.step-active{background-color:var(--p-primary-200)}.step-item.step-active span{color:#334155}.step-item.step-active:after{border-left:12px solid var(--p-primary-200)}\n"], dependencies: [{ kind: "ngmodule", type: FormsModule }, { kind: "ngmodule", type: ListboxModule }, { kind: "component", type: i1.Listbox, selector: "p-listbox, p-listBox, p-list-box", inputs: ["id", "searchMessage", "emptySelectionMessage", "selectionMessage", "autoOptionFocus", "ariaLabel", "selectOnFocus", "searchLocale", "focusOnHover", "filterMessage", "filterFields", "lazy", "virtualScroll", "virtualScrollItemSize", "virtualScrollOptions", "scrollHeight", "tabindex", "multiple", "style", "styleClass", "listStyle", "listStyleClass", "readonly", "disabled", "checkbox", "filter", "filterBy", "filterMatchMode", "filterLocale", "metaKeySelection", "dataKey", "showToggleAll", "optionLabel", "optionValue", "optionGroupChildren", "optionGroupLabel", "optionDisabled", "ariaFilterLabel", "filterPlaceHolder", "emptyFilterMessage", "emptyMessage", "group", "options", "filterValue", "selectAll", "striped", "highlightOnSelect", "checkmark"], outputs: ["onChange", "onClick", "onDblClick", "onFilter", "onFocus", "onBlur", "onSelectAllChange", "onLazyLoad"] }, { kind: "component", type: Popover, selector: "p-popover", inputs: ["ariaLabel", "ariaLabelledBy", "dismissable", "showCloseIcon", "style", "styleClass", "appendTo", "autoZIndex", "ariaCloseLabel", "baseZIndex", "focusOnShow", "showTransitionOptions", "hideTransitionOptions"], outputs: ["onShow", "onHide"] }] }); }
|
|
@@ -186,4 +191,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
186
191
|
type: HostListener,
|
|
187
192
|
args: ['window:resize', ['$event']]
|
|
188
193
|
}] } });
|
|
189
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"steps.component.js","sourceRoot":"","sources":["../../../../../projects/imm-element-ui/src/lib/steps/steps.component.ts","../../../../../projects/imm-element-ui/src/lib/steps/steps.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, computed, effect, ElementRef, HostListener, inject, input, output, Renderer2, signal, ViewChild } from '@angular/core';\r\nimport { I18nService } from '../service/i18n.service';\r\nimport { FormsModule } from '@angular/forms';\r\nimport { ListboxModule } from 'primeng/listbox';\r\nimport { Popover } from 'primeng/popover';\r\nexport interface Step {\r\n\tlabel: string;\r\n\ti18nKey?: string;\r\n\tvalue: number | 'start' | 'end';\r\n}\r\n\r\n@Component({\r\n\tselector: 'custom-steps',\r\n\tstandalone: true,\r\n\timports: [FormsModule, ListboxModule, Popover],\r\n\ttemplateUrl: './steps.component.html',\r\n\tstyleUrl: './steps.component.scss',\r\n})\r\nexport class StepsComponent {\r\n\t@ViewChild('container', { static: false }) containerRef!: ElementRef;\r\n\t@ViewChild('endBtn', { static: false }) endBtn!: ElementRef;\r\n\tsteps = input<Step[]>([]);\r\n\tdisplaySteps = computed(() => {\r\n\t\tconst steps = [...this.steps()];\r\n\t\tsteps.unshift({ value: 'start', label: '...' });\r\n\t\tsteps.push({ value: 'end', label: '...' });\r\n\t\treturn steps.filter((step) => !this.excludeValues().includes(step.value));\r\n\t});\r\n\texcludeValues = signal<(number | 'start' | 'end')[]>([]);\r\n\tcurrent = input<number>(2);\r\n\ti18n = inject(I18nService);\r\n\tchange = output<number>();\r\n\tauthLevel = input<number>(-1);\r\n\r\n\twidthList: number[] = [];\r\n\tSTART_BUTTON_WIDTH = 32;\r\n\tEND_BUTTON_WIDTH = 47;\r\n\r\n\tstartIndex = 0;\r\n\tendIndex = 0;\r\n\tstartSteps: Step[] = [];\r\n\tendSteps: Step[] = [];\r\n\tmaxWidth = 0;\r\n\r\n\t@HostListener('window:resize', ['$event'])\r\n\tonResize() {\r\n\t\tthis.calcMaxWidth();\r\n\t\tthis.alternateWidthList();\r\n\t\tthis.handleSteps();\r\n\t}\r\n\r\n\tconstructor(private renderer: Renderer2) {}\r\n\r\n\tngAfterViewInit() {\r\n\t\tthis.calcMaxWidth();\r\n\t\tthis.initWidthList();\r\n\t\tthis.alternateWidthList();\r\n\t\tthis.handleSteps();\r\n\t}\r\n\r\n\tinitWidthList() {\r\n\t\tconst children = this.renderer.parentNode(this.containerRef.nativeElement).children[0].children;\r\n\t\tfor (let i = 0; i < children.length; i++) {\r\n\t\t\tif (!children[i].classList.contains('step-item')) {\r\n\t\t\t\tcontinue;\r\n\t\t\t}\r\n\t\t\tif (children[i].classList.contains('start-item')) {\r\n\t\t\t\tcontinue;\r\n\t\t\t}\r\n\t\t\tif (children[i].classList.contains('end-item')) {\r\n\t\t\t\tcontinue;\r\n\t\t\t}\r\n\t\t\tthis.widthList.push(children[i].offsetWidth || 0);\r\n\t\t}\r\n\t}\r\n\r\n\tcalcMaxWidth() {\r\n\t\tthis.maxWidth = window.innerWidth < 768 ? window.innerWidth * 0.96 : window.innerWidth * 0.42;\r\n\t}\r\n\r\n\tshowStartSteps(event: any, startOp: any) {\r\n\t\tif (this.authLevel() < 4) return;\r\n\t\tstartOp.toggle(event);\r\n\t}\r\n\r\n\tshowEndSteps(event: any, endOp: any) {\r\n\t\tif (this.authLevel() < 4) return;\r\n\t\tendOp.toggle(event);\r\n\t}\r\n\r\n\tgetClass(i: number, classes: string[]) {\r\n\t\tlet result = ['step-item', 'flex', 'items-center', 'justify-center'];\r\n\t\tresult = result.concat(classes);\r\n\t\tif (this.authLevel() < 4) {\r\n\t\t\tresult.push('cursor-not-allowed');\r\n\t\t} else {\r\n\t\t\tresult.push('cursor-pointer allow-hover');\r\n\t\t}\r\n\t\tconst { value } = this.displaySteps()![i];\r\n\t\tif (i == 0) {\r\n\t\t\tresult.push('step-first');\r\n\t\t} else if (i + 1 == this.displaySteps()?.length) {\r\n\t\t\tresult.push('step-last');\r\n\t\t}\r\n\t\tif (value == this.current()) {\r\n\t\t\tresult.push('step-active');\r\n\t\t\tresult.push('md:flex-none flex-1');\r\n\t\t}\r\n\t\treturn result.join(' ');\r\n\t}\r\n\r\n\tchangeStatus(step: any) {\r\n\t\tthis.change.emit(step.value);\r\n\t}\r\n\r\n\tonStartStepsChange(event: any) {\r\n\t\tconst step = event.value;\r\n\t\tthis.change.emit(step.value);\r\n\t}\r\n\r\n\tonEndStepsChange(event: any) {\r\n\t\tconst step = event.value;\r\n\t\tthis.change.emit(step.value);\r\n\t}\r\n\r\n\talternateWidthList() {\r\n\t\tlet index = this.steps().findIndex((s) => s.value === this.current());\r\n\t\tindex = index === -1 ? 0 : index;\r\n\t\tthis.startIndex = index;\r\n\t\tthis.endIndex = index;\r\n\r\n\t\tlet leftIndex = index - 1;\r\n\t\tlet rightIndex = index + 1;\r\n\t\tlet turn = 'right';\r\n\t\tlet totalWidth = this.widthList[index];\r\n\r\n\t\twhile (leftIndex >= 0 || rightIndex < this.widthList.length) {\r\n\t\t\tif (turn === 'right' && rightIndex < this.widthList.length) {\r\n\t\t\t\ttotalWidth += this.widthList[rightIndex];\r\n\t\t\t\tif (this.isExceedMaxWidth(totalWidth)) {\r\n\t\t\t\t\tbreak;\r\n\t\t\t\t}\r\n\t\t\t\tthis.endIndex = rightIndex;\r\n\t\t\t\trightIndex++;\r\n\t\t\t\tturn = 'left';\r\n\t\t\t} else if (turn === 'left' && leftIndex >= 0) {\r\n\t\t\t\ttotalWidth += this.widthList[leftIndex];\r\n\t\t\t\tif (this.isExceedMaxWidth(totalWidth)) {\r\n\t\t\t\t\tbreak;\r\n\t\t\t\t}\r\n\t\t\t\tthis.startIndex = leftIndex;\r\n\t\t\t\tleftIndex--;\r\n\t\t\t\tturn = 'right';\r\n\t\t\t} else {\r\n\t\t\t\tturn = rightIndex < this.widthList.length ? 'right' : 'left';\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\n\tisExceedMaxWidth(totalWidth: number) {\r\n\t\ttotalWidth += this.startIndex === 0 ? 0 : this.START_BUTTON_WIDTH;\r\n\t\ttotalWidth += this.endIndex === this.widthList.length - 1 ? 0 : this.END_BUTTON_WIDTH;\r\n\t\treturn totalWidth >= this.maxWidth;\r\n\t}\r\n\r\n\thandleSteps() {\r\n\t\tconst steps = this.steps();\r\n\t\tconst excludeValues: any[] = [];\r\n\t\tfor (let i = 0; i < steps.length; i++) {\r\n\t\t\tif (i < this.startIndex) {\r\n\t\t\t\texcludeValues.push(steps[i].value);\r\n\t\t\t}\r\n\t\t\tif (i > this.endIndex) {\r\n\t\t\t\texcludeValues.push(steps[i].value);\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\tif (this.startIndex > 0) {\r\n\t\t\tthis.startSteps = steps.slice(0, this.startIndex);\r\n\t\t} else {\r\n\t\t\texcludeValues.push('start');\r\n\t\t}\r\n\t\tif (this.endIndex < steps.length - 1) {\r\n\t\t\tthis.endSteps = steps.slice(this.endIndex + 1);\r\n\t\t} else {\r\n\t\t\texcludeValues.push('end');\r\n\t\t}\r\n\t\tthis.excludeValues.set(excludeValues);\r\n\t}\r\n\r\n\trefreshSteps() {\r\n\t\tsetTimeout(() => {\r\n\t\t\tthis.alternateWidthList();\r\n\t\t\tthis.handleSteps();\r\n\t\t});\r\n\t}\r\n}\r\n","<div\r\n\t#container\r\n\tclass=\"flex my-1 w-full justify-end\">\r\n\t@for (st of displaySteps(); track st; let i = $index) {\r\n\t\t@if (st.value === 'start') {\r\n\t\t\t<div\r\n\t\t\t\t#startItem\r\n\t\t\t\t[class]=\"getClass(i, ['start-item'])\"\r\n\t\t\t\t(click)=\"showStartSteps($event, startOp)\">\r\n\t\t\t\t<span>...</span>\r\n\t\t\t</div>\r\n\t\t\t<p-popover\r\n\t\t\t\t#startOp\r\n\t\t\t\t[styleClass]=\"'pop-steps start-steps'\"\r\n\t\t\t\t[appendTo]=\"startItem\">\r\n\t\t\t\t<p-listbox\r\n\t\t\t\t\t[options]=\"startSteps\"\r\n\t\t\t\t\t(onChange)=\"onStartStepsChange($event)\"\r\n\t\t\t\t\toptionLabel=\"label\"\r\n\t\t\t\t\tclass=\"w-full md:w-56\" />\r\n\t\t\t</p-popover>\r\n\t\t} @else if (st.value === 'end') {\r\n\t\t\t<div\r\n\t\t\t\t#endItem\r\n\t\t\t\t[class]=\"getClass(i, ['end-item'])\"\r\n\t\t\t\t(click)=\"showEndSteps($event, endOp)\">\r\n\t\t\t\t<span>...</span>\r\n\t\t\t</div>\r\n\t\t\t<p-popover\r\n\t\t\t\t#endOp\r\n\t\t\t\t[styleClass]=\"'pop-steps end-steps'\"\r\n\t\t\t\t[appendTo]=\"endItem\">\r\n\t\t\t\t<p-listbox\r\n\t\t\t\t\t[options]=\"endSteps\"\r\n\t\t\t\t\t(onChange)=\"onEndStepsChange($event)\"\r\n\t\t\t\t\toptionLabel=\"label\"\r\n\t\t\t\t\tclass=\"w-full md:w-56\" />\r\n\t\t\t</p-popover>\r\n\t\t} @else {\r\n\t\t\t<div\r\n\t\t\t\t[class]=\"getClass(i, [])\"\r\n\t\t\t\t(click)=\"changeStatus(st)\">\r\n\t\t\t\t<span>{{ st.i18nKey ? i18n.fanyi(st.i18nKey) : st.label }}</span>\r\n\t\t\t</div>\r\n\t\t}\r\n\t}\r\n</div>\r\n"]}
|
|
194
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"steps.component.js","sourceRoot":"","sources":["../../../../../projects/imm-element-ui/src/lib/steps/steps.component.ts","../../../../../projects/imm-element-ui/src/lib/steps/steps.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, computed, effect, ElementRef, HostListener, inject, input, output, Renderer2, signal, ViewChild } from '@angular/core';\r\nimport { I18nService } from '../service/i18n.service';\r\nimport { FormsModule } from '@angular/forms';\r\nimport { ListboxModule } from 'primeng/listbox';\r\nimport { Popover } from 'primeng/popover';\r\nexport interface Step {\r\n\tlabel: string;\r\n\ti18nKey?: string;\r\n\tvalue: number | 'start' | 'end';\r\n}\r\n\r\n@Component({\r\n\tselector: 'custom-steps',\r\n\tstandalone: true,\r\n\timports: [FormsModule, ListboxModule, Popover],\r\n\ttemplateUrl: './steps.component.html',\r\n\tstyleUrl: './steps.component.scss',\r\n})\r\nexport class StepsComponent {\r\n\t@ViewChild('container', { static: false }) containerRef!: ElementRef;\r\n\t@ViewChild('endBtn', { static: false }) endBtn!: ElementRef;\r\n\tsteps = input<Step[]>([]);\r\n\tdisplaySteps = computed(() => {\r\n\t\tconst steps = [...this.steps()];\r\n\t\tsteps.unshift({ value: 'start', label: '...' });\r\n\t\tsteps.push({ value: 'end', label: '...' });\r\n\t\treturn steps.filter((step) => !this.excludeValues().includes(step.value));\r\n\t});\r\n\texcludeValues = signal<(number | 'start' | 'end')[]>([]);\r\n\tcurrent = input<number>(2);\r\n\ti18n = inject(I18nService);\r\n\tchange = output<number>();\r\n\tauthLevel = input<number>(-1);\r\n\r\n\twidthList: number[] = [];\r\n\tSTART_BUTTON_WIDTH = 32;\r\n\tEND_BUTTON_WIDTH = 47;\r\n\tSTEP_ITEM_MARGIN = 2;\r\n\r\n\tstartIndex = 0;\r\n\tendIndex = 0;\r\n\tstartSteps: Step[] = [];\r\n\tendSteps: Step[] = [];\r\n\tmaxWidth = 0;\r\n\r\n\t@HostListener('window:resize', ['$event'])\r\n\tonResize() {\r\n\t\tthis.calcMaxWidth();\r\n\t\tthis.alternateWidthList();\r\n\t\tthis.handleSteps();\r\n\t}\r\n\r\n\tconstructor(private renderer: Renderer2) {\r\n\t\teffect(() => {\r\n\t\t\tlet current = this.current()\r\n\t\t\tif(current != 0 && this.steps().length > 0){\r\n\t\t\t\tthis.refreshSteps()\r\n\t\t\t}\r\n\t\t},{allowSignalWrites: true})\r\n\t}\r\n\r\n\tngAfterViewInit() {\r\n\t\tthis.calcMaxWidth();\r\n\t\tthis.initWidthList();\r\n\t\tthis.alternateWidthList();\r\n\t\tthis.handleSteps();\r\n\t}\r\n\r\n\tinitWidthList() {\r\n\t\tconst children = this.renderer.parentNode(this.containerRef.nativeElement).children[0].children;\r\n\t\tfor (let i = 0; i < children.length; i++) {\r\n\t\t\tif (!children[i].classList.contains('step-item')) {\r\n\t\t\t\tcontinue;\r\n\t\t\t}\r\n\t\t\tif (children[i].classList.contains('start-item')) {\r\n\t\t\t\tcontinue;\r\n\t\t\t}\r\n\t\t\tif (children[i].classList.contains('end-item')) {\r\n\t\t\t\tcontinue;\r\n\t\t\t}\r\n\t\t\tthis.widthList.push((children[i].offsetWidth || 0) + this.STEP_ITEM_MARGIN);\r\n\t\t}\r\n\t}\r\n\r\n\tcalcMaxWidth() {\r\n\t\tthis.maxWidth = window.innerWidth < 768 ? window.innerWidth * 0.96 : window.innerWidth * 0.42;\r\n\t}\r\n\r\n\tshowStartSteps(event: any, startOp: any) {\r\n\t\tif (this.authLevel() < 4) return;\r\n\t\tstartOp.toggle(event);\r\n\t}\r\n\r\n\tshowEndSteps(event: any, endOp: any) {\r\n\t\tif (this.authLevel() < 4) return;\r\n\t\tendOp.toggle(event);\r\n\t}\r\n\r\n\tgetClass(i: number, classes: string[]) {\r\n\t\tlet result = ['step-item', 'flex', 'items-center', 'justify-center'];\r\n\t\tresult = result.concat(classes);\r\n\t\tif (this.authLevel() < 4) {\r\n\t\t\tresult.push('cursor-not-allowed');\r\n\t\t} else {\r\n\t\t\tresult.push('cursor-pointer allow-hover');\r\n\t\t}\r\n\t\tconst { value } = this.displaySteps()![i];\r\n\t\tif (i == 0) {\r\n\t\t\tresult.push('step-first');\r\n\t\t} else if (i + 1 == this.displaySteps()?.length) {\r\n\t\t\tresult.push('step-last');\r\n\t\t}\r\n\t\tif (value == this.current()) {\r\n\t\t\tresult.push('step-active');\r\n\t\t\tresult.push('md:flex-none flex-1');\r\n\t\t}\r\n\t\treturn result.join(' ');\r\n\t}\r\n\r\n\tchangeStatus(step: any) {\r\n\t\tthis.change.emit(step.value);\r\n\t}\r\n\r\n\tonStartStepsChange(event: any) {\r\n\t\tconst step = event.value;\r\n\t\tthis.change.emit(step.value);\r\n\t}\r\n\r\n\tonEndStepsChange(event: any) {\r\n\t\tconst step = event.value;\r\n\t\tthis.change.emit(step.value);\r\n\t}\r\n\r\n\talternateWidthList() {\r\n\t\tlet index = this.steps().findIndex((s) => s.value === this.current());\r\n\t\tindex = index === -1 ? 0 : index;\r\n\t\tthis.startIndex = index;\r\n\t\tthis.endIndex = index;\r\n\r\n\t\tlet leftIndex = index - 1;\r\n\t\tlet rightIndex = index + 1;\r\n\t\tlet turn = 'right';\r\n\t\tlet totalWidth = this.widthList[index];\r\n\r\n\t\twhile (leftIndex >= 0 || rightIndex < this.widthList.length) {\r\n\t\t\tif (turn === 'right' && rightIndex < this.widthList.length) {\r\n\t\t\t\ttotalWidth += this.widthList[rightIndex];\r\n\t\t\t\tif (this.isExceedMaxWidth(totalWidth)) {\r\n\t\t\t\t\tbreak;\r\n\t\t\t\t}\r\n\t\t\t\tthis.endIndex = rightIndex;\r\n\t\t\t\trightIndex++;\r\n\t\t\t\tturn = 'left';\r\n\t\t\t} else if (turn === 'left' && leftIndex >= 0) {\r\n\t\t\t\ttotalWidth += this.widthList[leftIndex];\r\n\t\t\t\tif (this.isExceedMaxWidth(totalWidth)) {\r\n\t\t\t\t\tbreak;\r\n\t\t\t\t}\r\n\t\t\t\tthis.startIndex = leftIndex;\r\n\t\t\t\tleftIndex--;\r\n\t\t\t\tturn = 'right';\r\n\t\t\t} else {\r\n\t\t\t\tturn = rightIndex < this.widthList.length ? 'right' : 'left';\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\n\tisExceedMaxWidth(totalWidth: number) {\r\n\t\ttotalWidth += this.startIndex === 0 ? 0 : this.START_BUTTON_WIDTH;\r\n\t\ttotalWidth += this.endIndex === this.widthList.length - 1 ? 0 : this.END_BUTTON_WIDTH;\r\n\t\treturn totalWidth >= this.maxWidth;\r\n\t}\r\n\r\n\thandleSteps() {\r\n\t\tconst steps = this.steps();\r\n\t\tconst excludeValues: any[] = [];\r\n\t\tfor (let i = 0; i < steps.length; i++) {\r\n\t\t\tif (i < this.startIndex) {\r\n\t\t\t\texcludeValues.push(steps[i].value);\r\n\t\t\t}\r\n\t\t\tif (i > this.endIndex) {\r\n\t\t\t\texcludeValues.push(steps[i].value);\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\tif (this.startIndex > 0) {\r\n\t\t\tthis.startSteps = steps.slice(0, this.startIndex);\r\n\t\t} else {\r\n\t\t\texcludeValues.push('start');\r\n\t\t}\r\n\t\tif (this.endIndex < steps.length - 1) {\r\n\t\t\tthis.endSteps = steps.slice(this.endIndex + 1);\r\n\t\t} else {\r\n\t\t\texcludeValues.push('end');\r\n\t\t}\r\n\t\tthis.excludeValues.set(excludeValues);\r\n\t}\r\n\r\n\trefreshSteps() {\r\n\t\tthis.alternateWidthList();\r\n\t\tthis.handleSteps();\r\n\t}\r\n}\r\n","<div\r\n\t#container\r\n\tclass=\"flex my-1 w-full justify-end\">\r\n\t@for (st of displaySteps(); track st; let i = $index) {\r\n\t\t@if (st.value === 'start') {\r\n\t\t\t<div\r\n\t\t\t\t#startItem\r\n\t\t\t\t[class]=\"getClass(i, ['start-item'])\"\r\n\t\t\t\t(click)=\"showStartSteps($event, startOp)\">\r\n\t\t\t\t<span>...</span>\r\n\t\t\t</div>\r\n\t\t\t<p-popover\r\n\t\t\t\t#startOp\r\n\t\t\t\t[styleClass]=\"'pop-steps start-steps'\"\r\n\t\t\t\t[appendTo]=\"startItem\">\r\n\t\t\t\t<p-listbox\r\n\t\t\t\t\t[options]=\"startSteps\"\r\n\t\t\t\t\t(onChange)=\"onStartStepsChange($event)\"\r\n\t\t\t\t\toptionLabel=\"label\"\r\n\t\t\t\t\tclass=\"w-full md:w-56\" />\r\n\t\t\t</p-popover>\r\n\t\t} @else if (st.value === 'end') {\r\n\t\t\t<div\r\n\t\t\t\t#endItem\r\n\t\t\t\t[class]=\"getClass(i, ['end-item'])\"\r\n\t\t\t\t(click)=\"showEndSteps($event, endOp)\">\r\n\t\t\t\t<span>...</span>\r\n\t\t\t</div>\r\n\t\t\t<p-popover\r\n\t\t\t\t#endOp\r\n\t\t\t\t[styleClass]=\"'pop-steps end-steps'\"\r\n\t\t\t\t[appendTo]=\"endItem\">\r\n\t\t\t\t<p-listbox\r\n\t\t\t\t\t[options]=\"endSteps\"\r\n\t\t\t\t\t(onChange)=\"onEndStepsChange($event)\"\r\n\t\t\t\t\toptionLabel=\"label\"\r\n\t\t\t\t\tclass=\"w-full md:w-56\" />\r\n\t\t\t</p-popover>\r\n\t\t} @else {\r\n\t\t\t<div\r\n\t\t\t\t[class]=\"getClass(i, [])\"\r\n\t\t\t\t(click)=\"changeStatus(st)\">\r\n\t\t\t\t<span>{{ st.i18nKey ? i18n.fanyi(st.i18nKey) : st.label }}</span>\r\n\t\t\t</div>\r\n\t\t}\r\n\t}\r\n</div>\r\n"]}
|