ets-fe-ng-sdk 18.0.129 → 18.0.131
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/Shared/components/form-generator/form-generator.component.mjs +4 -4
- package/esm2022/lib/Shared/components/page-template/page-template.component.mjs +1 -1
- package/esm2022/lib/Shared/components/vertical-nav/vertical-nav.component.mjs +3 -3
- package/fesm2022/ets-fe-ng-sdk.mjs +4 -4
- package/fesm2022/ets-fe-ng-sdk.mjs.map +1 -1
- package/lib/Shared/components/form-generator/form-generated-value/form-generated-value.component.d.ts +5 -13
- package/lib/Shared/components/form-generator/form-generator.component.d.ts +1 -1
- package/lib/Shared/components/page-template/page-template.component.d.ts +2 -0
- package/lib/Shared/components/table/table-https/table-https.component.d.ts +3 -3
- package/package.json +1 -1
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { Component, EventEmitter, Input, Output, computed, effect, inject, input, model, signal, viewChild, } from '@angular/core';
|
|
2
2
|
import { FormControl, FormGroup, FormsModule, ReactiveFormsModule, Validators, } from '@angular/forms';
|
|
3
3
|
import { cloneDeep } from 'lodash-es';
|
|
4
|
-
import { debounceTime, filter, switchMap, map, startWith, } from 'rxjs/operators';
|
|
4
|
+
import { debounceTime, filter, switchMap, tap, map, startWith, } from 'rxjs/operators';
|
|
5
5
|
import { FunctionCaller2, ToAnyPipe } from '../../pipes/utility.pipe';
|
|
6
6
|
import { BtnComponent } from '../btn/btn.component';
|
|
7
7
|
import { InputBasicComponent } from '../input/input-basic.component';
|
|
@@ -164,9 +164,9 @@ export class FormGeneratorComponent extends BaseFormGenerator {
|
|
|
164
164
|
if (scheme.debug)
|
|
165
165
|
debugger;
|
|
166
166
|
this.subs[scheme.field?.toString() + '_onFormChange'] = this.formValue$
|
|
167
|
-
.pipe(scheme.onFormChangePipeOperators())
|
|
167
|
+
.pipe(scheme.onFormChangePipeOperators ? scheme.onFormChangePipeOperators() : tap())
|
|
168
168
|
.subscribe((r) => {
|
|
169
|
-
scheme.onFormChange(
|
|
169
|
+
scheme.onFormChange(r, r?.[scheme.field], this);
|
|
170
170
|
});
|
|
171
171
|
}
|
|
172
172
|
}
|
|
@@ -263,4 +263,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.0", ngImpor
|
|
|
263
263
|
type: Input,
|
|
264
264
|
args: ['isShow']
|
|
265
265
|
}] } });
|
|
266
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-generator.component.js","sourceRoot":"","sources":["../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/form-generator/form-generator.component.ts","../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/form-generator/form-generator.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  DestroyRef,\n  ElementRef,\n  EventEmitter,\n  Input,\n  Output,\n  TemplateRef,\n  computed,\n  effect,\n  inject,\n  input,\n  model,\n  signal,\n  viewChild,\n} from '@angular/core';\nimport {\n  AbstractControl,\n  FormControl,\n  FormGroup,\n  FormsModule,\n  ReactiveFormsModule,\n  Validators,\n} from '@angular/forms';\nimport { cloneDeep, isEqual } from 'lodash-es';\nimport {\n  debounceTime,\n  filter,\n  last,\n  switchMap,\n  tap,\n  map,\n  startWith,\n  distinctUntilChanged,\n} from 'rxjs/operators';\nimport { FunctionCaller2, ToAnyPipe } from '../../pipes/utility.pipe';\nimport { BtnComponent } from '../btn/btn.component';\nimport { InputBasicComponent, OptionLabelType } from '../input/input-basic.component';\nimport { AutocompleteComponent } from '../autocomplete/autocomplete.component';\nimport { ValidationMessageComponent } from '../input/validation-message/validation-message.component';\nimport { PhoneNumberComponent } from '../phone-number/phone-number.component';\nimport { CommonModule, NgSwitchDefault, NgTemplateOutlet } from '@angular/common';\nimport { LoaderComponent } from '../loader/loader.component';\nimport { InputSubType } from '../../models/index.model';\nimport { RichTextEditorRFComponent } from '../rich-text-editor-rf/rich-text-editor-rf.component';\nimport { FormGeneratorService } from './form-generator.service';\nimport { BaseFormGenerator, IBaseFormSchema } from './form-generator.base.component';\nimport { Observable, Subscription, fromEvent } from 'rxjs';\nimport { toObservable, toSignal } from '@angular/core/rxjs-interop';\n\n/**\n * Form should be set before the the formSchema\n */\n@Component({\n  selector: 'form-generator',\n  templateUrl: './form-generator.component.html',\n  styleUrls: ['./form-generator.component.scss'],\n  standalone: true,\n  //  changeDetection: ChangeDetectionStrategy.OnPush,\n  imports: [\n    LoaderComponent,\n    FormsModule,\n    CommonModule,\n    PhoneNumberComponent,\n    ValidationMessageComponent,\n    AutocompleteComponent,\n    NgSwitchDefault,\n    NgTemplateOutlet,\n    InputBasicComponent,\n    RichTextEditorRFComponent,\n    BtnComponent,\n    ReactiveFormsModule,\n    FunctionCaller2,\n    ToAnyPipe,\n  ],\n})\nexport class FormGeneratorComponent<\n  TFormGroup extends { [K in keyof TFormGroup]: AbstractControl<any, any> },\n  TFormSchema extends IFormSchema<TFormGroup> = IFormSchema<TFormGroup>,\n> extends BaseFormGenerator<TFormGroup, TFormSchema> {\n  @Input() keyField: 'field' | 'label' = 'field';\n  readonly presetValueForSingleOption = input(false);\n  readonly isCreate = input<boolean>();\n  readonly submitOnEnterKey = input<boolean>(false);\n  readonly formTagRef = viewChild<ElementRef<HTMLFormElement>>('formTag');\n\n  /**Emitted just before calling the save function */\n  @Output() onSubmit = new EventEmitter<any>();\n  @Output() mchange = new EventEmitter<any>();\n  /**Emitted after receiving feedback from the submit function */\n  @Output() saved = new EventEmitter<any>();\n  @Input() submitFunc: (value: any) => Promise<any>;\n  readonly submitBtnText = input('Submit');\n  readonly submitBtnTemplate = input<TemplateRef<any>>();\n  readonly submitSuccessText = input('Saved successfully');\n  readonly showSubmitBtn = input(true);\n\n  readonly gridStyle = input<number | 'auto'>();\n  readonly gridMDStyle = input<number | 'auto'>();\n  readonly gridLGStyle = input<number | 'auto'>();\n  readonly gridXXLStyle = input<number | 'auto'>();\n\n  readonly formGridClass = input<string>();\n  readonly useLoader = input<boolean>();\n  readonly loading = input<boolean>();\n\n  readonly _loading = signal<boolean>(false);\n\n  readonly computedLoading = computed(() =>\n    this.useLoader() ? this.loading() || this._loading() : false,\n  );\n\n  readonly submitBtnRef = viewChild<BtnComponent>('submitBtn');\n  readonly form = model<FormGroup<TFormGroup>>();\n  readonly form$ = toObservable(this.form);\n\n  readonly formValue$ = this.form$.pipe(\n    filter(() => !!this.form()),\n    switchMap(() =>\n      this.form()\n        .valueChanges.pipe(map(() => this.form()?.getRawValue() || {}))\n        .pipe(startWith(this.form()?.getRawValue() || {})),\n    ),\n  );\n  readonly formValue = toSignal(\n    this.formValue$,\n    // { initialValue: this.form()?.getRawValue() || {} },\n  );\n\n  submissionResponse: any;\n  @Input({ alias: 'formSchema' }) set _formSchema(v: TFormSchema[] | IFormSchema<any>[]) {\n    this.init(cloneDeep(v.filter((x) => x)) as TFormSchema[]);\n  }\n  @Input({ alias: 'formSchemaNoForm' }) set _formSchemaNoForm(v: TFormSchema[]) {\n    if (v) {\n      const form = new FormGroup({});\n      for (const item of v) {\n        form.addControl(\n          item.field?.toString(),\n          new FormControl(item.value, [].concat(item.isRequired ? [Validators.required] : [])),\n        );\n      }\n      this.form.set(form as any as FormGroup<TFormGroup>);\n      this._formSchema = v;\n    }\n  }\n  @Input('isShow') set _isShow(v: boolean) {\n    if (v) this.form()?.disable({ emitEvent: false });\n    else this.form()?.enable();\n\n    setTimeout(() => {\n      if (v) this.form()?.disable({ emitEvent: false });\n      else this.form()?.enable();\n    }, 500);\n  }\n  readonly optionsMap = signal<IFormOptions>({});\n  // formVal = computed(() => this.form?.getRawValue());\n\n  readonly computedFormSchema = computed<IFormSchema<TFormGroup>[]>(() => {\n    const formSchema = this.formSchema() || [],\n      presetValueForSingleOption = this.presetValueForSingleOption(),\n      isCreate = this.isCreate(),\n      ret: IFormSchema<TFormGroup>[] = [];\n    formSchema.forEach((scheme) => {\n      if (!scheme.hidden) {\n        if (isCreate)\n          scheme.presetValue =\n            scheme.presetValue == null ? presetValueForSingleOption : scheme.presetValue;\n        ret.push(scheme);\n      }\n    });\n    if (ret.some((x) => !x.field)) debugger;\n    return ret;\n  });\n  // miscIndex: TMiscIndex;\n  public formService = inject(FormGeneratorService);\n\n  constructor() {\n    super();\n\n    let listenToKey: Subscription;\n    this.destroyRef.onDestroy(() => {\n      listenToKey?.unsubscribe();\n    });\n    // effect(() => {\n    //   console.log(this.formSchema());\n    // });\n    effect(() => {\n      const ftr = this.formTagRef(),\n        submitOnEnterKey = this.submitOnEnterKey();\n      // debugger;\n\n      listenToKey?.unsubscribe();\n      if (ftr?.nativeElement && submitOnEnterKey)\n        listenToKey = fromEvent(ftr.nativeElement, 'keydown')\n          .pipe(\n            debounceTime(100),\n            filter(\n              (r: KeyboardEvent) => (r.code === 'Enter' || r.keyCode === 13) && this.form().valid,\n            ),\n          )\n          .subscribe((r: KeyboardEvent) => {\n            this.submit(this.submitBtnRef());\n          });\n    });\n  }\n\n  init(schema: TFormSchema[]) {\n    // debugger;\n    if (this.debug()) debugger;\n    this.onDestroy();\n    this._setFormSchemas(schema || []);\n    if (schema) for (const scheme of schema) this.handleFormScheme(scheme);\n    if (schema)\n      for (const scheme of schema)\n        if (scheme.triggerOnChangeOnInit) {\n          const formValue = this.form()?.getRawValue();\n          scheme.onChangeFunc(formValue, formValue[scheme.field?.toString()], this);\n        }\n  }\n\n  handleFormScheme(scheme: TFormSchema) {\n    scheme.id = this.utilityService.generateUUID();\n    if (scheme.stacked == null) scheme.stacked = true;\n    if (scheme.showValidationMsg == null) scheme.showValidationMsg = true;\n    if (this.formService.config.showValidationMessagesByDefault)\n      if (scheme.autoPickValueField == null && (!scheme.valueField || !scheme.labelField))\n        scheme.autoPickValueField = true;\n    // if (!this.form.controls[scheme.field as any]) debugger;\n    this.updateFormSchema(scheme.field, scheme);\n\n    if (scheme.optionsInitFunc) this.handleOptionsFetched(scheme, scheme.optionsInitFunc);\n    if (scheme.optionsInitFunc2) this.handleOptionsFetched(scheme, scheme.optionsInitFunc2());\n    if (scheme.onChangeFunc) {\n      if (scheme.debug) debugger;\n      this.subs[scheme.field?.toString()] = this.form$\n        .pipe(\n          switchMap((form) =>\n            form?.controls[scheme.field?.toString()]?.valueChanges.pipe(debounceTime(0)),\n          ),\n        )\n        .subscribe((r) => {\n          scheme.onChangeFunc(this.formValue(), r, this);\n        });\n    }\n    if (scheme.onFormChange) {\n      if (scheme.debug) debugger;\n      this.subs[scheme.field?.toString() + '_onFormChange'] = this.formValue$\n        .pipe(scheme.onFormChangePipeOperators())\n        .subscribe((r) => {\n          scheme.onFormChange(this.formValue(), r, this);\n        });\n    }\n  }\n\n  protected handleOptionsFetched(scheme: TFormSchema, options$: Observable<any[]>) {\n    options$.subscribe((r) => {\n      this.updateFormSchema(scheme.field, { options: r } as TFormSchema);\n    });\n  }\n\n  detachFormScheme(fieldName?: keyof TFormGroup) {\n    this.subs[fieldName as string]?.unsubscribe();\n  }\n\n  protected mchangeEmitter() {\n    this.mchange.emit(this.formValue());\n  }\n\n  getFormScheme = (fieldName: keyof TFormGroup) => {\n    // debugger;\n    return this.formSchemaMap()[fieldName as string];\n  };\n\n  addToFormSchema(formScheme: TFormSchema) {\n    this.removeFromFormSchema(formScheme.field);\n    this.handleFormScheme(formScheme);\n  }\n\n  updateFormSchema(fieldName: keyof TFormGroup, scheme: Partial<TFormSchema>) {\n    return super._updateFormSchema(fieldName as string, scheme);\n  }\n  updateAllFormSchema(map: (formField: IFormSchema<TFormGroup>) => TFormSchema) {\n    return super._updateAllFormSchema(map);\n  }\n\n  removeFromFormSchema(fieldName: keyof TFormGroup) {\n    this.detachFormScheme(fieldName);\n    const onRemove = this.formSchemaMap()[fieldName as string]?.onRemoveFunc;\n    if (onRemove) onRemove(this.formValue() as any, this.formValue()[fieldName as any], this);\n    this._removeFormSchema(fieldName as string);\n  }\n\n  protected setOptionLabel($event: any, scheme: IFormSchema<TFormGroup>) {\n    scheme.selectedOptionLabel = $event;\n  }\n\n  async submit(btn?: BtnComponent) {\n    if (this.submitFunc) {\n      btn?.setLoader(true);\n      this._loading.set(true);\n      const formVal = this.formValue();\n      this.onSubmit.emit(formVal);\n      try {\n        this.submissionResponse = await this.submitFunc(formVal);\n        if (this.submitSuccessText()) this.utilityService.info(this.submitSuccessText(), 1);\n        this.saved.emit(this.submissionResponse);\n      } catch (error) {\n        this.utilityService.info(error, 0);\n      }\n      this._loading.set(false);\n      btn?.setLoader(false);\n    } else this.onSubmit.emit(this.formValue());\n  }\n}\n\nexport interface IFormSchema<\n  TFormGroup extends {\n    [K in keyof TFormGroup]: AbstractControl<any, any>;\n  } = any,\n> extends IBaseFormSchema<TFormGroup, FormGeneratorComponent<TFormGroup>> {\n  children?: IFormSchema<TFormGroup>[];\n  labelType?: OptionLabelType;\n  field: keyof TFormGroup;\n  subType?: InputSubType;\n  presetValue?: boolean;\n  /**\n   * Template variable model:\n   * ```\n   * {\n   *    row: FormGroup<TFormGroup>;\n   *    scheme: IFormSchema;\n   * }\n   * ```\n   */\n  templateRef?: TemplateRef<any>;\n}\nexport interface IFormSchema2<TStruct = any>\n  extends IFormSchema<{\n    [K in keyof TStruct]?: AbstractControl<any, any>;\n  }> {}\n\nexport interface IFormOptions {\n  [field: string]: any;\n}\n","<!-- {{formValue()|json}}\n{{formValid()|json}} -->\n<loader [loading]=\"computedLoading()\">\n  <form [formGroup]=\"form()\" #formTag>\n    <div\n      class=\"row row-cols-{{ gridStyle() }} row-cols-md-{{ gridMDStyle() }} row-cols-lg-{{\n        gridLGStyle()\n      }} row-cols-xxl-{{ gridXXLStyle() }} align-items-center {{ formGridClass() }}\">\n      @for (scheme of computedFormSchema(); track scheme.field) {\n        <div class=\"col {{ scheme.cls }} \">\n          @switch (true) {\n            @case (scheme.type == 'template') {\n              <ng-container\n                *ngTemplateOutlet=\"\n                  customTemplates()[scheme.field];\n                  context: { $implicit: { scheme, form: form() } }\n                \"/>\n            }\n            @case (scheme.type == 'tel') {\n              <app-phone-number\n                [form]=\"scheme.form || form()\"\n                [label]=\"scheme.label\"\n                [clearOnDisable]=\"scheme.clearOnDisable\"\n                [stacked]=\"scheme.stacked\"\n                [name]=\"scheme.field\"\n                [noFormat]=\"scheme.noFormat\"\n                [verbose]=\"scheme.verbose\"\n                [debug]=\"scheme.debug\"\n                (mchange)=\"mchangeEmitter()\"\n                [showValidation]=\"scheme.showValidation || !!scheme.asyncValidators\"\n                [showValidationIcon]=\"scheme.showValidationIcon || !!scheme.asyncValidators\"\n                [autoPickValueField]=\"scheme.autoPickValueField\"\n                [showRequiredTag]=\"scheme.showRequiredTag\"\n                [showValidationMsg]=\"scheme.showValidationMsg\"\n                [countryCode3]=\"scheme.countryCode3\"\n                [disabled]=\"\n                  scheme.disabled ||\n                  (scheme.disabledIf | functionCaller2: formValue() : (scheme.field | toAny))\n                \" />\n            }\n            @case (scheme.type == 'autocomplete') {\n              <app-autocomplete\n                [form]=\"scheme.form || form()\"\n                [label]=\"scheme.label\"\n                [clearOnDisable]=\"scheme.clearOnDisable\"\n                [stacked]=\"scheme.stacked\"\n                [verbose]=\"scheme.verbose\"\n                [skipDoesOptionExistCheck]=\"scheme.skipDoesOptionExistCheck\"\n                [presetValue]=\"scheme.presetValue\"\n                [labelField]=\"scheme.labelField\"\n                [noFormat]=\"scheme.noFormat\"\n                [showValidation]=\"scheme.showValidation || !!scheme.asyncValidators\"\n                [showValidationIcon]=\"scheme.showValidationIcon || !!scheme.asyncValidators\"\n                [labelType]=\"scheme.labelType | toAny\"\n                (mchange)=\"mchangeEmitter()\"\n                (mSelectedOptionLabel)=\"setOptionLabel($event, scheme)\"\n                [name]=\"scheme.field\"\n                [debug]=\"scheme.debug\"\n                [setFormattedValue]=\"scheme.setControlFormattedValue\"\n                [showRequiredTag]=\"scheme.showRequiredTag\"\n                [optionFormatter]=\"scheme.optionFormatter\"\n                [valueField]=\"scheme.valueField\"\n                [optionsFunc]=\"scheme.optionsFunc\"\n                [showValidationMsg]=\"scheme.showValidationMsg\"\n                [autoPickValueField]=\"scheme.autoPickValueField\"\n                [options]=\"scheme.options || optionsMap()[scheme.field | toAny]\"\n                [hint]=\"scheme.hint\"\n                [disabled]=\"\n                  scheme.disabled ||\n                  (scheme.disabledIf | functionCaller2: formValue() : (scheme.field | toAny))\n                \" />\n            }\n            @case (scheme.type == 'richtext') {\n              <rich-text-editor-rf\n                [form]=\"scheme.form || form()\"\n                [label]=\"scheme.label!\"\n                [clearOnDisable]=\"scheme.clearOnDisable!\"\n                [stacked]=\"scheme.stacked\"\n                [verbose]=\"scheme.verbose\"\n                [labelField]=\"scheme.labelField!\"\n                [noFormat]=\"scheme.noFormat!\"\n                [showValidation]=\"scheme.showValidation || !!scheme.asyncValidators\"\n                [showValidationIcon]=\"scheme.showValidationIcon || !!scheme.asyncValidators\"\n                [labelType]=\"scheme.labelType | toAny\"\n                (mchange)=\"mchangeEmitter()\"\n                (mSelectedOptionLabel)=\"setOptionLabel($event, scheme)\"\n                [name]=\"scheme.field\"\n                [debug]=\"scheme.debug!\"\n                [setFormattedValue]=\"scheme.setControlFormattedValue\"\n                [showRequiredTag]=\"scheme.showRequiredTag!\"\n                [optionFormatter]=\"scheme.optionFormatter!\"\n                [valueField]=\"scheme.valueField!\"\n                [optionsFunc]=\"scheme.optionsFunc!\"\n                [showValidationMsg]=\"scheme.showValidationMsg\"\n                [autoPickValueField]=\"scheme.autoPickValueField!\"\n                [options]=\"scheme.options || optionsMap()[scheme.field | toAny]\"\n                [hint]=\"scheme.hint!\"\n                [maxLength]=\"scheme.maxLength\"\n                [minLength]=\"scheme.minLength\"\n                [disabled]=\"\n                  scheme.disabled ||\n                  (scheme.disabledIf! | functionCaller2: formValue() : (scheme.field | toAny))\n                \" />\n            }\n            @default {\n              <app-input-basic\n                [noFormat]=\"scheme.noFormat\"\n                [name]=\"scheme.field\"\n                [form]=\"scheme.form || form()\"\n                [clearOnDisable]=\"scheme.clearOnDisable\"\n                [type]=\"scheme.type\"\n                [verbose]=\"scheme.verbose\"\n                [valueField]=\"scheme.valueField\"\n                [autoPickValueField]=\"scheme.autoPickValueField\"\n                [presetValue]=\"scheme.presetValue\"\n                [stacked]=\"scheme.stacked\"\n                [labelType]=\"scheme.labelType | toAny\"\n                [checkedSignal]=\"scheme.checked\"\n                [showValidation]=\"scheme.showValidation || !!scheme.asyncValidators\"\n                [showValidationIcon]=\"scheme.showValidationIcon || !!scheme.asyncValidators\"\n                [debug]=\"scheme.debug\"\n                (mchange)=\"mchangeEmitter()\"\n                [setFormattedValue]=\"scheme.setControlFormattedValue\"\n                [showRequiredTag]=\"scheme.showRequiredTag\"\n                [labelField]=\"scheme.labelField\"\n                [optionFormatter]=\"scheme.optionFormatter\"\n                (mSelectedOptionLabel)=\"setOptionLabel($event, scheme)\"\n                [options]=\"scheme.options || optionsMap()[scheme.field | toAny]\"\n                [decimalPoints]=\"scheme.decimalPoints\"\n                [hint]=\"scheme.hint\"\n                [max]=\"scheme.max\"\n                [min]=\"scheme.min\"\n                [maxLength]=\"scheme.maxLength\"\n                [minLength]=\"scheme.minLength\"\n                [placeholder]=\"scheme.placeholder\"\n                [label]=\"scheme.label\"\n                [showValidationMsg]=\"scheme.showValidationMsg\"\n                [disabled]=\"\n                  scheme.disabled ||\n                  (scheme.disabledIf | functionCaller2: formValue() : (scheme.field | toAny))\n                \" />\n            }\n          }\n        </div>\n      }\n    </div>\n    <div class=\"row row-cols-auto justify-content-end\">\n      <div class=\"\">\n        @if (showSubmitBtn()) {\n          <app-btn\n            [text]=\"submitBtnText()\"\n            group=\"submit\"\n            [form]=\"form()\"\n            (mclick)=\"submit(submitBtn)\"\n            #submitBtn />\n        }\n        @if (submitBtnTemplate()) {\n          <ng-container *ngTemplateOutlet=\"submitBtnTemplate()\"/>\n        }\n      </div>\n    </div>\n  </form>\n</loader>\n"]}
|
|
266
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-generator.component.js","sourceRoot":"","sources":["../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/form-generator/form-generator.component.ts","../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/form-generator/form-generator.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  DestroyRef,\n  ElementRef,\n  EventEmitter,\n  Input,\n  Output,\n  TemplateRef,\n  computed,\n  effect,\n  inject,\n  input,\n  model,\n  signal,\n  viewChild,\n} from '@angular/core';\nimport {\n  AbstractControl,\n  FormControl,\n  FormGroup,\n  FormsModule,\n  ReactiveFormsModule,\n  Validators,\n} from '@angular/forms';\nimport { cloneDeep, isEqual } from 'lodash-es';\nimport {\n  debounceTime,\n  filter,\n  last,\n  switchMap,\n  tap,\n  map,\n  startWith,\n  distinctUntilChanged,\n} from 'rxjs/operators';\nimport { FunctionCaller2, ToAnyPipe } from '../../pipes/utility.pipe';\nimport { BtnComponent } from '../btn/btn.component';\nimport { InputBasicComponent, OptionLabelType } from '../input/input-basic.component';\nimport { AutocompleteComponent } from '../autocomplete/autocomplete.component';\nimport { ValidationMessageComponent } from '../input/validation-message/validation-message.component';\nimport { PhoneNumberComponent } from '../phone-number/phone-number.component';\nimport { CommonModule, NgSwitchDefault, NgTemplateOutlet } from '@angular/common';\nimport { LoaderComponent } from '../loader/loader.component';\nimport { InputSubType } from '../../models/index.model';\nimport { RichTextEditorRFComponent } from '../rich-text-editor-rf/rich-text-editor-rf.component';\nimport { FormGeneratorService } from './form-generator.service';\nimport { BaseFormGenerator, IBaseFormSchema } from './form-generator.base.component';\nimport { Observable, Subscription, fromEvent } from 'rxjs';\nimport { toObservable, toSignal } from '@angular/core/rxjs-interop';\n\n/**\n * Form should be set before the the formSchema\n */\n@Component({\n  selector: 'form-generator',\n  templateUrl: './form-generator.component.html',\n  styleUrls: ['./form-generator.component.scss'],\n  standalone: true,\n  //  changeDetection: ChangeDetectionStrategy.OnPush,\n  imports: [\n    LoaderComponent,\n    FormsModule,\n    CommonModule,\n    PhoneNumberComponent,\n    ValidationMessageComponent,\n    AutocompleteComponent,\n    NgSwitchDefault,\n    NgTemplateOutlet,\n    InputBasicComponent,\n    RichTextEditorRFComponent,\n    BtnComponent,\n    ReactiveFormsModule,\n    FunctionCaller2,\n    ToAnyPipe,\n  ],\n})\nexport class FormGeneratorComponent<\n  TFormGroup extends { [K in keyof TFormGroup]: AbstractControl<any, any> },\n  TFormSchema extends IFormSchema<TFormGroup> = IFormSchema<TFormGroup>,\n> extends BaseFormGenerator<TFormGroup, TFormSchema> {\n  @Input() keyField: 'field' | 'label' = 'field';\n  readonly presetValueForSingleOption = input(false);\n  readonly isCreate = input<boolean>();\n  readonly submitOnEnterKey = input<boolean>(false);\n  readonly formTagRef = viewChild<ElementRef<HTMLFormElement>>('formTag');\n\n  /**Emitted just before calling the save function */\n  @Output() onSubmit = new EventEmitter<any>();\n  @Output() mchange = new EventEmitter<any>();\n  /**Emitted after receiving feedback from the submit function */\n  @Output() saved = new EventEmitter<any>();\n  @Input() submitFunc: (value: any) => Promise<any>;\n  readonly submitBtnText = input('Submit');\n  readonly submitBtnTemplate = input<TemplateRef<any>>();\n  readonly submitSuccessText = input('Saved successfully');\n  readonly showSubmitBtn = input(true);\n\n  readonly gridStyle = input<number | 'auto'>();\n  readonly gridMDStyle = input<number | 'auto'>();\n  readonly gridLGStyle = input<number | 'auto'>();\n  readonly gridXXLStyle = input<number | 'auto'>();\n\n  readonly formGridClass = input<string>();\n  readonly useLoader = input<boolean>();\n  readonly loading = input<boolean>();\n\n  readonly _loading = signal<boolean>(false);\n\n  readonly computedLoading = computed(() =>\n    this.useLoader() ? this.loading() || this._loading() : false,\n  );\n\n  readonly submitBtnRef = viewChild<BtnComponent>('submitBtn');\n  readonly form = model<FormGroup<TFormGroup>>();\n  readonly form$ = toObservable(this.form);\n\n  readonly formValue$ = this.form$.pipe(\n    filter(() => !!this.form()),\n    switchMap(() =>\n      this.form()\n        .valueChanges.pipe(map(() => this.form()?.getRawValue() || {}))\n        .pipe(startWith(this.form()?.getRawValue() || {})),\n    ),\n  );\n  readonly formValue = toSignal(\n    this.formValue$,\n    // { initialValue: this.form()?.getRawValue() || {} },\n  );\n\n  submissionResponse: any;\n  @Input({ alias: 'formSchema' }) set _formSchema(v: TFormSchema[] | IFormSchema<any>[]) {\n    this.init(cloneDeep(v.filter((x) => x)) as TFormSchema[]);\n  }\n  @Input({ alias: 'formSchemaNoForm' }) set _formSchemaNoForm(v: TFormSchema[]) {\n    if (v) {\n      const form = new FormGroup({});\n      for (const item of v) {\n        form.addControl(\n          item.field?.toString(),\n          new FormControl(item.value, [].concat(item.isRequired ? [Validators.required] : [])),\n        );\n      }\n      this.form.set(form as any as FormGroup<TFormGroup>);\n      this._formSchema = v;\n    }\n  }\n  @Input('isShow') set _isShow(v: boolean) {\n    if (v) this.form()?.disable({ emitEvent: false });\n    else this.form()?.enable();\n\n    setTimeout(() => {\n      if (v) this.form()?.disable({ emitEvent: false });\n      else this.form()?.enable();\n    }, 500);\n  }\n  readonly optionsMap = signal<IFormOptions>({});\n  // formVal = computed(() => this.form?.getRawValue());\n\n  readonly computedFormSchema = computed<IFormSchema<TFormGroup>[]>(() => {\n    const formSchema = this.formSchema() || [],\n      presetValueForSingleOption = this.presetValueForSingleOption(),\n      isCreate = this.isCreate(),\n      ret: IFormSchema<TFormGroup>[] = [];\n    formSchema.forEach((scheme) => {\n      if (!scheme.hidden) {\n        if (isCreate)\n          scheme.presetValue =\n            scheme.presetValue == null ? presetValueForSingleOption : scheme.presetValue;\n        ret.push(scheme);\n      }\n    });\n    if (ret.some((x) => !x.field)) debugger;\n    return ret;\n  });\n  // miscIndex: TMiscIndex;\n  public formService = inject(FormGeneratorService);\n\n  constructor() {\n    super();\n\n    let listenToKey: Subscription;\n    this.destroyRef.onDestroy(() => {\n      listenToKey?.unsubscribe();\n    });\n    // effect(() => {\n    //   console.log(this.formSchema());\n    // });\n    effect(() => {\n      const ftr = this.formTagRef(),\n        submitOnEnterKey = this.submitOnEnterKey();\n      // debugger;\n\n      listenToKey?.unsubscribe();\n      if (ftr?.nativeElement && submitOnEnterKey)\n        listenToKey = fromEvent(ftr.nativeElement, 'keydown')\n          .pipe(\n            debounceTime(100),\n            filter(\n              (r: KeyboardEvent) => (r.code === 'Enter' || r.keyCode === 13) && this.form().valid,\n            ),\n          )\n          .subscribe((r: KeyboardEvent) => {\n            this.submit(this.submitBtnRef());\n          });\n    });\n  }\n\n  init(schema: TFormSchema[]) {\n    // debugger;\n    if (this.debug()) debugger;\n    this.onDestroy();\n    this._setFormSchemas(schema || []);\n    if (schema) for (const scheme of schema) this.handleFormScheme(scheme);\n    if (schema)\n      for (const scheme of schema)\n        if (scheme.triggerOnChangeOnInit) {\n          const formValue = this.form()?.getRawValue();\n          scheme.onChangeFunc(formValue, formValue[scheme.field?.toString()], this);\n        }\n  }\n\n  handleFormScheme(scheme: TFormSchema) {\n    scheme.id = this.utilityService.generateUUID();\n    if (scheme.stacked == null) scheme.stacked = true;\n    if (scheme.showValidationMsg == null) scheme.showValidationMsg = true;\n    if (this.formService.config.showValidationMessagesByDefault)\n      if (scheme.autoPickValueField == null && (!scheme.valueField || !scheme.labelField))\n        scheme.autoPickValueField = true;\n    // if (!this.form.controls[scheme.field as any]) debugger;\n    this.updateFormSchema(scheme.field, scheme);\n\n    if (scheme.optionsInitFunc) this.handleOptionsFetched(scheme, scheme.optionsInitFunc);\n    if (scheme.optionsInitFunc2) this.handleOptionsFetched(scheme, scheme.optionsInitFunc2());\n    if (scheme.onChangeFunc) {\n      if (scheme.debug) debugger;\n      this.subs[scheme.field?.toString()] = this.form$\n        .pipe(\n          switchMap((form) =>\n            form?.controls[scheme.field?.toString()]?.valueChanges.pipe(debounceTime(0)),\n          ),\n        )\n        .subscribe((r) => {\n          scheme.onChangeFunc(this.formValue(), r, this);\n        });\n    }\n    if (scheme.onFormChange) {\n      if (scheme.debug) debugger;\n      this.subs[scheme.field?.toString() + '_onFormChange'] = this.formValue$\n        .pipe(scheme.onFormChangePipeOperators ? scheme.onFormChangePipeOperators() : tap())\n        .subscribe((r) => {\n          scheme.onFormChange(r, r?.[scheme.field], this);\n        });\n    }\n  }\n\n  protected handleOptionsFetched(scheme: TFormSchema, options$: Observable<any[]>) {\n    options$.subscribe((r) => {\n      this.updateFormSchema(scheme.field, { options: r } as TFormSchema);\n    });\n  }\n\n  detachFormScheme(fieldName?: keyof TFormGroup) {\n    this.subs[fieldName as string]?.unsubscribe();\n  }\n\n  protected mchangeEmitter() {\n    this.mchange.emit(this.formValue());\n  }\n\n  getFormScheme = (fieldName: keyof TFormGroup) => {\n    // debugger;\n    return this.formSchemaMap()[fieldName as string];\n  };\n\n  addToFormSchema(formScheme: TFormSchema) {\n    this.removeFromFormSchema(formScheme.field);\n    this.handleFormScheme(formScheme);\n  }\n\n  updateFormSchema(fieldName: keyof TFormGroup, scheme: Partial<TFormSchema>) {\n    return super._updateFormSchema(fieldName as string, scheme);\n  }\n  updateAllFormSchema(map: (formField: IFormSchema<TFormGroup>) => TFormSchema) {\n    return super._updateAllFormSchema(map);\n  }\n\n  removeFromFormSchema(fieldName: keyof TFormGroup) {\n    this.detachFormScheme(fieldName);\n    const onRemove = this.formSchemaMap()[fieldName as string]?.onRemoveFunc;\n    if (onRemove) onRemove(this.formValue() as any, this.formValue()[fieldName as any], this);\n    this._removeFormSchema(fieldName as string);\n  }\n\n  protected setOptionLabel($event: any, scheme: IFormSchema<TFormGroup>) {\n    scheme.selectedOptionLabel = $event;\n  }\n\n  async submit(btn?: BtnComponent) {\n    if (this.submitFunc) {\n      btn?.setLoader(true);\n      this._loading.set(true);\n      const formVal = this.formValue();\n      this.onSubmit.emit(formVal);\n      try {\n        this.submissionResponse = await this.submitFunc(formVal);\n        if (this.submitSuccessText()) this.utilityService.info(this.submitSuccessText(), 1);\n        this.saved.emit(this.submissionResponse);\n      } catch (error) {\n        this.utilityService.info(error, 0);\n      }\n      this._loading.set(false);\n      btn?.setLoader(false);\n    } else this.onSubmit.emit(this.formValue());\n  }\n}\n\nexport interface IFormSchema<\n  TFormGroup extends {\n    [K in keyof TFormGroup]: AbstractControl<any, any>;\n  } = any,\n> extends IBaseFormSchema<TFormGroup, FormGeneratorComponent<TFormGroup>, TFormGroup> {\n  children?: IFormSchema<TFormGroup>[];\n  labelType?: OptionLabelType;\n  field: keyof TFormGroup;\n  subType?: InputSubType;\n  presetValue?: boolean;\n  /**\n   * Template variable model:\n   * ```\n   * {\n   *    row: FormGroup<TFormGroup>;\n   *    scheme: IFormSchema;\n   * }\n   * ```\n   */\n  templateRef?: TemplateRef<any>;\n}\nexport interface IFormSchema2<TStruct = any>\n  extends IFormSchema<{\n    [K in keyof TStruct]?: AbstractControl<any, any>;\n  }> {}\n\nexport interface IFormOptions {\n  [field: string]: any;\n}\n","<!-- {{formValue()|json}}\n{{formValid()|json}} -->\n<loader [loading]=\"computedLoading()\">\n  <form [formGroup]=\"form()\" #formTag>\n    <div\n      class=\"row row-cols-{{ gridStyle() }} row-cols-md-{{ gridMDStyle() }} row-cols-lg-{{\n        gridLGStyle()\n      }} row-cols-xxl-{{ gridXXLStyle() }} align-items-center {{ formGridClass() }}\">\n      @for (scheme of computedFormSchema(); track scheme.field) {\n        <div class=\"col {{ scheme.cls }} \">\n          @switch (true) {\n            @case (scheme.type == 'template') {\n              <ng-container\n                *ngTemplateOutlet=\"\n                  customTemplates()[scheme.field];\n                  context: { $implicit: { scheme, form: form() } }\n                \"/>\n            }\n            @case (scheme.type == 'tel') {\n              <app-phone-number\n                [form]=\"scheme.form || form()\"\n                [label]=\"scheme.label\"\n                [clearOnDisable]=\"scheme.clearOnDisable\"\n                [stacked]=\"scheme.stacked\"\n                [name]=\"scheme.field\"\n                [noFormat]=\"scheme.noFormat\"\n                [verbose]=\"scheme.verbose\"\n                [debug]=\"scheme.debug\"\n                (mchange)=\"mchangeEmitter()\"\n                [showValidation]=\"scheme.showValidation || !!scheme.asyncValidators\"\n                [showValidationIcon]=\"scheme.showValidationIcon || !!scheme.asyncValidators\"\n                [autoPickValueField]=\"scheme.autoPickValueField\"\n                [showRequiredTag]=\"scheme.showRequiredTag\"\n                [showValidationMsg]=\"scheme.showValidationMsg\"\n                [countryCode3]=\"scheme.countryCode3\"\n                [disabled]=\"\n                  scheme.disabled ||\n                  (scheme.disabledIf | functionCaller2: formValue() : (scheme.field | toAny))\n                \" />\n            }\n            @case (scheme.type == 'autocomplete') {\n              <app-autocomplete\n                [form]=\"scheme.form || form()\"\n                [label]=\"scheme.label\"\n                [clearOnDisable]=\"scheme.clearOnDisable\"\n                [stacked]=\"scheme.stacked\"\n                [verbose]=\"scheme.verbose\"\n                [skipDoesOptionExistCheck]=\"scheme.skipDoesOptionExistCheck\"\n                [presetValue]=\"scheme.presetValue\"\n                [labelField]=\"scheme.labelField\"\n                [noFormat]=\"scheme.noFormat\"\n                [showValidation]=\"scheme.showValidation || !!scheme.asyncValidators\"\n                [showValidationIcon]=\"scheme.showValidationIcon || !!scheme.asyncValidators\"\n                [labelType]=\"scheme.labelType | toAny\"\n                (mchange)=\"mchangeEmitter()\"\n                (mSelectedOptionLabel)=\"setOptionLabel($event, scheme)\"\n                [name]=\"scheme.field\"\n                [debug]=\"scheme.debug\"\n                [setFormattedValue]=\"scheme.setControlFormattedValue\"\n                [showRequiredTag]=\"scheme.showRequiredTag\"\n                [optionFormatter]=\"scheme.optionFormatter\"\n                [valueField]=\"scheme.valueField\"\n                [optionsFunc]=\"scheme.optionsFunc\"\n                [showValidationMsg]=\"scheme.showValidationMsg\"\n                [autoPickValueField]=\"scheme.autoPickValueField\"\n                [options]=\"scheme.options || optionsMap()[scheme.field | toAny]\"\n                [hint]=\"scheme.hint\"\n                [disabled]=\"\n                  scheme.disabled ||\n                  (scheme.disabledIf | functionCaller2: formValue() : (scheme.field | toAny))\n                \" />\n            }\n            @case (scheme.type == 'richtext') {\n              <rich-text-editor-rf\n                [form]=\"scheme.form || form()\"\n                [label]=\"scheme.label!\"\n                [clearOnDisable]=\"scheme.clearOnDisable!\"\n                [stacked]=\"scheme.stacked\"\n                [verbose]=\"scheme.verbose\"\n                [labelField]=\"scheme.labelField!\"\n                [noFormat]=\"scheme.noFormat!\"\n                [showValidation]=\"scheme.showValidation || !!scheme.asyncValidators\"\n                [showValidationIcon]=\"scheme.showValidationIcon || !!scheme.asyncValidators\"\n                [labelType]=\"scheme.labelType | toAny\"\n                (mchange)=\"mchangeEmitter()\"\n                (mSelectedOptionLabel)=\"setOptionLabel($event, scheme)\"\n                [name]=\"scheme.field\"\n                [debug]=\"scheme.debug!\"\n                [setFormattedValue]=\"scheme.setControlFormattedValue\"\n                [showRequiredTag]=\"scheme.showRequiredTag!\"\n                [optionFormatter]=\"scheme.optionFormatter!\"\n                [valueField]=\"scheme.valueField!\"\n                [optionsFunc]=\"scheme.optionsFunc!\"\n                [showValidationMsg]=\"scheme.showValidationMsg\"\n                [autoPickValueField]=\"scheme.autoPickValueField!\"\n                [options]=\"scheme.options || optionsMap()[scheme.field | toAny]\"\n                [hint]=\"scheme.hint!\"\n                [maxLength]=\"scheme.maxLength\"\n                [minLength]=\"scheme.minLength\"\n                [disabled]=\"\n                  scheme.disabled ||\n                  (scheme.disabledIf! | functionCaller2: formValue() : (scheme.field | toAny))\n                \" />\n            }\n            @default {\n              <app-input-basic\n                [noFormat]=\"scheme.noFormat\"\n                [name]=\"scheme.field\"\n                [form]=\"scheme.form || form()\"\n                [clearOnDisable]=\"scheme.clearOnDisable\"\n                [type]=\"scheme.type\"\n                [verbose]=\"scheme.verbose\"\n                [valueField]=\"scheme.valueField\"\n                [autoPickValueField]=\"scheme.autoPickValueField\"\n                [presetValue]=\"scheme.presetValue\"\n                [stacked]=\"scheme.stacked\"\n                [labelType]=\"scheme.labelType | toAny\"\n                [checkedSignal]=\"scheme.checked\"\n                [showValidation]=\"scheme.showValidation || !!scheme.asyncValidators\"\n                [showValidationIcon]=\"scheme.showValidationIcon || !!scheme.asyncValidators\"\n                [debug]=\"scheme.debug\"\n                (mchange)=\"mchangeEmitter()\"\n                [setFormattedValue]=\"scheme.setControlFormattedValue\"\n                [showRequiredTag]=\"scheme.showRequiredTag\"\n                [labelField]=\"scheme.labelField\"\n                [optionFormatter]=\"scheme.optionFormatter\"\n                (mSelectedOptionLabel)=\"setOptionLabel($event, scheme)\"\n                [options]=\"scheme.options || optionsMap()[scheme.field | toAny]\"\n                [decimalPoints]=\"scheme.decimalPoints\"\n                [hint]=\"scheme.hint\"\n                [max]=\"scheme.max\"\n                [min]=\"scheme.min\"\n                [maxLength]=\"scheme.maxLength\"\n                [minLength]=\"scheme.minLength\"\n                [placeholder]=\"scheme.placeholder\"\n                [label]=\"scheme.label\"\n                [showValidationMsg]=\"scheme.showValidationMsg\"\n                [disabled]=\"\n                  scheme.disabled ||\n                  (scheme.disabledIf | functionCaller2: formValue() : (scheme.field | toAny))\n                \" />\n            }\n          }\n        </div>\n      }\n    </div>\n    <div class=\"row row-cols-auto justify-content-end\">\n      <div class=\"\">\n        @if (showSubmitBtn()) {\n          <app-btn\n            [text]=\"submitBtnText()\"\n            group=\"submit\"\n            [form]=\"form()\"\n            (mclick)=\"submit(submitBtn)\"\n            #submitBtn />\n        }\n        @if (submitBtnTemplate()) {\n          <ng-container *ngTemplateOutlet=\"submitBtnTemplate()\"/>\n        }\n      </div>\n    </div>\n  </form>\n</loader>\n"]}
|
|
@@ -157,4 +157,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.0", ngImpor
|
|
|
157
157
|
}], modalSubmitted: [{
|
|
158
158
|
type: Output
|
|
159
159
|
}] } });
|
|
160
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"page-template.component.js","sourceRoot":"","sources":["../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/page-template/page-template.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, Output, computed, inject, signal } from '@angular/core';\nimport { ActivatedRoute, Router } from '@angular/router';\nimport { UtilityService } from '../../../../lib/Services/utility.service';\nimport { EPageType, IObjectLiteral } from '../../models/index.model';\nimport { Environment, SDKEnvironment } from '../../models/environment.model';\nimport { toSignal } from '@angular/core/rxjs-interop';\nimport { Observable } from 'rxjs';\n\n@Component({\n  template: ``,\n  standalone: true,\n})\nexport class PageTemplateComponent<\n  ModelData = any,\n  TEnvironment extends SDKEnvironment = Environment,\n> {\n  loading: boolean;\n  readonly loadingSignal = signal<boolean>(false);\n  readonly isModal = signal<boolean>(false);\n  @Input('isModal') set _isModal(v: boolean) {\n    this.isModal.set(v);\n  }\n  @Input() modelData: ModelData;\n  modalOnComplete: (...args) => any;\n  @Output() modalSubmitted = new EventEmitter();\n  code?: string;\n  readonly overridePageTypeSignal = signal<EPageType>(undefined);\n  public get pageType(): EPageType {\n    return this.overridePageTypeSignal();\n  }\n  public set pageType(value: EPageType) {\n    this.overridePageTypeSignal.set(value);\n  }\n\n  idField = 'code';\n  readonly isCreate = computed<boolean>(() =>\n    this.uS.pageS.isCreate(this.route, this.overridePageTypeSignal()),\n  );\n  readonly isIndex = computed<boolean>(() =>\n    this.uS.pageS.isIndex(this.route, this.overridePageTypeSignal()),\n  );\n  readonly isClone = computed<boolean>(() =>\n    this.uS.pageS.isClone(this.route, this.overridePageTypeSignal()),\n  );\n  readonly isEdit = computed<boolean>(() =>\n    this.uS.pageS.isEdit(this.route, this.overridePageTypeSignal()),\n  );\n  readonly isShow = computed<boolean>(() =>\n    this.uS.pageS.isShow(this.route, this.overridePageTypeSignal()),\n  );\n  get infoFunc() {\n    return this.uS.info;\n  }\n  public route = inject(ActivatedRoute);\n  public uS = inject(UtilityService<TEnvironment>);\n  router = inject(Router);\n  constructor() {}\n\n  async init(func?: () => Promise<any>, err?: () => any) {\n    this.setLoader(true);\n    try {\n      const code =\n        this.route.snapshot.queryParamMap.get(this.idField) ||\n        this.route.snapshot.paramMap.get(this.idField);\n      this.pageType = this.route.snapshot.data.type;\n      this[this.idField] = code;\n      if (this.isCreate() && code) throw 'Page is impure';\n      if (code && func) await func();\n    } catch (error) {\n      console.error(error);\n      if (err) err();\n      else {\n        await this.infoFunc(error, 0);\n        this.uS.back();\n      }\n    }\n    this.setLoader(false);\n  }\n\n  setLoader = (v: boolean) => {\n    this.loading = v;\n    this.loadingSignal.set(v);\n  };\n\n readonly pageState = computed<IPageState>(() => ({\n    isClone: this.isClone(),\n    isCreate: this.isCreate(),\n    isEdit: this.isEdit(),\n    isShow: this.isShow(),\n    isModal: this.isModal(),\n  }));\n\n  setAsIndex() {\n    this.overridePageTypeSignal.set(EPageType.indexPage);\n  }\n  setAsClone() {\n    this.overridePageTypeSignal.set(EPageType.clonePage);\n  }\n  setAsCreate() {\n    this.overridePageTypeSignal.set(EPageType.createPage);\n  }\n  setAsEdit() {\n    this.overridePageTypeSignal.set(EPageType.editPage);\n  }\n  setAsShow() {\n    this.overridePageTypeSignal.set(EPageType.showPage);\n  }\n\n  readonly queryParamsSignal = toSignal(this.route.queryParams as Observable<{ code?: string }>);\n  get _queryParams() {\n    return this.queryParamsSignal() || {};\n  }\n\n  async checkParams(params: string[] = ['code']) {\n    if (this.isCreate()) return;\n    try {\n      for (const param of params)\n        if (!this._queryParams?.[param as keyof typeof this._queryParams])\n          throw `${param} is missing.`;\n    } catch (error) {\n      this.bounce(error);\n    }\n  }\n\n  readonly hideCode = computed(() => {\n    const isCreate = this.isCreate(),\n      isClone = this.isClone();\n    return isCreate || isClone;\n  });\n\n  async bounce(error: any) {\n    await this.uS.info(error, 0);\n    this.uS.goR('/');\n  }\n\n  handleForm() {\n    switch (true) {\n      case this.isShow():\n        this.ifShow();\n        break;\n      case this.isClone():\n        this.ifClone();\n        break;\n      case this.isEdit():\n        this.ifEdit();\n        break;\n      case this.isCreate():\n        this.ifCreate();\n        break;\n\n      default:\n        break;\n    }\n  }\n\n  ifEdit = () => {};\n  ifCreate = () => {};\n  ifShow = () => {};\n  ifClone = () => {};\n  ifParams = (func: () => any) => {\n    if (!this.isCreate()) {\n      func();\n    }\n  };\n\n  async onSubmitComplete(config: {\n    notificationMessage?: string;\n    param?: IObjectLiteral;\n    route?: string;\n  }) {\n    if (config.notificationMessage) await this.uS.info(config.notificationMessage);\n    this.router.navigate([config.route || '../show'], {\n      relativeTo: this.route,\n      queryParams: config.param,\n    });\n  }\n}\n\nexport interface IPageState {\n  isClone?: boolean;\n  isCreate?: boolean;\n  isEdit?: boolean;\n  isShow?: boolean;\n  isModal?: boolean;\n}\n"]}
|
|
160
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"page-template.component.js","sourceRoot":"","sources":["../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/page-template/page-template.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, Output, computed, inject, signal } from '@angular/core';\nimport { ActivatedRoute, Router } from '@angular/router';\nimport { UtilityService } from '../../../../lib/Services/utility.service';\nimport { EPageType, IObjectLiteral } from '../../models/index.model';\nimport { Environment, SDKEnvironment } from '../../models/environment.model';\nimport { toSignal } from '@angular/core/rxjs-interop';\nimport { Observable } from 'rxjs';\n\n@Component({\n  template: ``,\n  standalone: true,\n})\nexport class PageTemplateComponent<\n  ModelData = any,\n  TEnvironment extends SDKEnvironment = Environment,\n> {\n  loading: boolean;\n  readonly loadingSignal = signal<boolean>(false);\n  readonly isModal = signal<boolean>(false);\n  @Input('isModal') set _isModal(v: boolean) {\n    this.isModal.set(v);\n  }\n  @Input() modelData: ModelData;\n  modalOnComplete: (...args) => any;\n  @Output() modalSubmitted = new EventEmitter();\n  code?: string;\n  readonly overridePageTypeSignal = signal<EPageType>(undefined);\n  public get pageType(): EPageType {\n    return this.overridePageTypeSignal();\n  }\n  public set pageType(value: EPageType) {\n    this.overridePageTypeSignal.set(value);\n  }\n\n  idField = 'code';\n  readonly isCreate = computed<boolean>(() =>\n    this.uS.pageS.isCreate(this.route, this.overridePageTypeSignal()),\n  );\n  readonly isIndex = computed<boolean>(() =>\n    this.uS.pageS.isIndex(this.route, this.overridePageTypeSignal()),\n  );\n  readonly isClone = computed<boolean>(() =>\n    this.uS.pageS.isClone(this.route, this.overridePageTypeSignal()),\n  );\n  readonly isEdit = computed<boolean>(() =>\n    this.uS.pageS.isEdit(this.route, this.overridePageTypeSignal()),\n  );\n  readonly isShow = computed<boolean>(() =>\n    this.uS.pageS.isShow(this.route, this.overridePageTypeSignal()),\n  );\n  get infoFunc() {\n    return this.uS.info;\n  }\n  public route = inject(ActivatedRoute);\n  public uS = inject(UtilityService<TEnvironment>);\n  router = inject(Router);\n  constructor() {}\n\n  async init(func?: () => Promise<any>, err?: () => any) {\n    this.setLoader(true);\n    try {\n      const code =\n        this.route.snapshot.queryParamMap.get(this.idField) ||\n        this.route.snapshot.paramMap.get(this.idField);\n      this.pageType = this.route.snapshot.data.type;\n      this[this.idField] = code;\n      if (this.isCreate() && code) throw 'Page is impure';\n      if (code && func) await func();\n    } catch (error) {\n      console.error(error);\n      if (err) err();\n      else {\n        await this.infoFunc(error, 0);\n        this.uS.back();\n      }\n    }\n    this.setLoader(false);\n  }\n\n  setLoader = (v: boolean) => {\n    this.loading = v;\n    this.loadingSignal.set(v);\n  };\n\n  readonly pageState = computed<IPageState>(() => ({\n    isClone: this.isClone(),\n    isCreate: this.isCreate(),\n    isEdit: this.isEdit(),\n    isShow: this.isShow(),\n    isModal: this.isModal(),\n  }));\n\n  setAsIndex() {\n    this.overridePageTypeSignal.set(EPageType.indexPage);\n  }\n  setAsClone() {\n    this.overridePageTypeSignal.set(EPageType.clonePage);\n  }\n  setAsCreate() {\n    this.overridePageTypeSignal.set(EPageType.createPage);\n  }\n  setAsEdit() {\n    this.overridePageTypeSignal.set(EPageType.editPage);\n  }\n  setAsShow() {\n    this.overridePageTypeSignal.set(EPageType.showPage);\n  }\n\n  readonly queryParamsSignal = toSignal(\n    this.route.queryParams as Observable<{ code?: string; id?: string }>,\n  );\n  get _queryParams() {\n    return this.queryParamsSignal() || {};\n  }\n\n  async checkParams(params: string[] = ['code']) {\n    if (this.isCreate()) return;\n    try {\n      for (const param of params)\n        if (!this._queryParams?.[param as keyof typeof this._queryParams])\n          throw `${param} is missing.`;\n    } catch (error) {\n      this.bounce(error);\n    }\n  }\n\n  readonly hideCode = computed(() => {\n    const isCreate = this.isCreate(),\n      isClone = this.isClone();\n    return isCreate || isClone;\n  });\n\n  async bounce(error: any) {\n    await this.uS.info(error, 0);\n    this.uS.goR('/');\n  }\n\n  handleForm() {\n    switch (true) {\n      case this.isShow():\n        this.ifShow();\n        break;\n      case this.isClone():\n        this.ifClone();\n        break;\n      case this.isEdit():\n        this.ifEdit();\n        break;\n      case this.isCreate():\n        this.ifCreate();\n        break;\n\n      default:\n        break;\n    }\n  }\n\n  ifEdit = () => {};\n  ifCreate = () => {};\n  ifShow = () => {};\n  ifClone = () => {};\n  ifParams = (func: () => any) => {\n    if (!this.isCreate()) {\n      func();\n    }\n  };\n\n  async onSubmitComplete(config: {\n    notificationMessage?: string;\n    param?: IObjectLiteral;\n    route?: string;\n  }) {\n    if (config.notificationMessage) await this.uS.info(config.notificationMessage);\n    this.router.navigate([config.route || '../show'], {\n      relativeTo: this.route,\n      queryParams: config.param,\n    });\n  }\n}\n\nexport interface IPageState {\n  isClone?: boolean;\n  isCreate?: boolean;\n  isEdit?: boolean;\n  isShow?: boolean;\n  isModal?: boolean;\n}\n"]}
|
|
@@ -64,7 +64,7 @@ export class VerticalNavComponent {
|
|
|
64
64
|
}
|
|
65
65
|
}
|
|
66
66
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: VerticalNavComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
67
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.1.0", type: VerticalNavComponent, isStandalone: true, selector: "vertical-nav", inputs: { shouldShowChildInput: { classPropertyName: "shouldShowChildInput", publicName: "shouldShowChildInput", isSignal: true, isRequired: false, transformFunction: null }, toolbarTitle: { classPropertyName: "toolbarTitle", publicName: "toolbarTitle", isSignal: true, isRequired: false, transformFunction: null }, toolbarLogo: { classPropertyName: "toolbarLogo", publicName: "toolbarLogo", isSignal: true, isRequired: false, transformFunction: null }, toolbarLogoStyle: { classPropertyName: "toolbarLogoStyle", publicName: "toolbarLogoStyle", isSignal: true, isRequired: false, transformFunction: null }, fixedTopGap: { classPropertyName: "fixedTopGap", publicName: "fixedTopGap", isSignal: true, isRequired: false, transformFunction: null }, sidenavTemplate: { classPropertyName: "sidenavTemplate", publicName: "sidenavTemplate", isSignal: true, isRequired: false, transformFunction: null }, toolbarTemplate: { classPropertyName: "toolbarTemplate", publicName: "toolbarTemplate", isSignal: true, isRequired: false, transformFunction: null }, toolbarEndTemplate: { classPropertyName: "toolbarEndTemplate", publicName: "toolbarEndTemplate", isSignal: true, isRequired: false, transformFunction: null }, bodyTemplate: { classPropertyName: "bodyTemplate", publicName: "bodyTemplate", isSignal: true, isRequired: false, transformFunction: null }, useToolbar: { classPropertyName: "useToolbar", publicName: "useToolbar", isSignal: true, isRequired: false, transformFunction: null }, showMenu: { classPropertyName: "showMenu", publicName: "showMenu", isSignal: true, isRequired: false, transformFunction: null }, menuItems: { classPropertyName: "menuItems", publicName: "menuItems", isSignal: true, isRequired: false, transformFunction: null } }, viewQueries: [{ propertyName: "drawer", first: true, predicate: ["snav"], descendants: true, isSignal: true }, { propertyName: "toolbarContRef", first: true, predicate: ["toolbarCont"], descendants: true, isSignal: true }], ngImport: i0, template: "<div class=\"vertical-nav\" [class.vertical-nav-is-mobile]=\"uS.isMobileSignal()\">\n @if (useToolbar()) {\n <div #toolbarCont class=\"vertical-nav-toolbar\">\n @if (toolbarTemplate()) {\n <ng-container *ngTemplateOutlet=\"toolbarTemplate()\" />\n } @else {\n <mat-toolbar color=\"primary\" class=\"bg-primary d-flex justify-content-between\">\n <div class=\"d-flex align-items-center w-100\">\n <button mat-icon-button (click)=\"snav.toggle()\">\n <mat-icon>menu</mat-icon>\n </button>\n @if (toolbarLogo()) {\n <img\n [src]=\"toolbarLogo()\"\n [ngStyle]=\"toolbarLogoStyle()\"\n alt=\"toolbar logo\"\n class=\"toolbarLogo\" />\n }\n @if (toolbarTitle()) {\n <h1 class=\"vertical-nav-app-name\">{{ toolbarTitle() | appTranslate | async }}</h1>\n }\n </div>\n <div>\n @if (toolbarEndTemplate()) {\n <ng-container *ngTemplateOutlet=\"toolbarEndTemplate()\" />\n }\n </div>\n </mat-toolbar>\n }\n </div>\n }\n\n <mat-sidenav-container\n [id]=\"id()\"\n class=\"vertical-nav-container\"\n [style.marginTop.px]=\"\n uS.isMobileSignal() ? fixedTopGap() || toolbarContRef()?.nativeElement?.offsetHeight : 0\n \">\n <mat-sidenav\n class=\"side-w\"\n [ngClass]=\"{ mobile: this.uS.isMobileSignal() }\"\n #snav\n [mode]=\"uS.isMobileSignal() ? 'over' : 'side'\"\n [opened]=\"!uS.isMobileSignal() && showMenu()\"\n [fixedInViewport]=\"uS.isMobileSignal()\"\n [fixedTopGap]=\" uS.isMobileSignal() ? fixedTopGap() || toolbarContRef()?.nativeElement?.offsetHeight : 0\"\n [hidden]=\"!showMenu()\">\n <div class=\"vertical-nav-side-padding\">\n @if (sidenavTemplate()) {\n <ng-container *ngTemplateOutlet=\"sidenavTemplate()\" />\n } @else {\n <mat-tree\n [dataSource]=\"dataSource()\"\n [treeControl]=\"treeControl()\"\n class=\"vertical-nav-tree\">\n <!-- This is the tree node template for leaf nodes -->\n <!-- This is the tree node template for expandable nodes -->\n <mat-nested-tree-node\n *matTreeNodeDef=\"let node; when: hasChild()\"\n class=\"expandable-node\">\n <div class=\"mat-tree-node\">\n <button\n matTreeNodeToggle\n [attr.aria-label]=\"'Toggle ' + node.name\"\n class=\"menu-btn level{{ node.level }}\">\n <div class=\"row\">\n <div class=\"col\">\n <span class=\"{{ node.icon }}\"></span>\n {{ node.label | appTranslate | async }}\n </div>\n <div class=\"col-auto\">\n <span\n class=\"fa {{\n treeControl().isExpanded(node) ? 'fa-chevron-down' : 'fa-chevron-right'\n }} \"></span>\n </div>\n </div>\n </button>\n </div>\n <div>\n <!-- There is inline padding applied to this div using styles.\n This padding value depends on the mat-icon-button width. -->\n <div\n [class.vertical-nav-tree-invisible]=\"!treeControl().isExpanded(node)\"\n role=\"group\"\n class=\"group\">\n <ng-container matTreeNodeOutlet />\n </div>\n </div>\n </mat-nested-tree-node>\n <!-- There is inline padding applied to this node using styles.\n This padding value depends on the mat-icon-button width. -->\n <mat-tree-node\n *matTreeNodeDef=\"let node; when: shouldShowChild()\"\n matTreeNodeToggle\n class=\"single-node level{{ node.level }}\">\n <a [routerLink]=\"node.link\" class=\"d-block w-100\">\n <span class=\"{{ node.icon }}\"></span>\n {{ node.label | appTranslate | async }}\n </a>\n </mat-tree-node>\n <mat-tree-node\n *matTreeNodeDef=\"let node\"\n matTreeNodeToggle\n class=\"single-node restricted level{{ node.level }}\" />\n </mat-tree>\n }\n </div>\n </mat-sidenav>\n\n <mat-sidenav-content class=\"vertical-nav-body\">\n @if (bodyTemplate()) {\n <ng-container *ngTemplateOutlet=\"bodyTemplate()\" />\n } @else {\n <ng-content />\n }\n </mat-sidenav-content>\n </mat-sidenav-container>\n</div>\n", styles: [".menu{background-color:#fff}.vertical-nav{display:flex;flex-direction:column;height:100%}.vertical-nav.fullScreen{position:absolute;inset:0}.toolbarLogo{--toolbarLogoDimen: 50px;height:var(--toolbarLogoDimen)}h1.vertical-nav-app-name{margin-left:8px}.vertical-nav-container{flex:1}.vertical-nav-is-mobile .vertical-nav-toolbar{position:fixed;z-index:2;width:100%}.vertical-nav-is-mobile .vertical-nav-container{flex:1 0 auto}.mat-drawer-container{background-color:unset}.mat-drawer-content{background-color:#e9e9e9}.expandable-node button{width:100%;border-radius:0;text-align:left}.single-node button{width:24px}.level0{border-bottom:1px solid rgba(141,141,141,.231372549)}.side-w{width:auto;margin:10px;border-radius:16px}.side-w.mobile{width:90%;margin:0;border-radius:0}.vertical-nav-tree-invisible{display:none}.vertical-nav-tree ul,.vertical-nav-tree li{margin-top:0;margin-bottom:0;list-style-type:none}.vertical-nav-tree div[role=group]{border-radius:var(--borderRadius);background-color:#ffffff57}.vertical-nav-tree div[role=group]>.mat-tree-node{padding:10px 20px}a{color:inherit}.restricted{display:none}mat-sidenav.mat-drawer.mat-drawer-opened.mat-drawer-side.mat-sidenav{min-width:200px;overflow-x:auto;white-space:nowrap}.menu-btn{background-color:#ffffff57;border-radius:var(--borderRadius)!important;padding:10px 20px;color:#2b2b2b;border:none}.expandable-node .group{border:1px solid rgba(0,0,0,.11)!important}.profile{position:sticky;bottom:0;right:0;left:0;background-color:var(--primary);background-image:linear-gradient(45deg,#ffffffa8,#ffffffa8);padding:10px}.vertical-nav-side-padding{padding:var(--space-8)}\n"], dependencies: [{ kind: "ngmodule", type: MatToolbarModule }, { kind: "component", type: i1.MatToolbar, selector: "mat-toolbar", inputs: ["color"], exportAs: ["matToolbar"] }, { kind: "ngmodule", type: MatButtonModule }, { kind: "component", type: i2.MatIconButton, selector: "button[mat-icon-button]", exportAs: ["matButton"] }, { kind: "ngmodule", type: MatIconModule }, { kind: "component", type: i3.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "ngmodule", type: MatSidenavModule }, { kind: "component", type: i4.MatSidenav, selector: "mat-sidenav", inputs: ["fixedInViewport", "fixedTopGap", "fixedBottomGap"], exportAs: ["matSidenav"] }, { kind: "component", type: i4.MatSidenavContainer, selector: "mat-sidenav-container", exportAs: ["matSidenavContainer"] }, { kind: "component", type: i4.MatSidenavContent, selector: "mat-sidenav-content" }, { kind: "ngmodule", type: MatTreeModule }, { kind: "directive", type: i5.MatNestedTreeNode, selector: "mat-nested-tree-node", inputs: ["matNestedTreeNode", "disabled", "tabIndex"], exportAs: ["matNestedTreeNode"] }, { kind: "directive", type: i5.MatTreeNodeDef, selector: "[matTreeNodeDef]", inputs: ["matTreeNodeDefWhen", "matTreeNode"] }, { kind: "directive", type: i5.MatTreeNodeToggle, selector: "[matTreeNodeToggle]", inputs: ["matTreeNodeToggleRecursive"] }, { kind: "component", type: i5.MatTree, selector: "mat-tree", exportAs: ["matTree"] }, { kind: "directive", type: i5.MatTreeNode, selector: "mat-tree-node", inputs: ["disabled", "tabIndex"], exportAs: ["matTreeNode"] }, { kind: "directive", type: i5.MatTreeNodeOutlet, selector: "[matTreeNodeOutlet]" }, { kind: "directive", type: RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "info", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "ngmodule", type: MatMenuModule }, { kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i6.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i6.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i6.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "pipe", type: i6.AsyncPipe, name: "async" }, { kind: "pipe", type: SDKTranslatePipe, name: "appTranslate" }] }); }
|
|
67
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.1.0", type: VerticalNavComponent, isStandalone: true, selector: "vertical-nav", inputs: { shouldShowChildInput: { classPropertyName: "shouldShowChildInput", publicName: "shouldShowChildInput", isSignal: true, isRequired: false, transformFunction: null }, toolbarTitle: { classPropertyName: "toolbarTitle", publicName: "toolbarTitle", isSignal: true, isRequired: false, transformFunction: null }, toolbarLogo: { classPropertyName: "toolbarLogo", publicName: "toolbarLogo", isSignal: true, isRequired: false, transformFunction: null }, toolbarLogoStyle: { classPropertyName: "toolbarLogoStyle", publicName: "toolbarLogoStyle", isSignal: true, isRequired: false, transformFunction: null }, fixedTopGap: { classPropertyName: "fixedTopGap", publicName: "fixedTopGap", isSignal: true, isRequired: false, transformFunction: null }, sidenavTemplate: { classPropertyName: "sidenavTemplate", publicName: "sidenavTemplate", isSignal: true, isRequired: false, transformFunction: null }, toolbarTemplate: { classPropertyName: "toolbarTemplate", publicName: "toolbarTemplate", isSignal: true, isRequired: false, transformFunction: null }, toolbarEndTemplate: { classPropertyName: "toolbarEndTemplate", publicName: "toolbarEndTemplate", isSignal: true, isRequired: false, transformFunction: null }, bodyTemplate: { classPropertyName: "bodyTemplate", publicName: "bodyTemplate", isSignal: true, isRequired: false, transformFunction: null }, useToolbar: { classPropertyName: "useToolbar", publicName: "useToolbar", isSignal: true, isRequired: false, transformFunction: null }, showMenu: { classPropertyName: "showMenu", publicName: "showMenu", isSignal: true, isRequired: false, transformFunction: null }, menuItems: { classPropertyName: "menuItems", publicName: "menuItems", isSignal: true, isRequired: false, transformFunction: null } }, viewQueries: [{ propertyName: "drawer", first: true, predicate: ["snav"], descendants: true, isSignal: true }, { propertyName: "toolbarContRef", first: true, predicate: ["toolbarCont"], descendants: true, isSignal: true }], ngImport: i0, template: "<div class=\"vertical-nav\" [class.vertical-nav-is-mobile]=\"uS.isMobileSignal()\">\n @if (useToolbar()) {\n <div #toolbarCont class=\"vertical-nav-toolbar\">\n @if (toolbarTemplate()) {\n <ng-container *ngTemplateOutlet=\"toolbarTemplate()\" />\n } @else {\n <mat-toolbar color=\"primary\" class=\"bg-primary d-flex justify-content-between\">\n <div class=\"d-flex align-items-center w-100\">\n @if (showMenu()) {\n <button mat-icon-button (click)=\"snav.toggle()\">\n <mat-icon>menu</mat-icon>\n </button>\n }\n @if (toolbarLogo()) {\n <img\n [src]=\"toolbarLogo()\"\n [ngStyle]=\"toolbarLogoStyle()\"\n alt=\"toolbar logo\"\n class=\"toolbarLogo\" />\n }\n @if (toolbarTitle()) {\n <h1 class=\"vertical-nav-app-name\">{{ toolbarTitle() | appTranslate | async }}</h1>\n }\n </div>\n <div>\n @if (toolbarEndTemplate()) {\n <ng-container *ngTemplateOutlet=\"toolbarEndTemplate()\" />\n }\n </div>\n </mat-toolbar>\n }\n </div>\n }\n\n <mat-sidenav-container\n [id]=\"id()\"\n class=\"vertical-nav-container\"\n [style.marginTop.px]=\"\n uS.isMobileSignal() ? fixedTopGap() || toolbarContRef()?.nativeElement?.offsetHeight : 0\n \">\n <mat-sidenav\n class=\"side-w\"\n [ngClass]=\"{ mobile: this.uS.isMobileSignal() }\"\n #snav\n [mode]=\"uS.isMobileSignal() ? 'over' : 'side'\"\n [opened]=\"!uS.isMobileSignal() && showMenu()\"\n [fixedInViewport]=\"uS.isMobileSignal()\"\n [fixedTopGap]=\"\n uS.isMobileSignal() ? fixedTopGap() || toolbarContRef()?.nativeElement?.offsetHeight : 0\n \"\n [hidden]=\"!showMenu()\">\n <div class=\"vertical-nav-side-padding\">\n @if (sidenavTemplate()) {\n <ng-container *ngTemplateOutlet=\"sidenavTemplate()\" />\n } @else {\n <mat-tree\n [dataSource]=\"dataSource()\"\n [treeControl]=\"treeControl()\"\n class=\"vertical-nav-tree\">\n <!-- This is the tree node template for leaf nodes -->\n <!-- This is the tree node template for expandable nodes -->\n <mat-nested-tree-node\n *matTreeNodeDef=\"let node; when: hasChild()\"\n class=\"expandable-node\">\n <div class=\"mat-tree-node\">\n <button\n matTreeNodeToggle\n [attr.aria-label]=\"'Toggle ' + node.name\"\n class=\"menu-btn level{{ node.level }}\">\n <div class=\"row\">\n <div class=\"col\">\n <span class=\"{{ node.icon }}\"></span>\n {{ node.label | appTranslate | async }}\n </div>\n <div class=\"col-auto\">\n <span\n class=\"fa {{\n treeControl().isExpanded(node) ? 'fa-chevron-down' : 'fa-chevron-right'\n }} \"></span>\n </div>\n </div>\n </button>\n </div>\n <div>\n <!-- There is inline padding applied to this div using styles.\n This padding value depends on the mat-icon-button width. -->\n <div\n [class.vertical-nav-tree-invisible]=\"!treeControl().isExpanded(node)\"\n role=\"group\"\n class=\"group\">\n <ng-container matTreeNodeOutlet />\n </div>\n </div>\n </mat-nested-tree-node>\n <!-- There is inline padding applied to this node using styles.\n This padding value depends on the mat-icon-button width. -->\n <mat-tree-node\n *matTreeNodeDef=\"let node; when: shouldShowChild()\"\n matTreeNodeToggle\n class=\"single-node level{{ node.level }}\">\n <a [routerLink]=\"node.link\" class=\"d-block w-100\">\n <span class=\"{{ node.icon }}\"></span>\n {{ node.label | appTranslate | async }}\n </a>\n </mat-tree-node>\n <mat-tree-node\n *matTreeNodeDef=\"let node\"\n matTreeNodeToggle\n class=\"single-node restricted level{{ node.level }}\" />\n </mat-tree>\n }\n </div>\n </mat-sidenav>\n\n <mat-sidenav-content class=\"vertical-nav-body\">\n @if (bodyTemplate()) {\n <ng-container *ngTemplateOutlet=\"bodyTemplate()\" />\n } @else {\n <ng-content />\n }\n </mat-sidenav-content>\n </mat-sidenav-container>\n</div>\n", styles: [".menu{background-color:#fff}.vertical-nav{display:flex;flex-direction:column;height:100%}.vertical-nav.fullScreen{position:absolute;inset:0}.toolbarLogo{--toolbarLogoDimen: 50px;height:var(--toolbarLogoDimen)}h1.vertical-nav-app-name{margin-left:8px}.vertical-nav-container{flex:1}.vertical-nav-is-mobile .vertical-nav-toolbar{position:fixed;z-index:2;width:100%}.vertical-nav-is-mobile .vertical-nav-container{flex:1 0 auto}.mat-drawer-container{background-color:unset}.mat-drawer-content{background-color:#e9e9e9}.expandable-node button{width:100%;border-radius:0;text-align:left}.single-node button{width:24px}.level0{border-bottom:1px solid rgba(141,141,141,.231372549)}.side-w{width:auto;margin:10px;border-radius:16px}.side-w.mobile{width:90%;margin:0;border-radius:0}.vertical-nav-tree-invisible{display:none}.vertical-nav-tree ul,.vertical-nav-tree li{margin-top:0;margin-bottom:0;list-style-type:none}.vertical-nav-tree div[role=group]{border-radius:var(--borderRadius);background-color:#ffffff57}.vertical-nav-tree div[role=group]>.mat-tree-node{padding:10px 20px}a{color:inherit}.restricted{display:none}mat-sidenav.mat-drawer.mat-drawer-opened.mat-drawer-side.mat-sidenav{min-width:200px;overflow-x:auto;white-space:nowrap}.menu-btn{background-color:#ffffff57;border-radius:var(--borderRadius)!important;padding:10px 20px;color:#2b2b2b;border:none}.expandable-node .group{border:1px solid rgba(0,0,0,.11)!important}.profile{position:sticky;bottom:0;right:0;left:0;background-color:var(--primary);background-image:linear-gradient(45deg,#ffffffa8,#ffffffa8);padding:10px}.vertical-nav-side-padding{padding:var(--space-8)}\n"], dependencies: [{ kind: "ngmodule", type: MatToolbarModule }, { kind: "component", type: i1.MatToolbar, selector: "mat-toolbar", inputs: ["color"], exportAs: ["matToolbar"] }, { kind: "ngmodule", type: MatButtonModule }, { kind: "component", type: i2.MatIconButton, selector: "button[mat-icon-button]", exportAs: ["matButton"] }, { kind: "ngmodule", type: MatIconModule }, { kind: "component", type: i3.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "ngmodule", type: MatSidenavModule }, { kind: "component", type: i4.MatSidenav, selector: "mat-sidenav", inputs: ["fixedInViewport", "fixedTopGap", "fixedBottomGap"], exportAs: ["matSidenav"] }, { kind: "component", type: i4.MatSidenavContainer, selector: "mat-sidenav-container", exportAs: ["matSidenavContainer"] }, { kind: "component", type: i4.MatSidenavContent, selector: "mat-sidenav-content" }, { kind: "ngmodule", type: MatTreeModule }, { kind: "directive", type: i5.MatNestedTreeNode, selector: "mat-nested-tree-node", inputs: ["matNestedTreeNode", "disabled", "tabIndex"], exportAs: ["matNestedTreeNode"] }, { kind: "directive", type: i5.MatTreeNodeDef, selector: "[matTreeNodeDef]", inputs: ["matTreeNodeDefWhen", "matTreeNode"] }, { kind: "directive", type: i5.MatTreeNodeToggle, selector: "[matTreeNodeToggle]", inputs: ["matTreeNodeToggleRecursive"] }, { kind: "component", type: i5.MatTree, selector: "mat-tree", exportAs: ["matTree"] }, { kind: "directive", type: i5.MatTreeNode, selector: "mat-tree-node", inputs: ["disabled", "tabIndex"], exportAs: ["matTreeNode"] }, { kind: "directive", type: i5.MatTreeNodeOutlet, selector: "[matTreeNodeOutlet]" }, { kind: "directive", type: RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "info", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "ngmodule", type: MatMenuModule }, { kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i6.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i6.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i6.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "pipe", type: i6.AsyncPipe, name: "async" }, { kind: "pipe", type: SDKTranslatePipe, name: "appTranslate" }] }); }
|
|
68
68
|
}
|
|
69
69
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: VerticalNavComponent, decorators: [{
|
|
70
70
|
type: Component,
|
|
@@ -79,6 +79,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.0", ngImpor
|
|
|
79
79
|
ImageLoaderDirective,
|
|
80
80
|
CommonModule,
|
|
81
81
|
SDKTranslatePipe,
|
|
82
|
-
], template: "<div class=\"vertical-nav\" [class.vertical-nav-is-mobile]=\"uS.isMobileSignal()\">\n @if (useToolbar()) {\n <div #toolbarCont class=\"vertical-nav-toolbar\">\n @if (toolbarTemplate()) {\n <ng-container *ngTemplateOutlet=\"toolbarTemplate()\" />\n } @else {\n <mat-toolbar color=\"primary\" class=\"bg-primary d-flex justify-content-between\">\n <div class=\"d-flex align-items-center w-100\">\n <button mat-icon-button (click)=\"snav.toggle()\">\n
|
|
82
|
+
], template: "<div class=\"vertical-nav\" [class.vertical-nav-is-mobile]=\"uS.isMobileSignal()\">\n @if (useToolbar()) {\n <div #toolbarCont class=\"vertical-nav-toolbar\">\n @if (toolbarTemplate()) {\n <ng-container *ngTemplateOutlet=\"toolbarTemplate()\" />\n } @else {\n <mat-toolbar color=\"primary\" class=\"bg-primary d-flex justify-content-between\">\n <div class=\"d-flex align-items-center w-100\">\n @if (showMenu()) {\n <button mat-icon-button (click)=\"snav.toggle()\">\n <mat-icon>menu</mat-icon>\n </button>\n }\n @if (toolbarLogo()) {\n <img\n [src]=\"toolbarLogo()\"\n [ngStyle]=\"toolbarLogoStyle()\"\n alt=\"toolbar logo\"\n class=\"toolbarLogo\" />\n }\n @if (toolbarTitle()) {\n <h1 class=\"vertical-nav-app-name\">{{ toolbarTitle() | appTranslate | async }}</h1>\n }\n </div>\n <div>\n @if (toolbarEndTemplate()) {\n <ng-container *ngTemplateOutlet=\"toolbarEndTemplate()\" />\n }\n </div>\n </mat-toolbar>\n }\n </div>\n }\n\n <mat-sidenav-container\n [id]=\"id()\"\n class=\"vertical-nav-container\"\n [style.marginTop.px]=\"\n uS.isMobileSignal() ? fixedTopGap() || toolbarContRef()?.nativeElement?.offsetHeight : 0\n \">\n <mat-sidenav\n class=\"side-w\"\n [ngClass]=\"{ mobile: this.uS.isMobileSignal() }\"\n #snav\n [mode]=\"uS.isMobileSignal() ? 'over' : 'side'\"\n [opened]=\"!uS.isMobileSignal() && showMenu()\"\n [fixedInViewport]=\"uS.isMobileSignal()\"\n [fixedTopGap]=\"\n uS.isMobileSignal() ? fixedTopGap() || toolbarContRef()?.nativeElement?.offsetHeight : 0\n \"\n [hidden]=\"!showMenu()\">\n <div class=\"vertical-nav-side-padding\">\n @if (sidenavTemplate()) {\n <ng-container *ngTemplateOutlet=\"sidenavTemplate()\" />\n } @else {\n <mat-tree\n [dataSource]=\"dataSource()\"\n [treeControl]=\"treeControl()\"\n class=\"vertical-nav-tree\">\n <!-- This is the tree node template for leaf nodes -->\n <!-- This is the tree node template for expandable nodes -->\n <mat-nested-tree-node\n *matTreeNodeDef=\"let node; when: hasChild()\"\n class=\"expandable-node\">\n <div class=\"mat-tree-node\">\n <button\n matTreeNodeToggle\n [attr.aria-label]=\"'Toggle ' + node.name\"\n class=\"menu-btn level{{ node.level }}\">\n <div class=\"row\">\n <div class=\"col\">\n <span class=\"{{ node.icon }}\"></span>\n {{ node.label | appTranslate | async }}\n </div>\n <div class=\"col-auto\">\n <span\n class=\"fa {{\n treeControl().isExpanded(node) ? 'fa-chevron-down' : 'fa-chevron-right'\n }} \"></span>\n </div>\n </div>\n </button>\n </div>\n <div>\n <!-- There is inline padding applied to this div using styles.\n This padding value depends on the mat-icon-button width. -->\n <div\n [class.vertical-nav-tree-invisible]=\"!treeControl().isExpanded(node)\"\n role=\"group\"\n class=\"group\">\n <ng-container matTreeNodeOutlet />\n </div>\n </div>\n </mat-nested-tree-node>\n <!-- There is inline padding applied to this node using styles.\n This padding value depends on the mat-icon-button width. -->\n <mat-tree-node\n *matTreeNodeDef=\"let node; when: shouldShowChild()\"\n matTreeNodeToggle\n class=\"single-node level{{ node.level }}\">\n <a [routerLink]=\"node.link\" class=\"d-block w-100\">\n <span class=\"{{ node.icon }}\"></span>\n {{ node.label | appTranslate | async }}\n </a>\n </mat-tree-node>\n <mat-tree-node\n *matTreeNodeDef=\"let node\"\n matTreeNodeToggle\n class=\"single-node restricted level{{ node.level }}\" />\n </mat-tree>\n }\n </div>\n </mat-sidenav>\n\n <mat-sidenav-content class=\"vertical-nav-body\">\n @if (bodyTemplate()) {\n <ng-container *ngTemplateOutlet=\"bodyTemplate()\" />\n } @else {\n <ng-content />\n }\n </mat-sidenav-content>\n </mat-sidenav-container>\n</div>\n", styles: [".menu{background-color:#fff}.vertical-nav{display:flex;flex-direction:column;height:100%}.vertical-nav.fullScreen{position:absolute;inset:0}.toolbarLogo{--toolbarLogoDimen: 50px;height:var(--toolbarLogoDimen)}h1.vertical-nav-app-name{margin-left:8px}.vertical-nav-container{flex:1}.vertical-nav-is-mobile .vertical-nav-toolbar{position:fixed;z-index:2;width:100%}.vertical-nav-is-mobile .vertical-nav-container{flex:1 0 auto}.mat-drawer-container{background-color:unset}.mat-drawer-content{background-color:#e9e9e9}.expandable-node button{width:100%;border-radius:0;text-align:left}.single-node button{width:24px}.level0{border-bottom:1px solid rgba(141,141,141,.231372549)}.side-w{width:auto;margin:10px;border-radius:16px}.side-w.mobile{width:90%;margin:0;border-radius:0}.vertical-nav-tree-invisible{display:none}.vertical-nav-tree ul,.vertical-nav-tree li{margin-top:0;margin-bottom:0;list-style-type:none}.vertical-nav-tree div[role=group]{border-radius:var(--borderRadius);background-color:#ffffff57}.vertical-nav-tree div[role=group]>.mat-tree-node{padding:10px 20px}a{color:inherit}.restricted{display:none}mat-sidenav.mat-drawer.mat-drawer-opened.mat-drawer-side.mat-sidenav{min-width:200px;overflow-x:auto;white-space:nowrap}.menu-btn{background-color:#ffffff57;border-radius:var(--borderRadius)!important;padding:10px 20px;color:#2b2b2b;border:none}.expandable-node .group{border:1px solid rgba(0,0,0,.11)!important}.profile{position:sticky;bottom:0;right:0;left:0;background-color:var(--primary);background-image:linear-gradient(45deg,#ffffffa8,#ffffffa8);padding:10px}.vertical-nav-side-padding{padding:var(--space-8)}\n"] }]
|
|
83
83
|
}], ctorParameters: () => [] });
|
|
84
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"vertical-nav.component.js","sourceRoot":"","sources":["../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/vertical-nav/vertical-nav.component.ts","../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/vertical-nav/vertical-nav.component.html"],"names":[],"mappings":"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","sourcesContent":["import { MediaMatcher } from '@angular/cdk/layout';\nimport { NestedTreeControl } from '@angular/cdk/tree';\nimport {\n  Component,\n  Input,\n  ViewChild,\n  ChangeDetectorRef,\n  TemplateRef,\n  inject,\n  input,\n  computed,\n  viewChild,\n  signal,\n  ElementRef,\n  ChangeDetectionStrategy,\n} from '@angular/core';\nimport { MatDrawer, MatSidenavModule } from '@angular/material/sidenav';\nimport { MatTreeNestedDataSource, MatTreeModule } from '@angular/material/tree';\nimport { Router, RouterLink } from '@angular/router';\nimport PS from 'perfect-scrollbar';\n\nimport { SDKTranslatePipe } from '../../../Shared/pipes/translate.pipe';\nimport { ImageLoaderDirective } from '../../../Shared/directives/index.directive';\nimport { MatMenuModule } from '@angular/material/menu';\nimport { MatIconModule } from '@angular/material/icon';\nimport { MatButtonModule } from '@angular/material/button';\nimport { MatToolbar, MatToolbarModule } from '@angular/material/toolbar';\nimport { NgClass, NgIf, AsyncPipe, CommonModule } from '@angular/common';\nimport { UtilityService } from '../../../Services/utility.service';\nimport { IObjectLiteral } from '../../models/index.model';\nimport { ETSMenuItem } from '../../models/IMenuItem';\n\n@Component({\n  selector: 'vertical-nav',\n  templateUrl: './vertical-nav.component.html',\n  styleUrls: ['./vertical-nav.component.scss'],\n\n  standalone: true,\n  imports: [\n    MatToolbarModule,\n    MatButtonModule,\n    MatIconModule,\n    MatSidenavModule,\n    MatTreeModule,\n    RouterLink,\n    MatMenuModule,\n    ImageLoaderDirective,\n    CommonModule,\n    SDKTranslatePipe,\n  ],\n})\nexport class VerticalNavComponent {\n  public uS = inject(UtilityService);\n  public router = inject(Router);\n\n  shouldShowChildInput = input<(_: number, node: IMenuItem) => boolean>();\n  shouldShowChild = computed<(_: number, node: IMenuItem) => boolean>(\n    () => this.shouldShowChildInput() || (() => true),\n  );\n  readonly toolbarTitle = input<string>();\n  readonly toolbarLogo = input<string>();\n  readonly toolbarLogoStyle = input<IObjectLiteral>();\n  readonly fixedTopGap = input<number>();\n  readonly sidenavTemplate = input<TemplateRef<any>>();\n  readonly toolbarTemplate = input<TemplateRef<any>>();\n  /**This only works when the toolbarTemplate is not set */\n  readonly toolbarEndTemplate = input<TemplateRef<any> | undefined>();\n  readonly bodyTemplate = input<TemplateRef<any>>();\n  readonly useToolbar = input<boolean>(true);\n  readonly showMenu = input<boolean>();\n  readonly menuItems = input<IMenuItem[]>();\n\n  readonly dataSource = computed(() => {\n    const ds = new MatTreeNestedDataSource<IMenuItem>(),\n      menu = this.menuItems();\n\n    if (!menu?.length) return ds;\n    menu.forEach((x) => (x.level = 0));\n    ds.data = menu;\n    return ds;\n  });\n\n  readonly id = signal('matSideNav' + this.uS.genRandomID);\n  readonly treeControl = signal(new NestedTreeControl<IMenuItem>((node) => node.subs));\n\n  readonly drawer = viewChild<MatDrawer | undefined>('snav');\n  readonly toolbarContRef = viewChild<ElementRef<HTMLDivElement>>('toolbarCont');\n\n  constructor() {}\n\n  ngAfterViewInit(): void {\n    const doc = document.querySelector<HTMLDivElement>(`#${this.id()} .mat-drawer-inner-container`);\n    if (doc) {\n      doc.style.position = 'relative';\n      const ps = new PS(doc, {\n        wheelSpeed: 0.5,\n        swipeEasing: false,\n        wheelPropagation: true,\n        minScrollbarLength: 40,\n      });\n    }\n  }\n\n  readonly hasChild = signal(\n    (_: number, node: IMenuItem) => node.hasSub && this.shouldShowChild()(_, node),\n  );\n}\ntype IMenuItem = Partial<ETSMenuItem>;\n// interface IETSMenuItem {\n//   label: string;\n//   link: string;\n//   hasSub?: boolean;\n//   icon?: string;\n//   level?: number;\n//   id?: string;\n//   children?: IETSMenuItem[];\n// }\n","<div class=\"vertical-nav\" [class.vertical-nav-is-mobile]=\"uS.isMobileSignal()\">\n  @if (useToolbar()) {\n    <div #toolbarCont class=\"vertical-nav-toolbar\">\n      @if (toolbarTemplate()) {\n        <ng-container *ngTemplateOutlet=\"toolbarTemplate()\" />\n      } @else {\n        <mat-toolbar color=\"primary\" class=\"bg-primary d-flex justify-content-between\">\n          <div class=\"d-flex align-items-center w-100\">\n            <button mat-icon-button (click)=\"snav.toggle()\">\n              <mat-icon>menu</mat-icon>\n            </button>\n            @if (toolbarLogo()) {\n              <img\n                [src]=\"toolbarLogo()\"\n                [ngStyle]=\"toolbarLogoStyle()\"\n                alt=\"toolbar logo\"\n                class=\"toolbarLogo\" />\n            }\n            @if (toolbarTitle()) {\n              <h1 class=\"vertical-nav-app-name\">{{ toolbarTitle() | appTranslate | async }}</h1>\n            }\n          </div>\n          <div>\n            @if (toolbarEndTemplate()) {\n              <ng-container *ngTemplateOutlet=\"toolbarEndTemplate()\" />\n            }\n          </div>\n        </mat-toolbar>\n      }\n    </div>\n  }\n\n  <mat-sidenav-container\n    [id]=\"id()\"\n    class=\"vertical-nav-container\"\n    [style.marginTop.px]=\"\n      uS.isMobileSignal() ? fixedTopGap() || toolbarContRef()?.nativeElement?.offsetHeight : 0\n    \">\n    <mat-sidenav\n      class=\"side-w\"\n      [ngClass]=\"{ mobile: this.uS.isMobileSignal() }\"\n      #snav\n      [mode]=\"uS.isMobileSignal() ? 'over' : 'side'\"\n      [opened]=\"!uS.isMobileSignal() && showMenu()\"\n      [fixedInViewport]=\"uS.isMobileSignal()\"\n      [fixedTopGap]=\" uS.isMobileSignal() ? fixedTopGap() || toolbarContRef()?.nativeElement?.offsetHeight : 0\"\n      [hidden]=\"!showMenu()\">\n      <div class=\"vertical-nav-side-padding\">\n        @if (sidenavTemplate()) {\n          <ng-container *ngTemplateOutlet=\"sidenavTemplate()\" />\n        } @else {\n          <mat-tree\n            [dataSource]=\"dataSource()\"\n            [treeControl]=\"treeControl()\"\n            class=\"vertical-nav-tree\">\n            <!-- This is the tree node template for leaf nodes -->\n            <!-- This is the tree node template for expandable nodes -->\n            <mat-nested-tree-node\n              *matTreeNodeDef=\"let node; when: hasChild()\"\n              class=\"expandable-node\">\n              <div class=\"mat-tree-node\">\n                <button\n                  matTreeNodeToggle\n                  [attr.aria-label]=\"'Toggle ' + node.name\"\n                  class=\"menu-btn level{{ node.level }}\">\n                  <div class=\"row\">\n                    <div class=\"col\">\n                      <span class=\"{{ node.icon }}\"></span>\n                      {{ node.label | appTranslate | async }}\n                    </div>\n                    <div class=\"col-auto\">\n                      <span\n                        class=\"fa {{\n                          treeControl().isExpanded(node) ? 'fa-chevron-down' : 'fa-chevron-right'\n                        }} \"></span>\n                    </div>\n                  </div>\n                </button>\n              </div>\n              <div>\n                <!-- There is inline padding applied to this div using styles.\n            This padding value depends on the mat-icon-button width.  -->\n                <div\n                  [class.vertical-nav-tree-invisible]=\"!treeControl().isExpanded(node)\"\n                  role=\"group\"\n                  class=\"group\">\n                  <ng-container matTreeNodeOutlet />\n                </div>\n              </div>\n            </mat-nested-tree-node>\n            <!-- There is inline padding applied to this node using styles.\n    This padding value depends on the mat-icon-button width. -->\n            <mat-tree-node\n              *matTreeNodeDef=\"let node; when: shouldShowChild()\"\n              matTreeNodeToggle\n              class=\"single-node level{{ node.level }}\">\n              <a [routerLink]=\"node.link\" class=\"d-block w-100\">\n                <span class=\"{{ node.icon }}\"></span>\n                {{ node.label | appTranslate | async }}\n              </a>\n            </mat-tree-node>\n            <mat-tree-node\n              *matTreeNodeDef=\"let node\"\n              matTreeNodeToggle\n              class=\"single-node restricted level{{ node.level }}\" />\n          </mat-tree>\n        }\n      </div>\n    </mat-sidenav>\n\n    <mat-sidenav-content class=\"vertical-nav-body\">\n      @if (bodyTemplate()) {\n        <ng-container *ngTemplateOutlet=\"bodyTemplate()\" />\n      } @else {\n        <ng-content />\n      }\n    </mat-sidenav-content>\n  </mat-sidenav-container>\n</div>\n"]}
|
|
84
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"vertical-nav.component.js","sourceRoot":"","sources":["../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/vertical-nav/vertical-nav.component.ts","../../../../../../../projects/ets-fe-ng-sdk/src/lib/Shared/components/vertical-nav/vertical-nav.component.html"],"names":[],"mappings":"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","sourcesContent":["import { MediaMatcher } from '@angular/cdk/layout';\nimport { NestedTreeControl } from '@angular/cdk/tree';\nimport {\n  Component,\n  Input,\n  ViewChild,\n  ChangeDetectorRef,\n  TemplateRef,\n  inject,\n  input,\n  computed,\n  viewChild,\n  signal,\n  ElementRef,\n  ChangeDetectionStrategy,\n} from '@angular/core';\nimport { MatDrawer, MatSidenavModule } from '@angular/material/sidenav';\nimport { MatTreeNestedDataSource, MatTreeModule } from '@angular/material/tree';\nimport { Router, RouterLink } from '@angular/router';\nimport PS from 'perfect-scrollbar';\n\nimport { SDKTranslatePipe } from '../../../Shared/pipes/translate.pipe';\nimport { ImageLoaderDirective } from '../../../Shared/directives/index.directive';\nimport { MatMenuModule } from '@angular/material/menu';\nimport { MatIconModule } from '@angular/material/icon';\nimport { MatButtonModule } from '@angular/material/button';\nimport { MatToolbar, MatToolbarModule } from '@angular/material/toolbar';\nimport { NgClass, NgIf, AsyncPipe, CommonModule } from '@angular/common';\nimport { UtilityService } from '../../../Services/utility.service';\nimport { IObjectLiteral } from '../../models/index.model';\nimport { ETSMenuItem } from '../../models/IMenuItem';\n\n@Component({\n  selector: 'vertical-nav',\n  templateUrl: './vertical-nav.component.html',\n  styleUrls: ['./vertical-nav.component.scss'],\n\n  standalone: true,\n  imports: [\n    MatToolbarModule,\n    MatButtonModule,\n    MatIconModule,\n    MatSidenavModule,\n    MatTreeModule,\n    RouterLink,\n    MatMenuModule,\n    ImageLoaderDirective,\n    CommonModule,\n    SDKTranslatePipe,\n  ],\n})\nexport class VerticalNavComponent {\n  public uS = inject(UtilityService);\n  public router = inject(Router);\n\n  shouldShowChildInput = input<(_: number, node: IMenuItem) => boolean>();\n  shouldShowChild = computed<(_: number, node: IMenuItem) => boolean>(\n    () => this.shouldShowChildInput() || (() => true),\n  );\n  readonly toolbarTitle = input<string>();\n  readonly toolbarLogo = input<string>();\n  readonly toolbarLogoStyle = input<IObjectLiteral>();\n  readonly fixedTopGap = input<number>();\n  readonly sidenavTemplate = input<TemplateRef<any>>();\n  readonly toolbarTemplate = input<TemplateRef<any>>();\n  /**This only works when the toolbarTemplate is not set */\n  readonly toolbarEndTemplate = input<TemplateRef<any> | undefined>();\n  readonly bodyTemplate = input<TemplateRef<any>>();\n  readonly useToolbar = input<boolean>(true);\n  readonly showMenu = input<boolean>();\n  readonly menuItems = input<IMenuItem[]>();\n\n  readonly dataSource = computed(() => {\n    const ds = new MatTreeNestedDataSource<IMenuItem>(),\n      menu = this.menuItems();\n\n    if (!menu?.length) return ds;\n    menu.forEach((x) => (x.level = 0));\n    ds.data = menu;\n    return ds;\n  });\n\n  readonly id = signal('matSideNav' + this.uS.genRandomID);\n  readonly treeControl = signal(new NestedTreeControl<IMenuItem>((node) => node.subs));\n\n  readonly drawer = viewChild<MatDrawer | undefined>('snav');\n  readonly toolbarContRef = viewChild<ElementRef<HTMLDivElement>>('toolbarCont');\n\n  constructor() {}\n\n  ngAfterViewInit(): void {\n    const doc = document.querySelector<HTMLDivElement>(`#${this.id()} .mat-drawer-inner-container`);\n    if (doc) {\n      doc.style.position = 'relative';\n      const ps = new PS(doc, {\n        wheelSpeed: 0.5,\n        swipeEasing: false,\n        wheelPropagation: true,\n        minScrollbarLength: 40,\n      });\n    }\n  }\n\n  readonly hasChild = signal(\n    (_: number, node: IMenuItem) => node.hasSub && this.shouldShowChild()(_, node),\n  );\n}\ntype IMenuItem = Partial<ETSMenuItem>;\n// interface IETSMenuItem {\n//   label: string;\n//   link: string;\n//   hasSub?: boolean;\n//   icon?: string;\n//   level?: number;\n//   id?: string;\n//   children?: IETSMenuItem[];\n// }\n","<div class=\"vertical-nav\" [class.vertical-nav-is-mobile]=\"uS.isMobileSignal()\">\n  @if (useToolbar()) {\n    <div #toolbarCont class=\"vertical-nav-toolbar\">\n      @if (toolbarTemplate()) {\n        <ng-container *ngTemplateOutlet=\"toolbarTemplate()\" />\n      } @else {\n        <mat-toolbar color=\"primary\" class=\"bg-primary d-flex justify-content-between\">\n          <div class=\"d-flex align-items-center w-100\">\n            @if (showMenu()) {\n              <button mat-icon-button (click)=\"snav.toggle()\">\n                <mat-icon>menu</mat-icon>\n              </button>\n            }\n            @if (toolbarLogo()) {\n              <img\n                [src]=\"toolbarLogo()\"\n                [ngStyle]=\"toolbarLogoStyle()\"\n                alt=\"toolbar logo\"\n                class=\"toolbarLogo\" />\n            }\n            @if (toolbarTitle()) {\n              <h1 class=\"vertical-nav-app-name\">{{ toolbarTitle() | appTranslate | async }}</h1>\n            }\n          </div>\n          <div>\n            @if (toolbarEndTemplate()) {\n              <ng-container *ngTemplateOutlet=\"toolbarEndTemplate()\" />\n            }\n          </div>\n        </mat-toolbar>\n      }\n    </div>\n  }\n\n  <mat-sidenav-container\n    [id]=\"id()\"\n    class=\"vertical-nav-container\"\n    [style.marginTop.px]=\"\n      uS.isMobileSignal() ? fixedTopGap() || toolbarContRef()?.nativeElement?.offsetHeight : 0\n    \">\n    <mat-sidenav\n      class=\"side-w\"\n      [ngClass]=\"{ mobile: this.uS.isMobileSignal() }\"\n      #snav\n      [mode]=\"uS.isMobileSignal() ? 'over' : 'side'\"\n      [opened]=\"!uS.isMobileSignal() && showMenu()\"\n      [fixedInViewport]=\"uS.isMobileSignal()\"\n      [fixedTopGap]=\"\n        uS.isMobileSignal() ? fixedTopGap() || toolbarContRef()?.nativeElement?.offsetHeight : 0\n      \"\n      [hidden]=\"!showMenu()\">\n      <div class=\"vertical-nav-side-padding\">\n        @if (sidenavTemplate()) {\n          <ng-container *ngTemplateOutlet=\"sidenavTemplate()\" />\n        } @else {\n          <mat-tree\n            [dataSource]=\"dataSource()\"\n            [treeControl]=\"treeControl()\"\n            class=\"vertical-nav-tree\">\n            <!-- This is the tree node template for leaf nodes -->\n            <!-- This is the tree node template for expandable nodes -->\n            <mat-nested-tree-node\n              *matTreeNodeDef=\"let node; when: hasChild()\"\n              class=\"expandable-node\">\n              <div class=\"mat-tree-node\">\n                <button\n                  matTreeNodeToggle\n                  [attr.aria-label]=\"'Toggle ' + node.name\"\n                  class=\"menu-btn level{{ node.level }}\">\n                  <div class=\"row\">\n                    <div class=\"col\">\n                      <span class=\"{{ node.icon }}\"></span>\n                      {{ node.label | appTranslate | async }}\n                    </div>\n                    <div class=\"col-auto\">\n                      <span\n                        class=\"fa {{\n                          treeControl().isExpanded(node) ? 'fa-chevron-down' : 'fa-chevron-right'\n                        }} \"></span>\n                    </div>\n                  </div>\n                </button>\n              </div>\n              <div>\n                <!-- There is inline padding applied to this div using styles.\n            This padding value depends on the mat-icon-button width.  -->\n                <div\n                  [class.vertical-nav-tree-invisible]=\"!treeControl().isExpanded(node)\"\n                  role=\"group\"\n                  class=\"group\">\n                  <ng-container matTreeNodeOutlet />\n                </div>\n              </div>\n            </mat-nested-tree-node>\n            <!-- There is inline padding applied to this node using styles.\n    This padding value depends on the mat-icon-button width. -->\n            <mat-tree-node\n              *matTreeNodeDef=\"let node; when: shouldShowChild()\"\n              matTreeNodeToggle\n              class=\"single-node level{{ node.level }}\">\n              <a [routerLink]=\"node.link\" class=\"d-block w-100\">\n                <span class=\"{{ node.icon }}\"></span>\n                {{ node.label | appTranslate | async }}\n              </a>\n            </mat-tree-node>\n            <mat-tree-node\n              *matTreeNodeDef=\"let node\"\n              matTreeNodeToggle\n              class=\"single-node restricted level{{ node.level }}\" />\n          </mat-tree>\n        }\n      </div>\n    </mat-sidenav>\n\n    <mat-sidenav-content class=\"vertical-nav-body\">\n      @if (bodyTemplate()) {\n        <ng-container *ngTemplateOutlet=\"bodyTemplate()\" />\n      } @else {\n        <ng-content />\n      }\n    </mat-sidenav-content>\n  </mat-sidenav-container>\n</div>\n"]}
|
|
@@ -12369,9 +12369,9 @@ class FormGeneratorComponent extends BaseFormGenerator {
|
|
|
12369
12369
|
if (scheme.debug)
|
|
12370
12370
|
debugger;
|
|
12371
12371
|
this.subs[scheme.field?.toString() + '_onFormChange'] = this.formValue$
|
|
12372
|
-
.pipe(scheme.onFormChangePipeOperators())
|
|
12372
|
+
.pipe(scheme.onFormChangePipeOperators ? scheme.onFormChangePipeOperators() : tap())
|
|
12373
12373
|
.subscribe((r) => {
|
|
12374
|
-
scheme.onFormChange(
|
|
12374
|
+
scheme.onFormChange(r, r?.[scheme.field], this);
|
|
12375
12375
|
});
|
|
12376
12376
|
}
|
|
12377
12377
|
}
|
|
@@ -16210,7 +16210,7 @@ class VerticalNavComponent {
|
|
|
16210
16210
|
}
|
|
16211
16211
|
}
|
|
16212
16212
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: VerticalNavComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
16213
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.1.0", type: VerticalNavComponent, isStandalone: true, selector: "vertical-nav", inputs: { shouldShowChildInput: { classPropertyName: "shouldShowChildInput", publicName: "shouldShowChildInput", isSignal: true, isRequired: false, transformFunction: null }, toolbarTitle: { classPropertyName: "toolbarTitle", publicName: "toolbarTitle", isSignal: true, isRequired: false, transformFunction: null }, toolbarLogo: { classPropertyName: "toolbarLogo", publicName: "toolbarLogo", isSignal: true, isRequired: false, transformFunction: null }, toolbarLogoStyle: { classPropertyName: "toolbarLogoStyle", publicName: "toolbarLogoStyle", isSignal: true, isRequired: false, transformFunction: null }, fixedTopGap: { classPropertyName: "fixedTopGap", publicName: "fixedTopGap", isSignal: true, isRequired: false, transformFunction: null }, sidenavTemplate: { classPropertyName: "sidenavTemplate", publicName: "sidenavTemplate", isSignal: true, isRequired: false, transformFunction: null }, toolbarTemplate: { classPropertyName: "toolbarTemplate", publicName: "toolbarTemplate", isSignal: true, isRequired: false, transformFunction: null }, toolbarEndTemplate: { classPropertyName: "toolbarEndTemplate", publicName: "toolbarEndTemplate", isSignal: true, isRequired: false, transformFunction: null }, bodyTemplate: { classPropertyName: "bodyTemplate", publicName: "bodyTemplate", isSignal: true, isRequired: false, transformFunction: null }, useToolbar: { classPropertyName: "useToolbar", publicName: "useToolbar", isSignal: true, isRequired: false, transformFunction: null }, showMenu: { classPropertyName: "showMenu", publicName: "showMenu", isSignal: true, isRequired: false, transformFunction: null }, menuItems: { classPropertyName: "menuItems", publicName: "menuItems", isSignal: true, isRequired: false, transformFunction: null } }, viewQueries: [{ propertyName: "drawer", first: true, predicate: ["snav"], descendants: true, isSignal: true }, { propertyName: "toolbarContRef", first: true, predicate: ["toolbarCont"], descendants: true, isSignal: true }], ngImport: i0, template: "<div class=\"vertical-nav\" [class.vertical-nav-is-mobile]=\"uS.isMobileSignal()\">\n @if (useToolbar()) {\n <div #toolbarCont class=\"vertical-nav-toolbar\">\n @if (toolbarTemplate()) {\n <ng-container *ngTemplateOutlet=\"toolbarTemplate()\" />\n } @else {\n <mat-toolbar color=\"primary\" class=\"bg-primary d-flex justify-content-between\">\n <div class=\"d-flex align-items-center w-100\">\n <button mat-icon-button (click)=\"snav.toggle()\">\n <mat-icon>menu</mat-icon>\n </button>\n @if (toolbarLogo()) {\n <img\n [src]=\"toolbarLogo()\"\n [ngStyle]=\"toolbarLogoStyle()\"\n alt=\"toolbar logo\"\n class=\"toolbarLogo\" />\n }\n @if (toolbarTitle()) {\n <h1 class=\"vertical-nav-app-name\">{{ toolbarTitle() | appTranslate | async }}</h1>\n }\n </div>\n <div>\n @if (toolbarEndTemplate()) {\n <ng-container *ngTemplateOutlet=\"toolbarEndTemplate()\" />\n }\n </div>\n </mat-toolbar>\n }\n </div>\n }\n\n <mat-sidenav-container\n [id]=\"id()\"\n class=\"vertical-nav-container\"\n [style.marginTop.px]=\"\n uS.isMobileSignal() ? fixedTopGap() || toolbarContRef()?.nativeElement?.offsetHeight : 0\n \">\n <mat-sidenav\n class=\"side-w\"\n [ngClass]=\"{ mobile: this.uS.isMobileSignal() }\"\n #snav\n [mode]=\"uS.isMobileSignal() ? 'over' : 'side'\"\n [opened]=\"!uS.isMobileSignal() && showMenu()\"\n [fixedInViewport]=\"uS.isMobileSignal()\"\n [fixedTopGap]=\" uS.isMobileSignal() ? fixedTopGap() || toolbarContRef()?.nativeElement?.offsetHeight : 0\"\n [hidden]=\"!showMenu()\">\n <div class=\"vertical-nav-side-padding\">\n @if (sidenavTemplate()) {\n <ng-container *ngTemplateOutlet=\"sidenavTemplate()\" />\n } @else {\n <mat-tree\n [dataSource]=\"dataSource()\"\n [treeControl]=\"treeControl()\"\n class=\"vertical-nav-tree\">\n <!-- This is the tree node template for leaf nodes -->\n <!-- This is the tree node template for expandable nodes -->\n <mat-nested-tree-node\n *matTreeNodeDef=\"let node; when: hasChild()\"\n class=\"expandable-node\">\n <div class=\"mat-tree-node\">\n <button\n matTreeNodeToggle\n [attr.aria-label]=\"'Toggle ' + node.name\"\n class=\"menu-btn level{{ node.level }}\">\n <div class=\"row\">\n <div class=\"col\">\n <span class=\"{{ node.icon }}\"></span>\n {{ node.label | appTranslate | async }}\n </div>\n <div class=\"col-auto\">\n <span\n class=\"fa {{\n treeControl().isExpanded(node) ? 'fa-chevron-down' : 'fa-chevron-right'\n }} \"></span>\n </div>\n </div>\n </button>\n </div>\n <div>\n <!-- There is inline padding applied to this div using styles.\n This padding value depends on the mat-icon-button width. -->\n <div\n [class.vertical-nav-tree-invisible]=\"!treeControl().isExpanded(node)\"\n role=\"group\"\n class=\"group\">\n <ng-container matTreeNodeOutlet />\n </div>\n </div>\n </mat-nested-tree-node>\n <!-- There is inline padding applied to this node using styles.\n This padding value depends on the mat-icon-button width. -->\n <mat-tree-node\n *matTreeNodeDef=\"let node; when: shouldShowChild()\"\n matTreeNodeToggle\n class=\"single-node level{{ node.level }}\">\n <a [routerLink]=\"node.link\" class=\"d-block w-100\">\n <span class=\"{{ node.icon }}\"></span>\n {{ node.label | appTranslate | async }}\n </a>\n </mat-tree-node>\n <mat-tree-node\n *matTreeNodeDef=\"let node\"\n matTreeNodeToggle\n class=\"single-node restricted level{{ node.level }}\" />\n </mat-tree>\n }\n </div>\n </mat-sidenav>\n\n <mat-sidenav-content class=\"vertical-nav-body\">\n @if (bodyTemplate()) {\n <ng-container *ngTemplateOutlet=\"bodyTemplate()\" />\n } @else {\n <ng-content />\n }\n </mat-sidenav-content>\n </mat-sidenav-container>\n</div>\n", styles: [".menu{background-color:#fff}.vertical-nav{display:flex;flex-direction:column;height:100%}.vertical-nav.fullScreen{position:absolute;inset:0}.toolbarLogo{--toolbarLogoDimen: 50px;height:var(--toolbarLogoDimen)}h1.vertical-nav-app-name{margin-left:8px}.vertical-nav-container{flex:1}.vertical-nav-is-mobile .vertical-nav-toolbar{position:fixed;z-index:2;width:100%}.vertical-nav-is-mobile .vertical-nav-container{flex:1 0 auto}.mat-drawer-container{background-color:unset}.mat-drawer-content{background-color:#e9e9e9}.expandable-node button{width:100%;border-radius:0;text-align:left}.single-node button{width:24px}.level0{border-bottom:1px solid rgba(141,141,141,.231372549)}.side-w{width:auto;margin:10px;border-radius:16px}.side-w.mobile{width:90%;margin:0;border-radius:0}.vertical-nav-tree-invisible{display:none}.vertical-nav-tree ul,.vertical-nav-tree li{margin-top:0;margin-bottom:0;list-style-type:none}.vertical-nav-tree div[role=group]{border-radius:var(--borderRadius);background-color:#ffffff57}.vertical-nav-tree div[role=group]>.mat-tree-node{padding:10px 20px}a{color:inherit}.restricted{display:none}mat-sidenav.mat-drawer.mat-drawer-opened.mat-drawer-side.mat-sidenav{min-width:200px;overflow-x:auto;white-space:nowrap}.menu-btn{background-color:#ffffff57;border-radius:var(--borderRadius)!important;padding:10px 20px;color:#2b2b2b;border:none}.expandable-node .group{border:1px solid rgba(0,0,0,.11)!important}.profile{position:sticky;bottom:0;right:0;left:0;background-color:var(--primary);background-image:linear-gradient(45deg,#ffffffa8,#ffffffa8);padding:10px}.vertical-nav-side-padding{padding:var(--space-8)}\n"], dependencies: [{ kind: "ngmodule", type: MatToolbarModule }, { kind: "component", type: i1$6.MatToolbar, selector: "mat-toolbar", inputs: ["color"], exportAs: ["matToolbar"] }, { kind: "ngmodule", type: MatButtonModule }, { kind: "component", type: i2$3.MatIconButton, selector: "button[mat-icon-button]", exportAs: ["matButton"] }, { kind: "ngmodule", type: MatIconModule }, { kind: "component", type: i9$1.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "ngmodule", type: MatSidenavModule }, { kind: "component", type: i4.MatSidenav, selector: "mat-sidenav", inputs: ["fixedInViewport", "fixedTopGap", "fixedBottomGap"], exportAs: ["matSidenav"] }, { kind: "component", type: i4.MatSidenavContainer, selector: "mat-sidenav-container", exportAs: ["matSidenavContainer"] }, { kind: "component", type: i4.MatSidenavContent, selector: "mat-sidenav-content" }, { kind: "ngmodule", type: MatTreeModule }, { kind: "directive", type: i5$1.MatNestedTreeNode, selector: "mat-nested-tree-node", inputs: ["matNestedTreeNode", "disabled", "tabIndex"], exportAs: ["matNestedTreeNode"] }, { kind: "directive", type: i5$1.MatTreeNodeDef, selector: "[matTreeNodeDef]", inputs: ["matTreeNodeDefWhen", "matTreeNode"] }, { kind: "directive", type: i5$1.MatTreeNodeToggle, selector: "[matTreeNodeToggle]", inputs: ["matTreeNodeToggleRecursive"] }, { kind: "component", type: i5$1.MatTree, selector: "mat-tree", exportAs: ["matTree"] }, { kind: "directive", type: i5$1.MatTreeNode, selector: "mat-tree-node", inputs: ["disabled", "tabIndex"], exportAs: ["matTreeNode"] }, { kind: "directive", type: i5$1.MatTreeNodeOutlet, selector: "[matTreeNodeOutlet]" }, { kind: "directive", type: RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "info", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "ngmodule", type: MatMenuModule }, { kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "pipe", type: SDKTranslatePipe, name: "appTranslate" }] }); }
|
|
16213
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.1.0", type: VerticalNavComponent, isStandalone: true, selector: "vertical-nav", inputs: { shouldShowChildInput: { classPropertyName: "shouldShowChildInput", publicName: "shouldShowChildInput", isSignal: true, isRequired: false, transformFunction: null }, toolbarTitle: { classPropertyName: "toolbarTitle", publicName: "toolbarTitle", isSignal: true, isRequired: false, transformFunction: null }, toolbarLogo: { classPropertyName: "toolbarLogo", publicName: "toolbarLogo", isSignal: true, isRequired: false, transformFunction: null }, toolbarLogoStyle: { classPropertyName: "toolbarLogoStyle", publicName: "toolbarLogoStyle", isSignal: true, isRequired: false, transformFunction: null }, fixedTopGap: { classPropertyName: "fixedTopGap", publicName: "fixedTopGap", isSignal: true, isRequired: false, transformFunction: null }, sidenavTemplate: { classPropertyName: "sidenavTemplate", publicName: "sidenavTemplate", isSignal: true, isRequired: false, transformFunction: null }, toolbarTemplate: { classPropertyName: "toolbarTemplate", publicName: "toolbarTemplate", isSignal: true, isRequired: false, transformFunction: null }, toolbarEndTemplate: { classPropertyName: "toolbarEndTemplate", publicName: "toolbarEndTemplate", isSignal: true, isRequired: false, transformFunction: null }, bodyTemplate: { classPropertyName: "bodyTemplate", publicName: "bodyTemplate", isSignal: true, isRequired: false, transformFunction: null }, useToolbar: { classPropertyName: "useToolbar", publicName: "useToolbar", isSignal: true, isRequired: false, transformFunction: null }, showMenu: { classPropertyName: "showMenu", publicName: "showMenu", isSignal: true, isRequired: false, transformFunction: null }, menuItems: { classPropertyName: "menuItems", publicName: "menuItems", isSignal: true, isRequired: false, transformFunction: null } }, viewQueries: [{ propertyName: "drawer", first: true, predicate: ["snav"], descendants: true, isSignal: true }, { propertyName: "toolbarContRef", first: true, predicate: ["toolbarCont"], descendants: true, isSignal: true }], ngImport: i0, template: "<div class=\"vertical-nav\" [class.vertical-nav-is-mobile]=\"uS.isMobileSignal()\">\n @if (useToolbar()) {\n <div #toolbarCont class=\"vertical-nav-toolbar\">\n @if (toolbarTemplate()) {\n <ng-container *ngTemplateOutlet=\"toolbarTemplate()\" />\n } @else {\n <mat-toolbar color=\"primary\" class=\"bg-primary d-flex justify-content-between\">\n <div class=\"d-flex align-items-center w-100\">\n @if (showMenu()) {\n <button mat-icon-button (click)=\"snav.toggle()\">\n <mat-icon>menu</mat-icon>\n </button>\n }\n @if (toolbarLogo()) {\n <img\n [src]=\"toolbarLogo()\"\n [ngStyle]=\"toolbarLogoStyle()\"\n alt=\"toolbar logo\"\n class=\"toolbarLogo\" />\n }\n @if (toolbarTitle()) {\n <h1 class=\"vertical-nav-app-name\">{{ toolbarTitle() | appTranslate | async }}</h1>\n }\n </div>\n <div>\n @if (toolbarEndTemplate()) {\n <ng-container *ngTemplateOutlet=\"toolbarEndTemplate()\" />\n }\n </div>\n </mat-toolbar>\n }\n </div>\n }\n\n <mat-sidenav-container\n [id]=\"id()\"\n class=\"vertical-nav-container\"\n [style.marginTop.px]=\"\n uS.isMobileSignal() ? fixedTopGap() || toolbarContRef()?.nativeElement?.offsetHeight : 0\n \">\n <mat-sidenav\n class=\"side-w\"\n [ngClass]=\"{ mobile: this.uS.isMobileSignal() }\"\n #snav\n [mode]=\"uS.isMobileSignal() ? 'over' : 'side'\"\n [opened]=\"!uS.isMobileSignal() && showMenu()\"\n [fixedInViewport]=\"uS.isMobileSignal()\"\n [fixedTopGap]=\"\n uS.isMobileSignal() ? fixedTopGap() || toolbarContRef()?.nativeElement?.offsetHeight : 0\n \"\n [hidden]=\"!showMenu()\">\n <div class=\"vertical-nav-side-padding\">\n @if (sidenavTemplate()) {\n <ng-container *ngTemplateOutlet=\"sidenavTemplate()\" />\n } @else {\n <mat-tree\n [dataSource]=\"dataSource()\"\n [treeControl]=\"treeControl()\"\n class=\"vertical-nav-tree\">\n <!-- This is the tree node template for leaf nodes -->\n <!-- This is the tree node template for expandable nodes -->\n <mat-nested-tree-node\n *matTreeNodeDef=\"let node; when: hasChild()\"\n class=\"expandable-node\">\n <div class=\"mat-tree-node\">\n <button\n matTreeNodeToggle\n [attr.aria-label]=\"'Toggle ' + node.name\"\n class=\"menu-btn level{{ node.level }}\">\n <div class=\"row\">\n <div class=\"col\">\n <span class=\"{{ node.icon }}\"></span>\n {{ node.label | appTranslate | async }}\n </div>\n <div class=\"col-auto\">\n <span\n class=\"fa {{\n treeControl().isExpanded(node) ? 'fa-chevron-down' : 'fa-chevron-right'\n }} \"></span>\n </div>\n </div>\n </button>\n </div>\n <div>\n <!-- There is inline padding applied to this div using styles.\n This padding value depends on the mat-icon-button width. -->\n <div\n [class.vertical-nav-tree-invisible]=\"!treeControl().isExpanded(node)\"\n role=\"group\"\n class=\"group\">\n <ng-container matTreeNodeOutlet />\n </div>\n </div>\n </mat-nested-tree-node>\n <!-- There is inline padding applied to this node using styles.\n This padding value depends on the mat-icon-button width. -->\n <mat-tree-node\n *matTreeNodeDef=\"let node; when: shouldShowChild()\"\n matTreeNodeToggle\n class=\"single-node level{{ node.level }}\">\n <a [routerLink]=\"node.link\" class=\"d-block w-100\">\n <span class=\"{{ node.icon }}\"></span>\n {{ node.label | appTranslate | async }}\n </a>\n </mat-tree-node>\n <mat-tree-node\n *matTreeNodeDef=\"let node\"\n matTreeNodeToggle\n class=\"single-node restricted level{{ node.level }}\" />\n </mat-tree>\n }\n </div>\n </mat-sidenav>\n\n <mat-sidenav-content class=\"vertical-nav-body\">\n @if (bodyTemplate()) {\n <ng-container *ngTemplateOutlet=\"bodyTemplate()\" />\n } @else {\n <ng-content />\n }\n </mat-sidenav-content>\n </mat-sidenav-container>\n</div>\n", styles: [".menu{background-color:#fff}.vertical-nav{display:flex;flex-direction:column;height:100%}.vertical-nav.fullScreen{position:absolute;inset:0}.toolbarLogo{--toolbarLogoDimen: 50px;height:var(--toolbarLogoDimen)}h1.vertical-nav-app-name{margin-left:8px}.vertical-nav-container{flex:1}.vertical-nav-is-mobile .vertical-nav-toolbar{position:fixed;z-index:2;width:100%}.vertical-nav-is-mobile .vertical-nav-container{flex:1 0 auto}.mat-drawer-container{background-color:unset}.mat-drawer-content{background-color:#e9e9e9}.expandable-node button{width:100%;border-radius:0;text-align:left}.single-node button{width:24px}.level0{border-bottom:1px solid rgba(141,141,141,.231372549)}.side-w{width:auto;margin:10px;border-radius:16px}.side-w.mobile{width:90%;margin:0;border-radius:0}.vertical-nav-tree-invisible{display:none}.vertical-nav-tree ul,.vertical-nav-tree li{margin-top:0;margin-bottom:0;list-style-type:none}.vertical-nav-tree div[role=group]{border-radius:var(--borderRadius);background-color:#ffffff57}.vertical-nav-tree div[role=group]>.mat-tree-node{padding:10px 20px}a{color:inherit}.restricted{display:none}mat-sidenav.mat-drawer.mat-drawer-opened.mat-drawer-side.mat-sidenav{min-width:200px;overflow-x:auto;white-space:nowrap}.menu-btn{background-color:#ffffff57;border-radius:var(--borderRadius)!important;padding:10px 20px;color:#2b2b2b;border:none}.expandable-node .group{border:1px solid rgba(0,0,0,.11)!important}.profile{position:sticky;bottom:0;right:0;left:0;background-color:var(--primary);background-image:linear-gradient(45deg,#ffffffa8,#ffffffa8);padding:10px}.vertical-nav-side-padding{padding:var(--space-8)}\n"], dependencies: [{ kind: "ngmodule", type: MatToolbarModule }, { kind: "component", type: i1$6.MatToolbar, selector: "mat-toolbar", inputs: ["color"], exportAs: ["matToolbar"] }, { kind: "ngmodule", type: MatButtonModule }, { kind: "component", type: i2$3.MatIconButton, selector: "button[mat-icon-button]", exportAs: ["matButton"] }, { kind: "ngmodule", type: MatIconModule }, { kind: "component", type: i9$1.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "ngmodule", type: MatSidenavModule }, { kind: "component", type: i4.MatSidenav, selector: "mat-sidenav", inputs: ["fixedInViewport", "fixedTopGap", "fixedBottomGap"], exportAs: ["matSidenav"] }, { kind: "component", type: i4.MatSidenavContainer, selector: "mat-sidenav-container", exportAs: ["matSidenavContainer"] }, { kind: "component", type: i4.MatSidenavContent, selector: "mat-sidenav-content" }, { kind: "ngmodule", type: MatTreeModule }, { kind: "directive", type: i5$1.MatNestedTreeNode, selector: "mat-nested-tree-node", inputs: ["matNestedTreeNode", "disabled", "tabIndex"], exportAs: ["matNestedTreeNode"] }, { kind: "directive", type: i5$1.MatTreeNodeDef, selector: "[matTreeNodeDef]", inputs: ["matTreeNodeDefWhen", "matTreeNode"] }, { kind: "directive", type: i5$1.MatTreeNodeToggle, selector: "[matTreeNodeToggle]", inputs: ["matTreeNodeToggleRecursive"] }, { kind: "component", type: i5$1.MatTree, selector: "mat-tree", exportAs: ["matTree"] }, { kind: "directive", type: i5$1.MatTreeNode, selector: "mat-tree-node", inputs: ["disabled", "tabIndex"], exportAs: ["matTreeNode"] }, { kind: "directive", type: i5$1.MatTreeNodeOutlet, selector: "[matTreeNodeOutlet]" }, { kind: "directive", type: RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "info", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }, { kind: "ngmodule", type: MatMenuModule }, { kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "pipe", type: SDKTranslatePipe, name: "appTranslate" }] }); }
|
|
16214
16214
|
}
|
|
16215
16215
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.0", ngImport: i0, type: VerticalNavComponent, decorators: [{
|
|
16216
16216
|
type: Component,
|
|
@@ -16225,7 +16225,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.0", ngImpor
|
|
|
16225
16225
|
ImageLoaderDirective,
|
|
16226
16226
|
CommonModule,
|
|
16227
16227
|
SDKTranslatePipe,
|
|
16228
|
-
], template: "<div class=\"vertical-nav\" [class.vertical-nav-is-mobile]=\"uS.isMobileSignal()\">\n @if (useToolbar()) {\n <div #toolbarCont class=\"vertical-nav-toolbar\">\n @if (toolbarTemplate()) {\n <ng-container *ngTemplateOutlet=\"toolbarTemplate()\" />\n } @else {\n <mat-toolbar color=\"primary\" class=\"bg-primary d-flex justify-content-between\">\n <div class=\"d-flex align-items-center w-100\">\n <button mat-icon-button (click)=\"snav.toggle()\">\n
|
|
16228
|
+
], template: "<div class=\"vertical-nav\" [class.vertical-nav-is-mobile]=\"uS.isMobileSignal()\">\n @if (useToolbar()) {\n <div #toolbarCont class=\"vertical-nav-toolbar\">\n @if (toolbarTemplate()) {\n <ng-container *ngTemplateOutlet=\"toolbarTemplate()\" />\n } @else {\n <mat-toolbar color=\"primary\" class=\"bg-primary d-flex justify-content-between\">\n <div class=\"d-flex align-items-center w-100\">\n @if (showMenu()) {\n <button mat-icon-button (click)=\"snav.toggle()\">\n <mat-icon>menu</mat-icon>\n </button>\n }\n @if (toolbarLogo()) {\n <img\n [src]=\"toolbarLogo()\"\n [ngStyle]=\"toolbarLogoStyle()\"\n alt=\"toolbar logo\"\n class=\"toolbarLogo\" />\n }\n @if (toolbarTitle()) {\n <h1 class=\"vertical-nav-app-name\">{{ toolbarTitle() | appTranslate | async }}</h1>\n }\n </div>\n <div>\n @if (toolbarEndTemplate()) {\n <ng-container *ngTemplateOutlet=\"toolbarEndTemplate()\" />\n }\n </div>\n </mat-toolbar>\n }\n </div>\n }\n\n <mat-sidenav-container\n [id]=\"id()\"\n class=\"vertical-nav-container\"\n [style.marginTop.px]=\"\n uS.isMobileSignal() ? fixedTopGap() || toolbarContRef()?.nativeElement?.offsetHeight : 0\n \">\n <mat-sidenav\n class=\"side-w\"\n [ngClass]=\"{ mobile: this.uS.isMobileSignal() }\"\n #snav\n [mode]=\"uS.isMobileSignal() ? 'over' : 'side'\"\n [opened]=\"!uS.isMobileSignal() && showMenu()\"\n [fixedInViewport]=\"uS.isMobileSignal()\"\n [fixedTopGap]=\"\n uS.isMobileSignal() ? fixedTopGap() || toolbarContRef()?.nativeElement?.offsetHeight : 0\n \"\n [hidden]=\"!showMenu()\">\n <div class=\"vertical-nav-side-padding\">\n @if (sidenavTemplate()) {\n <ng-container *ngTemplateOutlet=\"sidenavTemplate()\" />\n } @else {\n <mat-tree\n [dataSource]=\"dataSource()\"\n [treeControl]=\"treeControl()\"\n class=\"vertical-nav-tree\">\n <!-- This is the tree node template for leaf nodes -->\n <!-- This is the tree node template for expandable nodes -->\n <mat-nested-tree-node\n *matTreeNodeDef=\"let node; when: hasChild()\"\n class=\"expandable-node\">\n <div class=\"mat-tree-node\">\n <button\n matTreeNodeToggle\n [attr.aria-label]=\"'Toggle ' + node.name\"\n class=\"menu-btn level{{ node.level }}\">\n <div class=\"row\">\n <div class=\"col\">\n <span class=\"{{ node.icon }}\"></span>\n {{ node.label | appTranslate | async }}\n </div>\n <div class=\"col-auto\">\n <span\n class=\"fa {{\n treeControl().isExpanded(node) ? 'fa-chevron-down' : 'fa-chevron-right'\n }} \"></span>\n </div>\n </div>\n </button>\n </div>\n <div>\n <!-- There is inline padding applied to this div using styles.\n This padding value depends on the mat-icon-button width. -->\n <div\n [class.vertical-nav-tree-invisible]=\"!treeControl().isExpanded(node)\"\n role=\"group\"\n class=\"group\">\n <ng-container matTreeNodeOutlet />\n </div>\n </div>\n </mat-nested-tree-node>\n <!-- There is inline padding applied to this node using styles.\n This padding value depends on the mat-icon-button width. -->\n <mat-tree-node\n *matTreeNodeDef=\"let node; when: shouldShowChild()\"\n matTreeNodeToggle\n class=\"single-node level{{ node.level }}\">\n <a [routerLink]=\"node.link\" class=\"d-block w-100\">\n <span class=\"{{ node.icon }}\"></span>\n {{ node.label | appTranslate | async }}\n </a>\n </mat-tree-node>\n <mat-tree-node\n *matTreeNodeDef=\"let node\"\n matTreeNodeToggle\n class=\"single-node restricted level{{ node.level }}\" />\n </mat-tree>\n }\n </div>\n </mat-sidenav>\n\n <mat-sidenav-content class=\"vertical-nav-body\">\n @if (bodyTemplate()) {\n <ng-container *ngTemplateOutlet=\"bodyTemplate()\" />\n } @else {\n <ng-content />\n }\n </mat-sidenav-content>\n </mat-sidenav-container>\n</div>\n", styles: [".menu{background-color:#fff}.vertical-nav{display:flex;flex-direction:column;height:100%}.vertical-nav.fullScreen{position:absolute;inset:0}.toolbarLogo{--toolbarLogoDimen: 50px;height:var(--toolbarLogoDimen)}h1.vertical-nav-app-name{margin-left:8px}.vertical-nav-container{flex:1}.vertical-nav-is-mobile .vertical-nav-toolbar{position:fixed;z-index:2;width:100%}.vertical-nav-is-mobile .vertical-nav-container{flex:1 0 auto}.mat-drawer-container{background-color:unset}.mat-drawer-content{background-color:#e9e9e9}.expandable-node button{width:100%;border-radius:0;text-align:left}.single-node button{width:24px}.level0{border-bottom:1px solid rgba(141,141,141,.231372549)}.side-w{width:auto;margin:10px;border-radius:16px}.side-w.mobile{width:90%;margin:0;border-radius:0}.vertical-nav-tree-invisible{display:none}.vertical-nav-tree ul,.vertical-nav-tree li{margin-top:0;margin-bottom:0;list-style-type:none}.vertical-nav-tree div[role=group]{border-radius:var(--borderRadius);background-color:#ffffff57}.vertical-nav-tree div[role=group]>.mat-tree-node{padding:10px 20px}a{color:inherit}.restricted{display:none}mat-sidenav.mat-drawer.mat-drawer-opened.mat-drawer-side.mat-sidenav{min-width:200px;overflow-x:auto;white-space:nowrap}.menu-btn{background-color:#ffffff57;border-radius:var(--borderRadius)!important;padding:10px 20px;color:#2b2b2b;border:none}.expandable-node .group{border:1px solid rgba(0,0,0,.11)!important}.profile{position:sticky;bottom:0;right:0;left:0;background-color:var(--primary);background-image:linear-gradient(45deg,#ffffffa8,#ffffffa8);padding:10px}.vertical-nav-side-padding{padding:var(--space-8)}\n"] }]
|
|
16229
16229
|
}], ctorParameters: () => [] });
|
|
16230
16230
|
|
|
16231
16231
|
class TextAreaModalComponent {
|