@seniorsistemas/angular-components 17.16.1 → 17.16.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/bundles/seniorsistemas-angular-components.umd.js +20 -0
- package/bundles/seniorsistemas-angular-components.umd.js.map +1 -1
- package/bundles/seniorsistemas-angular-components.umd.min.js +1 -1
- package/bundles/seniorsistemas-angular-components.umd.min.js.map +1 -1
- package/components/tiered-menu/utils.d.ts +2 -0
- package/components/utils/index.d.ts +1 -0
- package/components/utils/utils.d.ts +1 -0
- package/esm2015/components/table/table-column/table-columns.component.js +6 -3
- package/esm2015/components/tiered-menu/components/tiered-menu/tiered-menu.component.js +7 -1
- package/esm2015/components/tiered-menu/components/tiered-menu-nested/tiered-menu-nested.component.js +5 -2
- package/esm2015/components/tiered-menu/tiered-menu.directive.js +3 -1
- package/esm2015/components/tiered-menu/utils.js +7 -0
- package/esm2015/components/utils/index.js +2 -1
- package/esm2015/components/utils/utils.js +2 -0
- package/esm5/components/table/table-column/table-columns.component.js +4 -1
- package/esm5/components/tiered-menu/components/tiered-menu/tiered-menu.component.js +7 -1
- package/esm5/components/tiered-menu/components/tiered-menu-nested/tiered-menu-nested.component.js +5 -2
- package/esm5/components/tiered-menu/tiered-menu.directive.js +3 -1
- package/esm5/components/tiered-menu/utils.js +7 -0
- package/esm5/components/utils/index.js +2 -1
- package/esm5/components/utils/utils.js +2 -0
- package/fesm2015/seniorsistemas-angular-components.js +22 -3
- package/fesm2015/seniorsistemas-angular-components.js.map +1 -1
- package/fesm5/seniorsistemas-angular-components.js +20 -1
- package/fesm5/seniorsistemas-angular-components.js.map +1 -1
- package/package.json +1 -1
- package/seniorsistemas-angular-components.metadata.json +1 -1
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare const isNullOrUndefined: (value: unknown) => boolean;
|
|
@@ -9,6 +9,7 @@ import { EnumColumnFieldType } from "./models";
|
|
|
9
9
|
import { LocaleService } from "../../locale/locale.service";
|
|
10
10
|
import { convertToMomentDateFormat } from "../../utils/locale-utils";
|
|
11
11
|
import { NumericService } from "../../locale/services/numeric.service";
|
|
12
|
+
import { isNullOrUndefined } from "../../utils/utils";
|
|
12
13
|
const moment = moment_;
|
|
13
14
|
let TableColumnsComponent = class TableColumnsComponent {
|
|
14
15
|
constructor(localeService, viewContainerRef, translate, numericService, hostProjectConfigs) {
|
|
@@ -64,8 +65,8 @@ let TableColumnsComponent = class TableColumnsComponent {
|
|
|
64
65
|
const columns = ((_a = changes.columns) === null || _a === void 0 ? void 0 : _a.currentValue) || this.columns;
|
|
65
66
|
const rowValue = ((_b = changes.rowValue) === null || _b === void 0 ? void 0 : _b.currentValue) || this.rowValue;
|
|
66
67
|
const locale = ((_c = changes.locale) === null || _c === void 0 ? void 0 : _c.currentValue) || this.locale;
|
|
67
|
-
this.formattedColumns = columns.map(column => this.getColumnValue(column, rowValue, locale));
|
|
68
|
-
this.cellsData = this.formattedColumns.map(column => this.getCellData(column));
|
|
68
|
+
this.formattedColumns = columns.map((column) => this.getColumnValue(column, rowValue, locale));
|
|
69
|
+
this.cellsData = this.formattedColumns.map((column) => this.getCellData(column));
|
|
69
70
|
this.viewContainerRef.createEmbeddedView(this.columnsTemplate);
|
|
70
71
|
}
|
|
71
72
|
getColumnSeparator(column) {
|
|
@@ -75,8 +76,10 @@ let TableColumnsComponent = class TableColumnsComponent {
|
|
|
75
76
|
return column.prefix ? column.prefix : `${this.hostProjectConfigs.domain}.${this.hostProjectConfigs.service}.`;
|
|
76
77
|
}
|
|
77
78
|
isAttributeValueInvalid(attributeValue) {
|
|
79
|
+
var _a;
|
|
78
80
|
return (attributeValue === null ||
|
|
79
81
|
attributeValue === undefined ||
|
|
82
|
+
(((_a = attributeValue === null || attributeValue === void 0 ? void 0 : attributeValue.options) === null || _a === void 0 ? void 0 : _a.numberFormatOptions) && isNullOrUndefined(attributeValue === null || attributeValue === void 0 ? void 0 : attributeValue.value)) ||
|
|
80
83
|
(this.isArray(attributeValue) && !attributeValue.length) ||
|
|
81
84
|
(typeof attributeValue === "string" && attributeValue.trim() === ""));
|
|
82
85
|
}
|
|
@@ -262,4 +265,4 @@ TableColumnsComponent = __decorate([
|
|
|
262
265
|
__param(4, Inject(HostProjectConfigsInjectionToken))
|
|
263
266
|
], TableColumnsComponent);
|
|
264
267
|
export { TableColumnsComponent };
|
|
265
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-columns.component.js","sourceRoot":"ng://@seniorsistemas/angular-components/","sources":["components/table/table-column/table-columns.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Inject, Input, OnChanges, SimpleChanges, TemplateRef, ViewChild, ViewContainerRef } from \"@angular/core\";\n\nimport { TranslateService } from \"@ngx-translate/core\";\nimport { MaskConfig, applyMask } from \"@seniorsistemas/ng2-currency-mask\";\nimport BigNumber from \"bignumber.js\";\nimport * as moment_ from \"moment\";\n\nimport { HostProjectConfigs, HostProjectConfigsInjectionToken } from \"../../../angular-components.module\";\nimport { IToken } from \"../../token-list\";\nimport { Column, ColumnValues, EnumColumnFieldType, TableColumnLocaleOptions } from \"./models\";\nimport { LocaleService } from \"../../locale/locale.service\";\nimport { convertToMomentDateFormat } from \"../../utils/locale-utils\";\nimport { NumericService } from \"../../locale/services/numeric.service\";\n\nconst moment = moment_;\n\n@Component({\n    templateUrl: \"./table-columns.component.html\",\n    styleUrls: [\"./table-columns.component.scss\"],\n    selector: \"s-table-columns\",\n})\nexport class TableColumnsComponent implements OnChanges {\n    @ViewChild(\"columnsTemplate\", { static: true }) columnsTemplate: TemplateRef<any>;\n\n    @Input()\n    public columns!: Column[];\n\n    @Input()\n    public rowValue!: any;\n\n    @Input()\n    public locale: TableColumnLocaleOptions = {\n        calendar: {\n            ...this.localeService.getLocaleOptions().calendar,\n            dateFormat: convertToMomentDateFormat(this.localeService.getLocaleOptions().calendar.dateFormat),\n        },\n        number: {\n            ...this.localeService.getLocaleOptions().number,\n            scale: 0,\n        },\n    };\n\n    cellsData: CellData[] = [];\n\n    formattedColumns: ColumnValues[] = [];\n\n    constructor(\n        private readonly localeService: LocaleService,\n        private readonly viewContainerRef: ViewContainerRef,\n        private readonly translate: TranslateService,\n        private readonly numericService: NumericService,\n        @Inject(HostProjectConfigsInjectionToken) private readonly hostProjectConfigs: HostProjectConfigs\n    ) {}\n\n    ngOnChanges(changes: SimpleChanges): void {\n        this.validateComponentAttributes(changes);\n\n        if (changes.columns && changes.columns.currentValue !== changes.columns.previousValue) {\n            this.columns = this.sortColumnsBySequence(changes.columns.currentValue);\n        }\n\n        this.createColumnsTemplate(changes);\n\n    }\n\n    public isArray(value: any): boolean {\n        return Array.isArray(value);\n    }\n\n    private getCellData(column: ColumnValues): CellData {\n        const { columnValue, separator, uninformed } = column;\n\n        if (typeof columnValue === \"string\") {\n            const splittedString = columnValue.split(separator);\n\n            return splittedString.map((string, index) => {\n                const isLastIndex = splittedString.length - 1 === index;\n\n                return {\n                    value: string,\n                    isUninformed: string === uninformed,\n                    separator: !isLastIndex ? separator : null,\n                };\n            });\n        }\n\n        return null;\n    }\n\n    private validateComponentAttributes(changes: SimpleChanges): void {\n        if (!this.columns && !changes.columns?.currentValue) {\n            throw new Error(\"The 'columns' attribute must be informed!\");\n        }\n        if (!this.rowValue && !changes.rowValue?.currentValue) {\n            throw new Error(\"The 'rowValue' attribute must be informed!\");\n        }\n    }\n\n    private createColumnsTemplate(changes: SimpleChanges): void {\n        this.viewContainerRef.clear();\n\n        const columns: Column[] = changes.columns?.currentValue || this.columns;\n        const rowValue: object = changes.rowValue?.currentValue || this.rowValue;\n        const locale: TableColumnLocaleOptions = changes.locale?.currentValue || this.locale;\n\n        this.formattedColumns = columns.map(column => this.getColumnValue(column, rowValue, locale));\n\n        this.cellsData = this.formattedColumns.map(column => this.getCellData(column));\n\n        this.viewContainerRef.createEmbeddedView(this.columnsTemplate);\n    }\n\n    private getColumnSeparator(column: Column) {\n        return column.separator ? column.separator : \" - \";\n    }\n\n    private getTranslationPrefix(column: Column) {\n        return column.prefix ? column.prefix : `${this.hostProjectConfigs.domain}.${this.hostProjectConfigs.service}.`;\n    }\n\n    private isAttributeValueInvalid(attributeValue: any) {\n        return (\n            attributeValue === null ||\n            attributeValue === undefined ||\n            (this.isArray(attributeValue) && !attributeValue.length) ||\n            (typeof attributeValue === \"string\" && attributeValue.trim() === \"\")\n        );\n    }\n\n    private getFormattedColumnValue(\n        column: Column,\n        columnValue: any[],\n        unifiedColumnValues: string,\n        uninformedText: string,\n        uninformedNumber: number\n    ) {\n        if (uninformedNumber === column.attributes.length) {\n            return uninformedText;\n        }\n\n        if (column.type === EnumColumnFieldType.TOKENS) {\n            return [].concat.apply(\n                [],\n                columnValue.filter((values) => values !== uninformedText)\n            );\n        }\n\n        return unifiedColumnValues;\n    }\n\n    private getAttributeValue(attribute: string, rowValue: object) {\n        let attributeValue!: any;\n\n        attribute.split(\"/\").forEach((value: string) => {\n            if (!attributeValue) {\n                value.split(\".\").forEach((val: string, i) => {\n                    if (!rowValue) {\n                        return;\n                    }\n\n                    if (i === 0) {\n                        attributeValue = rowValue[val];\n                    } else {\n                        if (attributeValue) {\n                            attributeValue = attributeValue[val];\n                        }\n                    }\n                });\n            }\n        });\n\n        return attributeValue;\n    }\n\n    private getNumberConfigs(column: Column): MaskConfig {\n        return {\n            ...this.locale.number,\n            scale: column.scale !== null && column.scale !== undefined ? this.getColumnScale(column.scale) : this.locale.number.scale,\n            prefix: `${this.locale.number.currencySymbol} `,\n        };\n    }\n\n    private getDateFormat(column: Column, locale: TableColumnLocaleOptions) {\n        return column.dateFormat ? column.dateFormat : locale.calendar.dateFormat;\n    }\n\n    private getColumnValue(column: Column, rowValue: object, locale: TableColumnLocaleOptions): ColumnValues {\n        const prefix = this.getTranslationPrefix(column);\n        const separator = this.getColumnSeparator(column);\n        const uninformed = this.translate.instant(prefix + \"empty_label\");\n        const style = column.style;\n\n        const columnValue = column.attributes.map((attribute: string) => {\n            const attributeValue = this.getAttributeValue(attribute, rowValue);\n\n            if (this.isAttributeValueInvalid(attributeValue)) {\n                return uninformed;\n            }\n\n            const numberConfigs = this.getNumberConfigs(column);\n\n            switch (column.type) {\n                case EnumColumnFieldType.ENUM:\n                    return this.translate.instant(column.enumPrefix + attributeValue.toString().toLowerCase());\n\n                case EnumColumnFieldType.CURRENCY:\n                    return attributeValue?.options?.numberFormatOptions\n                        ? this.numericService.instant(attributeValue.value, {\n                              numberFormatOptions: attributeValue.options.numberFormatOptions,\n                          })\n                        : applyMask(attributeValue, numberConfigs, this.isNumber(attributeValue));\n\n                case EnumColumnFieldType.DATE:\n                    const dateFormat = this.getDateFormat(column, locale);\n                    return moment(attributeValue).format(dateFormat);\n\n                case EnumColumnFieldType.BOOLEAN:\n                    const value = attributeValue ? \"yes\" : \"no\";\n                    return this.translate.instant(prefix + value);\n\n                case EnumColumnFieldType.NUMBER:\n                    numberConfigs.prefix = \"\";\n\n                    return attributeValue?.options?.numberFormatOptions\n                        ? this.numericService.instant(attributeValue.value, {\n                              numberFormatOptions: attributeValue.options.numberFormatOptions,\n                          })\n                        : column.numberFormatOptions\n                          ? this.numericService.instant(attributeValue, {\n                                numberFormatOptions: column.numberFormatOptions,\n                            })\n                          : applyMask(attributeValue, numberConfigs, this.isNumber(attributeValue));\n\n                case EnumColumnFieldType.TOKENS:\n                    return this.getTokens(attributeValue);\n\n                default:\n                    return attributeValue;\n            }\n        });\n\n        const unifiedColumnValues = columnValue.join(separator);\n        const uninformedNumber = unifiedColumnValues.split(separator).filter((value) => value === uninformed).length;\n        const formattedColumnValue = this.getFormattedColumnValue(column, columnValue, unifiedColumnValues, uninformed, uninformedNumber);\n\n        return {\n            style,\n            columnValue: formattedColumnValue,\n            separator,\n            uninformed,\n            badgeConfigs: column?.badgeConfigs?.find(\n                (badgeConfig) => badgeConfig.enumValue === rowValue[column.attributes[0] ?? column.field]\n            ),\n            type: column.type,\n            tooltip: this.getColumnTooltip(column.tooltip),\n            infoSign: this.getColumnInfoSign(column.infoSign),\n            onLinkClick: column.onLinkClick,\n            onColumnClick: column.onColumnClick,\n        };\n    }\n\n    private getColumnScale(scale: number | ((rowValue: any) => number)): number {\n        if (typeof scale === \"function\") {\n            return scale(this.rowValue);\n        }\n        return scale;\n    }\n\n    private getColumnInfoSign(infoSign: string | ((rowValue: any) => string)): string {\n        if (infoSign !== undefined && infoSign !== null) {\n            if (typeof infoSign === \"function\") {\n                return infoSign(this.rowValue);\n            }\n            return infoSign;\n        }\n        return null;\n    }\n\n    private getColumnTooltip(tooltip: string | ((rowValue: any) => string)): string {\n        if (tooltip !== undefined && tooltip !== null) {\n            if (typeof tooltip === \"function\") {\n                return tooltip(this.rowValue);\n            }\n            return tooltip;\n        }\n        return \"\";\n    }\n\n    private isNumber(value: any): boolean {\n        return !new BigNumber(value).isNaN();\n    }\n\n    private getTokens(values: any): IToken[] {\n        if (!this.isArray(values)) {\n            throw new Error(\"To use tokens an array must be informed\");\n        }\n\n        if (!this.isValidTokenArray(values)) {\n            throw new Error(\"Not a valid token array. Must be a primitive values array or an objects with label attribute array\");\n        }\n\n        if (this.isLabelObjectArray(values)) {\n            return values;\n        }\n\n        return values\n            .filter((value: any) => value !== undefined && value !== null)\n            .map((value: any) => {\n                const label = typeof value === \"symbol\" ? value.toString() : `${value}`;\n                return {\n                    label,\n                };\n            });\n    }\n\n    private isValidTokenArray(values: any[]): boolean {\n        return this.isPrimitiveValuesArray(values) || this.isLabelObjectArray(values);\n    }\n\n    private isPrimitiveValuesArray(values: any[]): boolean {\n        return values.filter((value) => value !== Object(value)).length === values.length;\n    }\n\n    private isLabelObjectArray(values: any[]): boolean {\n        return values.filter((value) => value?.label !== null && value?.label !== undefined).length === values.length;\n    }\n\n    private sortColumnsBySequence(columns: Column[]): Column[] {\n        return columns.sort((a, b) => a.sequence - b.sequence);\n    }\n}\n\ntype CellData = { value: string; isUninformed: boolean; separator: string }[];\n"]}
|
|
268
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"table-columns.component.js","sourceRoot":"ng://@seniorsistemas/angular-components/","sources":["components/table/table-column/table-columns.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Inject, Input, OnChanges, SimpleChanges, TemplateRef, ViewChild, ViewContainerRef } from \"@angular/core\";\n\nimport { TranslateService } from \"@ngx-translate/core\";\nimport { MaskConfig, applyMask } from \"@seniorsistemas/ng2-currency-mask\";\nimport BigNumber from \"bignumber.js\";\nimport * as moment_ from \"moment\";\n\nimport { HostProjectConfigs, HostProjectConfigsInjectionToken } from \"../../../angular-components.module\";\nimport { IToken } from \"../../token-list\";\nimport { Column, ColumnValues, EnumColumnFieldType, TableColumnLocaleOptions } from \"./models\";\nimport { LocaleService } from \"../../locale/locale.service\";\nimport { convertToMomentDateFormat } from \"../../utils/locale-utils\";\nimport { NumericService } from \"../../locale/services/numeric.service\";\nimport { isNullOrUndefined } from \"../../utils/utils\";\n\nconst moment = moment_;\n\n@Component({\n    templateUrl: \"./table-columns.component.html\",\n    styleUrls: [\"./table-columns.component.scss\"],\n    selector: \"s-table-columns\",\n})\nexport class TableColumnsComponent implements OnChanges {\n    @ViewChild(\"columnsTemplate\", { static: true }) columnsTemplate: TemplateRef<any>;\n\n    @Input()\n    public columns!: Column[];\n\n    @Input()\n    public rowValue!: any;\n\n    @Input()\n    public locale: TableColumnLocaleOptions = {\n        calendar: {\n            ...this.localeService.getLocaleOptions().calendar,\n            dateFormat: convertToMomentDateFormat(this.localeService.getLocaleOptions().calendar.dateFormat),\n        },\n        number: {\n            ...this.localeService.getLocaleOptions().number,\n            scale: 0,\n        },\n    };\n\n    cellsData: CellData[] = [];\n\n    formattedColumns: ColumnValues[] = [];\n\n    constructor(\n        private readonly localeService: LocaleService,\n        private readonly viewContainerRef: ViewContainerRef,\n        private readonly translate: TranslateService,\n        private readonly numericService: NumericService,\n        @Inject(HostProjectConfigsInjectionToken) private readonly hostProjectConfigs: HostProjectConfigs\n    ) {}\n\n    ngOnChanges(changes: SimpleChanges): void {\n        this.validateComponentAttributes(changes);\n\n        if (changes.columns && changes.columns.currentValue !== changes.columns.previousValue) {\n            this.columns = this.sortColumnsBySequence(changes.columns.currentValue);\n        }\n\n        this.createColumnsTemplate(changes);\n    }\n\n    public isArray(value: any): boolean {\n        return Array.isArray(value);\n    }\n\n    private getCellData(column: ColumnValues): CellData {\n        const { columnValue, separator, uninformed } = column;\n\n        if (typeof columnValue === \"string\") {\n            const splittedString = columnValue.split(separator);\n\n            return splittedString.map((string, index) => {\n                const isLastIndex = splittedString.length - 1 === index;\n\n                return {\n                    value: string,\n                    isUninformed: string === uninformed,\n                    separator: !isLastIndex ? separator : null,\n                };\n            });\n        }\n\n        return null;\n    }\n\n    private validateComponentAttributes(changes: SimpleChanges): void {\n        if (!this.columns && !changes.columns?.currentValue) {\n            throw new Error(\"The 'columns' attribute must be informed!\");\n        }\n        if (!this.rowValue && !changes.rowValue?.currentValue) {\n            throw new Error(\"The 'rowValue' attribute must be informed!\");\n        }\n    }\n\n    private createColumnsTemplate(changes: SimpleChanges): void {\n        this.viewContainerRef.clear();\n\n        const columns: Column[] = changes.columns?.currentValue || this.columns;\n        const rowValue: object = changes.rowValue?.currentValue || this.rowValue;\n        const locale: TableColumnLocaleOptions = changes.locale?.currentValue || this.locale;\n\n        this.formattedColumns = columns.map((column) => this.getColumnValue(column, rowValue, locale));\n\n        this.cellsData = this.formattedColumns.map((column) => this.getCellData(column));\n\n        this.viewContainerRef.createEmbeddedView(this.columnsTemplate);\n    }\n\n    private getColumnSeparator(column: Column) {\n        return column.separator ? column.separator : \" - \";\n    }\n\n    private getTranslationPrefix(column: Column) {\n        return column.prefix ? column.prefix : `${this.hostProjectConfigs.domain}.${this.hostProjectConfigs.service}.`;\n    }\n\n    private isAttributeValueInvalid(attributeValue: any) {\n        return (\n            attributeValue === null ||\n            attributeValue === undefined ||\n            (attributeValue?.options?.numberFormatOptions && isNullOrUndefined(attributeValue?.value)) ||\n            (this.isArray(attributeValue) && !attributeValue.length) ||\n            (typeof attributeValue === \"string\" && attributeValue.trim() === \"\")\n        );\n    }\n\n    private getFormattedColumnValue(\n        column: Column,\n        columnValue: any[],\n        unifiedColumnValues: string,\n        uninformedText: string,\n        uninformedNumber: number\n    ) {\n        if (uninformedNumber === column.attributes.length) {\n            return uninformedText;\n        }\n\n        if (column.type === EnumColumnFieldType.TOKENS) {\n            return [].concat.apply(\n                [],\n                columnValue.filter((values) => values !== uninformedText)\n            );\n        }\n\n        return unifiedColumnValues;\n    }\n\n    private getAttributeValue(attribute: string, rowValue: object) {\n        let attributeValue!: any;\n\n        attribute.split(\"/\").forEach((value: string) => {\n            if (!attributeValue) {\n                value.split(\".\").forEach((val: string, i) => {\n                    if (!rowValue) {\n                        return;\n                    }\n\n                    if (i === 0) {\n                        attributeValue = rowValue[val];\n                    } else {\n                        if (attributeValue) {\n                            attributeValue = attributeValue[val];\n                        }\n                    }\n                });\n            }\n        });\n\n        return attributeValue;\n    }\n\n    private getNumberConfigs(column: Column): MaskConfig {\n        return {\n            ...this.locale.number,\n            scale: column.scale !== null && column.scale !== undefined ? this.getColumnScale(column.scale) : this.locale.number.scale,\n            prefix: `${this.locale.number.currencySymbol} `,\n        };\n    }\n\n    private getDateFormat(column: Column, locale: TableColumnLocaleOptions) {\n        return column.dateFormat ? column.dateFormat : locale.calendar.dateFormat;\n    }\n\n    private getColumnValue(column: Column, rowValue: object, locale: TableColumnLocaleOptions): ColumnValues {\n        const prefix = this.getTranslationPrefix(column);\n        const separator = this.getColumnSeparator(column);\n        const uninformed = this.translate.instant(prefix + \"empty_label\");\n        const style = column.style;\n\n        const columnValue = column.attributes.map((attribute: string) => {\n            const attributeValue = this.getAttributeValue(attribute, rowValue);\n\n            if (this.isAttributeValueInvalid(attributeValue)) {\n                return uninformed;\n            }\n\n            const numberConfigs = this.getNumberConfigs(column);\n\n            switch (column.type) {\n                case EnumColumnFieldType.ENUM:\n                    return this.translate.instant(column.enumPrefix + attributeValue.toString().toLowerCase());\n\n                case EnumColumnFieldType.CURRENCY:\n                    return attributeValue?.options?.numberFormatOptions\n                        ? this.numericService.instant(attributeValue.value, {\n                              numberFormatOptions: attributeValue.options.numberFormatOptions,\n                          })\n                        : applyMask(attributeValue, numberConfigs, this.isNumber(attributeValue));\n\n                case EnumColumnFieldType.DATE:\n                    const dateFormat = this.getDateFormat(column, locale);\n                    return moment(attributeValue).format(dateFormat);\n\n                case EnumColumnFieldType.BOOLEAN:\n                    const value = attributeValue ? \"yes\" : \"no\";\n                    return this.translate.instant(prefix + value);\n\n                case EnumColumnFieldType.NUMBER:\n                    numberConfigs.prefix = \"\";\n\n                    return attributeValue?.options?.numberFormatOptions\n                        ? this.numericService.instant(attributeValue.value, {\n                              numberFormatOptions: attributeValue.options.numberFormatOptions,\n                          })\n                        : column.numberFormatOptions\n                          ? this.numericService.instant(attributeValue, {\n                                numberFormatOptions: column.numberFormatOptions,\n                            })\n                          : applyMask(attributeValue, numberConfigs, this.isNumber(attributeValue));\n\n                case EnumColumnFieldType.TOKENS:\n                    return this.getTokens(attributeValue);\n\n                default:\n                    return attributeValue;\n            }\n        });\n\n        const unifiedColumnValues = columnValue.join(separator);\n        const uninformedNumber = unifiedColumnValues.split(separator).filter((value) => value === uninformed).length;\n        const formattedColumnValue = this.getFormattedColumnValue(column, columnValue, unifiedColumnValues, uninformed, uninformedNumber);\n\n        return {\n            style,\n            columnValue: formattedColumnValue,\n            separator,\n            uninformed,\n            badgeConfigs: column?.badgeConfigs?.find(\n                (badgeConfig) => badgeConfig.enumValue === rowValue[column.attributes[0] ?? column.field]\n            ),\n            type: column.type,\n            tooltip: this.getColumnTooltip(column.tooltip),\n            infoSign: this.getColumnInfoSign(column.infoSign),\n            onLinkClick: column.onLinkClick,\n            onColumnClick: column.onColumnClick,\n        };\n    }\n\n    private getColumnScale(scale: number | ((rowValue: any) => number)): number {\n        if (typeof scale === \"function\") {\n            return scale(this.rowValue);\n        }\n        return scale;\n    }\n\n    private getColumnInfoSign(infoSign: string | ((rowValue: any) => string)): string {\n        if (infoSign !== undefined && infoSign !== null) {\n            if (typeof infoSign === \"function\") {\n                return infoSign(this.rowValue);\n            }\n            return infoSign;\n        }\n        return null;\n    }\n\n    private getColumnTooltip(tooltip: string | ((rowValue: any) => string)): string {\n        if (tooltip !== undefined && tooltip !== null) {\n            if (typeof tooltip === \"function\") {\n                return tooltip(this.rowValue);\n            }\n            return tooltip;\n        }\n        return \"\";\n    }\n\n    private isNumber(value: any): boolean {\n        return !new BigNumber(value).isNaN();\n    }\n\n    private getTokens(values: any): IToken[] {\n        if (!this.isArray(values)) {\n            throw new Error(\"To use tokens an array must be informed\");\n        }\n\n        if (!this.isValidTokenArray(values)) {\n            throw new Error(\"Not a valid token array. Must be a primitive values array or an objects with label attribute array\");\n        }\n\n        if (this.isLabelObjectArray(values)) {\n            return values;\n        }\n\n        return values\n            .filter((value: any) => value !== undefined && value !== null)\n            .map((value: any) => {\n                const label = typeof value === \"symbol\" ? value.toString() : `${value}`;\n                return {\n                    label,\n                };\n            });\n    }\n\n    private isValidTokenArray(values: any[]): boolean {\n        return this.isPrimitiveValuesArray(values) || this.isLabelObjectArray(values);\n    }\n\n    private isPrimitiveValuesArray(values: any[]): boolean {\n        return values.filter((value) => value !== Object(value)).length === values.length;\n    }\n\n    private isLabelObjectArray(values: any[]): boolean {\n        return values.filter((value) => value?.label !== null && value?.label !== undefined).length === values.length;\n    }\n\n    private sortColumnsBySequence(columns: Column[]): Column[] {\n        return columns.sort((a, b) => a.sequence - b.sequence);\n    }\n}\n\ntype CellData = { value: string; isUninformed: boolean; separator: string }[];\n"]}
|
|
@@ -5,6 +5,7 @@ import { Subject } from "rxjs";
|
|
|
5
5
|
import { takeUntil } from "rxjs/operators";
|
|
6
6
|
import { TieredMenuEventService } from "../../services/tiered-menu.event.service";
|
|
7
7
|
import { TieredMenuService } from "../../services/tiered-menu.service";
|
|
8
|
+
import { enableScroll, disabledScroll } from "../../utils";
|
|
8
9
|
let TieredMenuComponent = TieredMenuComponent_1 = class TieredMenuComponent {
|
|
9
10
|
constructor(_appRef, _componentFactoryResolver, _injector, _changeDetectorRef, tieredMenuService, _tieredMenuEventService) {
|
|
10
11
|
this._appRef = _appRef;
|
|
@@ -71,6 +72,7 @@ let TieredMenuComponent = TieredMenuComponent_1 = class TieredMenuComponent {
|
|
|
71
72
|
ngOnInit() {
|
|
72
73
|
this.tieredMenuService.currentItems = this.items;
|
|
73
74
|
this._subscribeEvents();
|
|
75
|
+
disabledScroll();
|
|
74
76
|
}
|
|
75
77
|
ngOnDestroy() {
|
|
76
78
|
this._unsubscribe$.next();
|
|
@@ -201,6 +203,7 @@ let TieredMenuComponent = TieredMenuComponent_1 = class TieredMenuComponent {
|
|
|
201
203
|
this.tieredMenuService.currentItem = null;
|
|
202
204
|
this.tieredMenuService.currentItems = this.tieredMenuService.items;
|
|
203
205
|
this.tieredMenuService.markAllItemsAsClosed(this.tieredMenuService.items);
|
|
206
|
+
enableScroll();
|
|
204
207
|
});
|
|
205
208
|
// Open item menu event.
|
|
206
209
|
this._tieredMenuEventService.openItemMenuEvent.pipe(takeUntil(this._unsubscribe$)).subscribe((item) => {
|
|
@@ -239,6 +242,9 @@ let TieredMenuComponent = TieredMenuComponent_1 = class TieredMenuComponent {
|
|
|
239
242
|
if (item.parent) {
|
|
240
243
|
item.parent.isOpen = false;
|
|
241
244
|
}
|
|
245
|
+
else {
|
|
246
|
+
enableScroll();
|
|
247
|
+
}
|
|
242
248
|
this.tieredMenuService.currentItems = ((_b = (_a = item === null || item === void 0 ? void 0 : item.parent) === null || _a === void 0 ? void 0 : _a.parent) === null || _b === void 0 ? void 0 : _b.submenu) || this.tieredMenuService.items;
|
|
243
249
|
this.tieredMenuService.currentItem = item.parent;
|
|
244
250
|
this.destroyRequest.emit(false);
|
|
@@ -274,4 +280,4 @@ TieredMenuComponent = TieredMenuComponent_1 = __decorate([
|
|
|
274
280
|
})
|
|
275
281
|
], TieredMenuComponent);
|
|
276
282
|
export { TieredMenuComponent };
|
|
277
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tiered-menu.component.js","sourceRoot":"ng://@seniorsistemas/angular-components/","sources":["components/tiered-menu/components/tiered-menu/tiered-menu.component.ts"],"names":[],"mappings":";;AAAA,OAAO,EACH,cAAc,EACd,iBAAiB,EACjB,SAAS,EACT,wBAAwB,EACxB,YAAY,EACZ,eAAe,EACf,YAAY,EACZ,YAAY,EACZ,QAAQ,EACR,SAAS,EACT,MAAM,EACN,MAAM,GACT,MAAM,eAAe,CAAC;AAEvB,OAAO,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AAE/B,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAE3C,OAAO,EAAE,sBAAsB,EAAE,MAAM,0CAA0C,CAAC;AAClF,OAAO,EAAE,iBAAiB,EAAE,MAAM,oCAAoC,CAAC;AAOvE,IAAa,mBAAmB,2BAAhC,MAAa,mBAAmB;IAa5B,YACqB,OAAuB,EACvB,yBAAmD,EACnD,SAAmB,EACnB,kBAAqC,EACtC,iBAAoC,EACnC,uBAA+C;QAL/C,YAAO,GAAP,OAAO,CAAgB;QACvB,8BAAyB,GAAzB,yBAAyB,CAA0B;QACnD,cAAS,GAAT,SAAS,CAAU;QACnB,uBAAkB,GAAlB,kBAAkB,CAAmB;QACtC,sBAAiB,GAAjB,iBAAiB,CAAmB;QACnC,4BAAuB,GAAvB,uBAAuB,CAAwB;QAjB7D,QAAG,GAAG,CAAC,CAAC;QACR,SAAI,GAAG,CAAC,CAAC;QACT,qBAAgB,GAAsB,OAAO,CAAC;QAE7C,kBAAa,GAAsC,IAAI,CAAC;QAExD,kBAAa,GAAG,IAAI,OAAO,EAAQ,CAAC;QAGrC,mBAAc,GAAG,IAAI,YAAY,EAAW,CAAC;IASjD,CAAC;IAGG,QAAQ;QACX,IAAI,CAAC,uBAAuB,CAAC,kBAAkB,CAAC,IAAI,EAAE,CAAC;IAC3D,CAAC;IAGM,eAAe,CAAC,KAAiB;QACpC,qCAAqC;QACrC,MAAM,MAAM,GAAG,KAAK,CAAC,MAAiB,CAAC;QACvC,MAAM,aAAa,GAAG,MAAM,CAAC,OAAO,CAAC,oBAAoB,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,uBAAuB,CAAC,CAAC;QACtG,IAAI,CAAC,aAAa,EAAE;YAChB,IAAI,CAAC,uBAAuB,CAAC,kBAAkB,CAAC,IAAI,EAAE,CAAC;SAC1D;IACL,CAAC;IAGM,gBAAgB,CAAC,KAAoB;QACxC,QAAQ,KAAK,CAAC,GAAG,EAAE;YACf,KAAK,QAAQ;gBACT,IAAI,CAAC,uBAAuB,CAAC,kBAAkB,CAAC,IAAI,EAAE,CAAC;gBACvD,MAAM;YACV,KAAK,GAAG,CAAC;YACT,KAAK,OAAO;gBACR,IAAI,CAAC,IAAI,CAAC,iBAAiB,CAAC,WAAW,CAAC,QAAQ,EAAE;oBAC9C,IAAI,CAAC,uBAAuB,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC,iBAAiB,CAAC,WAAW,CAAC,CAAC;iBACzF;gBACD,MAAM;YACV,KAAK,WAAW;gBACZ,IAAI,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,iBAAiB,CAAC,WAAW,CAAC,EAAE;oBACzD,IAAI,CAAC,uBAAuB,CAAC,kBAAkB,CAAC,IAAI,CAAC,IAAI,CAAC,iBAAiB,CAAC,WAAW,CAAC,CAAC;oBACzF,IAAI,CAAC,kBAAkB,CAAC,aAAa,EAAE,CAAC;iBAC3C;gBACD,MAAM;YACV,KAAK,YAAY;gBACb,IAAI,CAAC,IAAI,CAAC,iBAAiB,CAAC,WAAW,CAAC,QAAQ,IAAI,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,iBAAiB,CAAC,WAAW,CAAC,EAAE;oBACzG,IAAI,CAAC,uBAAuB,CAAC,iBAAiB,CAAC,IAAI,CAAC,IAAI,CAAC,iBAAiB,CAAC,WAAW,CAAC,CAAC;oBACxF,KAAK,CAAC,wBAAwB,EAAE,CAAC;iBACpC;gBACD,MAAM;YACV,KAAK,SAAS;gBACV,IAAI,CAAC,IAAI,CAAC,iBAAiB,CAAC,WAAW,IAAI,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,iBAAiB,CAAC,WAAW,CAAC,EAAE;oBAChG,IAAI,CAAC,uBAAuB,CAAC,yBAAyB,CAAC,IAAI,EAAE,CAAC;oBAC9D,KAAK,CAAC,wBAAwB,EAAE,CAAC;iBACpC;gBACD,MAAM;YACV,KAAK,WAAW;gBACZ,IAAI,CAAC,IAAI,CAAC,iBAAiB,CAAC,WAAW,IAAI,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,iBAAiB,CAAC,WAAW,CAAC,EAAE;oBAChG,IAAI,CAAC,uBAAuB,CAAC,yBAAyB,CAAC,IAAI,EAAE,CAAC;oBAC9D,KAAK,CAAC,wBAAwB,EAAE,CAAC;iBACpC;gBACD,MAAM;SACb;IACL,CAAC;IAEM,QAAQ;QACX,IAAI,CAAC,iBAAiB,CAAC,YAAY,GAAG,IAAI,CAAC,KAAK,CAAC;QACjD,IAAI,CAAC,gBAAgB,EAAE,CAAC;IAC5B,CAAC;IAEM,WAAW;QACd,IAAI,CAAC,aAAa,CAAC,IAAI,EAAE,CAAC;QAC1B,IAAI,CAAC,aAAa,CAAC,QAAQ,EAAE,CAAC;IAClC,CAAC;IAEO,iBAAiB;QACrB,IAAI,CAAC,IAAI,CAAC,iBAAiB,CAAC,WAAW,EAAE;YACrC,IAAI,CAAC,iBAAiB,CAAC,WAAW,GAAG,IAAI,CAAC,iBAAiB,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;YAC5E,OAAO;SACV;aAAM,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,iBAAiB,CAAC,WAAW,CAAC,EAAE;YACjE,sCAAsC;YACtC,OAAO;SACV;QAED,MAAM,YAAY,GAAG,IAAI,CAAC,iBAAiB,CAAC,YAAY,CAAC,OAAO,CAAC,IAAI,CAAC,iBAAiB,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC;QAEzG,IAAI,YAAY,GAAG,IAAI,CAAC,iBAAiB,CAAC,YAAY,CAAC,MAAM,EAAE;YAC3D,IAAI,CAAC,iBAAiB,CAAC,WAAW,GAAG,IAAI,CAAC,iBAAiB,CAAC,YAAY,CAAC,YAAY,CAAC,CAAC;SAC1F;aAAM;YACH,IAAI,CAAC,iBAAiB,CAAC,WAAW,GAAG,IAAI,CAAC,iBAAiB,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;SAC/E;QAED,IAAI,IAAI,CAAC,iBAAiB,CAAC,WAAW,CAAC,OAAO,EAAE;YAC5C,IAAI,CAAC,iBAAiB,EAAE,CAAC;SAC5B;IACL,CAAC;IAEO,iBAAiB;QACrB,IAAI,CAAC,IAAI,CAAC,iBAAiB,CAAC,WAAW,EAAE;YACrC,IAAI,CAAC,iBAAiB,CAAC,WAAW,GAAG,IAAI,CAAC,iBAAiB,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;YAC5E,OAAO;YACP,sCAAsC;SACzC;aAAM,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,iBAAiB,CAAC,WAAW,CAAC,EAAE;YACjE,OAAO;SACV;QAED,MAAM,QAAQ,GAAG,IAAI,CAAC,iBAAiB,CAAC,YAAY,CAAC,OAAO,CAAC,IAAI,CAAC,iBAAiB,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC;QAErG,IAAI,QAAQ,IAAI,CAAC,EAAE;YACf,IAAI,CAAC,iBAAiB,CAAC,WAAW,GAAG,IAAI,CAAC,iBAAiB,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC;SACtF;aAAM;YACH,IAAI,CAAC,iBAAiB,CAAC,WAAW,GAAG,IAAI,CAAC,iBAAiB,CAAC,YAAY,CAAC,IAAI,CAAC,iBAAiB,CAAC,YAAY,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;SAC5H;QAED,IAAI,IAAI,CAAC,iBAAiB,CAAC,WAAW,CAAC,OAAO,EAAE;YAC5C,IAAI,CAAC,iBAAiB,EAAE,CAAC;SAC5B;IACL,CAAC;IAEO,WAAW,CAAC,KAAmC,EAAE,QAAa;QAClE,IAAI,CAAC,IAAI,CAAC,aAAa,IAAI,KAAK,EAAE;YAC9B,MAAM,gBAAgB,GAAG,IAAI,CAAC,yBAAyB,CAAC,uBAAuB,CAAC,qBAAmB,CAAC,CAAC;YACrG,IAAI,CAAC,aAAa,GAAG,gBAAgB,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;YAC7D,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC;YACrD,MAAM,OAAO,GAAI,IAAI,CAAC,aAAa,CAAC,QAAiC,CAAC,SAAS,CAAC,CAAC,CAAgB,CAAC;YAClG,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC;YAEnC,0BAA0B;YAC1B,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,KAAK,GAAG,KAAK,CAAC;YAE1C,yBAAyB;YACzB,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,cAAc,CAAC,SAAS,CAAC,CAAC,SAAkB,EAAE,EAAE;gBACxE,IAAI,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC;YAC7B,CAAC,CAAC,CAAC;YAEH,IAAI,CAAC,eAAe,GAAG,OAAO,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC;YACtD,IAAI,CAAC,gBAAgB,CAAC,QAAQ,CAAC,CAAC;SACnC;IACL,CAAC;IAEO,QAAQ,CAAC,SAAS,GAAG,IAAI;QAC7B,IAAI,IAAI,CAAC,aAAa,KAAK,IAAI,EAAE;YAC7B,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC;YACrD,IAAI,CAAC,aAAa,CAAC,OAAO,EAAE,CAAC;YAC7B,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;YAC1B,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;SAC/B;QAED,IAAI,SAAS,EAAE;YACX,IAAI,CAAC,cAAc,CAAC,IAAI,EAAE,CAAC;SAC9B;IACL,CAAC;IAEO,gBAAgB,CAAC,QAAa;;QAClC,MAAM,WAAW,GAAG,EAAE,CAAC;QACvB,MAAM,cAAc,GAAG,CAAC,CAAC;QACzB,MAAM,OAAO,GAAG,CAAC,CAAC;QAElB,IAAI,IAAI,CAAC,aAAa,KAAK,IAAI,EAAE;YAC7B,MAAM,EAAE,GAAG,EAAE,KAAK,EAAE,MAAM,EAAE,IAAI,EAAE,GAAG,QAAQ,CAAC;YAE9C,MAAM,UAAU,SAAG,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,KAAK,0CAAE,MAAM,CAAC,CAAC,KAAa,EAAE,IAAgC,EAAE,EAAE;gBAC7G,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC;YAC7C,CAAC,EAAE,CAAC,CAAC,CAAC;YAEN,MAAM,aAAa,SAAG,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,KAAK,0CAAE,MAAM,CAAC,CAAC,KAAa,EAAE,IAAgC,EAAE,EAAE;gBAChH,OAAO,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC;YAC5C,CAAC,EAAE,CAAC,CAAC,CAAC;YAEN,2GAA2G;YAC3G,MAAM,UAAU,GAAG,UAAU,GAAG,WAAW,GAAG,aAAa,GAAG,cAAc,GAAG,OAAO,GAAG,CAAC,CAAC;YAC3F,MAAM,SAAS,GAAG,IAAI,CAAC,eAAe,CAAC,qBAAqB,EAAE,CAAC,KAAK,CAAC;YAErE,MAAM,cAAc,GAAG,MAAM,CAAC,UAAU,GAAG,KAAK,CAAC;YACjD,MAAM,eAAe,GAAG,MAAM,CAAC,WAAW,GAAG,MAAM,CAAC;YAEpD,IAAI,cAAc,GAAG,SAAS,EAAE;gBAC5B,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,IAAI,GAAG,KAAK,CAAC;aAC5C;iBAAM;gBACH,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,IAAI,GAAG,IAAI,GAAG,SAAS,CAAC;aACvD;YAED,IAAI,eAAe,IAAI,UAAU,EAAE;gBAC/B,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,MAAM,CAAC,WAAW,GAAG,UAAU,EAAE,MAAM,CAAC,OAAO,CAAC,CAAC;aAC/F;iBAAM;gBACH,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,GAAG,GAAG,MAAM,CAAC,OAAO,GAAG,GAAG,CAAC;aAC1D;SACJ;IACL,CAAC;IAEO,gBAAgB;QACpB,gCAAgC;QAChC,IAAI,CAAC,uBAAuB,CAAC,yBAAyB,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,SAAS,CAAC,GAAG,EAAE;YACtG,IAAI,CAAC,iBAAiB,EAAE,CAAC;QAC7B,CAAC,CAAC,CAAC;QACH,gCAAgC;QAChC,IAAI,CAAC,uBAAuB,CAAC,yBAAyB,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,SAAS,CAAC,GAAG,EAAE;YACtG,IAAI,CAAC,iBAAiB,EAAE,CAAC;QAC7B,CAAC,CAAC,CAAC;QACH,qBAAqB;QACrB,IAAI,CAAC,uBAAuB,CAAC,eAAe,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,IAAgC,EAAE,EAAE;YAC5H,IAAI,IAAI,CAAC,OAAO,EAAE;gBACd,IAAI,CAAC,uBAAuB,CAAC,iBAAiB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;aAC7D;iBAAM,IAAI,IAAI,CAAC,OAAO,EAAE;gBACrB,IAAI,CAAC,uBAAuB,CAAC,kBAAkB,CAAC,IAAI,EAAE,CAAC;gBACvD,IAAI,CAAC,OAAO,EAAE,CAAC;aAClB;QACL,CAAC,CAAC,CAAC;QACH,yBAAyB;QACzB,IAAI,CAAC,uBAAuB,CAAC,kBAAkB,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,SAAS,CAAC,GAAG,EAAE;YAC/F,IAAI,CAAC,QAAQ,EAAE,CAAC;YAChB,IAAI,CAAC,iBAAiB,CAAC,WAAW,GAAG,IAAI,CAAC;YAC1C,IAAI,CAAC,iBAAiB,CAAC,YAAY,GAAG,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC;YACnE,IAAI,CAAC,iBAAiB,CAAC,oBAAoB,CAAC,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,CAAC;QAC9E,CAAC,CAAC,CAAC;QAEH,wBAAwB;QACxB,IAAI,CAAC,uBAAuB,CAAC,iBAAiB,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,IAAgC,EAAE,EAAE;YAC9H,IAAI,IAAI,CAAC,iBAAiB,CAAC,WAAW,EAAE;gBACpC,IAAI,IAAI,CAAC,iBAAiB,CAAC,WAAW,CAAC,MAAM,KAAK,IAAI,EAAE;oBACpD,OAAO;iBACV;gBAED,IAAI,CAAC,IAAI,CAAC,iBAAiB,CAAC,kBAAkB,CAAC,IAAI,CAAC,iBAAiB,CAAC,WAAW,CAAC,MAAM,EAAE,IAAI,CAAC,EAAE;oBAC7F,IAAI,OAAO,GAAG,IAAI,CAAC,iBAAiB,CAAC,WAAW,CAAC;oBAEjD,OAAO,CAAC,MAAM,GAAG,KAAK,CAAC;oBAEvB,OAAO,CAAA,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,MAAM,MAAK,IAAI,CAAC,MAAM,EAAE;wBACpC,IAAI,CAAC,uBAAuB,CAAC,kBAAkB,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;wBAC9D,IAAI,CAAC,kBAAkB,CAAC,aAAa,EAAE,CAAC;wBAExC,OAAO,GAAG,OAAO,CAAC,MAAM,CAAC;qBAC5B;oBAED,IAAI,OAAO,EAAE;wBACT,OAAO,CAAC,MAAM,GAAG,KAAK,CAAC;qBAC1B;iBACJ;aACJ;YAED,IAAI,IAAI,CAAC,OAAO,IAAI,CAAC,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE;gBAC3D,MAAM,EAAE,GAAG,EAAE,KAAK,EAAE,IAAI,EAAE,MAAM,EAAE,GAAG,QAAQ,CAAC,aAAa,CAAC,IAAI,IAAI,CAAC,EAAE,EAAE,CAAC,CAAC,qBAAqB,EAAE,CAAC;gBACnG,MAAM,QAAQ,GAAG,EAAE,GAAG,EAAE,KAAK,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;gBAE9C,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,OAAO,EAAE,QAAQ,CAAC,CAAC;gBACzC,IAAI,CAAC,iBAAiB,CAAC,YAAY,GAAG,IAAI,CAAC,OAAO,CAAC;gBACnD,IAAI,CAAC,iBAAiB,CAAC,WAAW,GAAG,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;gBACrD,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;aACtB;QACL,CAAC,CAAC,CAAC;QAEH,yBAAyB;QACzB,IAAI,CAAC,uBAAuB,CAAC,kBAAkB;aAC1C,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;aACnC,SAAS,CAAC,CAAC,IAAgC,EAAE,EAAE;;YAC5C,IAAI,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,IAAI,CAAC,EAAE,CAAC,EAAE;gBAC1C,IAAI,IAAI,CAAC,MAAM,EAAE;oBACb,IAAI,CAAC,MAAM,CAAC,MAAM,GAAG,KAAK,CAAC;iBAC9B;gBACD,IAAI,CAAC,iBAAiB,CAAC,YAAY,GAAG,aAAA,IAAI,aAAJ,IAAI,uBAAJ,IAAI,CAAE,MAAM,0CAAE,MAAM,0CAAE,OAAO,KAAI,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC;gBACpG,IAAI,CAAC,iBAAiB,CAAC,WAAW,GAAG,IAAI,CAAC,MAAM,CAAC;gBACjD,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;aACnC;QACL,CAAC,CAAC,CAAC;IACX,CAAC;CACJ,CAAA;;YAvQiC,cAAc;YACI,wBAAwB;YACxC,QAAQ;YACC,iBAAiB;YACnB,iBAAiB;YACV,sBAAsB;;AARpE;IADC,MAAM,EAAE;2DAC2C;AAYpD;IADC,YAAY,CAAC,eAAe,CAAC;mDAG7B;AAGD;IADC,YAAY,CAAC,gBAAgB,EAAE,CAAC,QAAQ,CAAC,CAAC;0DAQ1C;AAGD;IADC,YAAY,CAAC,kBAAkB,EAAE,CAAC,QAAQ,CAAC,CAAC;2DAqC5C;AA1EQ,mBAAmB;IAL/B,SAAS,CAAC;QACP,QAAQ,EAAE,eAAe;QACzB,4kBAA2C;;KAE9C,CAAC;GACW,mBAAmB,CAqR/B;SArRY,mBAAmB","sourcesContent":["import {\n    ApplicationRef,\n    ChangeDetectorRef,\n    Component,\n    ComponentFactoryResolver,\n    ComponentRef,\n    EmbeddedViewRef,\n    EventEmitter,\n    HostListener,\n    Injector,\n    OnDestroy,\n    OnInit,\n    Output,\n} from \"@angular/core\";\n\nimport { Subject } from \"rxjs\";\n\nimport { takeUntil } from \"rxjs/operators\";\nimport { TieredMenuItemInternalData } from \"../../models/tiered-menu-item-internal-data\";\nimport { TieredMenuEventService } from \"../../services/tiered-menu.event.service\";\nimport { TieredMenuService } from \"../../services/tiered-menu.service\";\n\n@Component({\n    selector: \"s-tiered-menu\",\n    templateUrl: \"./tiered-menu.component.html\",\n    styleUrls: [\"./tiered-menu.component.scss\"],\n})\nexport class TieredMenuComponent implements OnInit, OnDestroy {\n    public items: TieredMenuItemInternalData[];\n    public top = 0;\n    public left = 0;\n    public menuTriggerEvent: \"click\" | \"hover\" = \"hover\";\n\n    private _componentRef: ComponentRef<TieredMenuComponent> = null;\n    private _menuDivElement?: HTMLElement;\n    private _unsubscribe$ = new Subject<void>();\n\n    @Output()\n    public destroyRequest = new EventEmitter<boolean>();\n\n    constructor(\n        private readonly _appRef: ApplicationRef,\n        private readonly _componentFactoryResolver: ComponentFactoryResolver,\n        private readonly _injector: Injector,\n        private readonly _changeDetectorRef: ChangeDetectorRef,\n        public readonly tieredMenuService: TieredMenuService,\n        private readonly _tieredMenuEventService: TieredMenuEventService\n    ) {}\n\n    @HostListener(\"window:resize\")\n    public onResize(): void {\n        this._tieredMenuEventService.closeAllMenusEvent.emit();\n    }\n\n    @HostListener(\"document:click\", [\"$event\"])\n    public onDocumentClick(event: MouseEvent): void {\n        // Closing menu when clicked outside.\n        const target = event.target as Element;\n        const clickedInside = target.closest(\"s-tiered-menu-item\") || target.closest(\"s-tiered-menu-divider\");\n        if (!clickedInside) {\n            this._tieredMenuEventService.closeAllMenusEvent.emit();\n        }\n    }\n\n    @HostListener(\"document:keydown\", [\"$event\"])\n    public onKeydownHandler(event: KeyboardEvent) {\n        switch (event.key) {\n            case \"Escape\":\n                this._tieredMenuEventService.closeAllMenusEvent.emit();\n                break;\n            case \" \":\n            case \"Enter\":\n                if (!this.tieredMenuService.currentItem.disabled) {\n                    this._tieredMenuEventService.selectItemEvent.emit(this.tieredMenuService.currentItem);\n                }\n                break;\n            case \"ArrowLeft\":\n                if (this.items.includes(this.tieredMenuService.currentItem)) {\n                    this._tieredMenuEventService.closeItemMenuEvent.emit(this.tieredMenuService.currentItem);\n                    this._changeDetectorRef.detectChanges();\n                }\n                break;\n            case \"ArrowRight\":\n                if (!this.tieredMenuService.currentItem.disabled && this.items.includes(this.tieredMenuService.currentItem)) {\n                    this._tieredMenuEventService.openItemMenuEvent.emit(this.tieredMenuService.currentItem);\n                    event.stopImmediatePropagation();\n                }\n                break;\n            case \"ArrowUp\":\n                if (!this.tieredMenuService.currentItem || this.items.includes(this.tieredMenuService.currentItem)) {\n                    this._tieredMenuEventService.decrementCurrentItemEvent.emit();\n                    event.stopImmediatePropagation();\n                }\n                break;\n            case \"ArrowDown\":\n                if (!this.tieredMenuService.currentItem || this.items.includes(this.tieredMenuService.currentItem)) {\n                    this._tieredMenuEventService.incrementCurrentItemEvent.emit();\n                    event.stopImmediatePropagation();\n                }\n                break;\n        }\n    }\n\n    public ngOnInit(): void {\n        this.tieredMenuService.currentItems = this.items;\n        this._subscribeEvents();\n    }\n\n    public ngOnDestroy(): void {\n        this._unsubscribe$.next();\n        this._unsubscribe$.complete();\n    }\n\n    private _incrementCurItem(): void {\n        if (!this.tieredMenuService.currentItem) {\n            this.tieredMenuService.currentItem = this.tieredMenuService.currentItems[0];\n            return;\n        } else if (!this.items.includes(this.tieredMenuService.currentItem)) {\n            // Checking if it is the current menu.\n            return;\n        }\n\n        const currentIndex = this.tieredMenuService.currentItems.indexOf(this.tieredMenuService.currentItem) + 1;\n\n        if (currentIndex < this.tieredMenuService.currentItems.length) {\n            this.tieredMenuService.currentItem = this.tieredMenuService.currentItems[currentIndex];\n        } else {\n            this.tieredMenuService.currentItem = this.tieredMenuService.currentItems[0];\n        }\n\n        if (this.tieredMenuService.currentItem.divider) {\n            this._incrementCurItem();\n        }\n    }\n\n    private _decrementCurItem(): void {\n        if (!this.tieredMenuService.currentItem) {\n            this.tieredMenuService.currentItem = this.tieredMenuService.currentItems[0];\n            return;\n            // Checking if it is the current menu.\n        } else if (!this.items.includes(this.tieredMenuService.currentItem)) {\n            return;\n        }\n\n        const curIndex = this.tieredMenuService.currentItems.indexOf(this.tieredMenuService.currentItem) - 1;\n\n        if (curIndex >= 0) {\n            this.tieredMenuService.currentItem = this.tieredMenuService.currentItems[curIndex];\n        } else {\n            this.tieredMenuService.currentItem = this.tieredMenuService.currentItems[this.tieredMenuService.currentItems.length - 1];\n        }\n\n        if (this.tieredMenuService.currentItem.divider) {\n            this._decrementCurItem();\n        }\n    }\n\n    private _createMenu(items: TieredMenuItemInternalData[], position: any): void {\n        if (!this._componentRef && items) {\n            const componentFactory = this._componentFactoryResolver.resolveComponentFactory(TieredMenuComponent);\n            this._componentRef = componentFactory.create(this._injector);\n            this._appRef.attachView(this._componentRef.hostView);\n            const domElem = (this._componentRef.hostView as EmbeddedViewRef<any>).rootNodes[0] as HTMLElement;\n            document.body.appendChild(domElem);\n\n            // Setting the menu items.\n            this._componentRef.instance.items = items;\n\n            // Subscribe menu events.\n            this._componentRef.instance.destroyRequest.subscribe((propagate: boolean) => {\n                this._destroy(propagate);\n            });\n\n            this._menuDivElement = domElem.querySelector(\".menu\");\n            this._setMenuPosition(position);\n        }\n    }\n\n    private _destroy(propagate = true): void {\n        if (this._componentRef !== null) {\n            this._appRef.detachView(this._componentRef.hostView);\n            this._componentRef.destroy();\n            this._componentRef = null;\n            this._menuDivElement = null;\n        }\n\n        if (propagate) {\n            this.destroyRequest.emit();\n        }\n    }\n\n    private _setMenuPosition(position: any): void {\n        const ITEM_HEIGHT = 37;\n        const DIVIDER_HEIGHT = 5;\n        const PADDING = 8;\n\n        if (this._componentRef !== null) {\n            const { top, right, bottom, left } = position;\n\n            const itemsCount = this._componentRef.instance.items?.reduce((count: number, item: TieredMenuItemInternalData) => {\n                return !item.divider ? count + 1 : count;\n            }, 0);\n\n            const dividersCount = this._componentRef.instance.items?.reduce((count: number, item: TieredMenuItemInternalData) => {\n                return item.divider ? count + 1 : count;\n            }, 0);\n\n            // I need to calculate the height of the component because the internal elements have not been created yet.\n            const menuHeight = itemsCount * ITEM_HEIGHT + dividersCount * DIVIDER_HEIGHT + PADDING + 8;\n            const menuWidth = this._menuDivElement.getBoundingClientRect().width;\n\n            const rightFreeSpace = window.innerWidth - right;\n            const bottomFreeSpace = window.innerHeight - bottom;\n\n            if (rightFreeSpace > menuWidth) {\n                this._componentRef.instance.left = right;\n            } else {\n                this._componentRef.instance.left = left - menuWidth;\n            }\n\n            if (bottomFreeSpace <= menuHeight) {\n                this._componentRef.instance.top = Math.max(window.innerHeight - menuHeight, window.scrollY);\n            } else {\n                this._componentRef.instance.top = window.scrollY + top;\n            }\n        }\n    }\n\n    private _subscribeEvents(): void {\n        // Increment current item event.\n        this._tieredMenuEventService.incrementCurrentItemEvent.pipe(takeUntil(this._unsubscribe$)).subscribe(() => {\n            this._incrementCurItem();\n        });\n        // Decrement current item event.\n        this._tieredMenuEventService.decrementCurrentItemEvent.pipe(takeUntil(this._unsubscribe$)).subscribe(() => {\n            this._decrementCurItem();\n        });\n        // Select item event.\n        this._tieredMenuEventService.selectItemEvent.pipe(takeUntil(this._unsubscribe$)).subscribe((item: TieredMenuItemInternalData) => {\n            if (item.submenu) {\n                this._tieredMenuEventService.openItemMenuEvent.emit(item);\n            } else if (item.command) {\n                this._tieredMenuEventService.closeAllMenusEvent.emit();\n                item.command();\n            }\n        });\n        // Close all menus event.\n        this._tieredMenuEventService.closeAllMenusEvent.pipe(takeUntil(this._unsubscribe$)).subscribe(() => {\n            this._destroy();\n            this.tieredMenuService.currentItem = null;\n            this.tieredMenuService.currentItems = this.tieredMenuService.items;\n            this.tieredMenuService.markAllItemsAsClosed(this.tieredMenuService.items);\n        });\n\n        // Open item menu event.\n        this._tieredMenuEventService.openItemMenuEvent.pipe(takeUntil(this._unsubscribe$)).subscribe((item: TieredMenuItemInternalData) => {\n            if (this.tieredMenuService.currentItem) {\n                if (this.tieredMenuService.currentItem.parent === item) {\n                    return;\n                }\n\n                if (!this.tieredMenuService.searchTheHierarchy(this.tieredMenuService.currentItem.parent, item)) {\n                    let current = this.tieredMenuService.currentItem;\n\n                    current.isOpen = false;\n\n                    while (current?.parent !== item.parent) {\n                        this._tieredMenuEventService.closeItemMenuEvent.emit(current);\n                        this._changeDetectorRef.detectChanges();\n\n                        current = current.parent;\n                    }\n\n                    if (current) {\n                        current.isOpen = false;\n                    }\n                }\n            }\n\n            if (item.submenu && !item.isOpen && this.items.includes(item)) {\n                const { top, right, left, bottom } = document.querySelector(`#${item.id}`).getBoundingClientRect();\n                const position = { top, right, left, bottom };\n\n                this._createMenu(item.submenu, position);\n                this.tieredMenuService.currentItems = item.submenu;\n                this.tieredMenuService.currentItem = item.submenu[0];\n                item.isOpen = true;\n            }\n        });\n\n        // Close item menu event.\n        this._tieredMenuEventService.closeItemMenuEvent\n            .pipe(takeUntil(this._unsubscribe$))\n            .subscribe((item: TieredMenuItemInternalData) => {\n                if (this.items.some((i) => i.id === item.id)) {\n                    if (item.parent) {\n                        item.parent.isOpen = false;\n                    }\n                    this.tieredMenuService.currentItems = item?.parent?.parent?.submenu || this.tieredMenuService.items;\n                    this.tieredMenuService.currentItem = item.parent;\n                    this.destroyRequest.emit(false);\n                }\n            });\n    }\n}\n"]}
|
|
283
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tiered-menu.component.js","sourceRoot":"ng://@seniorsistemas/angular-components/","sources":["components/tiered-menu/components/tiered-menu/tiered-menu.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    ApplicationRef,\n    ChangeDetectorRef,\n    Component,\n    ComponentFactoryResolver,\n    ComponentRef,\n    EmbeddedViewRef,\n    EventEmitter,\n    HostListener,\n    Injector,\n    OnDestroy,\n    OnInit,\n    Output,\n} from \"@angular/core\";\n\nimport { Subject } from \"rxjs\";\n\nimport { takeUntil } from \"rxjs/operators\";\nimport { TieredMenuItemInternalData } from \"../../models/tiered-menu-item-internal-data\";\nimport { TieredMenuEventService } from \"../../services/tiered-menu.event.service\";\nimport { TieredMenuService } from \"../../services/tiered-menu.service\";\nimport { enableScroll, disabledScroll } from \"../../utils\";\n\n@Component({\n    selector: \"s-tiered-menu\",\n    templateUrl: \"./tiered-menu.component.html\",\n    styleUrls: [\"./tiered-menu.component.scss\"],\n})\nexport class TieredMenuComponent implements OnInit, OnDestroy {\n    public items: TieredMenuItemInternalData[];\n    public top = 0;\n    public left = 0;\n    public menuTriggerEvent: \"click\" | \"hover\" = \"hover\";\n\n    private _componentRef: ComponentRef<TieredMenuComponent> = null;\n    private _menuDivElement?: HTMLElement;\n    private _unsubscribe$ = new Subject<void>();\n\n    @Output()\n    public destroyRequest = new EventEmitter<boolean>();\n\n    constructor(\n        private readonly _appRef: ApplicationRef,\n        private readonly _componentFactoryResolver: ComponentFactoryResolver,\n        private readonly _injector: Injector,\n        private readonly _changeDetectorRef: ChangeDetectorRef,\n        public readonly tieredMenuService: TieredMenuService,\n        private readonly _tieredMenuEventService: TieredMenuEventService\n    ) {}\n\n    @HostListener(\"window:resize\")\n    public onResize(): void {\n        this._tieredMenuEventService.closeAllMenusEvent.emit();\n    }\n\n    @HostListener(\"document:click\", [\"$event\"])\n    public onDocumentClick(event: MouseEvent): void {\n        // Closing menu when clicked outside.\n        const target = event.target as Element;\n        const clickedInside = target.closest(\"s-tiered-menu-item\") || target.closest(\"s-tiered-menu-divider\");\n        if (!clickedInside) {\n            this._tieredMenuEventService.closeAllMenusEvent.emit();\n        }\n    }\n\n    @HostListener(\"document:keydown\", [\"$event\"])\n    public onKeydownHandler(event: KeyboardEvent) {\n        switch (event.key) {\n            case \"Escape\":\n                this._tieredMenuEventService.closeAllMenusEvent.emit();\n                break;\n            case \" \":\n            case \"Enter\":\n                if (!this.tieredMenuService.currentItem.disabled) {\n                    this._tieredMenuEventService.selectItemEvent.emit(this.tieredMenuService.currentItem);\n                }\n                break;\n            case \"ArrowLeft\":\n                if (this.items.includes(this.tieredMenuService.currentItem)) {\n                    this._tieredMenuEventService.closeItemMenuEvent.emit(this.tieredMenuService.currentItem);\n                    this._changeDetectorRef.detectChanges();\n                }\n                break;\n            case \"ArrowRight\":\n                if (!this.tieredMenuService.currentItem.disabled && this.items.includes(this.tieredMenuService.currentItem)) {\n                    this._tieredMenuEventService.openItemMenuEvent.emit(this.tieredMenuService.currentItem);\n                    event.stopImmediatePropagation();\n                }\n                break;\n            case \"ArrowUp\":\n                if (!this.tieredMenuService.currentItem || this.items.includes(this.tieredMenuService.currentItem)) {\n                    this._tieredMenuEventService.decrementCurrentItemEvent.emit();\n                    event.stopImmediatePropagation();\n                }\n                break;\n            case \"ArrowDown\":\n                if (!this.tieredMenuService.currentItem || this.items.includes(this.tieredMenuService.currentItem)) {\n                    this._tieredMenuEventService.incrementCurrentItemEvent.emit();\n                    event.stopImmediatePropagation();\n                }\n                break;\n        }\n    }\n\n    public ngOnInit(): void {\n        this.tieredMenuService.currentItems = this.items;\n        this._subscribeEvents();\n        disabledScroll();\n    }\n\n    public ngOnDestroy(): void {\n        this._unsubscribe$.next();\n        this._unsubscribe$.complete();\n    }\n\n    private _incrementCurItem(): void {\n        if (!this.tieredMenuService.currentItem) {\n            this.tieredMenuService.currentItem = this.tieredMenuService.currentItems[0];\n            return;\n        } else if (!this.items.includes(this.tieredMenuService.currentItem)) {\n            // Checking if it is the current menu.\n            return;\n        }\n\n        const currentIndex = this.tieredMenuService.currentItems.indexOf(this.tieredMenuService.currentItem) + 1;\n\n        if (currentIndex < this.tieredMenuService.currentItems.length) {\n            this.tieredMenuService.currentItem = this.tieredMenuService.currentItems[currentIndex];\n        } else {\n            this.tieredMenuService.currentItem = this.tieredMenuService.currentItems[0];\n        }\n\n        if (this.tieredMenuService.currentItem.divider) {\n            this._incrementCurItem();\n        }\n    }\n\n    private _decrementCurItem(): void {\n        if (!this.tieredMenuService.currentItem) {\n            this.tieredMenuService.currentItem = this.tieredMenuService.currentItems[0];\n            return;\n            // Checking if it is the current menu.\n        } else if (!this.items.includes(this.tieredMenuService.currentItem)) {\n            return;\n        }\n\n        const curIndex = this.tieredMenuService.currentItems.indexOf(this.tieredMenuService.currentItem) - 1;\n\n        if (curIndex >= 0) {\n            this.tieredMenuService.currentItem = this.tieredMenuService.currentItems[curIndex];\n        } else {\n            this.tieredMenuService.currentItem = this.tieredMenuService.currentItems[this.tieredMenuService.currentItems.length - 1];\n        }\n\n        if (this.tieredMenuService.currentItem.divider) {\n            this._decrementCurItem();\n        }\n    }\n\n    private _createMenu(items: TieredMenuItemInternalData[], position: any): void {\n        if (!this._componentRef && items) {\n            const componentFactory = this._componentFactoryResolver.resolveComponentFactory(TieredMenuComponent);\n            this._componentRef = componentFactory.create(this._injector);\n            this._appRef.attachView(this._componentRef.hostView);\n            const domElem = (this._componentRef.hostView as EmbeddedViewRef<any>).rootNodes[0] as HTMLElement;\n            document.body.appendChild(domElem);\n\n            // Setting the menu items.\n            this._componentRef.instance.items = items;\n\n            // Subscribe menu events.\n            this._componentRef.instance.destroyRequest.subscribe((propagate: boolean) => {\n                this._destroy(propagate);\n            });\n\n            this._menuDivElement = domElem.querySelector(\".menu\");\n            this._setMenuPosition(position);\n        }\n    }\n\n    private _destroy(propagate = true): void {\n        if (this._componentRef !== null) {\n            this._appRef.detachView(this._componentRef.hostView);\n            this._componentRef.destroy();\n            this._componentRef = null;\n            this._menuDivElement = null;\n        }\n\n        if (propagate) {\n            this.destroyRequest.emit();\n        }\n    }\n\n    private _setMenuPosition(position: any): void {\n        const ITEM_HEIGHT = 37;\n        const DIVIDER_HEIGHT = 5;\n        const PADDING = 8;\n\n        if (this._componentRef !== null) {\n            const { top, right, bottom, left } = position;\n\n            const itemsCount = this._componentRef.instance.items?.reduce((count: number, item: TieredMenuItemInternalData) => {\n                return !item.divider ? count + 1 : count;\n            }, 0);\n\n            const dividersCount = this._componentRef.instance.items?.reduce((count: number, item: TieredMenuItemInternalData) => {\n                return item.divider ? count + 1 : count;\n            }, 0);\n\n            // I need to calculate the height of the component because the internal elements have not been created yet.\n            const menuHeight = itemsCount * ITEM_HEIGHT + dividersCount * DIVIDER_HEIGHT + PADDING + 8;\n            const menuWidth = this._menuDivElement.getBoundingClientRect().width;\n\n            const rightFreeSpace = window.innerWidth - right;\n            const bottomFreeSpace = window.innerHeight - bottom;\n\n            if (rightFreeSpace > menuWidth) {\n                this._componentRef.instance.left = right;\n            } else {\n                this._componentRef.instance.left = left - menuWidth;\n            }\n\n            if (bottomFreeSpace <= menuHeight) {\n                this._componentRef.instance.top = Math.max(window.innerHeight - menuHeight, window.scrollY);\n            } else {\n                this._componentRef.instance.top = window.scrollY + top;\n            }\n        }\n    }\n\n    private _subscribeEvents(): void {\n        // Increment current item event.\n        this._tieredMenuEventService.incrementCurrentItemEvent.pipe(takeUntil(this._unsubscribe$)).subscribe(() => {\n            this._incrementCurItem();\n        });\n        // Decrement current item event.\n        this._tieredMenuEventService.decrementCurrentItemEvent.pipe(takeUntil(this._unsubscribe$)).subscribe(() => {\n            this._decrementCurItem();\n        });\n        // Select item event.\n        this._tieredMenuEventService.selectItemEvent.pipe(takeUntil(this._unsubscribe$)).subscribe((item: TieredMenuItemInternalData) => {\n            if (item.submenu) {\n                this._tieredMenuEventService.openItemMenuEvent.emit(item);\n            } else if (item.command) {\n                this._tieredMenuEventService.closeAllMenusEvent.emit();\n                item.command();\n            }\n        });\n        // Close all menus event.\n        this._tieredMenuEventService.closeAllMenusEvent.pipe(takeUntil(this._unsubscribe$)).subscribe(() => {\n            this._destroy();\n            this.tieredMenuService.currentItem = null;\n            this.tieredMenuService.currentItems = this.tieredMenuService.items;\n            this.tieredMenuService.markAllItemsAsClosed(this.tieredMenuService.items);\n            enableScroll();\n        });\n\n        // Open item menu event.\n        this._tieredMenuEventService.openItemMenuEvent.pipe(takeUntil(this._unsubscribe$)).subscribe((item: TieredMenuItemInternalData) => {\n            if (this.tieredMenuService.currentItem) {\n                if (this.tieredMenuService.currentItem.parent === item) {\n                    return;\n                }\n\n                if (!this.tieredMenuService.searchTheHierarchy(this.tieredMenuService.currentItem.parent, item)) {\n                    let current = this.tieredMenuService.currentItem;\n\n                    current.isOpen = false;\n\n                    while (current?.parent !== item.parent) {\n                        this._tieredMenuEventService.closeItemMenuEvent.emit(current);\n                        this._changeDetectorRef.detectChanges();\n\n                        current = current.parent;\n                    }\n\n                    if (current) {\n                        current.isOpen = false;\n                    }\n                }\n            }\n\n            if (item.submenu && !item.isOpen && this.items.includes(item)) {\n                const { top, right, left, bottom } = document.querySelector(`#${item.id}`).getBoundingClientRect();\n                const position = { top, right, left, bottom };\n\n                this._createMenu(item.submenu, position);\n                this.tieredMenuService.currentItems = item.submenu;\n                this.tieredMenuService.currentItem = item.submenu[0];\n                item.isOpen = true;\n            }\n        });\n\n        // Close item menu event.\n        this._tieredMenuEventService.closeItemMenuEvent\n            .pipe(takeUntil(this._unsubscribe$))\n            .subscribe((item: TieredMenuItemInternalData) => {\n                if (this.items.some((i) => i.id === item.id)) {\n                    if (item.parent) {\n                        item.parent.isOpen = false;\n                    } else {\n                        enableScroll();\n                    }\n                    this.tieredMenuService.currentItems = item?.parent?.parent?.submenu || this.tieredMenuService.items;\n                    this.tieredMenuService.currentItem = item.parent;\n                    this.destroyRequest.emit(false);\n                }\n            });\n    }\n}\n"]}
|
package/esm2015/components/tiered-menu/components/tiered-menu-nested/tiered-menu-nested.component.js
CHANGED
|
@@ -1,9 +1,10 @@
|
|
|
1
1
|
import { __decorate } from "tslib";
|
|
2
2
|
import { Component, HostListener } from "@angular/core";
|
|
3
3
|
import { Subject } from "rxjs";
|
|
4
|
+
import { takeUntil } from "rxjs/operators";
|
|
4
5
|
import { TieredMenuEventService } from "../../services/tiered-menu.event.service";
|
|
5
6
|
import { TieredMenuService } from "../../services/tiered-menu.service";
|
|
6
|
-
import {
|
|
7
|
+
import { enableScroll, disabledScroll } from "../../utils";
|
|
7
8
|
let TieredMenuNestedComponent = class TieredMenuNestedComponent {
|
|
8
9
|
constructor(tieredMenuService, _tieredMenuEventService) {
|
|
9
10
|
this.tieredMenuService = tieredMenuService;
|
|
@@ -50,10 +51,12 @@ let TieredMenuNestedComponent = class TieredMenuNestedComponent {
|
|
|
50
51
|
ngOnInit() {
|
|
51
52
|
this.tieredMenuService.currentItems = this.items;
|
|
52
53
|
this._subscribeEvents();
|
|
54
|
+
disabledScroll();
|
|
53
55
|
}
|
|
54
56
|
ngOnDestroy() {
|
|
55
57
|
this._unsubscribe$.next();
|
|
56
58
|
this._unsubscribe$.complete();
|
|
59
|
+
enableScroll();
|
|
57
60
|
}
|
|
58
61
|
_incrementCurItem() {
|
|
59
62
|
if (!this.tieredMenuService.currentItem) {
|
|
@@ -172,4 +175,4 @@ TieredMenuNestedComponent = __decorate([
|
|
|
172
175
|
})
|
|
173
176
|
], TieredMenuNestedComponent);
|
|
174
177
|
export { TieredMenuNestedComponent };
|
|
175
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tiered-menu-nested.component.js","sourceRoot":"ng://@seniorsistemas/angular-components/","sources":["components/tiered-menu/components/tiered-menu-nested/tiered-menu-nested.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, HostListener, OnDestroy, OnInit } from \"@angular/core\";\n\nimport { Subject } from \"rxjs\";\n\nimport { TieredMenuItemInternalData } from \"../../models/tiered-menu-item-internal-data\";\nimport { TieredMenuEventService } from \"../../services/tiered-menu.event.service\";\nimport { TieredMenuService } from \"../../services/tiered-menu.service\";\nimport { takeUntil } from \"rxjs/operators\";\n\n@Component({\n    templateUrl: \"./tiered-menu-nested.component.html\",\n    styleUrls: [\"./tiered-menu-nested.component.scss\"],\n})\nexport class TieredMenuNestedComponent implements OnInit, OnDestroy {\n    public items: TieredMenuItemInternalData[];\n    public top = 0;\n    public left = 0;\n    // public maxHeight = 0;\n\n    // Saves the last opened item to close it when a new one is opened\n    private _lastOpenItem: TieredMenuItemInternalData;\n    private _unsubscribe$ = new Subject<void>();\n\n    @HostListener(\"window:resize\")\n    public onResize(): void {\n        this._tieredMenuEventService.closeAllMenusEvent.emit();\n    }\n\n    @HostListener(\"document:click\", [\"$event\"])\n    public onDocumentClick(event: MouseEvent): void {\n        // Closing menu when clicked outside.\n        const target = event.target as Element;\n        const clickedInside = target.closest(\"s-tiered-menu-item\") || target.closest(\"s-tiered-menu-divider\");\n        if (!clickedInside) {\n            this._tieredMenuEventService.closeAllMenusEvent.emit();\n        }\n    }\n\n    @HostListener(\"document:keydown\", [\"$event\"])\n    public onKeydownHandler(event: KeyboardEvent) {\n        switch (event.key) {\n            case \"Escape\":\n                this._tieredMenuEventService.closeAllMenusEvent.emit();\n                break;\n            case \" \":\n            case \"Enter\":\n                this._tieredMenuEventService.selectItemEvent.emit(this.tieredMenuService.currentItem);\n                break;\n            case \"ArrowLeft\":\n                // When nested I need a reference to the current item's parent item, otherwise just the current item.\n                this._tieredMenuEventService.closeItemMenuEvent.emit(this.tieredMenuService.currentItem.parent);\n                break;\n            case \"ArrowRight\":\n                this._tieredMenuEventService.openItemMenuEvent.emit(this.tieredMenuService.currentItem);\n                break;\n            case \"ArrowUp\":\n                this._tieredMenuEventService.decrementCurrentItemEvent.emit();\n                break;\n            case \"ArrowDown\":\n                this._tieredMenuEventService.incrementCurrentItemEvent.emit();\n                break;\n        }\n    }\n\n    constructor(\n        public readonly tieredMenuService: TieredMenuService,\n        private readonly _tieredMenuEventService: TieredMenuEventService,\n    ) { }\n\n    public ngOnInit(): void {\n        this.tieredMenuService.currentItems = this.items;\n        this._subscribeEvents();\n    }\n\n    public ngOnDestroy(): void {\n        this._unsubscribe$.next();\n        this._unsubscribe$.complete();\n    }\n\n    private _incrementCurItem(): void {\n        if (!this.tieredMenuService.currentItem) {\n            this.tieredMenuService.currentItem = this.tieredMenuService.currentItems[0];\n            return;\n        }\n\n        const curIndex = this.tieredMenuService.currentItems.indexOf(this.tieredMenuService.currentItem) + 1;\n\n        if (curIndex < this.tieredMenuService.currentItems.length) {\n            this.tieredMenuService.currentItem = this.tieredMenuService.currentItems[curIndex];\n        } else {\n            this.tieredMenuService.currentItem = this.tieredMenuService.currentItems[0];\n        }\n\n        if (this.tieredMenuService.currentItem.divider) {\n            this._incrementCurItem();\n        }\n    }\n\n    private _decrementCurItem(): void {\n        if (!this.tieredMenuService.currentItem) {\n            this.tieredMenuService.currentItem = this.tieredMenuService.currentItems[0];\n            return;\n        }\n\n        const curIndex = this.tieredMenuService.currentItems.indexOf(this.tieredMenuService.currentItem) - 1;\n\n        if (curIndex >= 0) {\n            this.tieredMenuService.currentItem = this.tieredMenuService.currentItems[curIndex];\n        } else {\n            this.tieredMenuService.currentItem = this.tieredMenuService.currentItems[this.tieredMenuService.currentItems.length - 1];\n        }\n\n        if (this.tieredMenuService.currentItem.divider) {\n            this._decrementCurItem();\n        }\n    }\n\n    private _closeItem(item: TieredMenuItemInternalData): void {\n        let itemAux = this._lastOpenItem;\n\n        while (itemAux && itemAux != item) {\n            itemAux.isOpen = false;\n            itemAux = itemAux.parent;\n        }\n\n        item.isOpen = false;\n\n        this.tieredMenuService.currentItem = itemAux ?? this.tieredMenuService.items[0];\n        this.tieredMenuService.currentItems = itemAux?.parent?.submenu || this.tieredMenuService.items;\n    }\n\n    private _openItem(item: TieredMenuItemInternalData): void {\n        if (item?.submenu) {\n            item.isOpen = true;\n            this.tieredMenuService.currentItems = item.submenu;\n\n            // Only has focus if there has already been interaction.\n            if (this.tieredMenuService.currentItem) {\n                this.tieredMenuService.currentItem = item.submenu[0];\n            }\n\n            this._lastOpenItem = item;\n        }\n    }\n\n    private _subscribeEvents(): void {\n        this._tieredMenuEventService.incrementCurrentItemEvent\n            .pipe(takeUntil(this._unsubscribe$))\n            .subscribe(() => {\n                this._incrementCurItem();\n            });\n\n        this._tieredMenuEventService.decrementCurrentItemEvent\n            .pipe(takeUntil(this._unsubscribe$))\n            .subscribe(() => {\n                this._decrementCurItem();\n            });\n\n        this._tieredMenuEventService.selectItemEvent\n            .pipe(takeUntil(this._unsubscribe$))\n            .subscribe((item: TieredMenuItemInternalData) => {\n                if (item.command) {\n                    item.command();\n                    // Close all menus after the item was selected.\n                    this._tieredMenuEventService.closeAllMenusEvent.emit();\n                }\n            });\n\n        this._tieredMenuEventService.openItemMenuEvent\n            .pipe(takeUntil(this._unsubscribe$))\n            .subscribe((item: TieredMenuItemInternalData) => {\n                if (!this.tieredMenuService.currentItems.includes(item)) {\n                    let itemAux = this._lastOpenItem;\n\n                    while (itemAux?.parent?.parent) {\n                        itemAux = itemAux.parent;\n                    }\n\n                    this._tieredMenuEventService.closeItemMenuEvent.emit(itemAux.parent ?? itemAux);\n                }\n\n                this._lastOpenItem = item;\n\n                this._openItem(item);\n            });\n\n        this._tieredMenuEventService.closeItemMenuEvent\n            .pipe(takeUntil(this._unsubscribe$))\n            .subscribe((item: TieredMenuItemInternalData) => {\n                if (item) {\n                    this._closeItem(item);\n                }\n            });\n    }\n}\n"]}
|
|
178
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tiered-menu-nested.component.js","sourceRoot":"ng://@seniorsistemas/angular-components/","sources":["components/tiered-menu/components/tiered-menu-nested/tiered-menu-nested.component.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAqB,MAAM,eAAe,CAAC;AAE3E,OAAO,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AAC/B,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAG3C,OAAO,EAAE,sBAAsB,EAAE,MAAM,0CAA0C,CAAC;AAClF,OAAO,EAAE,iBAAiB,EAAE,MAAM,oCAAoC,CAAC;AACvE,OAAO,EAAE,YAAY,EAAE,cAAc,EAAE,MAAM,aAAa,CAAC;AAK3D,IAAa,yBAAyB,GAAtC,MAAa,yBAAyB;IAmDlC,YACoB,iBAAoC,EACnC,uBAA+C;QADhD,sBAAiB,GAAjB,iBAAiB,CAAmB;QACnC,4BAAuB,GAAvB,uBAAuB,CAAwB;QAnD7D,QAAG,GAAG,CAAC,CAAC;QACR,SAAI,GAAG,CAAC,CAAC;QAKR,kBAAa,GAAG,IAAI,OAAO,EAAQ,CAAC;IA8CxC,CAAC;IA3CE,QAAQ;QACX,IAAI,CAAC,uBAAuB,CAAC,kBAAkB,CAAC,IAAI,EAAE,CAAC;IAC3D,CAAC;IAGM,eAAe,CAAC,KAAiB;QACpC,qCAAqC;QACrC,MAAM,MAAM,GAAG,KAAK,CAAC,MAAiB,CAAC;QACvC,MAAM,aAAa,GAAG,MAAM,CAAC,OAAO,CAAC,oBAAoB,CAAC,IAAI,MAAM,CAAC,OAAO,CAAC,uBAAuB,CAAC,CAAC;QACtG,IAAI,CAAC,aAAa,EAAE;YAChB,IAAI,CAAC,uBAAuB,CAAC,kBAAkB,CAAC,IAAI,EAAE,CAAC;SAC1D;IACL,CAAC;IAGM,gBAAgB,CAAC,KAAoB;QACxC,QAAQ,KAAK,CAAC,GAAG,EAAE;YACf,KAAK,QAAQ;gBACT,IAAI,CAAC,uBAAuB,CAAC,kBAAkB,CAAC,IAAI,EAAE,CAAC;gBACvD,MAAM;YACV,KAAK,GAAG,CAAC;YACT,KAAK,OAAO;gBACR,IAAI,CAAC,uBAAuB,CAAC,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC,iBAAiB,CAAC,WAAW,CAAC,CAAC;gBACtF,MAAM;YACV,KAAK,WAAW;gBACZ,qGAAqG;gBACrG,IAAI,CAAC,uBAAuB,CAAC,kBAAkB,CAAC,IAAI,CAAC,IAAI,CAAC,iBAAiB,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC;gBAChG,MAAM;YACV,KAAK,YAAY;gBACb,IAAI,CAAC,uBAAuB,CAAC,iBAAiB,CAAC,IAAI,CAAC,IAAI,CAAC,iBAAiB,CAAC,WAAW,CAAC,CAAC;gBACxF,MAAM;YACV,KAAK,SAAS;gBACV,IAAI,CAAC,uBAAuB,CAAC,yBAAyB,CAAC,IAAI,EAAE,CAAC;gBAC9D,MAAM;YACV,KAAK,WAAW;gBACZ,IAAI,CAAC,uBAAuB,CAAC,yBAAyB,CAAC,IAAI,EAAE,CAAC;gBAC9D,MAAM;SACb;IACL,CAAC;IAOM,QAAQ;QACX,IAAI,CAAC,iBAAiB,CAAC,YAAY,GAAG,IAAI,CAAC,KAAK,CAAC;QACjD,IAAI,CAAC,gBAAgB,EAAE,CAAC;QACxB,cAAc,EAAE,CAAC;IACrB,CAAC;IAEM,WAAW;QACd,IAAI,CAAC,aAAa,CAAC,IAAI,EAAE,CAAC;QAC1B,IAAI,CAAC,aAAa,CAAC,QAAQ,EAAE,CAAC;QAC9B,YAAY,EAAE,CAAC;IACnB,CAAC;IAEO,iBAAiB;QACrB,IAAI,CAAC,IAAI,CAAC,iBAAiB,CAAC,WAAW,EAAE;YACrC,IAAI,CAAC,iBAAiB,CAAC,WAAW,GAAG,IAAI,CAAC,iBAAiB,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;YAC5E,OAAO;SACV;QAED,MAAM,QAAQ,GAAG,IAAI,CAAC,iBAAiB,CAAC,YAAY,CAAC,OAAO,CAAC,IAAI,CAAC,iBAAiB,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC;QAErG,IAAI,QAAQ,GAAG,IAAI,CAAC,iBAAiB,CAAC,YAAY,CAAC,MAAM,EAAE;YACvD,IAAI,CAAC,iBAAiB,CAAC,WAAW,GAAG,IAAI,CAAC,iBAAiB,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC;SACtF;aAAM;YACH,IAAI,CAAC,iBAAiB,CAAC,WAAW,GAAG,IAAI,CAAC,iBAAiB,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;SAC/E;QAED,IAAI,IAAI,CAAC,iBAAiB,CAAC,WAAW,CAAC,OAAO,EAAE;YAC5C,IAAI,CAAC,iBAAiB,EAAE,CAAC;SAC5B;IACL,CAAC;IAEO,iBAAiB;QACrB,IAAI,CAAC,IAAI,CAAC,iBAAiB,CAAC,WAAW,EAAE;YACrC,IAAI,CAAC,iBAAiB,CAAC,WAAW,GAAG,IAAI,CAAC,iBAAiB,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;YAC5E,OAAO;SACV;QAED,MAAM,QAAQ,GAAG,IAAI,CAAC,iBAAiB,CAAC,YAAY,CAAC,OAAO,CAAC,IAAI,CAAC,iBAAiB,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC;QAErG,IAAI,QAAQ,IAAI,CAAC,EAAE;YACf,IAAI,CAAC,iBAAiB,CAAC,WAAW,GAAG,IAAI,CAAC,iBAAiB,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC;SACtF;aAAM;YACH,IAAI,CAAC,iBAAiB,CAAC,WAAW,GAAG,IAAI,CAAC,iBAAiB,CAAC,YAAY,CAAC,IAAI,CAAC,iBAAiB,CAAC,YAAY,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;SAC5H;QAED,IAAI,IAAI,CAAC,iBAAiB,CAAC,WAAW,CAAC,OAAO,EAAE;YAC5C,IAAI,CAAC,iBAAiB,EAAE,CAAC;SAC5B;IACL,CAAC;IAEO,UAAU,CAAC,IAAgC;;QAC/C,IAAI,OAAO,GAAG,IAAI,CAAC,aAAa,CAAC;QAEjC,OAAO,OAAO,IAAI,OAAO,IAAI,IAAI,EAAE;YAC/B,OAAO,CAAC,MAAM,GAAG,KAAK,CAAC;YACvB,OAAO,GAAG,OAAO,CAAC,MAAM,CAAC;SAC5B;QAED,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;QAEpB,IAAI,CAAC,iBAAiB,CAAC,WAAW,GAAG,OAAO,aAAP,OAAO,cAAP,OAAO,GAAI,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;QAChF,IAAI,CAAC,iBAAiB,CAAC,YAAY,GAAG,OAAA,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,MAAM,0CAAE,OAAO,KAAI,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC;IACnG,CAAC;IAEO,SAAS,CAAC,IAAgC;QAC9C,IAAI,IAAI,aAAJ,IAAI,uBAAJ,IAAI,CAAE,OAAO,EAAE;YACf,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;YACnB,IAAI,CAAC,iBAAiB,CAAC,YAAY,GAAG,IAAI,CAAC,OAAO,CAAC;YAEnD,wDAAwD;YACxD,IAAI,IAAI,CAAC,iBAAiB,CAAC,WAAW,EAAE;gBACpC,IAAI,CAAC,iBAAiB,CAAC,WAAW,GAAG,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;aACxD;YAED,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;SAC7B;IACL,CAAC;IAEO,gBAAgB;QACpB,IAAI,CAAC,uBAAuB,CAAC,yBAAyB;aACjD,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;aACnC,SAAS,CAAC,GAAG,EAAE;YACZ,IAAI,CAAC,iBAAiB,EAAE,CAAC;QAC7B,CAAC,CAAC,CAAC;QAEP,IAAI,CAAC,uBAAuB,CAAC,yBAAyB;aACjD,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;aACnC,SAAS,CAAC,GAAG,EAAE;YACZ,IAAI,CAAC,iBAAiB,EAAE,CAAC;QAC7B,CAAC,CAAC,CAAC;QAEP,IAAI,CAAC,uBAAuB,CAAC,eAAe;aACvC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;aACnC,SAAS,CAAC,CAAC,IAAgC,EAAE,EAAE;YAC5C,IAAI,IAAI,CAAC,OAAO,EAAE;gBACd,IAAI,CAAC,OAAO,EAAE,CAAC;gBACf,+CAA+C;gBAC/C,IAAI,CAAC,uBAAuB,CAAC,kBAAkB,CAAC,IAAI,EAAE,CAAC;aAC1D;QACL,CAAC,CAAC,CAAC;QAEP,IAAI,CAAC,uBAAuB,CAAC,iBAAiB;aACzC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;aACnC,SAAS,CAAC,CAAC,IAAgC,EAAE,EAAE;;YAC5C,IAAI,CAAC,IAAI,CAAC,iBAAiB,CAAC,YAAY,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE;gBACrD,IAAI,OAAO,GAAG,IAAI,CAAC,aAAa,CAAC;gBAEjC,aAAO,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,MAAM,0CAAE,MAAM,EAAE;oBAC5B,OAAO,GAAG,OAAO,CAAC,MAAM,CAAC;iBAC5B;gBAED,IAAI,CAAC,uBAAuB,CAAC,kBAAkB,CAAC,IAAI,OAAC,OAAO,CAAC,MAAM,mCAAI,OAAO,CAAC,CAAC;aACnF;YAED,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;YAE1B,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;QACzB,CAAC,CAAC,CAAC;QAEP,IAAI,CAAC,uBAAuB,CAAC,kBAAkB;aAC1C,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;aACnC,SAAS,CAAC,CAAC,IAAgC,EAAE,EAAE;YAC5C,IAAI,IAAI,EAAE;gBACN,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;aACzB;QACL,CAAC,CAAC,CAAC;IACX,CAAC;CACJ,CAAA;;YAnI0C,iBAAiB;YACV,sBAAsB;;AA1CpE;IADC,YAAY,CAAC,eAAe,CAAC;yDAG7B;AAGD;IADC,YAAY,CAAC,gBAAgB,EAAE,CAAC,QAAQ,CAAC,CAAC;gEAQ1C;AAGD;IADC,YAAY,CAAC,kBAAkB,EAAE,CAAC,QAAQ,CAAC,CAAC;iEAwB5C;AAjDQ,yBAAyB;IAJrC,SAAS,CAAC;QACP,s6BAAkD;;KAErD,CAAC;GACW,yBAAyB,CAuLrC;SAvLY,yBAAyB","sourcesContent":["import { Component, HostListener, OnDestroy, OnInit } from \"@angular/core\";\n\nimport { Subject } from \"rxjs\";\nimport { takeUntil } from \"rxjs/operators\";\n\nimport { TieredMenuItemInternalData } from \"../../models/tiered-menu-item-internal-data\";\nimport { TieredMenuEventService } from \"../../services/tiered-menu.event.service\";\nimport { TieredMenuService } from \"../../services/tiered-menu.service\";\nimport { enableScroll, disabledScroll } from \"../../utils\";\n@Component({\n    templateUrl: \"./tiered-menu-nested.component.html\",\n    styleUrls: [\"./tiered-menu-nested.component.scss\"],\n})\nexport class TieredMenuNestedComponent implements OnInit, OnDestroy {\n    public items: TieredMenuItemInternalData[];\n    public top = 0;\n    public left = 0;\n    // public maxHeight = 0;\n\n    // Saves the last opened item to close it when a new one is opened\n    private _lastOpenItem: TieredMenuItemInternalData;\n    private _unsubscribe$ = new Subject<void>();\n\n    @HostListener(\"window:resize\")\n    public onResize(): void {\n        this._tieredMenuEventService.closeAllMenusEvent.emit();\n    }\n\n    @HostListener(\"document:click\", [\"$event\"])\n    public onDocumentClick(event: MouseEvent): void {\n        // Closing menu when clicked outside.\n        const target = event.target as Element;\n        const clickedInside = target.closest(\"s-tiered-menu-item\") || target.closest(\"s-tiered-menu-divider\");\n        if (!clickedInside) {\n            this._tieredMenuEventService.closeAllMenusEvent.emit();\n        }\n    }\n\n    @HostListener(\"document:keydown\", [\"$event\"])\n    public onKeydownHandler(event: KeyboardEvent) {\n        switch (event.key) {\n            case \"Escape\":\n                this._tieredMenuEventService.closeAllMenusEvent.emit();\n                break;\n            case \" \":\n            case \"Enter\":\n                this._tieredMenuEventService.selectItemEvent.emit(this.tieredMenuService.currentItem);\n                break;\n            case \"ArrowLeft\":\n                // When nested I need a reference to the current item's parent item, otherwise just the current item.\n                this._tieredMenuEventService.closeItemMenuEvent.emit(this.tieredMenuService.currentItem.parent);\n                break;\n            case \"ArrowRight\":\n                this._tieredMenuEventService.openItemMenuEvent.emit(this.tieredMenuService.currentItem);\n                break;\n            case \"ArrowUp\":\n                this._tieredMenuEventService.decrementCurrentItemEvent.emit();\n                break;\n            case \"ArrowDown\":\n                this._tieredMenuEventService.incrementCurrentItemEvent.emit();\n                break;\n        }\n    }\n\n    constructor(\n        public readonly tieredMenuService: TieredMenuService,\n        private readonly _tieredMenuEventService: TieredMenuEventService,\n    ) { }\n\n    public ngOnInit(): void {\n        this.tieredMenuService.currentItems = this.items;\n        this._subscribeEvents();\n        disabledScroll();\n    }\n    \n    public ngOnDestroy(): void {\n        this._unsubscribe$.next();\n        this._unsubscribe$.complete();\n        enableScroll();\n    }\n\n    private _incrementCurItem(): void {\n        if (!this.tieredMenuService.currentItem) {\n            this.tieredMenuService.currentItem = this.tieredMenuService.currentItems[0];\n            return;\n        }\n\n        const curIndex = this.tieredMenuService.currentItems.indexOf(this.tieredMenuService.currentItem) + 1;\n\n        if (curIndex < this.tieredMenuService.currentItems.length) {\n            this.tieredMenuService.currentItem = this.tieredMenuService.currentItems[curIndex];\n        } else {\n            this.tieredMenuService.currentItem = this.tieredMenuService.currentItems[0];\n        }\n\n        if (this.tieredMenuService.currentItem.divider) {\n            this._incrementCurItem();\n        }\n    }\n\n    private _decrementCurItem(): void {\n        if (!this.tieredMenuService.currentItem) {\n            this.tieredMenuService.currentItem = this.tieredMenuService.currentItems[0];\n            return;\n        }\n\n        const curIndex = this.tieredMenuService.currentItems.indexOf(this.tieredMenuService.currentItem) - 1;\n\n        if (curIndex >= 0) {\n            this.tieredMenuService.currentItem = this.tieredMenuService.currentItems[curIndex];\n        } else {\n            this.tieredMenuService.currentItem = this.tieredMenuService.currentItems[this.tieredMenuService.currentItems.length - 1];\n        }\n\n        if (this.tieredMenuService.currentItem.divider) {\n            this._decrementCurItem();\n        }\n    }\n\n    private _closeItem(item: TieredMenuItemInternalData): void {\n        let itemAux = this._lastOpenItem;\n\n        while (itemAux && itemAux != item) {\n            itemAux.isOpen = false;\n            itemAux = itemAux.parent;\n        }\n\n        item.isOpen = false;\n\n        this.tieredMenuService.currentItem = itemAux ?? this.tieredMenuService.items[0];\n        this.tieredMenuService.currentItems = itemAux?.parent?.submenu || this.tieredMenuService.items;\n    }\n\n    private _openItem(item: TieredMenuItemInternalData): void {\n        if (item?.submenu) {\n            item.isOpen = true;\n            this.tieredMenuService.currentItems = item.submenu;\n\n            // Only has focus if there has already been interaction.\n            if (this.tieredMenuService.currentItem) {\n                this.tieredMenuService.currentItem = item.submenu[0];\n            }\n\n            this._lastOpenItem = item;\n        }\n    }\n\n    private _subscribeEvents(): void {\n        this._tieredMenuEventService.incrementCurrentItemEvent\n            .pipe(takeUntil(this._unsubscribe$))\n            .subscribe(() => {\n                this._incrementCurItem();\n            });\n\n        this._tieredMenuEventService.decrementCurrentItemEvent\n            .pipe(takeUntil(this._unsubscribe$))\n            .subscribe(() => {\n                this._decrementCurItem();\n            });\n\n        this._tieredMenuEventService.selectItemEvent\n            .pipe(takeUntil(this._unsubscribe$))\n            .subscribe((item: TieredMenuItemInternalData) => {\n                if (item.command) {\n                    item.command();\n                    // Close all menus after the item was selected.\n                    this._tieredMenuEventService.closeAllMenusEvent.emit();\n                }\n            });\n\n        this._tieredMenuEventService.openItemMenuEvent\n            .pipe(takeUntil(this._unsubscribe$))\n            .subscribe((item: TieredMenuItemInternalData) => {\n                if (!this.tieredMenuService.currentItems.includes(item)) {\n                    let itemAux = this._lastOpenItem;\n\n                    while (itemAux?.parent?.parent) {\n                        itemAux = itemAux.parent;\n                    }\n\n                    this._tieredMenuEventService.closeItemMenuEvent.emit(itemAux.parent ?? itemAux);\n                }\n\n                this._lastOpenItem = item;\n\n                this._openItem(item);\n            });\n\n        this._tieredMenuEventService.closeItemMenuEvent\n            .pipe(takeUntil(this._unsubscribe$))\n            .subscribe((item: TieredMenuItemInternalData) => {\n                if (item) {\n                    this._closeItem(item);\n                }\n            });\n    }\n}\n"]}
|