@nova-ui/bits
Version:
SolarWinds Nova Framework
121 lines • 17.2 kB
JavaScript
// © 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"]}