UNPKG

@taiga-ui/addon-doc

Version:

Taiga UI based library for developing documentation portals for Angular libraries.

134 lines 19.1 kB
import { Location } from '@angular/common'; import { Directive, EventEmitter, inject, Input, Output, signal, TemplateRef, } from '@angular/core'; import { ActivatedRoute, UrlSerializer } from '@angular/router'; import { TUI_DOC_URL_STATE_HANDLER } from '@taiga-ui/addon-doc/tokens'; import { tuiCleanObject, tuiCoerceValue, tuiInspectAny } from '@taiga-ui/addon-doc/utils'; import { tuiIsNumber } from '@taiga-ui/cdk/utils/miscellaneous'; import { TuiAlertService } from '@taiga-ui/core/components/alert'; import { Subject } from 'rxjs'; import * as i0 from "@angular/core"; const SERIALIZED_SUFFIX = '$'; // @bad TODO: refactor output and value sync class TuiDocDocumentationPropertyConnector { constructor() { this.locationRef = inject(Location); this.activatedRoute = inject(ActivatedRoute); this.urlSerializer = inject(UrlSerializer); this.urlStateHandler = inject(TUI_DOC_URL_STATE_HANDLER); this.alerts = inject(TuiAlertService); this.documentationPropertyName = ''; this.documentationPropertyMode = null; this.documentationPropertyType = ''; this.documentationPropertyDeprecated = false; this.documentationPropertyValues = null; this.documentationPropertyValueChange = new EventEmitter(); this.changed$ = new Subject(); this.emits = signal(1); this.template = inject(TemplateRef); } get attrName() { switch (this.documentationPropertyMode) { case 'input': return `[${this.documentationPropertyName}]`; case 'input-output': return `[(${this.documentationPropertyName})]`; case 'output': return `(${this.documentationPropertyName})`; default: return this.documentationPropertyName; } } get shouldShowValues() { return this.documentationPropertyMode !== 'output'; } get hasItems() { return !!this.documentationPropertyValues; } ngOnInit() { this.parseParams(this.activatedRoute.snapshot.queryParams); } ngOnChanges() { this.changed$.next(); } onValueChange(value) { this.documentationPropertyValue = value; this.documentationPropertyValueChange.emit(value); this.setQueryParam(value); } emitEvent(event) { // For more convenient debugging console.info(this.attrName, event); this.emits.update((x) => ++x); let content; if (event !== undefined) { content = tuiInspectAny(event, 2); } this.alerts.open(content, { label: this.attrName }).subscribe(); } parseParams(params) { const propertyValue = params[this.documentationPropertyName]; const propertyValueWithSuffix = params[`${this.documentationPropertyName}${SERIALIZED_SUFFIX}`]; if (!propertyValue && !propertyValueWithSuffix) { return; } let value = !!propertyValueWithSuffix && this.documentationPropertyValues ? this.documentationPropertyValues[propertyValueWithSuffix] : tuiCoerceValue(propertyValue); if (this.documentationPropertyType === 'string' && tuiIsNumber(value)) { value = value.toString(); } this.onValueChange(value); } setQueryParam(value) { const tree = this.urlSerializer.parse(this.locationRef.path()); const isValueAvailableByKey = value instanceof Object; const name = this.documentationPropertyName; const nameWithSuffix = `${name}${SERIALIZED_SUFFIX}`; const computedValue = isValueAvailableByKey && this.documentationPropertyValues ? this.documentationPropertyValues.indexOf(value) : value; tree.queryParams = tuiCleanObject({ ...tree.queryParams, /** * Caretaker note: reset previous conflicted param in route * issue: https://github.com/taiga-family/taiga-ui/issues/9764 */ ...(isValueAvailableByKey ? { [nameWithSuffix]: computedValue, [name]: undefined, } : { [nameWithSuffix]: undefined, [name]: computedValue, }), }); this.locationRef.go(this.urlStateHandler(tree)); } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiDocDocumentationPropertyConnector, deps: [], target: i0.ɵɵFactoryTarget.Directive }); } static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: TuiDocDocumentationPropertyConnector, isStandalone: true, selector: "ng-template[documentationPropertyName]", inputs: { documentationPropertyName: "documentationPropertyName", documentationPropertyMode: "documentationPropertyMode", documentationPropertyType: "documentationPropertyType", documentationPropertyValue: "documentationPropertyValue", documentationPropertyDeprecated: "documentationPropertyDeprecated", documentationPropertyValues: "documentationPropertyValues" }, outputs: { documentationPropertyValueChange: "documentationPropertyValueChange" }, exportAs: ["documentationProperty"], usesOnChanges: true, ngImport: i0 }); } } export { TuiDocDocumentationPropertyConnector }; i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiDocDocumentationPropertyConnector, decorators: [{ type: Directive, args: [{ standalone: true, selector: 'ng-template[documentationPropertyName]', exportAs: 'documentationProperty', }] }], propDecorators: { documentationPropertyName: [{ type: Input }], documentationPropertyMode: [{ type: Input }], documentationPropertyType: [{ type: Input }], documentationPropertyValue: [{ type: Input }], documentationPropertyDeprecated: [{ type: Input }], documentationPropertyValues: [{ type: Input }], documentationPropertyValueChange: [{ type: Output }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"documentation-property-connector.directive.js","sourceRoot":"","sources":["../../../../../projects/addon-doc/components/documentation/documentation-property-connector.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {Location} from '@angular/common';\nimport type {OnChanges, OnInit} from '@angular/core';\nimport {\n    Directive,\n    EventEmitter,\n    inject,\n    Input,\n    Output,\n    signal,\n    TemplateRef,\n} from '@angular/core';\nimport type {Params} from '@angular/router';\nimport {ActivatedRoute, UrlSerializer} from '@angular/router';\nimport {TUI_DOC_URL_STATE_HANDLER} from '@taiga-ui/addon-doc/tokens';\nimport {tuiCleanObject, tuiCoerceValue, tuiInspectAny} from '@taiga-ui/addon-doc/utils';\nimport {tuiIsNumber} from '@taiga-ui/cdk/utils/miscellaneous';\nimport {TuiAlertService} from '@taiga-ui/core/components/alert';\nimport {Subject} from 'rxjs';\n\nconst SERIALIZED_SUFFIX = '$';\n\nexport type TuiDocumentationPropertyType = 'input-output' | 'input' | 'output' | null;\n\n// @bad TODO: refactor output and value sync\n@Directive({\n    standalone: true,\n    selector: 'ng-template[documentationPropertyName]',\n    exportAs: 'documentationProperty',\n})\nexport class TuiDocDocumentationPropertyConnector<T> implements OnInit, OnChanges {\n    private readonly locationRef = inject(Location);\n    private readonly activatedRoute = inject(ActivatedRoute);\n    private readonly urlSerializer = inject(UrlSerializer);\n    private readonly urlStateHandler = inject(TUI_DOC_URL_STATE_HANDLER);\n    private readonly alerts = inject(TuiAlertService);\n\n    @Input()\n    public documentationPropertyName = '';\n\n    @Input()\n    public documentationPropertyMode: TuiDocumentationPropertyType = null;\n\n    @Input()\n    public documentationPropertyType = '';\n\n    @Input()\n    public documentationPropertyValue!: T;\n\n    @Input()\n    public documentationPropertyDeprecated = false;\n\n    @Input()\n    public documentationPropertyValues: readonly T[] | null = null;\n\n    @Output()\n    public readonly documentationPropertyValueChange = new EventEmitter<T>();\n\n    public readonly changed$ = new Subject<void>();\n\n    public readonly emits = signal(1);\n\n    public readonly template = inject(TemplateRef);\n\n    public get attrName(): string {\n        switch (this.documentationPropertyMode) {\n            case 'input':\n                return `[${this.documentationPropertyName}]`;\n            case 'input-output':\n                return `[(${this.documentationPropertyName})]`;\n            case 'output':\n                return `(${this.documentationPropertyName})`;\n            default:\n                return this.documentationPropertyName;\n        }\n    }\n\n    public get shouldShowValues(): boolean {\n        return this.documentationPropertyMode !== 'output';\n    }\n\n    public get hasItems(): boolean {\n        return !!this.documentationPropertyValues;\n    }\n\n    public ngOnInit(): void {\n        this.parseParams(this.activatedRoute.snapshot.queryParams);\n    }\n\n    public ngOnChanges(): void {\n        this.changed$.next();\n    }\n\n    public onValueChange(value: T): void {\n        this.documentationPropertyValue = value;\n        this.documentationPropertyValueChange.emit(value);\n        this.setQueryParam(value);\n    }\n\n    public emitEvent(event: unknown): void {\n        // For more convenient debugging\n        console.info(this.attrName, event);\n\n        this.emits.update((x) => ++x);\n\n        let content: string | undefined;\n\n        if (event !== undefined) {\n            content = tuiInspectAny(event, 2);\n        }\n\n        this.alerts.open(content, {label: this.attrName}).subscribe();\n    }\n\n    private parseParams(params: Params): void {\n        const propertyValue: string | undefined = params[this.documentationPropertyName];\n        const propertyValueWithSuffix: number | string | undefined =\n            params[`${this.documentationPropertyName}${SERIALIZED_SUFFIX}`];\n\n        if (!propertyValue && !propertyValueWithSuffix) {\n            return;\n        }\n\n        let value =\n            !!propertyValueWithSuffix && this.documentationPropertyValues\n                ? this.documentationPropertyValues[propertyValueWithSuffix as number]\n                : tuiCoerceValue(propertyValue);\n\n        if (this.documentationPropertyType === 'string' && tuiIsNumber(value)) {\n            value = value.toString();\n        }\n\n        this.onValueChange(value as T);\n    }\n\n    private setQueryParam(value: unknown): void {\n        const tree = this.urlSerializer.parse(this.locationRef.path());\n        const isValueAvailableByKey = value instanceof Object;\n        const name = this.documentationPropertyName;\n        const nameWithSuffix = `${name}${SERIALIZED_SUFFIX}`;\n\n        const computedValue =\n            isValueAvailableByKey && this.documentationPropertyValues\n                ? this.documentationPropertyValues.indexOf(value as T)\n                : value;\n\n        tree.queryParams = tuiCleanObject({\n            ...tree.queryParams,\n            /**\n             * Caretaker note: reset previous conflicted param in route\n             * issue: https://github.com/taiga-family/taiga-ui/issues/9764\n             */\n            ...(isValueAvailableByKey\n                ? {\n                      [nameWithSuffix]: computedValue,\n                      [name]: undefined,\n                  }\n                : {\n                      [nameWithSuffix]: undefined,\n                      [name]: computedValue,\n                  }),\n        });\n\n        this.locationRef.go(this.urlStateHandler(tree));\n    }\n}\n"]}