@alauda-fe/common 1.4.35 → 1.4.36
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/core/pipes/sanitize.pipe.d.ts +1 -1
- package/custom-columns-setting/component.d.ts +2 -1
- package/esm2022/core/abstract/base-nested-form-control.mjs +10 -7
- package/esm2022/core/pipes/sanitize.pipe.mjs +9 -4
- package/esm2022/custom-columns-setting/component.mjs +11 -9
- package/esm2022/page-scaffold/page-header/common-layout/common-layout.module.mjs +4 -5
- package/esm2022/page-scaffold/page-header/common-layout/product-select/component.mjs +4 -5
- package/package.json +1 -1
|
@@ -4,7 +4,7 @@ import * as i0 from "@angular/core";
|
|
|
4
4
|
export declare class SanitizePipe implements PipeTransform {
|
|
5
5
|
private readonly sanitizer;
|
|
6
6
|
constructor(sanitizer: DomSanitizer);
|
|
7
|
-
transform(value: string, type?: 'html' | 'url'): SafeHtml;
|
|
7
|
+
transform(value: string, type?: 'html' | 'url' | 'style'): SafeHtml | string | null;
|
|
8
8
|
static ɵfac: i0.ɵɵFactoryDeclaration<SanitizePipe, never>;
|
|
9
9
|
static ɵpipe: i0.ɵɵPipeDeclaration<SanitizePipe, "aclSanitize", true>;
|
|
10
10
|
}
|
|
@@ -4,6 +4,7 @@ import * as i0 from "@angular/core";
|
|
|
4
4
|
export declare class TableCustomColumnsComponent implements OnInit {
|
|
5
5
|
options: string[];
|
|
6
6
|
ignoreOptions: string[];
|
|
7
|
+
labels?: Record<string, string>;
|
|
7
8
|
columns?: string[];
|
|
8
9
|
marginLeft: string;
|
|
9
10
|
id: string;
|
|
@@ -12,5 +13,5 @@ export declare class TableCustomColumnsComponent implements OnInit {
|
|
|
12
13
|
ngOnInit(): void;
|
|
13
14
|
selectedChanged(event: string[]): void;
|
|
14
15
|
static ɵfac: i0.ɵɵFactoryDeclaration<TableCustomColumnsComponent, never>;
|
|
15
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<TableCustomColumnsComponent, "acl-table-column-setting", never, { "options": { "alias": "options"; "required": false; }; "ignoreOptions": { "alias": "ignoreOptions"; "required": false; }; "columns": { "alias": "columns"; "required": false; }; "marginLeft": { "alias": "marginLeft"; "required": false; }; "id": { "alias": "id"; "required": false; }; }, { "columnsChange": "columnsChange"; }, never, never, true, never>;
|
|
16
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<TableCustomColumnsComponent, "acl-table-column-setting", never, { "options": { "alias": "options"; "required": false; }; "ignoreOptions": { "alias": "ignoreOptions"; "required": false; }; "labels": { "alias": "labels"; "required": false; }; "columns": { "alias": "columns"; "required": false; }; "marginLeft": { "alias": "marginLeft"; "required": false; }; "id": { "alias": "id"; "required": false; }; }, { "columnsChange": "columnsChange"; }, never, never, true, never>;
|
|
16
17
|
}
|
|
@@ -77,12 +77,15 @@ export class BaseNestedFormControl {
|
|
|
77
77
|
this.cdr.markForCheck();
|
|
78
78
|
}
|
|
79
79
|
validate(_control) {
|
|
80
|
-
const getErrors = () =>
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
80
|
+
const getErrors = () => {
|
|
81
|
+
const errors = this.controls?.reduce((acc, control) => {
|
|
82
|
+
if (control.errors) {
|
|
83
|
+
return mergeDeepRight(acc, control.name ? { [control.name]: control.errors } : control.errors);
|
|
84
|
+
}
|
|
85
|
+
return acc;
|
|
86
|
+
}, {});
|
|
87
|
+
return errors && Object.keys(errors).length ? errors : null;
|
|
88
|
+
};
|
|
86
89
|
return this.asyncValidator
|
|
87
90
|
? combineLatest((this.controls?.toArray() ?? []).map(control => control.statusChanges.pipe(startWith(control.status)))).pipe(debounceTime(0), filter(statuses => statuses.includes('INVALID') || !statuses.includes('PENDING')), take(1), map(() => getErrors()), tap(() => {
|
|
88
91
|
this.cdr.markForCheck();
|
|
@@ -192,4 +195,4 @@ export function copyValue(from, to, mapper = identity) {
|
|
|
192
195
|
const toPath = parsePath(to);
|
|
193
196
|
return (object) => assocPath(toPath, mapper(path(fromPath, object)), object);
|
|
194
197
|
}
|
|
195
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base-nested-form-control.js","sourceRoot":"","sources":["../../../../../../libs/common/src/core/abstract/base-nested-form-control.ts"],"names":[],"mappings":"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","sourcesContent":["import { coerceAttrBoolean } from '@alauda/ui';\nimport {\n  AfterViewInit,\n  ChangeDetectorRef,\n  Directive,\n  inject,\n  Input,\n  OnDestroy,\n  QueryList,\n  ViewChildren,\n} from '@angular/core';\nimport {\n  AbstractControl,\n  ControlValueAccessor,\n  FormGroupDirective,\n  NgControl,\n  NgForm,\n  ValidationErrors,\n} from '@angular/forms';\nimport { assocPath, identity, mergeDeepRight, path } from 'ramda';\nimport {\n  ReplaySubject,\n  startWith,\n  switchMap,\n  Subject,\n  takeUntil,\n  debounceTime,\n  merge,\n  Observable,\n  combineLatest,\n  filter,\n  map,\n  tap,\n  take,\n  of,\n} from 'rxjs';\n\nexport function createNestedFormControl<V, M = V>({\n  autoEmitChange = false,\n  asyncValidator = false,\n}: {\n  autoEmitChange?: boolean;\n  asyncValidator?: boolean;\n} = {}): // workaround: https://github.com/microsoft/TypeScript/issues/30355\nnew () => BaseNestedFormControl<V, M> {\n  return class NestedFormControl extends BaseNestedFormControl<V, M> {\n    protected override autoEmitChange = autoEmitChange;\n    protected override asyncValidator = asyncValidator;\n  };\n}\n\n@Directive()\nexport class BaseNestedFormControl<V, M = V>\n  implements AfterViewInit, OnDestroy, ControlValueAccessor\n{\n  @ViewChildren(NgControl)\n  protected controls: QueryList<NgControl>;\n\n  @Input()\n  get disabled() {\n    return this._disabled;\n  }\n\n  set disabled(val: boolean | '') {\n    this._disabled = coerceAttrBoolean(val);\n  }\n\n  private _disabled = false;\n\n  onValidatorChange: () => void;\n  onChange: (_: V) => void;\n  onTouched: () => void;\n  onSubmitted: () => void;\n\n  model: M = null;\n  submitted = false;\n\n  protected autoEmitChange = false;\n  protected asyncValidator = false;\n  protected cdr = inject(ChangeDetectorRef);\n  protected destroy$$ = new Subject<void>();\n  protected hostForm =\n    inject(NgForm, { optional: true }) ??\n    inject(FormGroupDirective, { optional: true });\n\n  constructor() {\n    if (this.hostForm) {\n      this.hostForm.ngSubmit.pipe(takeUntil(this.destroy$$)).subscribe(() => {\n        this.submitted = this.hostForm.submitted;\n        this.onSubmitted?.();\n        this.cdr.markForCheck();\n      });\n    }\n  }\n\n  ngAfterViewInit() {\n    this.controls.changes\n      .pipe(\n        startWith(this.controls),\n        switchMap((controls: QueryList<NgControl>) =>\n          controls.length\n            ? merge(\n                ...controls.toArray().map(control => control.statusChanges),\n              ).pipe(startWith(null))\n            : of(null),\n        ),\n        debounceTime(0),\n      )\n      .subscribe(() => {\n        this.onValidatorChange?.();\n      });\n\n    if (this.autoEmitChange) {\n      this.controls.changes\n        .pipe(\n          startWith(this.controls),\n          switchMap((controls: QueryList<NgControl>) =>\n            merge(...controls.toArray().map(control => control.valueChanges)),\n          ),\n        )\n        .pipe(debounceTime(0))\n        .subscribe(() => {\n          this.emitModel(this.model);\n        });\n    }\n  }\n\n  ngOnDestroy() {\n    this.destroy$$.next();\n    this.destroy$$.complete();\n  }\n\n  registerOnValidatorChange(fn: () => void) {\n    this.onValidatorChange = fn;\n  }\n\n  registerOnChange(fn: (_: V) => void) {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: () => void) {\n    this.onTouched = fn;\n  }\n\n  setDisabledState(isDisabled: boolean) {\n    this.disabled = isDisabled;\n    this.cdr.markForCheck();\n  }\n\n  writeValue(value: V) {\n    this.model = this.valueIn(value);\n    this.cdr.markForCheck();\n  }\n\n  validate(\n    _control?: AbstractControl,\n  ): ValidationErrors | null | Observable<ValidationErrors | null> {\n    const getErrors = () =>\n      this.controls?.reduce((acc, control) => {\n        if (control.errors) {\n          return mergeDeepRight(\n            acc,\n            control.name ? { [control.name]: control.errors } : control.errors,\n          );\n        }\n        return acc;\n      }, {} as ValidationErrors);\n\n    return this.asyncValidator\n      ? combineLatest(\n          (this.controls?.toArray() ?? []).map(control =>\n            control.statusChanges.pipe(startWith(control.status)),\n          ),\n        ).pipe(\n          debounceTime(0),\n          filter(\n            statuses =>\n              statuses.includes('INVALID') || !statuses.includes('PENDING'),\n          ),\n          take(1),\n          map(() => getErrors()),\n          tap(() => {\n            this.cdr.markForCheck();\n          }),\n        )\n      : getErrors();\n  }\n\n  emitModel(model: M = this.model) {\n    this.model = model;\n    this.emitValue(this.modelOut(this.model));\n  }\n\n  emitValue(value: V) {\n    if (this.onChange) {\n      this.onChange(value);\n    }\n  }\n\n  protected valueIn(value: V): M {\n    return value as any;\n  }\n\n  protected modelOut(model: M): V {\n    return model as any;\n  }\n}\n\n/**\n * @deprecated use {@link BaseNestedFormControl} instead.\n */\n@Directive()\nexport class BaseNestedFormControlPure<V, M = V> extends BaseNestedFormControl<\n  V,\n  M\n> {\n  model$ = new ReplaySubject<M>(1);\n\n  constructor() {\n    super();\n\n    this.model$.subscribe(model => {\n      this.model = model;\n      this.cdr.markForCheck();\n    });\n  }\n\n  override writeValue(value: V) {\n    this.model$.next(this.valueIn(value));\n  }\n\n  override emitValue(value: V) {\n    if (this.onChange) {\n      this.onChange(value);\n      this.writeValue(value);\n    }\n  }\n}\n\ntype Path = string | Array<string | number>;\n\ninterface Mapper {\n  [x: string]: Mapper | Path;\n}\n\ntype PathTuple = [string[], string[]];\n\nfunction collectPaths(mapper: Mapper, parent: string[]): PathTuple[] {\n  return Object.entries(mapper).reduce((acc, [key, value]) => {\n    const path = typeof value === 'string' ? value.split('.') : value;\n    if (Array.isArray(path)) {\n      acc.push([parent.concat(key), path]);\n      return acc;\n    }\n    return acc.concat(collectPaths(path, parent.concat(key)));\n  }, []);\n}\n\nexport function dataTransfer<\n  S extends object,\n  T extends object,\n  M extends Record<keyof T, Path | Mapper> = Record<keyof T, Path | Mapper>,\n>(mapper: M): [(source: S) => T, (target: T) => S] {\n  const tuples = collectPaths(mapper, []);\n  let _source: S;\n  let _target: T = {} as T;\n  return [\n    source => {\n      _source = source;\n      return tuples.reduce((acc, [left, right]) => {\n        const newValue = path<unknown>(right, source);\n\n        if (path(left, acc) === newValue) {\n          return acc;\n        }\n\n        return (_target = assocPath<unknown, T>(left, newValue, acc));\n      }, _target);\n    },\n    target => {\n      _target = target;\n      return tuples.reduce((acc, [left, right]) => {\n        const newValue = path<unknown>(left, target);\n\n        if (path(right, acc) === newValue) {\n          return acc;\n        }\n\n        return (_source = assocPath<unknown, S>(right, newValue, acc));\n      }, _source);\n    },\n  ];\n}\n\nfunction parsePath(path: Path): Array<string | number> {\n  return typeof path === 'string' ? path.split('.') : path;\n}\n\nexport function copyValue<T extends object>(\n  from: Path,\n  to: Path,\n  mapper: (v: any) => any = identity,\n) {\n  const fromPath = parsePath(from);\n  const toPath = parsePath(to);\n  return (object: T) =>\n    assocPath(toPath, mapper(path(fromPath, object)), object);\n}\n"]}
|
|
198
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base-nested-form-control.js","sourceRoot":"","sources":["../../../../../../libs/common/src/core/abstract/base-nested-form-control.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,YAAY,CAAC;AAC/C,OAAO,EAEL,iBAAiB,EACjB,SAAS,EACT,MAAM,EACN,KAAK,EAEL,SAAS,EACT,YAAY,GACb,MAAM,eAAe,CAAC;AACvB,OAAO,EAGL,kBAAkB,EAClB,SAAS,EACT,MAAM,GAEP,MAAM,gBAAgB,CAAC;AACxB,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,cAAc,EAAE,IAAI,EAAE,MAAM,OAAO,CAAC;AAClE,OAAO,EACL,aAAa,EACb,SAAS,EACT,SAAS,EACT,OAAO,EACP,SAAS,EACT,YAAY,EACZ,KAAK,EAEL,aAAa,EACb,MAAM,EACN,GAAG,EACH,GAAG,EACH,IAAI,EACJ,EAAE,GACH,MAAM,MAAM,CAAC;;AAEd,MAAM,UAAU,uBAAuB,CAAW,EAChD,cAAc,GAAG,KAAK,EACtB,cAAc,GAAG,KAAK,MAIpB,EAAE;IAEJ,OAAO,MAAM,iBAAkB,SAAQ,qBAA2B;QAA3D;;YACc,mBAAc,GAAG,cAAc,CAAC;YAChC,mBAAc,GAAG,cAAc,CAAC;QACrD,CAAC;KAAA,CAAC;AACJ,CAAC;AAGD,MAAM,OAAO,qBAAqB;IAMhC,IACI,QAAQ;QACV,OAAO,IAAI,CAAC,SAAS,CAAC;IACxB,CAAC;IAED,IAAI,QAAQ,CAAC,GAAiB;QAC5B,IAAI,CAAC,SAAS,GAAG,iBAAiB,CAAC,GAAG,CAAC,CAAC;IAC1C,CAAC;IAoBD;QAlBQ,cAAS,GAAG,KAAK,CAAC;QAO1B,UAAK,GAAM,IAAI,CAAC;QAChB,cAAS,GAAG,KAAK,CAAC;QAER,mBAAc,GAAG,KAAK,CAAC;QACvB,mBAAc,GAAG,KAAK,CAAC;QACvB,QAAG,GAAG,MAAM,CAAC,iBAAiB,CAAC,CAAC;QAChC,cAAS,GAAG,IAAI,OAAO,EAAQ,CAAC;QAChC,aAAQ,GAChB,MAAM,CAAC,MAAM,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC;YAClC,MAAM,CAAC,kBAAkB,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC,CAAC;QAG/C,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;YAClB,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,GAAG,EAAE;gBACpE,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,QAAQ,CAAC,SAAS,CAAC;gBACzC,IAAI,CAAC,WAAW,EAAE,EAAE,CAAC;gBACrB,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;YAC1B,CAAC,CAAC,CAAC;QACL,CAAC;IACH,CAAC;IAED,eAAe;QACb,IAAI,CAAC,QAAQ,CAAC,OAAO;aAClB,IAAI,CACH,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,EACxB,SAAS,CAAC,CAAC,QAA8B,EAAE,EAAE,CAC3C,QAAQ,CAAC,MAAM;YACb,CAAC,CAAC,KAAK,CACH,GAAG,QAAQ,CAAC,OAAO,EAAE,CAAC,GAAG,CAAC,OAAO,CAAC,EAAE,CAAC,OAAO,CAAC,aAAa,CAAC,CAC5D,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;YACzB,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,CACb,EACD,YAAY,CAAC,CAAC,CAAC,CAChB;aACA,SAAS,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,iBAAiB,EAAE,EAAE,CAAC;QAC7B,CAAC,CAAC,CAAC;QAEL,IAAI,IAAI,CAAC,cAAc,EAAE,CAAC;YACxB,IAAI,CAAC,QAAQ,CAAC,OAAO;iBAClB,IAAI,CACH,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,EACxB,SAAS,CAAC,CAAC,QAA8B,EAAE,EAAE,CAC3C,KAAK,CAAC,GAAG,QAAQ,CAAC,OAAO,EAAE,CAAC,GAAG,CAAC,OAAO,CAAC,EAAE,CAAC,OAAO,CAAC,YAAY,CAAC,CAAC,CAClE,CACF;iBACA,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;iBACrB,SAAS,CAAC,GAAG,EAAE;gBACd,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YAC7B,CAAC,CAAC,CAAC;QACP,CAAC;IACH,CAAC;IAED,WAAW;QACT,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,CAAC;QACtB,IAAI,CAAC,SAAS,CAAC,QAAQ,EAAE,CAAC;IAC5B,CAAC;IAED,yBAAyB,CAAC,EAAc;QACtC,IAAI,CAAC,iBAAiB,GAAG,EAAE,CAAC;IAC9B,CAAC;IAED,gBAAgB,CAAC,EAAkB;QACjC,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC;IACrB,CAAC;IAED,iBAAiB,CAAC,EAAc;QAC9B,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;IACtB,CAAC;IAED,gBAAgB,CAAC,UAAmB;QAClC,IAAI,CAAC,QAAQ,GAAG,UAAU,CAAC;QAC3B,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;IAC1B,CAAC;IAED,UAAU,CAAC,KAAQ;QACjB,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;QACjC,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;IAC1B,CAAC;IAED,QAAQ,CACN,QAA0B;QAE1B,MAAM,SAAS,GAAG,GAAG,EAAE;YACrB,MAAM,MAAM,GAAG,IAAI,CAAC,QAAQ,EAAE,MAAM,CAAC,CAAC,GAAG,EAAE,OAAO,EAAE,EAAE;gBACpD,IAAI,OAAO,CAAC,MAAM,EAAE,CAAC;oBACnB,OAAO,cAAc,CACnB,GAAG,EACH,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,OAAO,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,MAAM,CACnE,CAAC;gBACJ,CAAC;gBACD,OAAO,GAAG,CAAC;YACb,CAAC,EAAE,EAAsB,CAAC,CAAC;YAE3B,OAAO,MAAM,IAAI,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC;QAC9D,CAAC,CAAC;QAEF,OAAO,IAAI,CAAC,cAAc;YACxB,CAAC,CAAC,aAAa,CACX,CAAC,IAAI,CAAC,QAAQ,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,CAAC,GAAG,CAAC,OAAO,CAAC,EAAE,CAC7C,OAAO,CAAC,aAAa,CAAC,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CACtD,CACF,CAAC,IAAI,CACJ,YAAY,CAAC,CAAC,CAAC,EACf,MAAM,CACJ,QAAQ,CAAC,EAAE,CACT,QAAQ,CAAC,QAAQ,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,SAAS,CAAC,CAChE,EACD,IAAI,CAAC,CAAC,CAAC,EACP,GAAG,CAAC,GAAG,EAAE,CAAC,SAAS,EAAE,CAAC,EACtB,GAAG,CAAC,GAAG,EAAE;gBACP,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;YAC1B,CAAC,CAAC,CACH;YACH,CAAC,CAAC,SAAS,EAAE,CAAC;IAClB,CAAC;IAED,SAAS,CAAC,QAAW,IAAI,CAAC,KAAK;QAC7B,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC;IAC5C,CAAC;IAED,SAAS,CAAC,KAAQ;QAChB,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;YAClB,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;QACvB,CAAC;IACH,CAAC;IAES,OAAO,CAAC,KAAQ;QACxB,OAAO,KAAY,CAAC;IACtB,CAAC;IAES,QAAQ,CAAC,KAAQ;QACzB,OAAO,KAAY,CAAC;IACtB,CAAC;sFA5JU,qBAAqB;oEAArB,qBAAqB;2BAGlB,SAAS;;;;;;iFAHZ,qBAAqB;cADjC,SAAS;oBAKE,QAAQ;kBADjB,YAAY;mBAAC,SAAS;YAInB,QAAQ;kBADX,KAAK;;AAyJR;;GAEG;AAEH,MAAM,OAAO,yBAAoC,SAAQ,qBAGxD;IAGC;QACE,KAAK,EAAE,CAAC;QAHV,WAAM,GAAG,IAAI,aAAa,CAAI,CAAC,CAAC,CAAC;QAK/B,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,KAAK,CAAC,EAAE;YAC5B,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;YACnB,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;QAC1B,CAAC,CAAC,CAAC;IACL,CAAC;IAEQ,UAAU,CAAC,KAAQ;QAC1B,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC;IACxC,CAAC;IAEQ,SAAS,CAAC,KAAQ;QACzB,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;YAClB,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;YACrB,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;QACzB,CAAC;IACH,CAAC;0FAxBU,yBAAyB;oEAAzB,yBAAyB;;iFAAzB,yBAAyB;cADrC,SAAS;;AAoCV,SAAS,YAAY,CAAC,MAAc,EAAE,MAAgB;IACpD,OAAO,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,CAAC,GAAG,EAAE,KAAK,CAAC,EAAE,EAAE;QACzD,MAAM,IAAI,GAAG,OAAO,KAAK,KAAK,QAAQ,CAAC,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC;QAClE,IAAI,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC;YACxB,GAAG,CAAC,IAAI,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,IAAI,CAAC,CAAC,CAAC;YACrC,OAAO,GAAG,CAAC;QACb,CAAC;QACD,OAAO,GAAG,CAAC,MAAM,CAAC,YAAY,CAAC,IAAI,EAAE,MAAM,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;IAC5D,CAAC,EAAE,EAAE,CAAC,CAAC;AACT,CAAC;AAED,MAAM,UAAU,YAAY,CAI1B,MAAS;IACT,MAAM,MAAM,GAAG,YAAY,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC;IACxC,IAAI,OAAU,CAAC;IACf,IAAI,OAAO,GAAM,EAAO,CAAC;IACzB,OAAO;QACL,MAAM,CAAC,EAAE;YACP,OAAO,GAAG,MAAM,CAAC;YACjB,OAAO,MAAM,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,CAAC,IAAI,EAAE,KAAK,CAAC,EAAE,EAAE;gBAC1C,MAAM,QAAQ,GAAG,IAAI,CAAU,KAAK,EAAE,MAAM,CAAC,CAAC;gBAE9C,IAAI,IAAI,CAAC,IAAI,EAAE,GAAG,CAAC,KAAK,QAAQ,EAAE,CAAC;oBACjC,OAAO,GAAG,CAAC;gBACb,CAAC;gBAED,OAAO,CAAC,OAAO,GAAG,SAAS,CAAa,IAAI,EAAE,QAAQ,EAAE,GAAG,CAAC,CAAC,CAAC;YAChE,CAAC,EAAE,OAAO,CAAC,CAAC;QACd,CAAC;QACD,MAAM,CAAC,EAAE;YACP,OAAO,GAAG,MAAM,CAAC;YACjB,OAAO,MAAM,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,CAAC,IAAI,EAAE,KAAK,CAAC,EAAE,EAAE;gBAC1C,MAAM,QAAQ,GAAG,IAAI,CAAU,IAAI,EAAE,MAAM,CAAC,CAAC;gBAE7C,IAAI,IAAI,CAAC,KAAK,EAAE,GAAG,CAAC,KAAK,QAAQ,EAAE,CAAC;oBAClC,OAAO,GAAG,CAAC;gBACb,CAAC;gBAED,OAAO,CAAC,OAAO,GAAG,SAAS,CAAa,KAAK,EAAE,QAAQ,EAAE,GAAG,CAAC,CAAC,CAAC;YACjE,CAAC,EAAE,OAAO,CAAC,CAAC;QACd,CAAC;KACF,CAAC;AACJ,CAAC;AAED,SAAS,SAAS,CAAC,IAAU;IAC3B,OAAO,OAAO,IAAI,KAAK,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;AAC3D,CAAC;AAED,MAAM,UAAU,SAAS,CACvB,IAAU,EACV,EAAQ,EACR,SAA0B,QAAQ;IAElC,MAAM,QAAQ,GAAG,SAAS,CAAC,IAAI,CAAC,CAAC;IACjC,MAAM,MAAM,GAAG,SAAS,CAAC,EAAE,CAAC,CAAC;IAC7B,OAAO,CAAC,MAAS,EAAE,EAAE,CACnB,SAAS,CAAC,MAAM,EAAE,MAAM,CAAC,IAAI,CAAC,QAAQ,EAAE,MAAM,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC;AAC9D,CAAC","sourcesContent":["import { coerceAttrBoolean } from '@alauda/ui';\nimport {\n  AfterViewInit,\n  ChangeDetectorRef,\n  Directive,\n  inject,\n  Input,\n  OnDestroy,\n  QueryList,\n  ViewChildren,\n} from '@angular/core';\nimport {\n  AbstractControl,\n  ControlValueAccessor,\n  FormGroupDirective,\n  NgControl,\n  NgForm,\n  ValidationErrors,\n} from '@angular/forms';\nimport { assocPath, identity, mergeDeepRight, path } from 'ramda';\nimport {\n  ReplaySubject,\n  startWith,\n  switchMap,\n  Subject,\n  takeUntil,\n  debounceTime,\n  merge,\n  Observable,\n  combineLatest,\n  filter,\n  map,\n  tap,\n  take,\n  of,\n} from 'rxjs';\n\nexport function createNestedFormControl<V, M = V>({\n  autoEmitChange = false,\n  asyncValidator = false,\n}: {\n  autoEmitChange?: boolean;\n  asyncValidator?: boolean;\n} = {}): // workaround: https://github.com/microsoft/TypeScript/issues/30355\nnew () => BaseNestedFormControl<V, M> {\n  return class NestedFormControl extends BaseNestedFormControl<V, M> {\n    protected override autoEmitChange = autoEmitChange;\n    protected override asyncValidator = asyncValidator;\n  };\n}\n\n@Directive()\nexport class BaseNestedFormControl<V, M = V>\n  implements AfterViewInit, OnDestroy, ControlValueAccessor\n{\n  @ViewChildren(NgControl)\n  protected controls: QueryList<NgControl>;\n\n  @Input()\n  get disabled() {\n    return this._disabled;\n  }\n\n  set disabled(val: boolean | '') {\n    this._disabled = coerceAttrBoolean(val);\n  }\n\n  private _disabled = false;\n\n  onValidatorChange: () => void;\n  onChange: (_: V) => void;\n  onTouched: () => void;\n  onSubmitted: () => void;\n\n  model: M = null;\n  submitted = false;\n\n  protected autoEmitChange = false;\n  protected asyncValidator = false;\n  protected cdr = inject(ChangeDetectorRef);\n  protected destroy$$ = new Subject<void>();\n  protected hostForm =\n    inject(NgForm, { optional: true }) ??\n    inject(FormGroupDirective, { optional: true });\n\n  constructor() {\n    if (this.hostForm) {\n      this.hostForm.ngSubmit.pipe(takeUntil(this.destroy$$)).subscribe(() => {\n        this.submitted = this.hostForm.submitted;\n        this.onSubmitted?.();\n        this.cdr.markForCheck();\n      });\n    }\n  }\n\n  ngAfterViewInit() {\n    this.controls.changes\n      .pipe(\n        startWith(this.controls),\n        switchMap((controls: QueryList<NgControl>) =>\n          controls.length\n            ? merge(\n                ...controls.toArray().map(control => control.statusChanges),\n              ).pipe(startWith(null))\n            : of(null),\n        ),\n        debounceTime(0),\n      )\n      .subscribe(() => {\n        this.onValidatorChange?.();\n      });\n\n    if (this.autoEmitChange) {\n      this.controls.changes\n        .pipe(\n          startWith(this.controls),\n          switchMap((controls: QueryList<NgControl>) =>\n            merge(...controls.toArray().map(control => control.valueChanges)),\n          ),\n        )\n        .pipe(debounceTime(0))\n        .subscribe(() => {\n          this.emitModel(this.model);\n        });\n    }\n  }\n\n  ngOnDestroy() {\n    this.destroy$$.next();\n    this.destroy$$.complete();\n  }\n\n  registerOnValidatorChange(fn: () => void) {\n    this.onValidatorChange = fn;\n  }\n\n  registerOnChange(fn: (_: V) => void) {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: () => void) {\n    this.onTouched = fn;\n  }\n\n  setDisabledState(isDisabled: boolean) {\n    this.disabled = isDisabled;\n    this.cdr.markForCheck();\n  }\n\n  writeValue(value: V) {\n    this.model = this.valueIn(value);\n    this.cdr.markForCheck();\n  }\n\n  validate(\n    _control?: AbstractControl,\n  ): ValidationErrors | null | Observable<ValidationErrors | null> {\n    const getErrors = () => {\n      const errors = this.controls?.reduce((acc, control) => {\n        if (control.errors) {\n          return mergeDeepRight(\n            acc,\n            control.name ? { [control.name]: control.errors } : control.errors,\n          );\n        }\n        return acc;\n      }, {} as ValidationErrors);\n\n      return errors && Object.keys(errors).length ? errors : null;\n    };\n\n    return this.asyncValidator\n      ? combineLatest(\n          (this.controls?.toArray() ?? []).map(control =>\n            control.statusChanges.pipe(startWith(control.status)),\n          ),\n        ).pipe(\n          debounceTime(0),\n          filter(\n            statuses =>\n              statuses.includes('INVALID') || !statuses.includes('PENDING'),\n          ),\n          take(1),\n          map(() => getErrors()),\n          tap(() => {\n            this.cdr.markForCheck();\n          }),\n        )\n      : getErrors();\n  }\n\n  emitModel(model: M = this.model) {\n    this.model = model;\n    this.emitValue(this.modelOut(this.model));\n  }\n\n  emitValue(value: V) {\n    if (this.onChange) {\n      this.onChange(value);\n    }\n  }\n\n  protected valueIn(value: V): M {\n    return value as any;\n  }\n\n  protected modelOut(model: M): V {\n    return model as any;\n  }\n}\n\n/**\n * @deprecated use {@link BaseNestedFormControl} instead.\n */\n@Directive()\nexport class BaseNestedFormControlPure<V, M = V> extends BaseNestedFormControl<\n  V,\n  M\n> {\n  model$ = new ReplaySubject<M>(1);\n\n  constructor() {\n    super();\n\n    this.model$.subscribe(model => {\n      this.model = model;\n      this.cdr.markForCheck();\n    });\n  }\n\n  override writeValue(value: V) {\n    this.model$.next(this.valueIn(value));\n  }\n\n  override emitValue(value: V) {\n    if (this.onChange) {\n      this.onChange(value);\n      this.writeValue(value);\n    }\n  }\n}\n\ntype Path = string | Array<string | number>;\n\ninterface Mapper {\n  [x: string]: Mapper | Path;\n}\n\ntype PathTuple = [string[], string[]];\n\nfunction collectPaths(mapper: Mapper, parent: string[]): PathTuple[] {\n  return Object.entries(mapper).reduce((acc, [key, value]) => {\n    const path = typeof value === 'string' ? value.split('.') : value;\n    if (Array.isArray(path)) {\n      acc.push([parent.concat(key), path]);\n      return acc;\n    }\n    return acc.concat(collectPaths(path, parent.concat(key)));\n  }, []);\n}\n\nexport function dataTransfer<\n  S extends object,\n  T extends object,\n  M extends Record<keyof T, Path | Mapper> = Record<keyof T, Path | Mapper>,\n>(mapper: M): [(source: S) => T, (target: T) => S] {\n  const tuples = collectPaths(mapper, []);\n  let _source: S;\n  let _target: T = {} as T;\n  return [\n    source => {\n      _source = source;\n      return tuples.reduce((acc, [left, right]) => {\n        const newValue = path<unknown>(right, source);\n\n        if (path(left, acc) === newValue) {\n          return acc;\n        }\n\n        return (_target = assocPath<unknown, T>(left, newValue, acc));\n      }, _target);\n    },\n    target => {\n      _target = target;\n      return tuples.reduce((acc, [left, right]) => {\n        const newValue = path<unknown>(left, target);\n\n        if (path(right, acc) === newValue) {\n          return acc;\n        }\n\n        return (_source = assocPath<unknown, S>(right, newValue, acc));\n      }, _source);\n    },\n  ];\n}\n\nfunction parsePath(path: Path): Array<string | number> {\n  return typeof path === 'string' ? path.split('.') : path;\n}\n\nexport function copyValue<T extends object>(\n  from: Path,\n  to: Path,\n  mapper: (v: any) => any = identity,\n) {\n  const fromPath = parsePath(from);\n  const toPath = parsePath(to);\n  return (object: T) =>\n    assocPath(toPath, mapper(path(fromPath, object)), object);\n}\n"]}
|
|
@@ -8,13 +8,18 @@ export class SanitizePipe {
|
|
|
8
8
|
this.sanitizer = sanitizer;
|
|
9
9
|
}
|
|
10
10
|
transform(value, type = 'html') {
|
|
11
|
-
const valueSanitizer = sanitize(value ?? '');
|
|
12
11
|
switch (type) {
|
|
13
12
|
case 'html': {
|
|
14
|
-
return this.sanitizer.bypassSecurityTrustHtml(
|
|
13
|
+
return this.sanitizer.bypassSecurityTrustHtml(sanitize(value ?? ''));
|
|
15
14
|
}
|
|
16
15
|
case 'url': {
|
|
17
|
-
return this.sanitizer.sanitize(SecurityContext.URL,
|
|
16
|
+
return this.sanitizer.sanitize(SecurityContext.URL, value ?? '');
|
|
17
|
+
}
|
|
18
|
+
case 'style': {
|
|
19
|
+
return this.sanitizer.sanitize(SecurityContext.STYLE, value ?? '');
|
|
20
|
+
}
|
|
21
|
+
default: {
|
|
22
|
+
throw new Error(`Invalid sanitize type specified: ${type}`);
|
|
18
23
|
}
|
|
19
24
|
}
|
|
20
25
|
}
|
|
@@ -28,4 +33,4 @@ export class SanitizePipe {
|
|
|
28
33
|
standalone: true,
|
|
29
34
|
}]
|
|
30
35
|
}], () => [{ type: i1.DomSanitizer }], null); })();
|
|
31
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
36
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2FuaXRpemUucGlwZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tbW9uL3NyYy9jb3JlL3BpcGVzL3Nhbml0aXplLnBpcGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLElBQUksRUFBaUIsZUFBZSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3JFLE9BQU8sRUFBRSxZQUFZLEVBQVksTUFBTSwyQkFBMkIsQ0FBQztBQUNuRSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sV0FBVyxDQUFDOzs7QUFNckMsTUFBTSxPQUFPLFlBQVk7SUFDdkIsWUFBNkIsU0FBdUI7UUFBdkIsY0FBUyxHQUFULFNBQVMsQ0FBYztJQUFHLENBQUM7SUFFeEQsU0FBUyxDQUNQLEtBQWEsRUFDYixPQUFpQyxNQUFNO1FBRXZDLFFBQVEsSUFBSSxFQUFFLENBQUM7WUFDYixLQUFLLE1BQU0sQ0FBQyxDQUFDLENBQUM7Z0JBQ1osT0FBTyxJQUFJLENBQUMsU0FBUyxDQUFDLHVCQUF1QixDQUFDLFFBQVEsQ0FBQyxLQUFLLElBQUksRUFBRSxDQUFDLENBQUMsQ0FBQztZQUN2RSxDQUFDO1lBQ0QsS0FBSyxLQUFLLENBQUMsQ0FBQyxDQUFDO2dCQUNYLE9BQU8sSUFBSSxDQUFDLFNBQVMsQ0FBQyxRQUFRLENBQUMsZUFBZSxDQUFDLEdBQUcsRUFBRSxLQUFLLElBQUksRUFBRSxDQUFDLENBQUM7WUFDbkUsQ0FBQztZQUNELEtBQUssT0FBTyxDQUFDLENBQUMsQ0FBQztnQkFDYixPQUFPLElBQUksQ0FBQyxTQUFTLENBQUMsUUFBUSxDQUFDLGVBQWUsQ0FBQyxLQUFLLEVBQUUsS0FBSyxJQUFJLEVBQUUsQ0FBQyxDQUFDO1lBQ3JFLENBQUM7WUFDRCxPQUFPLENBQUMsQ0FBQyxDQUFDO2dCQUNSLE1BQU0sSUFBSSxLQUFLLENBQUMsb0NBQW9DLElBQUksRUFBRSxDQUFDLENBQUM7WUFDOUQsQ0FBQztRQUNILENBQUM7SUFDSCxDQUFDOzZFQXJCVSxZQUFZO3FGQUFaLFlBQVk7O2lGQUFaLFlBQVk7Y0FKeEIsSUFBSTtlQUFDO2dCQUNKLElBQUksRUFBRSxhQUFhO2dCQUNuQixVQUFVLEVBQUUsSUFBSTthQUNqQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFBpcGUsIFBpcGVUcmFuc2Zvcm0sIFNlY3VyaXR5Q29udGV4dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRG9tU2FuaXRpemVyLCBTYWZlSHRtbCB9IGZyb20gJ0Bhbmd1bGFyL3BsYXRmb3JtLWJyb3dzZXInO1xuaW1wb3J0IHsgc2FuaXRpemUgfSBmcm9tICdkb21wdXJpZnknO1xuXG5AUGlwZSh7XG4gIG5hbWU6ICdhY2xTYW5pdGl6ZScsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG59KVxuZXhwb3J0IGNsYXNzIFNhbml0aXplUGlwZSBpbXBsZW1lbnRzIFBpcGVUcmFuc2Zvcm0ge1xuICBjb25zdHJ1Y3Rvcihwcml2YXRlIHJlYWRvbmx5IHNhbml0aXplcjogRG9tU2FuaXRpemVyKSB7fVxuXG4gIHRyYW5zZm9ybShcbiAgICB2YWx1ZTogc3RyaW5nLFxuICAgIHR5cGU6ICdodG1sJyB8ICd1cmwnIHwgJ3N0eWxlJyA9ICdodG1sJyxcbiAgKTogU2FmZUh0bWwgfCBzdHJpbmcgfCBudWxsIHtcbiAgICBzd2l0Y2ggKHR5cGUpIHtcbiAgICAgIGNhc2UgJ2h0bWwnOiB7XG4gICAgICAgIHJldHVybiB0aGlzLnNhbml0aXplci5ieXBhc3NTZWN1cml0eVRydXN0SHRtbChzYW5pdGl6ZSh2YWx1ZSA/PyAnJykpO1xuICAgICAgfVxuICAgICAgY2FzZSAndXJsJzoge1xuICAgICAgICByZXR1cm4gdGhpcy5zYW5pdGl6ZXIuc2FuaXRpemUoU2VjdXJpdHlDb250ZXh0LlVSTCwgdmFsdWUgPz8gJycpO1xuICAgICAgfVxuICAgICAgY2FzZSAnc3R5bGUnOiB7XG4gICAgICAgIHJldHVybiB0aGlzLnNhbml0aXplci5zYW5pdGl6ZShTZWN1cml0eUNvbnRleHQuU1RZTEUsIHZhbHVlID8/ICcnKTtcbiAgICAgIH1cbiAgICAgIGRlZmF1bHQ6IHtcbiAgICAgICAgdGhyb3cgbmV3IEVycm9yKGBJbnZhbGlkIHNhbml0aXplIHR5cGUgc3BlY2lmaWVkOiAke3R5cGV9YCk7XG4gICAgICB9XG4gICAgfVxuICB9XG59XG4iXX0=
|
|
@@ -3,13 +3,12 @@ import { CommonModule } from '@angular/common';
|
|
|
3
3
|
import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output, } from '@angular/core';
|
|
4
4
|
import { FormsModule } from '@angular/forms';
|
|
5
5
|
import { EffectDirectiveModule } from '../effect-directive/module';
|
|
6
|
-
import {
|
|
6
|
+
import { TranslatePipe } from '../translate/public-api';
|
|
7
7
|
import * as i0 from "@angular/core";
|
|
8
8
|
import * as i1 from "@angular/common";
|
|
9
9
|
import * as i2 from "@angular/forms";
|
|
10
10
|
import * as i3 from "@alauda/ui";
|
|
11
|
-
import * as i4 from "../
|
|
12
|
-
import * as i5 from "../effect-directive/e2e-attribute-binding.directive";
|
|
11
|
+
import * as i4 from "../effect-directive/e2e-attribute-binding.directive";
|
|
13
12
|
const _c0 = a0 => ({ "margin-left": a0 });
|
|
14
13
|
function TableCustomColumnsComponent_ng_template_3_aui_checkbox_2_Template(rf, ctx) { if (rf & 1) {
|
|
15
14
|
i0.ɵɵelementStart(0, "aui-checkbox", 7);
|
|
@@ -21,7 +20,7 @@ function TableCustomColumnsComponent_ng_template_3_aui_checkbox_2_Template(rf, c
|
|
|
21
20
|
const ctx_r1 = i0.ɵɵnextContext(2);
|
|
22
21
|
i0.ɵɵproperty("label", item_r3)("hidden", ctx_r1.ignoreOptions.includes(item_r3));
|
|
23
22
|
i0.ɵɵadvance();
|
|
24
|
-
i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(2, 3, item_r3), " ");
|
|
23
|
+
i0.ɵɵtextInterpolate1(" ", (ctx_r1.labels == null ? null : ctx_r1.labels[item_r3]) || i0.ɵɵpipeBind1(2, 3, item_r3), " ");
|
|
25
24
|
} }
|
|
26
25
|
function TableCustomColumnsComponent_ng_template_3_Template(rf, ctx) { if (rf & 1) {
|
|
27
26
|
const _r1 = i0.ɵɵgetCurrentView();
|
|
@@ -73,7 +72,7 @@ export class TableCustomColumnsComponent {
|
|
|
73
72
|
}
|
|
74
73
|
}
|
|
75
74
|
static { this.ɵfac = function TableCustomColumnsComponent_Factory(t) { return new (t || TableCustomColumnsComponent)(); }; }
|
|
76
|
-
static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: TableCustomColumnsComponent, selectors: [["acl-table-column-setting"]], inputs: { options: "options", ignoreOptions: "ignoreOptions", columns: "columns", marginLeft: "marginLeft", id: "id" }, outputs: { columnsChange: "columnsChange" }, standalone: true, features: [i0.ɵɵStandaloneFeature], decls: 5, vars: 6, consts: [["setting", ""], [3, "ngStyle"], ["aui-button", "", 3, "square", "auiDropdown", "auiDropdownHideOnClick"], ["icon", "gear"], ["size", "small"], ["direction", "column", 3, "ngModelChange", "ngModel"], [3, "label", "hidden", 4, "ngFor", "ngForOf"], [3, "label", "hidden"]], template: function TableCustomColumnsComponent_Template(rf, ctx) { if (rf & 1) {
|
|
75
|
+
static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: TableCustomColumnsComponent, selectors: [["acl-table-column-setting"]], inputs: { options: "options", ignoreOptions: "ignoreOptions", labels: "labels", columns: "columns", marginLeft: "marginLeft", id: "id" }, outputs: { columnsChange: "columnsChange" }, standalone: true, features: [i0.ɵɵStandaloneFeature], decls: 5, vars: 6, consts: [["setting", ""], [3, "ngStyle"], ["aui-button", "", 3, "square", "auiDropdown", "auiDropdownHideOnClick"], ["icon", "gear"], ["size", "small"], ["direction", "column", 3, "ngModelChange", "ngModel"], [3, "label", "hidden", 4, "ngFor", "ngForOf"], [3, "label", "hidden"]], template: function TableCustomColumnsComponent_Template(rf, ctx) { if (rf & 1) {
|
|
77
76
|
i0.ɵɵelementStart(0, "div", 1)(1, "button", 2);
|
|
78
77
|
i0.ɵɵelement(2, "aui-icon", 3);
|
|
79
78
|
i0.ɵɵelementEnd()();
|
|
@@ -83,7 +82,8 @@ export class TableCustomColumnsComponent {
|
|
|
83
82
|
i0.ɵɵproperty("ngStyle", i0.ɵɵpureFunction1(4, _c0, ctx.marginLeft));
|
|
84
83
|
i0.ɵɵadvance();
|
|
85
84
|
i0.ɵɵproperty("square", true)("auiDropdown", setting_r4)("auiDropdownHideOnClick", false);
|
|
86
|
-
} }, dependencies: [CommonModule, i1.NgForOf, i1.NgStyle, FormsModule, i2.NgControlStatus, i2.NgModel, DropdownModule, i3.DropdownDirective, i3.MenuComponent, ButtonModule, i3.ButtonComponent, IconModule, i3.IconComponent, CheckboxModule, i3.CheckboxComponent, i3.CheckboxGroupComponent,
|
|
85
|
+
} }, dependencies: [CommonModule, i1.NgForOf, i1.NgStyle, FormsModule, i2.NgControlStatus, i2.NgModel, DropdownModule, i3.DropdownDirective, i3.MenuComponent, ButtonModule, i3.ButtonComponent, IconModule, i3.IconComponent, CheckboxModule, i3.CheckboxComponent, i3.CheckboxGroupComponent, TranslatePipe,
|
|
86
|
+
EffectDirectiveModule, i4.E2eAttributeBindingDirective], encapsulation: 2, changeDetection: 0 }); }
|
|
87
87
|
}
|
|
88
88
|
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(TableCustomColumnsComponent, [{
|
|
89
89
|
type: Component,
|
|
@@ -94,13 +94,15 @@ export class TableCustomColumnsComponent {
|
|
|
94
94
|
ButtonModule,
|
|
95
95
|
IconModule,
|
|
96
96
|
CheckboxModule,
|
|
97
|
-
|
|
97
|
+
TranslatePipe,
|
|
98
98
|
EffectDirectiveModule,
|
|
99
|
-
], template: "<div [ngStyle]=\"{ 'margin-left': marginLeft }\">\n <button\n aui-button\n [square]=\"true\"\n [auiDropdown]=\"setting\"\n [auiDropdownHideOnClick]=\"false\"\n >\n <aui-icon icon=\"gear\"></aui-icon>\n </button>\n</div>\n<ng-template #setting
|
|
99
|
+
], template: "<div [ngStyle]=\"{ 'margin-left': marginLeft }\">\n <button\n aui-button\n [square]=\"true\"\n [auiDropdown]=\"setting\"\n [auiDropdownHideOnClick]=\"false\"\n >\n <aui-icon icon=\"gear\"></aui-icon>\n </button>\n</div>\n<ng-template #setting>\n <aui-menu size=\"small\">\n <aui-checkbox-group\n [(ngModel)]=\"columns\"\n direction=\"column\"\n (ngModelChange)=\"selectedChanged($event)\"\n >\n <aui-checkbox\n *ngFor=\"let item of options\"\n [label]=\"item\"\n [hidden]=\"ignoreOptions.includes(item)\"\n >\n {{ labels?.[item] || (item | translate) }}\n </aui-checkbox>\n </aui-checkbox-group>\n </aui-menu>\n</ng-template>\n" }]
|
|
100
100
|
}], null, { options: [{
|
|
101
101
|
type: Input
|
|
102
102
|
}], ignoreOptions: [{
|
|
103
103
|
type: Input
|
|
104
|
+
}], labels: [{
|
|
105
|
+
type: Input
|
|
104
106
|
}], columns: [{
|
|
105
107
|
type: Input
|
|
106
108
|
}], marginLeft: [{
|
|
@@ -111,4 +113,4 @@ export class TableCustomColumnsComponent {
|
|
|
111
113
|
type: Output
|
|
112
114
|
}] }); })();
|
|
113
115
|
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(TableCustomColumnsComponent, { className: "TableCustomColumnsComponent", filePath: "custom-columns-setting/component.ts", lineNumber: 40 }); })();
|
|
114
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
116
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vbGlicy9jb21tb24vc3JjL2N1c3RvbS1jb2x1bW5zLXNldHRpbmcvY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vbGlicy9jb21tb24vc3JjL2N1c3RvbS1jb2x1bW5zLXNldHRpbmcvdGVtcGxhdGUuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0wsWUFBWSxFQUNaLGNBQWMsRUFDZCxjQUFjLEVBQ2QsVUFBVSxHQUNYLE1BQU0sWUFBWSxDQUFDO0FBQ3BCLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQ0wsdUJBQXVCLEVBQ3ZCLFNBQVMsRUFDVCxZQUFZLEVBQ1osS0FBSyxFQUVMLE1BQU0sR0FDUCxNQUFNLGVBQWUsQ0FBQztBQUN2QixPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFHN0MsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0sNEJBQTRCLENBQUM7QUFDbkUsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHlCQUF5QixDQUFDOzs7Ozs7OztJQ0ZsRCx1Q0FJQztJQUNDLFlBQ0Y7O0lBQUEsaUJBQWU7Ozs7SUFIYixBQURBLCtCQUFjLGtEQUN5QjtJQUV2QyxjQUNGO0lBREUseUhBQ0Y7Ozs7SUFYRixBQURGLG1DQUF1Qiw0QkFLcEI7SUFIQyw4VEFBcUI7SUFFckIsaU9BQWlCLDhCQUF1QixLQUFDO0lBRXpDLDRHQUlDO0lBSUwsQUFERSxpQkFBcUIsRUFDWjs7O0lBWlAsY0FBcUI7SUFBckIsOENBQXFCO0lBS0YsY0FBVTtJQUFWLHdDQUFVOztBREduQyxNQUFNLGdDQUFnQyxHQUFHLHNDQUFzQyxDQUFDO0FBa0JoRixNQUFNLE9BQU8sMkJBQTJCO0lBaEJ4QztRQW1CVyxrQkFBYSxHQUFHLENBQUMsUUFBUSxDQUFDLENBQUM7UUFRcEMsZUFB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O2tCQURELEtBQUs7WUFJTixhQUFhO2tCQURaLE1BQU07O2tGQWhCSSwyQkFBMkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBCdXR0b25Nb2R1bGUsXG4gIENoZWNrYm94TW9kdWxlLFxuICBEcm9wZG93bk1vZHVsZSxcbiAgSWNvbk1vZHVsZSxcbn0gZnJvbSAnQGFsYXVkYS91aSc7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHtcbiAgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksXG4gIENvbXBvbmVudCxcbiAgRXZlbnRFbWl0dGVyLFxuICBJbnB1dCxcbiAgT25Jbml0LFxuICBPdXRwdXQsXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRm9ybXNNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5cbmltcG9ydCB7IFN0cmluZ01hcCB9IGZyb20gJy4uL2NvcmUvcHVibGljLWFwaSc7XG5pbXBvcnQgeyBFZmZlY3REaXJlY3RpdmVNb2R1bGUgfSBmcm9tICcuLi9lZmZlY3QtZGlyZWN0aXZlL21vZHVsZSc7XG5pbXBvcnQgeyBUcmFuc2xhdGVQaXBlIH0gZnJvbSAnLi4vdHJhbnNsYXRlL3B1YmxpYy1hcGknO1xuXG5jb25zdCBUQUJMRV9DVVNUT01fQ09MVU1OU19TRVRUSU5HX0tFWSA9ICdfX1RBQkxFX0NVU1RPTV9DT0xVTU5TX1NFVFRJTkdfS0VZX18nO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdhY2wtdGFibGUtY29sdW1uLXNldHRpbmcnLFxuICB0ZW1wbGF0ZVVybDogJ3RlbXBsYXRlLmh0bWwnLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgaW1wb3J0czogW1xuICAgIENvbW1vbk1vZHVsZSxcbiAgICBGb3Jtc01vZHVsZSxcbiAgICBEcm9wZG93bk1vZHVsZSxcbiAgICBCdXR0b25Nb2R1bGUsXG4gICAgSWNvbk1vZHVsZSxcbiAgICBDaGVja2JveE1vZHVsZSxcbiAgICBUcmFuc2xhdGVQaXBlLFxuICAgIEVmZmVjdERpcmVjdGl2ZU1vZHVsZSxcbiAgXSxcbn0pXG5leHBvcnQgY2xhc3MgVGFibGVDdXN0b21Db2x1bW5zQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcbiAgQElucHV0KCkgb3B0aW9uczogc3RyaW5nW107XG5cbiAgQElucHV0KCkgaWdub3JlT3B0aW9ucyA9IFsnYWN0aW9uJ107XG5cbiAgQElucHV0KCkgbGFiZWxzPzogUmVjb3JkPHN0cmluZywgc3RyaW5nPjtcblxuICBASW5wdXQoKVxuICBjb2x1bW5zPzogc3RyaW5nW107XG5cbiAgQElucHV0KClcbiAgbWFyZ2luTGVmdCA9ICc4cHgnO1xuXG4gIEBJbnB1dCgpXG4gIGlkOiBzdHJpbmc7XG5cbiAgQE91dHB1dCgpXG4gIGNvbHVtbnNDaGFuZ2UgPSBuZXcgRXZlbnRFbWl0dGVyPHN0cmluZ1tdPigpO1xuXG4gIHN0b3JhZ2U6IFN0cmluZ01hcDtcblxuICBuZ09uSW5pdCgpOiB2b2lkIHtcbiAgICB0aGlzLnN0b3JhZ2UgPSBKU09OLnBhcnNlKFxuICAgICAgbG9jYWxTdG9yYWdlLmdldEl0ZW0oVEFCTEVfQ1VTVE9NX0NPTFVNTlNfU0VUVElOR19LRVkpIHx8ICd7fScsXG4gICAgKTtcbiAgICBpZiAodGhpcy5pZCAmJiB0aGlzLnN0b3JhZ2VbdGhpcy5pZF0pIHtcbiAgICAgIGNvbnN0IHN0b3JhZ2VDb2x1bW5zID0gdGhpcy5zdG9yYWdlW3RoaXMuaWRdLnNwbGl0KCcsJyk7XG4gICAgICBjb25zdCBmaWx0ZXJlZEl0ZW1zID0gc3RvcmFnZUNvbHVtbnMuZmlsdGVyKGl0ZW0gPT5cbiAgICAgICAgdGhpcy5vcHRpb25zLmluY2x1ZGVzKGl0ZW0pLFxuICAgICAgKTtcbiAgICAgIHRoaXMuY29sdW1ucyA9IGZpbHRlcmVkSXRlbXM7XG4gICAgICB0aGlzLmNvbHVtbnNDaGFuZ2UuZW1pdChmaWx0ZXJlZEl0ZW1zKTtcbiAgICAgIHJldHVybjtcbiAgICB9XG5cbiAgICBpZiAodGhpcy5jb2x1bW5zPy5sZW5ndGgpIHtcbiAgICAgIGNvbnN0IGZpbHRlcmVkSXRlbXMgPSB0aGlzLmNvbHVtbnMuZmlsdGVyKGl0ZW0gPT5cbiAgICAgICAgdGhpcy5vcHRpb25zLmluY2x1ZGVzKGl0ZW0pLFxuICAgICAgKTtcbiAgICAgIHRoaXMuY29sdW1ucyA9IGZpbHRlcmVkSXRlbXM7XG4gICAgICB0aGlzLmNvbHVtbnNDaGFuZ2UuZW1pdChmaWx0ZXJlZEl0ZW1zKTtcbiAgICAgIHJldHVybjtcbiAgICB9XG5cbiAgICBpZiAoIXRoaXMuY29sdW1ucykge1xuICAgICAgdGhpcy5jb2x1bW5zID0gWy4uLnRoaXMub3B0aW9uc107XG4gICAgfVxuICB9XG5cbiAgc2VsZWN0ZWRDaGFuZ2VkKGV2ZW50OiBzdHJpbmdbXSkge1xuICAgIHRoaXMuY29sdW1uc0NoYW5nZS5lbWl0KGV2ZW50KTtcbiAgICBpZiAodGhpcy5pZCkge1xuICAgICAgbG9jYWxTdG9yYWdlLnNldEl0ZW0oXG4gICAgICAgIFRBQkxFX0NVU1RPTV9DT0xVTU5TX1NFVFRJTkdfS0VZLFxuICAgICAgICBKU09OLnN0cmluZ2lmeSh7XG4gICAgICAgICAgLi4udGhpcy5zdG9yYWdlLFxuICAgICAgICAgIFt0aGlzLmlkXTogZXZlbnQuam9pbignLCcpLFxuICAgICAgICB9KSxcbiAgICAgICk7XG4gICAgfVxuICB9XG59XG4iLCI8ZGl2IFtuZ1N0eWxlXT1cInsgJ21hcmdpbi1sZWZ0JzogbWFyZ2luTGVmdCB9XCI+XG4gIDxidXR0b25cbiAgICBhdWktYnV0dG9uXG4gICAgW3NxdWFyZV09XCJ0cnVlXCJcbiAgICBbYXVpRHJvcGRvd25dPVwic2V0dGluZ1wiXG4gICAgW2F1aURyb3Bkb3duSGlkZU9uQ2xpY2tdPVwiZmFsc2VcIlxuICA+XG4gICAgPGF1aS1pY29uIGljb249XCJnZWFyXCI+PC9hdWktaWNvbj5cbiAgPC9idXR0b24+XG48L2Rpdj5cbjxuZy10ZW1wbGF0ZSAjc2V0dGluZz5cbiAgPGF1aS1tZW51IHNpemU9XCJzbWFsbFwiPlxuICAgIDxhdWktY2hlY2tib3gtZ3JvdXBcbiAgICAgIFsobmdNb2RlbCldPVwiY29sdW1uc1wiXG4gICAgICBkaXJlY3Rpb249XCJjb2x1bW5cIlxuICAgICAgKG5nTW9kZWxDaGFuZ2UpPVwic2VsZWN0ZWRDaGFuZ2VkKCRldmVudClcIlxuICAgID5cbiAgICAgIDxhdWktY2hlY2tib3hcbiAgICAgICAgKm5nRm9yPVwibGV0IGl0ZW0gb2Ygb3B0aW9uc1wiXG4gICAgICAgIFtsYWJlbF09XCJpdGVtXCJcbiAgICAgICAgW2hpZGRlbl09XCJpZ25vcmVPcHRpb25zLmluY2x1ZGVzKGl0ZW0pXCJcbiAgICAgID5cbiAgICAgICAge3sgbGFiZWxzPy5baXRlbV0gfHwgKGl0ZW0gfCB0cmFuc2xhdGUpIH19XG4gICAgICA8L2F1aS1jaGVja2JveD5cbiAgICA8L2F1aS1jaGVja2JveC1ncm91cD5cbiAgPC9hdWktbWVudT5cbjwvbmctdGVtcGxhdGU+XG4iXX0=
|
|
@@ -17,8 +17,7 @@ import * as i3 from "../../../widget/loading-mask/loading-mask.component";
|
|
|
17
17
|
import * as i4 from "../../../translate/translate.pipe";
|
|
18
18
|
import * as i5 from "../../../core/pipes/pure.pipe";
|
|
19
19
|
import * as i6 from "../../../core/pipes/img-header.pipe";
|
|
20
|
-
import * as i7 from "../../../core/pipes/
|
|
21
|
-
import * as i8 from "../../../core/pipes/k8s-util.pipe";
|
|
20
|
+
import * as i7 from "../../../core/pipes/k8s-util.pipe";
|
|
22
21
|
export class CommonLayoutModule {
|
|
23
22
|
static { this.ɵfac = function CommonLayoutModule_Factory(t) { return new (t || CommonLayoutModule)(); }; }
|
|
24
23
|
static { this.ɵmod = /*@__PURE__*/ i0.ɵɵdefineNgModule({ type: CommonLayoutModule }); }
|
|
@@ -68,6 +67,6 @@ export class CommonLayoutModule {
|
|
|
68
67
|
SafePipe,
|
|
69
68
|
LoadingMaskComponent,
|
|
70
69
|
K8sUtilPipeModule], exports: [ProductSelectComponent, NamespaceSelectComponent] }); })();
|
|
71
|
-
i0.ɵɵsetComponentScope(ProductSelectComponent, [i1.NgClass, i1.NgForOf, i1.NgIf, i2.IconComponent, i2.TooltipDirective, i3.LoadingMaskComponent], [i1.AsyncPipe, i4.TranslatePipe, i5.PurePipe, i6.ImgHeaderPipe
|
|
72
|
-
i0.ɵɵsetComponentScope(NamespaceSelectComponent, [i1.NgForOf, i1.NgIf, i2.DropdownDirective, i2.DropdownActiveDirective, i2.MenuComponent, i2.MenuGroupComponent, i2.MenuGroupTitleDirective, i2.MenuItemComponent, i2.SearchComponent, i2.IconComponent], [i1.AsyncPipe, i4.TranslatePipe, i5.PurePipe,
|
|
73
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
70
|
+
i0.ɵɵsetComponentScope(ProductSelectComponent, [i1.NgClass, i1.NgForOf, i1.NgIf, i2.IconComponent, i2.TooltipDirective, i3.LoadingMaskComponent], [i1.AsyncPipe, i4.TranslatePipe, i5.PurePipe, i6.ImgHeaderPipe]);
|
|
71
|
+
i0.ɵɵsetComponentScope(NamespaceSelectComponent, [i1.NgForOf, i1.NgIf, i2.DropdownDirective, i2.DropdownActiveDirective, i2.MenuComponent, i2.MenuGroupComponent, i2.MenuGroupTitleDirective, i2.MenuItemComponent, i2.SearchComponent, i2.IconComponent], [i1.AsyncPipe, i4.TranslatePipe, i5.PurePipe, i7.K8sDisplayNamePipe, i7.K8sNamePipe]);
|
|
72
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tbW9uLWxheW91dC5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NvbW1vbi9zcmMvcGFnZS1zY2FmZm9sZC9wYWdlLWhlYWRlci9jb21tb24tbGF5b3V0L2NvbW1vbi1sYXlvdXQubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7R0FHRztBQUVILE9BQU8sRUFDTCxZQUFZLEVBQ1osY0FBYyxFQUNkLFVBQVUsRUFDVixXQUFXLEVBQ1gsV0FBVyxFQUNYLGFBQWEsR0FDZCxNQUFNLFlBQVksQ0FBQztBQUNwQixPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUV6QyxPQUFPLEVBQ0wsYUFBYSxFQUNiLGlCQUFpQixFQUNqQixRQUFRLEVBQ1IsUUFBUSxHQUNULE1BQU0sMEJBQTBCLENBQUM7QUFDbEMsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLHFDQUFxQyxDQUFDO0FBQ3RFLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLHFEQUFxRCxDQUFDO0FBRTNGLE9BQU8sRUFBRSx3QkFBd0IsRUFBRSxNQUFNLDhCQUE4QixDQUFDO0FBQ3hFLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLDRCQUE0QixDQUFDOzs7Ozs7Ozs7QUFxQnBFLE1BQU0sT0FBTyxrQkFBa0I7bUZBQWxCLGtCQUFrQjttRUFBbEIsa0JBQWtCO3VFQWYzQixZQUFZO1lBQ1osWUFBWTtZQUNaLGNBQWM7WUFDZCxXQUFXO1lBQ1gsVUFBVTtZQUNWLGVBQWU7WUFDZixhQUFhO1lBQ2IsV0FBVztZQUlYLG9CQUFvQjtZQUNwQixpQkFBaUI7O2lGQUdSLGtCQUFrQjtjQW5COUIsUUFBUTtlQUFDO2dCQUNSLFlBQVksRUFBRSxDQUFDLHNCQUFzQixFQUFFLHdCQUF3QixDQUFDO2dCQUNoRSxPQUFPLEVBQUUsQ0FBQyxzQkFBc0IsRUFBRSx3QkFBd0IsQ0FBQztnQkFDM0QsT0FBTyxFQUFFO29CQUNQLFlBQVk7b0JBQ1osWUFBWTtvQkFDWixjQUFjO29CQUNkLFdBQVc7b0JBQ1gsVUFBVTtvQkFDVixlQUFlO29CQUNmLGFBQWE7b0JBQ2IsV0FBVztvQkFDWCxRQUFRO29CQUNSLGFBQWE7b0JBQ2IsUUFBUTtvQkFDUixvQkFBb0I7b0JBQ3BCLGlCQUFpQjtpQkFDbEI7YUFDRjs7d0ZBQ1ksa0JBQWtCLG1CQWxCZCxzQkFBc0IsRUFBRSx3QkFBd0IsYUFHN0QsWUFBWTtRQUNaLFlBQVk7UUFDWixjQUFjO1FBQ2QsV0FBVztRQUNYLFVBQVU7UUFDVixlQUFlO1FBQ2YsYUFBYTtRQUNiLFdBQVc7UUFDWCxRQUFRO1FBQ1IsYUFBYTtRQUNiLFFBQVE7UUFDUixvQkFBb0I7UUFDcEIsaUJBQWlCLGFBZFQsc0JBQXNCLEVBQUUsd0JBQXdCO3VCQUQzQyxzQkFBc0I7dUJBQUUsd0JBQXdCIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAcGFja2FnZURvY3VtZW50YXRpb25cbiAqIEBtb2R1bGUgY29tbW9uLWxheW91dFxuICovXG5cbmltcG9ydCB7XG4gIERpYWxvZ01vZHVsZSxcbiAgRHJvcGRvd25Nb2R1bGUsXG4gIEljb25Nb2R1bGUsXG4gIElucHV0TW9kdWxlLFxuICBTdGVwc01vZHVsZSxcbiAgVG9vbHRpcE1vZHVsZSxcbn0gZnJvbSAnQGFsYXVkYS91aSc7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuaW1wb3J0IHtcbiAgSW1nSGVhZGVyUGlwZSxcbiAgSzhzVXRpbFBpcGVNb2R1bGUsXG4gIFB1cmVQaXBlLFxuICBTYWZlUGlwZSxcbn0gZnJvbSAnLi4vLi4vLi4vY29yZS9wdWJsaWMtYXBpJztcbmltcG9ydCB7IFRyYW5zbGF0ZU1vZHVsZSB9IGZyb20gJy4uLy4uLy4uL3RyYW5zbGF0ZS90cmFuc2xhdGUubW9kdWxlJztcbmltcG9ydCB7IExvYWRpbmdNYXNrQ29tcG9uZW50IH0gZnJvbSAnLi4vLi4vLi4vd2lkZ2V0L2xvYWRpbmctbWFzay9sb2FkaW5nLW1hc2suY29tcG9uZW50JztcblxuaW1wb3J0IHsgTmFtZXNwYWNlU2VsZWN0Q29tcG9uZW50IH0gZnJvbSAnLi9uYW1lc3BhY2Utc2VsZWN0L2NvbXBvbmVudCc7XG5pbXBvcnQgeyBQcm9kdWN0U2VsZWN0Q29tcG9uZW50IH0gZnJvbSAnLi9wcm9kdWN0LXNlbGVjdC9jb21wb25lbnQnO1xuXG5ATmdNb2R1bGUoe1xuICBkZWNsYXJhdGlvbnM6IFtQcm9kdWN0U2VsZWN0Q29tcG9uZW50LCBOYW1lc3BhY2VTZWxlY3RDb21wb25lbnRdLFxuICBleHBvcnRzOiBbUHJvZHVjdFNlbGVjdENvbXBvbmVudCwgTmFtZXNwYWNlU2VsZWN0Q29tcG9uZW50XSxcbiAgaW1wb3J0czogW1xuICAgIERpYWxvZ01vZHVsZSxcbiAgICBDb21tb25Nb2R1bGUsXG4gICAgRHJvcGRvd25Nb2R1bGUsXG4gICAgSW5wdXRNb2R1bGUsXG4gICAgSWNvbk1vZHVsZSxcbiAgICBUcmFuc2xhdGVNb2R1bGUsXG4gICAgVG9vbHRpcE1vZHVsZSxcbiAgICBTdGVwc01vZHVsZSxcbiAgICBQdXJlUGlwZSxcbiAgICBJbWdIZWFkZXJQaXBlLFxuICAgIFNhZmVQaXBlLFxuICAgIExvYWRpbmdNYXNrQ29tcG9uZW50LFxuICAgIEs4c1V0aWxQaXBlTW9kdWxlLFxuICBdLFxufSlcbmV4cG9ydCBjbGFzcyBDb21tb25MYXlvdXRNb2R1bGUge31cbiJdfQ==
|
|
@@ -39,10 +39,9 @@ function ProductSelectComponent_ng_template_13_ng_container_1_div_1_ng_container
|
|
|
39
39
|
function ProductSelectComponent_ng_template_13_ng_container_1_div_1_ng_template_4_Template(rf, ctx) { if (rf & 1) {
|
|
40
40
|
i0.ɵɵelement(0, "img", 16);
|
|
41
41
|
i0.ɵɵpipe(1, "aclImageHeader");
|
|
42
|
-
i0.ɵɵpipe(2, "aclSafe");
|
|
43
42
|
} if (rf & 2) {
|
|
44
43
|
const item_r3 = i0.ɵɵnextContext().$implicit;
|
|
45
|
-
i0.ɵɵproperty("src", i0.ɵɵ
|
|
44
|
+
i0.ɵɵproperty("src", i0.ɵɵpipeBind1(1, 1, item_r3.spec.logo) || "images/product-default-logo.png", i0.ɵɵsanitizeUrl);
|
|
46
45
|
} }
|
|
47
46
|
function ProductSelectComponent_ng_template_13_ng_container_1_div_1_aui_icon_9_Template(rf, ctx) { if (rf & 1) {
|
|
48
47
|
i0.ɵɵelement(0, "aui-icon", 17);
|
|
@@ -53,7 +52,7 @@ function ProductSelectComponent_ng_template_13_ng_container_1_div_1_Template(rf,
|
|
|
53
52
|
i0.ɵɵpipe(1, "pure");
|
|
54
53
|
i0.ɵɵlistener("click", function ProductSelectComponent_ng_template_13_ng_container_1_div_1_Template_div_click_0_listener($event) { const item_r3 = i0.ɵɵrestoreView(_r2).$implicit; const ctx_r3 = i0.ɵɵnextContext(3); return i0.ɵɵresetView(ctx_r3.navigateToProduct(item_r3, $event)); });
|
|
55
54
|
i0.ɵɵelementStart(2, "div", 12);
|
|
56
|
-
i0.ɵɵtemplate(3, ProductSelectComponent_ng_template_13_ng_container_1_div_1_ng_container_3_Template, 2, 1, "ng-container", 8)(4, ProductSelectComponent_ng_template_13_ng_container_1_div_1_ng_template_4_Template,
|
|
55
|
+
i0.ɵɵtemplate(3, ProductSelectComponent_ng_template_13_ng_container_1_div_1_ng_container_3_Template, 2, 1, "ng-container", 8)(4, ProductSelectComponent_ng_template_13_ng_container_1_div_1_ng_template_4_Template, 2, 3, "ng-template", null, 2, i0.ɵɵtemplateRefExtractor);
|
|
57
56
|
i0.ɵɵelementEnd();
|
|
58
57
|
i0.ɵɵelementStart(6, "div", 13);
|
|
59
58
|
i0.ɵɵtext(7);
|
|
@@ -224,11 +223,11 @@ export class ProductSelectComponent {
|
|
|
224
223
|
}
|
|
225
224
|
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(ProductSelectComponent, [{
|
|
226
225
|
type: Component,
|
|
227
|
-
args: [{ selector: 'acl-product-select', changeDetection: ChangeDetectionStrategy.OnPush, template: "<button\n class=\"acl-product-select\"\n [auiTooltip]=\"menu\"\n auiTooltipType=\"plain\"\n auiTooltipTrigger=\"click\"\n auiTooltipPosition=\"bottom start\"\n auiTooltipClass=\"aui-product-select-tooltip\"\n [auiTooltipHideOnClick]=\"true\"\n [disabled]=\"disabled$ | async\"\n [title]=\"\n (disabled$ | async)\n ? ''\n : (allProducts$\n | async\n | pure: getProductTitle : title : current\n | translate)\n \"\n [ngClass]=\"{ 'acl-product-select--disabled': disabled$ | async }\"\n>\n <span\n *ngIf=\"\n allProducts$\n | async\n | pure: getProductTitle : title : current as productTitle\n \"\n class=\"acl-product-select__title\"\n >\n {{ productTitle | translate }}\n </span>\n <aui-icon\n icon=\"menu_dot_s\"\n size=\"16px\"\n [auiTooltip]=\"'no_product_and_contact_admin' | translate\"\n [auiTooltipDisabled]=\"!(disabled$ | async)\"\n auiTooltipPosition=\"bottom start\"\n ></aui-icon>\n</button>\n<ng-template #menu>\n <div class=\"menu\">\n <ng-container *ngIf=\"selectableProducts$ | async as products; else loading\">\n <div\n class=\"menu__item\"\n [ngClass]=\"{\n 'menu__item--active': item | pure: isProductActive : current,\n }\"\n *ngFor=\"let item of products; trackBy: trackFn\"\n (click)=\"navigateToProduct(item, $event)\"\n >\n <div class=\"menu__item-icon\">\n <ng-container\n *ngIf=\"\n item.spec.packType !== 'Integrated' && !item.spec.logo;\n else logo\n \"\n >\n <aui-icon\n class=\"acl-colorful-icon\"\n [icon]=\"'bicolor:' + PRODUCT_ICON_MAP[item.metadata.name]\"\n ></aui-icon>\n </ng-container>\n <ng-template #logo>\n <img\n [src]=\"\n (item.spec.logo | aclImageHeader) ||\n
|
|
226
|
+
args: [{ selector: 'acl-product-select', changeDetection: ChangeDetectionStrategy.OnPush, template: "<button\n class=\"acl-product-select\"\n [auiTooltip]=\"menu\"\n auiTooltipType=\"plain\"\n auiTooltipTrigger=\"click\"\n auiTooltipPosition=\"bottom start\"\n auiTooltipClass=\"aui-product-select-tooltip\"\n [auiTooltipHideOnClick]=\"true\"\n [disabled]=\"disabled$ | async\"\n [title]=\"\n (disabled$ | async)\n ? ''\n : (allProducts$\n | async\n | pure: getProductTitle : title : current\n | translate)\n \"\n [ngClass]=\"{ 'acl-product-select--disabled': disabled$ | async }\"\n>\n <span\n *ngIf=\"\n allProducts$\n | async\n | pure: getProductTitle : title : current as productTitle\n \"\n class=\"acl-product-select__title\"\n >\n {{ productTitle | translate }}\n </span>\n <aui-icon\n icon=\"menu_dot_s\"\n size=\"16px\"\n [auiTooltip]=\"'no_product_and_contact_admin' | translate\"\n [auiTooltipDisabled]=\"!(disabled$ | async)\"\n auiTooltipPosition=\"bottom start\"\n ></aui-icon>\n</button>\n<ng-template #menu>\n <div class=\"menu\">\n <ng-container *ngIf=\"selectableProducts$ | async as products; else loading\">\n <div\n class=\"menu__item\"\n [ngClass]=\"{\n 'menu__item--active': item | pure: isProductActive : current,\n }\"\n *ngFor=\"let item of products; trackBy: trackFn\"\n (click)=\"navigateToProduct(item, $event)\"\n >\n <div class=\"menu__item-icon\">\n <ng-container\n *ngIf=\"\n item.spec.packType !== 'Integrated' && !item.spec.logo;\n else logo\n \"\n >\n <aui-icon\n class=\"acl-colorful-icon\"\n [icon]=\"'bicolor:' + PRODUCT_ICON_MAP[item.metadata.name]\"\n ></aui-icon>\n </ng-container>\n <ng-template #logo>\n <img\n [src]=\"\n (item.spec.logo | aclImageHeader) ||\n 'images/product-default-logo.png'\n \"\n class=\"default\"\n />\n </ng-template>\n </div>\n <div class=\"menu__item-info\">\n {{ item.spec.displayName | translate }}\n </div>\n <aui-icon\n *ngIf=\"item | pure: isProductActive : current\"\n class=\"check-triangle-badge\"\n icon=\"check\"\n ></aui-icon>\n </div>\n </ng-container>\n </div>\n <div\n *ngIf=\"portalProduct$ | async as portalMenu\"\n class=\"portal\"\n [ngClass]=\"{ 'portal--active': isPortal }\"\n >\n <div\n class=\"portal__item\"\n (click)=\"navigateToPortal($event)\"\n >\n <aui-icon icon=\"home_s\"></aui-icon>\n {{ portalMenu.spec.displayName | translate }}\n </div>\n </div>\n</ng-template>\n\n<ng-template #loading>\n <acl-loading-mask\n style=\"height: 148px\"\n [loading]=\"true\"\n ></acl-loading-mask>\n</ng-template>\n", styles: ["::ng-deep .aui-product-select-tooltip.aui-tooltip{margin-top:calc((var(--acl-page-header-height) - 32px) / 2 + 4px);background-color:rgb(var(--aui-color-n-10));padding:20px 20px 12px;border-radius:var(--aui-border-radius-l)}.portal{display:flex;justify-content:flex-end}.portal__item{display:flex;align-items:center;height:26px;padding:0 8px;font-size:var(--aui-font-size-l);font-weight:var(--aui-font-weight-bolder);color:rgb(var(--aui-color-primary));border-radius:var(--aui-border-radius-m);cursor:pointer}.portal__item:hover{color:rgb(var(--aui-color-p-1))}.portal aui-icon{font-size:var(--aui-icon-size-l);margin-right:8px}.acl-product-select{width:100%;min-height:32px;border-radius:2px;border:none;background:none;padding:4px 8px;cursor:pointer;outline:none;display:flex;align-items:center}.acl-product-select__title{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.acl-product-select--disabled{opacity:.3;cursor:default}.acl-product-select span{margin-right:8px;height:24px;line-height:24px;font-size:18px;font-weight:var(--aui-font-weight-bolder);color:var(--acl-page-header-title-color);white-space:nowrap;word-break:keep-all}.acl-product-select aui-icon{height:16px;color:rgb(var(--aui-color-n-4))}.acl-product-select.isActive,.acl-product-select:not(.acl-product-select--disabled):hover{background-color:rgb(var(--aui-color-primary))}.acl-product-select.isActive aui-icon,.acl-product-select.isActive span,.acl-product-select:not(.acl-product-select--disabled):hover aui-icon,.acl-product-select:not(.acl-product-select--disabled):hover span{color:#fff}::ng-deep .acl-product-select__menu .aui-menu{padding:0;max-width:unset}.menu{margin-bottom:8px;margin-right:-12px;display:flex;flex-flow:column wrap;max-height:360px}.menu__item{margin-bottom:12px;margin-right:12px;width:300px;height:48px;display:flex;align-items:center;position:relative;border-radius:var(--aui-border-radius-l);padding:0 20px;background-color:rgb(var(--aui-color-n-9));cursor:pointer}.menu__item:hover{border-color:rgb(var(--aui-color-primary));box-shadow:0 0 8px rgba(var(--aui-color-primary),.5)}.menu__item:not(.menu__item--active){position:relative}.menu__item:not(.menu__item--active):after{position:absolute;content:\"\";top:0;right:0;bottom:0;left:0;border:1px solid rgb(var(--aui-color-n-7));border-radius:4px;pointer-events:none;transition:all .2s ease-in-out}.menu__item:not(.menu__item--active).disabled{background-color:rgb(var(--aui-color-n-8));color:rgb(var(--aui-color-n-6));cursor:not-allowed}.menu__item:not(.menu__item--active):not(.disabled):hover:after{top:-4px;right:-4px;bottom:-4px;left:-4px;border-color:rgb(var(--aui-color-primary));box-shadow:inset 0 0 0 4px rgb(var(--aui-color-n-10)),0 0 8px rgba(var(--aui-color-primary),.5)}.menu__item:not(.menu__item--active):not(.disabled):active:after{top:0;right:0;bottom:0;left:0;box-shadow:0 0 4px rgba(var(--aui-color-primary),.5)}.menu__item:not(.menu__item--active):hover:after{box-shadow:inset 0 0 0 4px rgb(var(--aui-color-n-9)),0 0 8px rgba(var(--aui-color-primary),.5)!important}.menu__item-icon{height:24px;width:24px;font-size:24px;margin-right:8px;display:flex;justify-content:center;align-items:center;color:rgb(var(--aui-color-primary))}.menu__item-icon img{display:block;width:24px}.menu__item-icon img.activated{display:none}.menu__item-info{min-width:0;font-size:16px;color:rgb(var(--aui-color-n-1));text-overflow:ellipsis;overflow:hidden;white-space:nowrap}.menu__item--active{border:1px solid rgb(var(--aui-color-primary));position:relative;cursor:default}.menu__item--active:hover{box-shadow:none}.menu__item--active .check-triangle-badge{right:0;bottom:0;border-bottom-right-radius:var(--aui-border-radius-m);color:#fff;background-image:linear-gradient(to bottom right,transparent 50%,rgb(var(--aui-color-primary)) 50%)}acl-loading-mask{height:148px;width:800px;display:flex;align-items:center;justify-content:center}\n"] }]
|
|
228
227
|
}], () => [{ type: i1.CommonLayoutStoreService }, { type: i2.Router }, { type: i3.K8sPermissionService }, { type: i4.ProductSelectService }], { current: [{
|
|
229
228
|
type: Input
|
|
230
229
|
}], title: [{
|
|
231
230
|
type: Input
|
|
232
231
|
}] }); })();
|
|
233
232
|
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(ProductSelectComponent, { className: "ProductSelectComponent", filePath: "page-scaffold/page-header/common-layout/product-select/component.ts", lineNumber: 49 }); })();
|
|
234
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"component.js","sourceRoot":"","sources":["../../../../../../../../libs/common/src/page-scaffold/page-header/common-layout/product-select/component.ts","../../../../../../../../libs/common/src/page-scaffold/page-header/common-layout/product-select/component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  Input,\n  OnInit,\n} from '@angular/core';\nimport { Router } from '@angular/router';\nimport { get } from 'lodash-es';\nimport { combineLatest, map, switchMap } from 'rxjs';\n\nimport { redirectSSOEntry } from '../../../../authorization/authorization';\nimport {\n  StringMap,\n  ProductEntry,\n  publishRef,\n} from '../../../../core/public-api';\nimport { K8sPermissionService } from '../../../../permission/k8s-permission.service';\nimport { ProductEntryName } from '../context.service';\nimport { CommonLayoutStoreService } from '../store.service';\n\nimport { ProductSelectService } from './service';\n\nconst VIEW = {\n  type: 'views',\n  apiGroup: 'auth.alauda.io',\n};\n\nconst PREFIX = 'console-';\n\nexport const PRODUCT_ICON_MAP: StringMap = {\n  'console-acp': 'acp',\n  'console-asm': 'asm',\n  'console-devops': 'devops',\n  // console-e-aam prefix 为了兼容默认排序，等后续排序方案出来可以改成console-aam\n  'console-e-aam': 'app_store',\n  'console-security': 'bug_search',\n  'console-platform': 'platform_management',\n  'console-project': 'project_management',\n  'console-dataservices': 'data_services',\n  'console-cec': 'cloud_edge_collaboration',\n};\n\n@Component({\n  selector: 'acl-product-select',\n  templateUrl: './component.html',\n  styleUrls: ['./component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class ProductSelectComponent implements OnInit {\n  @Input()\n  current?: ProductEntryName;\n\n  @Input()\n  title?: string;\n\n  PRODUCT_ICON_MAP = PRODUCT_ICON_MAP;\n\n  allProducts$ = combineLatest([\n    this.productSelectService.reload$.pipe(\n      switchMap(() => this.store.selectAllProducts()),\n    ),\n    this.k8sPermission.isAllowed({\n      type: VIEW,\n      name: ['platformview', 'projectview'],\n    }),\n  ]).pipe(\n    map(([products, [consolePlatform, consoleProject]]) => {\n      const permissions: Record<string, boolean> = {\n        'console-platform': consolePlatform,\n        'console-project': consoleProject,\n      };\n      return products.filter(p => permissions[p.metadata.name] ?? true);\n    }),\n    publishRef(),\n  );\n\n  selectableProducts$ = this.allProducts$.pipe(\n    map(products =>\n      (products || []).filter(\n        product =>\n          !this.isPortalProduct(product) &&\n          (!product.status || product.status.hiddenOnPortal !== true),\n      ),\n    ),\n    publishRef(),\n  );\n\n  portalProduct$ = this.allProducts$.pipe(\n    map(res => res.find(p => this.isPortalProduct(p))),\n    publishRef(),\n  );\n\n  disabled$ = this.selectableProducts$.pipe(\n    map(products => !products.length),\n    publishRef(),\n  );\n\n  isPortal = false;\n\n  constructor(\n    private readonly store: CommonLayoutStoreService,\n    private readonly router: Router,\n    private readonly k8sPermission: K8sPermissionService,\n    private readonly productSelectService: ProductSelectService,\n  ) {}\n\n  ngOnInit() {\n    this.isPortal = this.router.url.startsWith('/portal');\n  }\n\n  jump(entrypoint: string, ssoEnabled: boolean, target = '_self') {\n    window.open(ssoEnabled ? redirectSSOEntry(entrypoint) : entrypoint, target);\n  }\n\n  navigateToPortal(event: MouseEvent) {\n    event.stopPropagation();\n    event.preventDefault();\n    window.open('/console-portal', '_self');\n  }\n\n  navigateToProduct(item: ProductEntry, event: MouseEvent) {\n    event.stopPropagation();\n    if (this.isProductActive(item, this.current)) {\n      return;\n    }\n    if (item.spec.packType === 'Integrated') {\n      this.jump(item.spec.entrypoint, item.spec.ssoEnabled, '_blank');\n    } else {\n      this.jump(item.spec.entrypoint, false);\n    }\n  }\n\n  trackFn = (_: number, item: ProductEntry) => item.metadata.name;\n\n  isProductActive(item: ProductEntry, current: ProductEntryName) {\n    return (\n      current &&\n      item.metadata.name ===\n        (current.startsWith(PREFIX) ? current : PREFIX + current)\n    );\n  }\n\n  isPortalProduct(item: ProductEntry) {\n    return item.metadata.name === 'console-portal';\n  }\n\n  getProductTitle = (\n    products: ProductEntry[],\n    title: string,\n    current: ProductEntryName,\n  ) =>\n    title ||\n    get(\n      (products || []).find(p => this.isProductActive(p, current)),\n      ['spec', 'displayName'],\n    );\n}\n","<button\n  class=\"acl-product-select\"\n  [auiTooltip]=\"menu\"\n  auiTooltipType=\"plain\"\n  auiTooltipTrigger=\"click\"\n  auiTooltipPosition=\"bottom start\"\n  auiTooltipClass=\"aui-product-select-tooltip\"\n  [auiTooltipHideOnClick]=\"true\"\n  [disabled]=\"disabled$ | async\"\n  [title]=\"\n    (disabled$ | async)\n      ? ''\n      : (allProducts$\n        | async\n        | pure: getProductTitle : title : current\n        | translate)\n  \"\n  [ngClass]=\"{ 'acl-product-select--disabled': disabled$ | async }\"\n>\n  <span\n    *ngIf=\"\n      allProducts$\n        | async\n        | pure: getProductTitle : title : current as productTitle\n    \"\n    class=\"acl-product-select__title\"\n  >\n    {{ productTitle | translate }}\n  </span>\n  <aui-icon\n    icon=\"menu_dot_s\"\n    size=\"16px\"\n    [auiTooltip]=\"'no_product_and_contact_admin' | translate\"\n    [auiTooltipDisabled]=\"!(disabled$ | async)\"\n    auiTooltipPosition=\"bottom start\"\n  ></aui-icon>\n</button>\n<ng-template #menu>\n  <div class=\"menu\">\n    <ng-container *ngIf=\"selectableProducts$ | async as products; else loading\">\n      <div\n        class=\"menu__item\"\n        [ngClass]=\"{\n          'menu__item--active': item | pure: isProductActive : current,\n        }\"\n        *ngFor=\"let item of products; trackBy: trackFn\"\n        (click)=\"navigateToProduct(item, $event)\"\n      >\n        <div class=\"menu__item-icon\">\n          <ng-container\n            *ngIf=\"\n              item.spec.packType !== 'Integrated' && !item.spec.logo;\n              else logo\n            \"\n          >\n            <aui-icon\n              class=\"acl-colorful-icon\"\n              [icon]=\"'bicolor:' + PRODUCT_ICON_MAP[item.metadata.name]\"\n            ></aui-icon>\n          </ng-container>\n          <ng-template #logo>\n            <img\n              [src]=\"\n                (item.spec.logo | aclImageHeader) ||\n                  'images/product-default-logo.png' | aclSafe: 'url'\n              \"\n              class=\"default\"\n            />\n          </ng-template>\n        </div>\n        <div class=\"menu__item-info\">\n          {{ item.spec.displayName | translate }}\n        </div>\n        <aui-icon\n          *ngIf=\"item | pure: isProductActive : current\"\n          class=\"check-triangle-badge\"\n          icon=\"check\"\n        ></aui-icon>\n      </div>\n    </ng-container>\n  </div>\n  <div\n    *ngIf=\"portalProduct$ | async as portalMenu\"\n    class=\"portal\"\n    [ngClass]=\"{ 'portal--active': isPortal }\"\n  >\n    <div\n      class=\"portal__item\"\n      (click)=\"navigateToPortal($event)\"\n    >\n      <aui-icon icon=\"home_s\"></aui-icon>\n      {{ portalMenu.spec.displayName | translate }}\n    </div>\n  </div>\n</ng-template>\n\n<ng-template #loading>\n  <acl-loading-mask\n    style=\"height: 148px\"\n    [loading]=\"true\"\n  ></acl-loading-mask>\n</ng-template>\n"]}
|
|
233
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"component.js","sourceRoot":"","sources":["../../../../../../../../libs/common/src/page-scaffold/page-header/common-layout/product-select/component.ts","../../../../../../../../libs/common/src/page-scaffold/page-header/common-layout/product-select/component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  Input,\n  OnInit,\n} from '@angular/core';\nimport { Router } from '@angular/router';\nimport { get } from 'lodash-es';\nimport { combineLatest, map, switchMap } from 'rxjs';\n\nimport { redirectSSOEntry } from '../../../../authorization/authorization';\nimport {\n  StringMap,\n  ProductEntry,\n  publishRef,\n} from '../../../../core/public-api';\nimport { K8sPermissionService } from '../../../../permission/k8s-permission.service';\nimport { ProductEntryName } from '../context.service';\nimport { CommonLayoutStoreService } from '../store.service';\n\nimport { ProductSelectService } from './service';\n\nconst VIEW = {\n  type: 'views',\n  apiGroup: 'auth.alauda.io',\n};\n\nconst PREFIX = 'console-';\n\nexport const PRODUCT_ICON_MAP: StringMap = {\n  'console-acp': 'acp',\n  'console-asm': 'asm',\n  'console-devops': 'devops',\n  // console-e-aam prefix 为了兼容默认排序，等后续排序方案出来可以改成console-aam\n  'console-e-aam': 'app_store',\n  'console-security': 'bug_search',\n  'console-platform': 'platform_management',\n  'console-project': 'project_management',\n  'console-dataservices': 'data_services',\n  'console-cec': 'cloud_edge_collaboration',\n};\n\n@Component({\n  selector: 'acl-product-select',\n  templateUrl: './component.html',\n  styleUrls: ['./component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class ProductSelectComponent implements OnInit {\n  @Input()\n  current?: ProductEntryName;\n\n  @Input()\n  title?: string;\n\n  PRODUCT_ICON_MAP = PRODUCT_ICON_MAP;\n\n  allProducts$ = combineLatest([\n    this.productSelectService.reload$.pipe(\n      switchMap(() => this.store.selectAllProducts()),\n    ),\n    this.k8sPermission.isAllowed({\n      type: VIEW,\n      name: ['platformview', 'projectview'],\n    }),\n  ]).pipe(\n    map(([products, [consolePlatform, consoleProject]]) => {\n      const permissions: Record<string, boolean> = {\n        'console-platform': consolePlatform,\n        'console-project': consoleProject,\n      };\n      return products.filter(p => permissions[p.metadata.name] ?? true);\n    }),\n    publishRef(),\n  );\n\n  selectableProducts$ = this.allProducts$.pipe(\n    map(products =>\n      (products || []).filter(\n        product =>\n          !this.isPortalProduct(product) &&\n          (!product.status || product.status.hiddenOnPortal !== true),\n      ),\n    ),\n    publishRef(),\n  );\n\n  portalProduct$ = this.allProducts$.pipe(\n    map(res => res.find(p => this.isPortalProduct(p))),\n    publishRef(),\n  );\n\n  disabled$ = this.selectableProducts$.pipe(\n    map(products => !products.length),\n    publishRef(),\n  );\n\n  isPortal = false;\n\n  constructor(\n    private readonly store: CommonLayoutStoreService,\n    private readonly router: Router,\n    private readonly k8sPermission: K8sPermissionService,\n    private readonly productSelectService: ProductSelectService,\n  ) {}\n\n  ngOnInit() {\n    this.isPortal = this.router.url.startsWith('/portal');\n  }\n\n  jump(entrypoint: string, ssoEnabled: boolean, target = '_self') {\n    window.open(ssoEnabled ? redirectSSOEntry(entrypoint) : entrypoint, target);\n  }\n\n  navigateToPortal(event: MouseEvent) {\n    event.stopPropagation();\n    event.preventDefault();\n    window.open('/console-portal', '_self');\n  }\n\n  navigateToProduct(item: ProductEntry, event: MouseEvent) {\n    event.stopPropagation();\n    if (this.isProductActive(item, this.current)) {\n      return;\n    }\n    if (item.spec.packType === 'Integrated') {\n      this.jump(item.spec.entrypoint, item.spec.ssoEnabled, '_blank');\n    } else {\n      this.jump(item.spec.entrypoint, false);\n    }\n  }\n\n  trackFn = (_: number, item: ProductEntry) => item.metadata.name;\n\n  isProductActive(item: ProductEntry, current: ProductEntryName) {\n    return (\n      current &&\n      item.metadata.name ===\n        (current.startsWith(PREFIX) ? current : PREFIX + current)\n    );\n  }\n\n  isPortalProduct(item: ProductEntry) {\n    return item.metadata.name === 'console-portal';\n  }\n\n  getProductTitle = (\n    products: ProductEntry[],\n    title: string,\n    current: ProductEntryName,\n  ) =>\n    title ||\n    get(\n      (products || []).find(p => this.isProductActive(p, current)),\n      ['spec', 'displayName'],\n    );\n}\n","<button\n  class=\"acl-product-select\"\n  [auiTooltip]=\"menu\"\n  auiTooltipType=\"plain\"\n  auiTooltipTrigger=\"click\"\n  auiTooltipPosition=\"bottom start\"\n  auiTooltipClass=\"aui-product-select-tooltip\"\n  [auiTooltipHideOnClick]=\"true\"\n  [disabled]=\"disabled$ | async\"\n  [title]=\"\n    (disabled$ | async)\n      ? ''\n      : (allProducts$\n        | async\n        | pure: getProductTitle : title : current\n        | translate)\n  \"\n  [ngClass]=\"{ 'acl-product-select--disabled': disabled$ | async }\"\n>\n  <span\n    *ngIf=\"\n      allProducts$\n        | async\n        | pure: getProductTitle : title : current as productTitle\n    \"\n    class=\"acl-product-select__title\"\n  >\n    {{ productTitle | translate }}\n  </span>\n  <aui-icon\n    icon=\"menu_dot_s\"\n    size=\"16px\"\n    [auiTooltip]=\"'no_product_and_contact_admin' | translate\"\n    [auiTooltipDisabled]=\"!(disabled$ | async)\"\n    auiTooltipPosition=\"bottom start\"\n  ></aui-icon>\n</button>\n<ng-template #menu>\n  <div class=\"menu\">\n    <ng-container *ngIf=\"selectableProducts$ | async as products; else loading\">\n      <div\n        class=\"menu__item\"\n        [ngClass]=\"{\n          'menu__item--active': item | pure: isProductActive : current,\n        }\"\n        *ngFor=\"let item of products; trackBy: trackFn\"\n        (click)=\"navigateToProduct(item, $event)\"\n      >\n        <div class=\"menu__item-icon\">\n          <ng-container\n            *ngIf=\"\n              item.spec.packType !== 'Integrated' && !item.spec.logo;\n              else logo\n            \"\n          >\n            <aui-icon\n              class=\"acl-colorful-icon\"\n              [icon]=\"'bicolor:' + PRODUCT_ICON_MAP[item.metadata.name]\"\n            ></aui-icon>\n          </ng-container>\n          <ng-template #logo>\n            <img\n              [src]=\"\n                (item.spec.logo | aclImageHeader) ||\n                'images/product-default-logo.png'\n              \"\n              class=\"default\"\n            />\n          </ng-template>\n        </div>\n        <div class=\"menu__item-info\">\n          {{ item.spec.displayName | translate }}\n        </div>\n        <aui-icon\n          *ngIf=\"item | pure: isProductActive : current\"\n          class=\"check-triangle-badge\"\n          icon=\"check\"\n        ></aui-icon>\n      </div>\n    </ng-container>\n  </div>\n  <div\n    *ngIf=\"portalProduct$ | async as portalMenu\"\n    class=\"portal\"\n    [ngClass]=\"{ 'portal--active': isPortal }\"\n  >\n    <div\n      class=\"portal__item\"\n      (click)=\"navigateToPortal($event)\"\n    >\n      <aui-icon icon=\"home_s\"></aui-icon>\n      {{ portalMenu.spec.displayName | translate }}\n    </div>\n  </div>\n</ng-template>\n\n<ng-template #loading>\n  <acl-loading-mask\n    style=\"height: 148px\"\n    [loading]=\"true\"\n  ></acl-loading-mask>\n</ng-template>\n"]}
|