@netgrif/components-core
Version:
Netgrif Application engine frontend core Angular library
99 lines • 12 kB
JavaScript
import { Injectable, Optional } from '@angular/core';
import * as i0 from "@angular/core";
import * as i1 from "../../user/services/view-id.service";
export class OverflowService {
_viewIdService;
DEFAULT_COLUMN_WIDTH = 200;
DEFAULT_COLUMN_COUNT = 6;
_overflowMode;
_columnWidth;
_columnCount;
_state;
_initializedCount;
constructor(_viewIdService) {
this._viewIdService = _viewIdService;
this._initializedCount = false;
this._overflowMode = this.initializeItem('overflowMode', false) === 'true';
this._columnCount = this.checkIsNan(this.initializeItem('columnCount', this.DEFAULT_COLUMN_COUNT), this.DEFAULT_COLUMN_COUNT);
this._columnWidth = this.checkIsNan(this.initializeItem('columnWidth', this.DEFAULT_COLUMN_WIDTH), this.DEFAULT_COLUMN_WIDTH);
}
get overflowMode() {
return this._overflowMode;
}
set overflowMode(value) {
this._overflowMode = value;
}
get columnWidth() {
return this._columnWidth;
}
set columnWidth(value) {
this._columnWidth = value;
}
get columnCount() {
return this._columnCount;
}
set columnCount(value) {
this._columnCount = value;
}
get initializedCount() {
return this._initializedCount;
}
saveState() {
this._state = {
overflowMode: this._overflowMode,
columnWidth: this._columnWidth,
columnCount: this._columnCount,
};
}
saveNewState() {
const viewId = this.getViewId();
if (viewId) {
localStorage.setItem(viewId + '-overflowMode', this._overflowMode + '');
localStorage.setItem(viewId + '-columnCount', this._columnCount + '');
localStorage.setItem(viewId + '-columnWidth', this._columnWidth + '');
}
this._state = undefined;
}
restoreLastState() {
this._overflowMode = this._state.overflowMode;
this._columnWidth = this._state.columnWidth;
this._columnCount = this._state.columnCount;
this._state = undefined;
}
initializeItem(id, defaultValue) {
const viewId = this.getViewId();
if (!viewId) {
return defaultValue;
}
const item = localStorage.getItem(viewId + '-' + id);
if (item !== null) {
if (id?.includes('columnCount')) {
this._initializedCount = true;
}
return item;
}
else {
return defaultValue;
}
}
checkIsNan(item, defaultValue) {
return isNaN(parseInt(item, 10)) ? defaultValue : parseInt(item, 10);
}
/**
* @returns the Id of the view, if the ViewIdService was injected. Returns `undefined` if the service was not injected.
*/
getViewId() {
if (this._viewIdService) {
return this._viewIdService.viewId;
}
return undefined;
}
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: OverflowService, deps: [{ token: i1.ViewIdService, optional: true }], target: i0.ɵɵFactoryTarget.Injectable });
static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: OverflowService });
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: OverflowService, decorators: [{
type: Injectable
}], ctorParameters: () => [{ type: i1.ViewIdService, decorators: [{
type: Optional
}] }] });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"overflow.service.js","sourceRoot":"","sources":["../../../../../../projects/netgrif-components-core/src/lib/header/services/overflow.service.ts"],"names":[],"mappings":"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","sourcesContent":["import {Injectable, Optional} from '@angular/core';\nimport {ViewIdService} from '../../user/services/view-id.service';\n\ninterface OverflowState {\n    overflowMode: boolean;\n    columnWidth: number;\n    columnCount: number;\n}\n\n@Injectable()\nexport class OverflowService {\n\n    protected readonly DEFAULT_COLUMN_WIDTH = 200;\n    protected readonly DEFAULT_COLUMN_COUNT = 6;\n    private _overflowMode: boolean;\n    private _columnWidth: number;\n    private _columnCount: number;\n    private _state: OverflowState;\n    private _initializedCount: boolean;\n\n    constructor(@Optional() private _viewIdService: ViewIdService) {\n        this._initializedCount = false;\n        this._overflowMode = this.initializeItem('overflowMode', false) === 'true';\n        this._columnCount = this.checkIsNan(this.initializeItem('columnCount', this.DEFAULT_COLUMN_COUNT), this.DEFAULT_COLUMN_COUNT);\n        this._columnWidth = this.checkIsNan(this.initializeItem('columnWidth', this.DEFAULT_COLUMN_WIDTH), this.DEFAULT_COLUMN_WIDTH);\n    }\n\n    get overflowMode(): boolean {\n        return this._overflowMode;\n    }\n\n    set overflowMode(value: boolean) {\n        this._overflowMode = value;\n    }\n\n    get columnWidth(): number {\n        return this._columnWidth;\n    }\n\n    set columnWidth(value: number) {\n        this._columnWidth = value;\n    }\n\n    get columnCount(): number {\n        return this._columnCount;\n    }\n\n    set columnCount(value: number) {\n        this._columnCount = value;\n    }\n\n    get initializedCount(): boolean {\n        return this._initializedCount;\n    }\n\n    public saveState(): void {\n        this._state = {\n            overflowMode: this._overflowMode,\n            columnWidth: this._columnWidth,\n            columnCount: this._columnCount,\n        };\n    }\n\n    public saveNewState(): void {\n        const viewId = this.getViewId();\n        if (viewId) {\n            localStorage.setItem(viewId + '-overflowMode', this._overflowMode + '');\n            localStorage.setItem(viewId + '-columnCount', this._columnCount + '');\n            localStorage.setItem(viewId + '-columnWidth', this._columnWidth + '');\n        }\n        this._state = undefined;\n    }\n\n    public restoreLastState(): void {\n        this._overflowMode = this._state.overflowMode;\n        this._columnWidth = this._state.columnWidth;\n        this._columnCount = this._state.columnCount;\n        this._state = undefined;\n    }\n\n    protected initializeItem(id: string, defaultValue) {\n        const viewId = this.getViewId();\n        if (!viewId) {\n            return defaultValue;\n        }\n\n        const item = localStorage.getItem(viewId + '-' + id);\n        if (item !== null) {\n            if (id?.includes('columnCount')) {\n                this._initializedCount = true;\n            }\n            return item;\n        } else {\n            return defaultValue;\n        }\n    }\n\n    protected checkIsNan(item, defaultValue) {\n        return isNaN(parseInt(item, 10)) ? defaultValue : parseInt(item, 10);\n    }\n\n    /**\n     * @returns the Id of the view, if the ViewIdService was injected. Returns `undefined` if the service was not injected.\n     */\n    protected getViewId(): string | undefined {\n        if (this._viewIdService) {\n            return this._viewIdService.viewId;\n        }\n        return undefined;\n    }\n}\n"]}