@taiga-ui/addon-doc
Version:
Taiga UI based library for developing documentation portals for Angular libraries.
134 lines • 19.1 kB
JavaScript
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"]}