@alauda-fe/common
Version:
Alauda frontend team common codes.
212 lines • 27 kB
JavaScript
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"]}