UNPKG

@nova-ui/bits

Version:

SolarWinds Nova Framework

121 lines 17.2 kB
// © 2022 SolarWinds Worldwide, LLC. All rights reserved. // // Permission is hereby granted, free of charge, to any person obtaining a copy // of this software and associated documentation files (the "Software"), to // deal in the Software without restriction, including without limitation the // rights to use, copy, modify, merge, publish, distribute, sublicense, and/or // sell copies of the Software, and to permit persons to whom the Software is // furnished to do so, subject to the following conditions: // // The above copyright notice and this permission notice shall be included in // all copies or substantial portions of the Software. // // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR // IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, // FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE // AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER // LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, // OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN // THE SOFTWARE. import { Injectable } from "@angular/core"; import { SelectionModel } from "./public-api"; import { SelectorService } from "../lib/selector/selector.service"; import * as i0 from "@angular/core"; import * as i1 from "../lib/selector/selector.service"; export class ListService { constructor(selectorService) { this.selectorService = selectorService; } /** * Updates the selector checkbox status, selector menu items, and the repeat selected items. * * @param {INovaFilteringOutputs} state The filtering outputs state * * @returns {INovaFilteringOutputs} The updated state */ updateSelectionState(state) { const selection = new SelectionModel(state.selector?.selection ?? {}); const itemsSource = (state.repeat && state.repeat.itemsSource) || []; const paginator = state.paginator || { total: undefined }; const selectedItems = this.selectorService.getSelectedItems(selection, itemsSource); const outputState = { ...state, repeat: { itemsSource, ...state.repeat, selectedItems, }, selector: { ...state.selector, selection, selectorState: this.selectorService.getSelectorState(selection, itemsSource.length, selectedItems.length, paginator.total, selection.include.length), }, }; return outputState; } /** * Updates the selector selection state, selector checkbox status, selector menu items, and the * selected items in the repeat based on the items in the provided list and the specified selection * mode. * * @param {any[]} selectedItems The items to select * @param {RepeatSelectionMode} selectionMode The mode to use for selection * @param {INovaFilteringOutputs} state The filtering outputs state * * @returns {INovaFilteringOutputs} The updated state */ selectItems(selectedItems, selectionMode, state) { if (!state.selector || !state.selector.selection) { throw new Error("State must contain selector property"); } if (!state.repeat) { throw new Error("State must contain repeat property"); } if (!state.paginator) { throw new Error("State must contain paginator property"); } const outputState = { ...state, selector: { ...state.selector, selection: this.selectorService.selectItems(state.selector.selection, selectedItems, state.repeat.itemsSource, selectionMode), }, }; return this.updateSelectionState(outputState); } /** * Updates the selector selection state, selector checkbox status, selector menu items, and the * selected items in the repeat based on the selection type. * * @param {SelectionType} selectionType The selection type to apply * @param {INovaFilteringOutputs} state The filtering outputs state * * @returns {INovaFilteringOutputs} The updated state */ applySelector(selectionType, state) { if (!state.selector || !state.selector.selection) { throw new Error("State must contain selector property"); } if (!state.repeat) { throw new Error("State must contain repeat property"); } if (!state.paginator) { throw new Error("State must contain paginator property"); } const outputState = { ...state, selector: { ...state.selector, selection: this.selectorService.applySelector(state.selector.selection, state.repeat.itemsSource, selectionType, state.paginator.total), }, }; return this.updateSelectionState(outputState); } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ListService, deps: [{ token: i1.SelectorService }], target: i0.ɵɵFactoryTarget.Injectable }); } static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ListService, providedIn: "root" }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ListService, decorators: [{ type: Injectable, args: [{ providedIn: "root" }] }], ctorParameters: () => [{ type: i1.SelectorService }] }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"list.service.js","sourceRoot":"","sources":["../../../src/services/list.service.ts"],"names":[],"mappings":"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","sourcesContent":["// © 2022 SolarWinds Worldwide, LLC. All rights reserved.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n//  of this software and associated documentation files (the \"Software\"), to\n//  deal in the Software without restriction, including without limitation the\n//  rights to use, copy, modify, merge, publish, distribute, sublicense, and/or\n//  sell copies of the Software, and to permit persons to whom the Software is\n//  furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in\n//  all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n//  IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n//  FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n//  AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n//  LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n//  OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n//  THE SOFTWARE.\n\nimport { Injectable } from \"@angular/core\";\n\nimport { INovaFilteringOutputs } from \"./data-source/public-api\";\nimport { SelectionModel } from \"./public-api\";\nimport { RepeatSelectionMode } from \"../lib/repeat/types\";\nimport { SelectionType } from \"../lib/selector/public-api\";\nimport { SelectorService } from \"../lib/selector/selector.service\";\n\n@Injectable({ providedIn: \"root\" })\nexport class ListService {\n    constructor(private selectorService: SelectorService) {}\n\n    /**\n     * Updates the selector checkbox status, selector menu items, and the repeat selected items.\n     *\n     * @param {INovaFilteringOutputs} state The filtering outputs state\n     *\n     * @returns {INovaFilteringOutputs} The updated state\n     */\n    public updateSelectionState(\n        state: INovaFilteringOutputs\n    ): INovaFilteringOutputs {\n        const selection = new SelectionModel(state.selector?.selection ?? {});\n        const itemsSource = (state.repeat && state.repeat.itemsSource) || [];\n        const paginator = state.paginator || { total: undefined };\n\n        const selectedItems = this.selectorService.getSelectedItems(\n            selection,\n            itemsSource\n        );\n        const outputState = {\n            ...state,\n            repeat: {\n                itemsSource,\n                ...state.repeat,\n                selectedItems,\n            },\n            selector: {\n                ...state.selector,\n                selection,\n                selectorState: this.selectorService.getSelectorState(\n                    selection,\n                    itemsSource.length,\n                    selectedItems.length,\n                    paginator.total,\n                    selection.include.length\n                ),\n            },\n        };\n\n        return outputState;\n    }\n\n    /**\n     * Updates the selector selection state, selector checkbox status, selector menu items, and the\n     * selected items in the repeat based on the items in the provided list and the specified selection\n     * mode.\n     *\n     * @param {any[]} selectedItems The items to select\n     * @param {RepeatSelectionMode} selectionMode The mode to use for selection\n     * @param {INovaFilteringOutputs} state The filtering outputs state\n     *\n     * @returns {INovaFilteringOutputs} The updated state\n     */\n    public selectItems(\n        selectedItems: any[],\n        selectionMode: RepeatSelectionMode,\n        state: INovaFilteringOutputs\n    ): INovaFilteringOutputs {\n        if (!state.selector || !state.selector.selection) {\n            throw new Error(\"State must contain selector property\");\n        }\n\n        if (!state.repeat) {\n            throw new Error(\"State must contain repeat property\");\n        }\n\n        if (!state.paginator) {\n            throw new Error(\"State must contain paginator property\");\n        }\n\n        const outputState = {\n            ...state,\n            selector: {\n                ...state.selector,\n                selection: this.selectorService.selectItems(\n                    state.selector.selection,\n                    selectedItems,\n                    state.repeat.itemsSource,\n                    selectionMode\n                ),\n            },\n        };\n\n        return this.updateSelectionState(outputState);\n    }\n\n    /**\n     * Updates the selector selection state, selector checkbox status, selector menu items, and the\n     * selected items in the repeat based on the selection type.\n     *\n     * @param {SelectionType} selectionType The selection type to apply\n     * @param {INovaFilteringOutputs} state The filtering outputs state\n     *\n     * @returns {INovaFilteringOutputs} The updated state\n     */\n    public applySelector(\n        selectionType: SelectionType,\n        state: INovaFilteringOutputs\n    ): INovaFilteringOutputs {\n        if (!state.selector || !state.selector.selection) {\n            throw new Error(\"State must contain selector property\");\n        }\n\n        if (!state.repeat) {\n            throw new Error(\"State must contain repeat property\");\n        }\n\n        if (!state.paginator) {\n            throw new Error(\"State must contain paginator property\");\n        }\n\n        const outputState = {\n            ...state,\n            selector: {\n                ...state.selector,\n                selection: this.selectorService.applySelector(\n                    state.selector.selection,\n                    state.repeat.itemsSource,\n                    selectionType,\n                    state.paginator.total\n                ),\n            },\n        };\n\n        return this.updateSelectionState(outputState);\n    }\n}\n"]}