UNPKG

@alauda-fe/common

Version:

Alauda frontend team common codes.

89 lines 13.8 kB
import { __decorate, __metadata } from "tslib"; import { MultiSelectComponent } from '@alauda/ui'; import { ChangeDetectorRef, Directive, ElementRef, Input, Optional, Renderer2, ViewContainerRef, } from '@angular/core'; import { ValueHook } from '../../core/public-api'; import * as i0 from "@angular/core"; import * as i1 from "@alauda/ui"; export const PREFIX_LABEL_CLASS = 'acl-select-prefix__label'; const PREFIX_LABEL_WRAPPER_CLASS = 'acl-select-prefix__wrapper'; // 补全父级div的padding-left: 7px和prefixLabel的margin-right: 8px; const PREFIX_LABEL_PLACEHOLDER_PADDING_LEFT_FIX = 7 + 8; const AUI_SELECT_CLASS = 'aui-select'; const AUI_MULTI_SELECT_CLASS = 'aui-multi-select'; const AUI_MULTI_SELECT_SUFFIX_CLASS = 'aui-multi-select__suffix'; const AUI_MULTI_SELECT_PLACEHOLDER_CLASS = 'aui-multi-select__placeholder'; // NOTE: 提供此指令,是由于个人不支持此组件行为,不建议直接引入aui,希望作为业务上的尝试,因此提供指令以供删改 // 纯css无法提供本问题的完整解决方案,若有更优方案,请删除此部分代码,以及 acl-select-prefix mixin export class SelectPrefixLabelDirective { queryElementByClassName(className) { return this.elementRef.nativeElement?.querySelector(`.${className}`); } createInlineLabel(value, className = PREFIX_LABEL_CLASS) { const label = this.renderer.createElement('span'); this.renderer.addClass(label, className); if (typeof value === 'string') { // 此处加上 ':' 是由于 template 时无需分隔符,不希望再加入额外的class进行控制 label.textContent = `${value}:`; } else { const view = this.viewContainerRef.createEmbeddedView(value); const templateElement = view.rootNodes[0]; label.append(templateElement); } return label; } insertNode(container, value, refChild) { let inlineLabel = this.queryElementByClassName(PREFIX_LABEL_CLASS); if (inlineLabel) { inlineLabel.remove(); } inlineLabel = this.createInlineLabel(value); this.renderer.insertBefore(container, inlineLabel, refChild, false); const placeholder = this.queryElementByClassName(AUI_MULTI_SELECT_PLACEHOLDER_CLASS); if (placeholder) { placeholder.style.paddingLeft = `${inlineLabel.offsetWidth + PREFIX_LABEL_PLACEHOLDER_PADDING_LEFT_FIX}px`; } } constructor(elementRef, renderer, viewContainerRef, multiSelectComponent) { this.elementRef = elementRef; this.renderer = renderer; this.viewContainerRef = viewContainerRef; this.multiSelectComponent = multiSelectComponent; } static { this.ɵfac = function SelectPrefixLabelDirective_Factory(t) { return new (t || SelectPrefixLabelDirective)(i0.ɵɵdirectiveInject(i0.ElementRef), i0.ɵɵdirectiveInject(i0.Renderer2), i0.ɵɵdirectiveInject(i0.ViewContainerRef), i0.ɵɵdirectiveInject(i1.MultiSelectComponent, 8)); }; } static { this.ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: SelectPrefixLabelDirective, selectors: [["aui-select", "aclPrefixLabel", ""], ["aui-multi-select", "aclPrefixLabel", ""]], inputs: { aclPrefixLabel: "aclPrefixLabel" }, standalone: true }); } } __decorate([ ValueHook(function (value) { requestAnimationFrame(() => { if (!value) { return; } // 适配 multi select if (this.multiSelectComponent) { const container = this.queryElementByClassName(AUI_MULTI_SELECT_CLASS); const childRef = this.queryElementByClassName(AUI_MULTI_SELECT_SUFFIX_CLASS); this.insertNode(container, value, childRef); } else { const container = this.queryElementByClassName(AUI_SELECT_CLASS); this.renderer.addClass(container, PREFIX_LABEL_WRAPPER_CLASS); this.insertNode(container, value); } this.viewContainerRef.injector.get(ChangeDetectorRef).markForCheck(); }); }), __metadata("design:type", Object) ], SelectPrefixLabelDirective.prototype, "aclPrefixLabel", void 0); (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(SelectPrefixLabelDirective, [{ type: Directive, args: [{ selector: 'aui-select[aclPrefixLabel],aui-multi-select[aclPrefixLabel]', standalone: true, }] }], () => [{ type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i0.ViewContainerRef }, { type: i1.MultiSelectComponent, decorators: [{ type: Optional }] }], { aclPrefixLabel: [{ type: Input }] }); })(); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"directive.js","sourceRoot":"","sources":["../../../../../../libs/common/src/widget/select-prefix-label/directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { MultiSelectComponent } from '@alauda/ui';\nimport {\n  ChangeDetectorRef,\n  Directive,\n  ElementRef,\n  Input,\n  Optional,\n  Renderer2,\n  TemplateRef,\n  ViewContainerRef,\n} from '@angular/core';\n\nimport { ValueHook } from '../../core/public-api';\n\nexport const PREFIX_LABEL_CLASS = 'acl-select-prefix__label';\nconst PREFIX_LABEL_WRAPPER_CLASS = 'acl-select-prefix__wrapper';\n// 补全父级div的padding-left: 7px和prefixLabel的margin-right: 8px;\nconst PREFIX_LABEL_PLACEHOLDER_PADDING_LEFT_FIX = 7 + 8;\nconst AUI_SELECT_CLASS = 'aui-select';\nconst AUI_MULTI_SELECT_CLASS = 'aui-multi-select';\nconst AUI_MULTI_SELECT_SUFFIX_CLASS = 'aui-multi-select__suffix';\nconst AUI_MULTI_SELECT_PLACEHOLDER_CLASS = 'aui-multi-select__placeholder';\n\n// NOTE: 提供此指令，是由于个人不支持此组件行为，不建议直接引入aui，希望作为业务上的尝试，因此提供指令以供删改\n// 纯css无法提供本问题的完整解决方案,若有更优方案，请删除此部分代码，以及 acl-select-prefix mixin\n@Directive({\n  selector: 'aui-select[aclPrefixLabel],aui-multi-select[aclPrefixLabel]',\n  standalone: true,\n})\nexport class SelectPrefixLabelDirective {\n  @ValueHook(function (\n    this: SelectPrefixLabelDirective,\n    value: string | TemplateRef<any>,\n  ) {\n    requestAnimationFrame(() => {\n      if (!value) {\n        return;\n      }\n      // 适配 multi select\n      if (this.multiSelectComponent) {\n        const container = this.queryElementByClassName(AUI_MULTI_SELECT_CLASS);\n        const childRef = this.queryElementByClassName(\n          AUI_MULTI_SELECT_SUFFIX_CLASS,\n        );\n        this.insertNode(container, value, childRef);\n      } else {\n        const container = this.queryElementByClassName(AUI_SELECT_CLASS);\n        this.renderer.addClass(container, PREFIX_LABEL_WRAPPER_CLASS);\n        this.insertNode(container, value);\n      }\n      this.viewContainerRef.injector.get(ChangeDetectorRef).markForCheck();\n    });\n  })\n  @Input()\n  aclPrefixLabel: string | TemplateRef<any>;\n\n  queryElementByClassName(className: string) {\n    return (this.elementRef.nativeElement as HTMLElement)?.querySelector(\n      `.${className}`,\n    );\n  }\n\n  createInlineLabel(\n    value: string | TemplateRef<any>,\n    className = PREFIX_LABEL_CLASS,\n  ) {\n    const label = this.renderer.createElement('span') as HTMLSpanElement;\n    this.renderer.addClass(label, className);\n\n    if (typeof value === 'string') {\n      // 此处加上 ':' 是由于 template 时无需分隔符，不希望再加入额外的class进行控制\n      label.textContent = `${value}:`;\n    } else {\n      const view = this.viewContainerRef.createEmbeddedView(value);\n      const templateElement = view.rootNodes[0] as HTMLElement;\n      label.append(templateElement);\n    }\n\n    return label;\n  }\n\n  insertNode(\n    container: Element,\n    value: string | TemplateRef<any>,\n    refChild?: Element,\n  ) {\n    let inlineLabel = this.queryElementByClassName(\n      PREFIX_LABEL_CLASS,\n    ) as HTMLSpanElement;\n    if (inlineLabel) {\n      inlineLabel.remove();\n    }\n\n    inlineLabel = this.createInlineLabel(value);\n    this.renderer.insertBefore(container, inlineLabel, refChild, false);\n    const placeholder = this.queryElementByClassName(\n      AUI_MULTI_SELECT_PLACEHOLDER_CLASS,\n    ) as HTMLSpanElement;\n    if (placeholder) {\n      placeholder.style.paddingLeft = `${\n        inlineLabel.offsetWidth + PREFIX_LABEL_PLACEHOLDER_PADDING_LEFT_FIX\n      }px`;\n    }\n  }\n\n  constructor(\n    private readonly elementRef: ElementRef,\n    private readonly renderer: Renderer2,\n    private readonly viewContainerRef: ViewContainerRef,\n    @Optional()\n    private readonly multiSelectComponent: MultiSelectComponent,\n  ) {}\n}\n"]}