UNPKG

@alauda-fe/common

Version:

Alauda frontend team common codes.

212 lines 27 kB
import { FORM_MODULE, SelectModule, TooltipDirective, } from '@alauda/ui'; import { AsyncPipe, NgForOf, NgIf, NgTemplateOutlet } from '@angular/common'; import { Component, ChangeDetectionStrategy, Input, Output, EventEmitter, forwardRef, TemplateRef, ChangeDetectorRef, } from '@angular/core'; import { FormsModule, NG_VALUE_ACCESSOR, } from '@angular/forms'; import { BehaviorSubject } from 'rxjs'; import { PurePipe, noop } from '../../core/public-api'; import { EffectDirectiveModule } from '../../effect-directive/module'; import { TranslateModule } from '../../translate/public-api'; import { SelectPrefixLabelDirective } from '../../widget/select-prefix-label/directive'; import { DEFAULT_LIMIT_COUNT, ALL_VALUE, checkValueExit } from './util'; import * as i0 from "@angular/core"; import * as i1 from "@angular/forms"; import * as i2 from "../../translate/translate.pipe"; import * as i3 from "@alauda/ui"; import * as i4 from "../../effect-directive/e2e-attribute-binding.directive"; import * as i5 from "../../effect-directive/validators.directive"; const _c0 = a0 => ({ count: a0 }); const _c1 = a0 => ({ $implicit: a0 }); const _c2 = a0 => ({ resource: a0 }); const _c3 = a0 => ({ resource: a0, inOption: true }); function ResourceMultiSelectComponent_aui_option_group_3_ng_container_2_Template(rf, ctx) { if (rf & 1) { i0.ɵɵelementContainer(0); } } function ResourceMultiSelectComponent_aui_option_group_3_Template(rf, ctx) { if (rf & 1) { i0.ɵɵelementStart(0, "aui-option-group")(1, "aui-option", 3); i0.ɵɵtemplate(2, ResourceMultiSelectComponent_aui_option_group_3_ng_container_2_Template, 1, 0, "ng-container", 4); i0.ɵɵelementEnd()(); } if (rf & 2) { const ctx_r0 = i0.ɵɵnextContext(); i0.ɵɵadvance(); i0.ɵɵproperty("value", ctx_r0.ALL_VALUE)("label", ctx_r0.allOptionTemplate); i0.ɵɵadvance(); i0.ɵɵproperty("ngTemplateOutlet", ctx_r0.allOptionTemplate)("ngTemplateOutletContext", i0.ɵɵpureFunction1(4, _c1, ctx_r0.allOptionTemplateContext)); } } function ResourceMultiSelectComponent_aui_option_5_Template(rf, ctx) { if (rf & 1) { i0.ɵɵelementStart(0, "aui-option", 5); i0.ɵɵpipe(1, "async"); i0.ɵɵpipe(2, "pure"); i0.ɵɵpipe(3, "translate"); i0.ɵɵelementContainer(4, 6); i0.ɵɵelementEnd(); } if (rf & 2) { const option_r2 = ctx.$implicit; const ctx_r0 = i0.ɵɵnextContext(); i0.ɵɵproperty("value", option_r2)("label", ctx_r0.optionTemplate)("disabled", i0.ɵɵpipeBind3(2, 10, option_r2, ctx_r0.disableOption, i0.ɵɵpipeBind1(1, 8, ctx_r0.values$$)))("auiTooltip", i0.ɵɵpipeBind2(3, 14, "multi_select_limit", i0.ɵɵpureFunction1(17, _c0, ctx_r0.limit)))("auiTooltipDisabled", !ctx_r0.countLimited ? true : !ctx_r0.isPartial)("labelContext", i0.ɵɵpureFunction1(19, _c2, option_r2)); i0.ɵɵadvance(4); i0.ɵɵproperty("ngTemplateOutlet", ctx_r0.optionTemplate)("ngTemplateOutletContext", i0.ɵɵpureFunction1(21, _c3, option_r2)); } } export class ResourceMultiSelectComponent { constructor(cdr) { this.cdr = cdr; this.limit = DEFAULT_LIMIT_COUNT; this.disabled = false; this.required = false; this.readonly = false; this.placeholder = ''; this.countLimited = true; this.filter = (filter, option) => option.value?.includes(filter); this.trackBy = (val) => val; this.allowEmpty = false; this.valueChange = new EventEmitter(); this.values$$ = new BehaviorSubject([]); this.values = []; this.isSelectAllOption = false; this.isPartial = false; this.ALL_VALUE = ALL_VALUE; this.onChange = noop; this.onTouched = noop; this.disableOption = (checkedValue, values) => { this.isPartial = false; if (!checkedValue) { return false; } if (this.isSelectAllOption) { return true; } // 如果不限制个数直接返回 false if (!this.countLimited) { return false; } if (values?.length === this.limit && values?.length < this.list?.length) { this.isPartial = true; return !checkValueExit(checkedValue, values); } return false; }; this.filterFn = (filter, option) => { const value = option.value; if (value === ALL_VALUE) { return true; } return this.filter?.(filter, option); }; this.trackByFn = (value) => { if (value === ALL_VALUE) { return ALL_VALUE; } return this.trackBy?.(value); }; } writeValue(values) { this.values$$.next(values); this.isSelectAllOption = checkValueExit(ALL_VALUE, values); this.cdr.markForCheck(); } registerOnChange(fn) { this.onChange = fn; } registerOnTouched(fn) { this.onTouched = fn; } onValueChange(values) { this.isSelectAllOption = checkValueExit(ALL_VALUE, values); const currentValue = this.isSelectAllOption ? [ALL_VALUE] : values; this.values$$.next(currentValue); this.valueChange.emit(currentValue); this.onChange(currentValue); this.onTouched(); } static { this.ɵfac = function ResourceMultiSelectComponent_Factory(t) { return new (t || ResourceMultiSelectComponent)(i0.ɵɵdirectiveInject(i0.ChangeDetectorRef)); }; } static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: ResourceMultiSelectComponent, selectors: [["acl-resource-multi-select"]], inputs: { list: "list", limit: "limit", prefixLabel: "prefixLabel", disabled: "disabled", required: "required", readonly: "readonly", allOptionTemplate: "allOptionTemplate", allOptionTemplateContext: "allOptionTemplateContext", optionTemplate: "optionTemplate", placeholder: "placeholder", countLimited: "countLimited", filter: "filter", trackBy: "trackBy", allowEmpty: "allowEmpty" }, outputs: { valueChange: "valueChange" }, standalone: true, features: [i0.ɵɵProvidersFeature([ { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => ResourceMultiSelectComponent), multi: true, }, ]), i0.ɵɵStandaloneFeature], decls: 9, vars: 23, consts: [["auiFormItemControl", "", 3, "ngModelChange", "ngModel", "filterFn", "trackFn", "aclPrefixLabel", "placeholder", "maxRowCount", "disabled", "required", "readonly", "filterable", "clearable"], [4, "ngIf"], [3, "value", "label", "disabled", "auiTooltip", "auiTooltipDisabled", "labelContext", 4, "ngFor", "ngForOf"], [3, "value", "label"], [4, "ngTemplateOutlet", "ngTemplateOutletContext"], [3, "value", "label", "disabled", "auiTooltip", "auiTooltipDisabled", "labelContext"], [3, "ngTemplateOutlet", "ngTemplateOutletContext"]], template: function ResourceMultiSelectComponent_Template(rf, ctx) { if (rf & 1) { i0.ɵɵelementStart(0, "aui-multi-select", 0); i0.ɵɵpipe(1, "async"); i0.ɵɵpipe(2, "translate"); i0.ɵɵlistener("ngModelChange", function ResourceMultiSelectComponent_Template_aui_multi_select_ngModelChange_0_listener($event) { return ctx.onValueChange($event); }); i0.ɵɵtemplate(3, ResourceMultiSelectComponent_aui_option_group_3_Template, 3, 6, "aui-option-group", 1); i0.ɵɵelementStart(4, "aui-option-group"); i0.ɵɵtemplate(5, ResourceMultiSelectComponent_aui_option_5_Template, 5, 23, "aui-option", 2); i0.ɵɵelementEnd(); i0.ɵɵelementStart(6, "aui-option-placeholder"); i0.ɵɵtext(7); i0.ɵɵpipe(8, "translate"); i0.ɵɵelementEnd()(); } if (rf & 2) { i0.ɵɵproperty("ngModel", i0.ɵɵpipeBind1(1, 14, ctx.values$$))("filterFn", ctx.filterFn)("trackFn", ctx.trackByFn)("aclPrefixLabel", ctx.prefixLabel)("placeholder", ctx.placeholder || ctx.countLimited ? i0.ɵɵpipeBind2(2, 16, "multi_select_limit", i0.ɵɵpureFunction1(21, _c0, ctx.limit)) : "")("maxRowCount", 6)("disabled", ctx.disabled)("required", ctx.required)("readonly", ctx.readonly)("filterable", true)("clearable", true); i0.ɵɵadvance(3); i0.ɵɵproperty("ngIf", ctx.allOptionTemplate && (ctx.list == null ? null : ctx.list.length) || ctx.allowEmpty); i0.ɵɵadvance(2); i0.ɵɵproperty("ngForOf", ctx.list); i0.ɵɵadvance(2); i0.ɵɵtextInterpolate1(" ", i0.ɵɵpipeBind1(8, 19, "no_data"), " "); } }, dependencies: [FormsModule, i1.NgControlStatus, i1.RequiredValidator, i1.NgModel, AsyncPipe, NgIf, TranslateModule, i2.TranslatePipe, SelectModule, i3.OptionComponent, i3.OptionGroupComponent, i3.OptionPlaceholderComponent, i3.MultiSelectComponent, NgForOf, NgTemplateOutlet, PurePipe, TooltipDirective, i3.FormItemControlDirective, SelectPrefixLabelDirective, EffectDirectiveModule, i4.E2eAttributeBindingDirective, i5.ValidatorsDirective], encapsulation: 2, changeDetection: 0 }); } } (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(ResourceMultiSelectComponent, [{ type: Component, args: [{ selector: 'acl-resource-multi-select', changeDetection: ChangeDetectionStrategy.OnPush, providers: [ { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => ResourceMultiSelectComponent), multi: true, }, ], standalone: true, imports: [ FormsModule, AsyncPipe, NgIf, TranslateModule, SelectModule, NgForOf, NgTemplateOutlet, PurePipe, TooltipDirective, ...FORM_MODULE, SelectPrefixLabelDirective, EffectDirectiveModule, ], template: "<aui-multi-select\n [ngModel]=\"values$$ | async\"\n auiFormItemControl\n [filterFn]=\"filterFn\"\n [trackFn]=\"trackByFn\"\n (ngModelChange)=\"onValueChange($event)\"\n [aclPrefixLabel]=\"prefixLabel\"\n [placeholder]=\"\n placeholder || countLimited\n ? ('multi_select_limit' | translate: { count: limit })\n : ''\n \"\n [maxRowCount]=\"6\"\n [disabled]=\"disabled\"\n [required]=\"required\"\n [readonly]=\"readonly\"\n [filterable]=\"true\"\n [clearable]=\"true\"\n>\n <aui-option-group *ngIf=\"(allOptionTemplate && list?.length) || allowEmpty\">\n <aui-option\n [value]=\"ALL_VALUE\"\n [label]=\"allOptionTemplate\"\n >\n <ng-container\n *ngTemplateOutlet=\"\n allOptionTemplate;\n context: { $implicit: allOptionTemplateContext }\n \"\n ></ng-container>\n </aui-option>\n </aui-option-group>\n\n <aui-option-group>\n <aui-option\n *ngFor=\"let option of list\"\n [value]=\"option\"\n [label]=\"optionTemplate\"\n [disabled]=\"option | pure: disableOption:(values$$ | async)\"\n [auiTooltip]=\"'multi_select_limit' | translate: { count: limit }\"\n [auiTooltipDisabled]=\"!countLimited ? true : !isPartial\"\n [labelContext]=\"{ resource: option }\"\n >\n <ng-container\n [ngTemplateOutlet]=\"optionTemplate\"\n [ngTemplateOutletContext]=\"{ resource: option, inOption: true }\"\n ></ng-container>\n </aui-option>\n </aui-option-group>\n <aui-option-placeholder>\n {{ 'no_data' | translate }}\n </aui-option-placeholder>\n</aui-multi-select>\n" }] }], () => [{ type: i0.ChangeDetectorRef }], { list: [{ type: Input }], limit: [{ type: Input }], prefixLabel: [{ type: Input }], disabled: [{ type: Input }], required: [{ type: Input }], readonly: [{ type: Input }], allOptionTemplate: [{ type: Input }], allOptionTemplateContext: [{ type: Input }], optionTemplate: [{ type: Input }], placeholder: [{ type: Input }], countLimited: [{ type: Input }], filter: [{ type: Input }], trackBy: [{ type: Input }], allowEmpty: [{ type: Input }], valueChange: [{ type: Output }] }); })(); (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(ResourceMultiSelectComponent, { className: "ResourceMultiSelectComponent" }); })(); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"component.js","sourceRoot":"","sources":["../../../../../../libs/common/src/widget/resource-multi-select/component.ts","../../../../../../libs/common/src/widget/resource-multi-select/template.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  FORM_MODULE,\n  OptionFilterFn,\n  SelectFilterOption,\n  SelectModule,\n  TooltipDirective,\n  TrackFn,\n} from '@alauda/ui';\nimport { AsyncPipe, NgForOf, NgIf, NgTemplateOutlet } from '@angular/common';\nimport {\n  Component,\n  ChangeDetectionStrategy,\n  Input,\n  Output,\n  EventEmitter,\n  forwardRef,\n  TemplateRef,\n  ChangeDetectorRef,\n} from '@angular/core';\nimport {\n  ControlValueAccessor,\n  FormsModule,\n  NG_VALUE_ACCESSOR,\n} from '@angular/forms';\nimport { BehaviorSubject } from 'rxjs';\n\nimport { PurePipe, StringMap, noop } from '../../core/public-api';\nimport { EffectDirectiveModule } from '../../effect-directive/module';\nimport { TranslateModule } from '../../translate/public-api';\nimport { SelectPrefixLabelDirective } from '../../widget/select-prefix-label/directive';\n\nimport { DEFAULT_LIMIT_COUNT, ALL_VALUE, checkValueExit } from './util';\n\n@Component({\n  selector: 'acl-resource-multi-select',\n  templateUrl: './template.html',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => ResourceMultiSelectComponent),\n      multi: true,\n    },\n  ],\n  standalone: true,\n  imports: [\n    FormsModule,\n    AsyncPipe,\n    NgIf,\n    TranslateModule,\n    SelectModule,\n    NgForOf,\n    NgTemplateOutlet,\n    PurePipe,\n    TooltipDirective,\n    ...FORM_MODULE,\n    SelectPrefixLabelDirective,\n    EffectDirectiveModule,\n  ],\n})\nexport class ResourceMultiSelectComponent implements ControlValueAccessor {\n  @Input()\n  list: string[];\n\n  @Input()\n  limit: number = DEFAULT_LIMIT_COUNT;\n\n  @Input()\n  prefixLabel: string;\n\n  @Input()\n  disabled = false;\n\n  @Input()\n  required = false;\n\n  @Input()\n  readonly = false;\n\n  @Input()\n  allOptionTemplate: TemplateRef<any>;\n\n  @Input()\n  allOptionTemplateContext: StringMap;\n\n  @Input()\n  optionTemplate: TemplateRef<any>;\n\n  @Input()\n  placeholder = '';\n\n  @Input()\n  countLimited = true;\n\n  @Input()\n  filter: OptionFilterFn<string> = (\n    filter: string,\n    option: SelectFilterOption<string>,\n  ) => option.value?.includes(filter);\n\n  @Input()\n  trackBy: TrackFn<string> = (val: string) => val;\n\n  @Input()\n  allowEmpty = false;\n\n  @Output()\n  valueChange = new EventEmitter<string[]>();\n\n  values$$ = new BehaviorSubject<string[]>([]);\n  values: string[] = [];\n  isSelectAllOption = false;\n  isPartial = false;\n  ALL_VALUE = ALL_VALUE;\n\n  constructor(private readonly cdr: ChangeDetectorRef) {}\n\n  writeValue(values: string[]) {\n    this.values$$.next(values);\n    this.isSelectAllOption = checkValueExit(ALL_VALUE as string, values);\n    this.cdr.markForCheck();\n  }\n\n  onChange = noop;\n\n  onTouched = noop;\n\n  registerOnChange(fn: () => void) {\n    this.onChange = fn;\n  }\n\n  registerOnTouched(fn: () => void) {\n    this.onTouched = fn;\n  }\n\n  disableOption = (checkedValue: string, values: string[]) => {\n    this.isPartial = false;\n    if (!checkedValue) {\n      return false;\n    }\n\n    if (this.isSelectAllOption) {\n      return true;\n    }\n    // 如果不限制个数直接返回 false\n    if (!this.countLimited) {\n      return false;\n    }\n    if (values?.length === this.limit && values?.length < this.list?.length) {\n      this.isPartial = true;\n      return !checkValueExit(checkedValue, values);\n    }\n    return false;\n  };\n\n  onValueChange(values: string[]) {\n    this.isSelectAllOption = checkValueExit(ALL_VALUE as string, values);\n    const currentValue = this.isSelectAllOption\n      ? [ALL_VALUE as string]\n      : values;\n    this.values$$.next(currentValue);\n    this.valueChange.emit(currentValue);\n    this.onChange(currentValue);\n    this.onTouched();\n  }\n\n  filterFn = (filter: string, option: SelectFilterOption<string>) => {\n    const value = option.value;\n    if (value === ALL_VALUE) {\n      return true;\n    }\n    return this.filter?.(filter, option);\n  };\n\n  trackByFn = (value: string) => {\n    if (value === ALL_VALUE) {\n      return ALL_VALUE;\n    }\n    return this.trackBy?.(value);\n  };\n}\n","<aui-multi-select\n  [ngModel]=\"values$$ | async\"\n  auiFormItemControl\n  [filterFn]=\"filterFn\"\n  [trackFn]=\"trackByFn\"\n  (ngModelChange)=\"onValueChange($event)\"\n  [aclPrefixLabel]=\"prefixLabel\"\n  [placeholder]=\"\n    placeholder || countLimited\n      ? ('multi_select_limit' | translate: { count: limit })\n      : ''\n  \"\n  [maxRowCount]=\"6\"\n  [disabled]=\"disabled\"\n  [required]=\"required\"\n  [readonly]=\"readonly\"\n  [filterable]=\"true\"\n  [clearable]=\"true\"\n>\n  <aui-option-group *ngIf=\"(allOptionTemplate && list?.length) || allowEmpty\">\n    <aui-option\n      [value]=\"ALL_VALUE\"\n      [label]=\"allOptionTemplate\"\n    >\n      <ng-container\n        *ngTemplateOutlet=\"\n          allOptionTemplate;\n          context: { $implicit: allOptionTemplateContext }\n        \"\n      ></ng-container>\n    </aui-option>\n  </aui-option-group>\n\n  <aui-option-group>\n    <aui-option\n      *ngFor=\"let option of list\"\n      [value]=\"option\"\n      [label]=\"optionTemplate\"\n      [disabled]=\"option | pure: disableOption:(values$$ | async)\"\n      [auiTooltip]=\"'multi_select_limit' | translate: { count: limit }\"\n      [auiTooltipDisabled]=\"!countLimited ? true : !isPartial\"\n      [labelContext]=\"{ resource: option }\"\n    >\n      <ng-container\n        [ngTemplateOutlet]=\"optionTemplate\"\n        [ngTemplateOutletContext]=\"{ resource: option, inOption: true }\"\n      ></ng-container>\n    </aui-option>\n  </aui-option-group>\n  <aui-option-placeholder>\n    {{ 'no_data' | translate }}\n  </aui-option-placeholder>\n</aui-multi-select>\n"]}