@nova-ui/bits
Version:
SolarWinds Nova Framework
271 lines • 39.8 kB
JavaScript
import { Injectable } from "@angular/core";
import isNil from "lodash/isNil";
import { OVERLAY_ARROW_SIZE } from "./constants";
import { OverlayPlacement, OverlayPosition, } from "./types";
import * as i0 from "@angular/core";
var OverlayPanelClass;
(function (OverlayPanelClass) {
OverlayPanelClass["overlayCenterTop"] = "overlay-center-top";
OverlayPanelClass["overlayTopLeft"] = "overlay-top-left";
OverlayPanelClass["overlayTopRight"] = "overlay-top-right";
OverlayPanelClass["overlayCenterBottom"] = "overlay-center-bottom";
OverlayPanelClass["overlayBottomRight"] = "overlay-bottom-right";
OverlayPanelClass["overlayBottomLeft"] = "overlay-bottom-left";
OverlayPanelClass["overlayCenterLeft"] = "overlay-center-left";
OverlayPanelClass["overlayLeftTop"] = "overlay-left-top";
OverlayPanelClass["overlayLeftBottom"] = "overlay-left-bottom";
OverlayPanelClass["overlayCenterRight"] = "overlay-center-right";
OverlayPanelClass["overlayRightTop"] = "overlay-right-top";
OverlayPanelClass["overlayRightBottom"] = "overlay-right-bottom";
})(OverlayPanelClass || (OverlayPanelClass = {}));
export class OverlayPositionService {
setOverlayPositionConfig(config) {
this.arrowSize = !isNil(config?.arrowSize)
? config?.arrowSize
: OVERLAY_ARROW_SIZE;
this.arrowPadding = !isNil(config?.arrowPadding)
? config?.arrowPadding
: 0;
this.overlayPositions = getOverlayPositions();
}
updateOffsetOnPositionChanges(positionStrategy, getOverlayRef) {
return positionStrategy.positionChanges.subscribe((connectedPosition) => {
const overlayRefElement = getOverlayRef().overlayElement;
const panelClass = connectedPosition.connectionPair.panelClass;
if (!panelClass) {
return;
}
this.setOverlayOffset(panelClass, overlayRefElement);
});
}
setOverlayOffset(panelClass, overlayRefElement) {
if (Array.isArray(panelClass)) {
panelClass = this.getOverlayPositionPanelClass(panelClass);
}
if (!panelClass) {
return;
}
overlayRefElement.style.marginLeft = "";
overlayRefElement.style.marginTop = "";
overlayRefElement.style.marginBottom = "";
overlayRefElement.style.marginRight = "";
switch (panelClass) {
case OverlayPanelClass.overlayCenterTop:
overlayRefElement.style.marginBottom = this.arrowSize + "px";
break;
case OverlayPanelClass.overlayTopLeft:
overlayRefElement.style.marginRight =
2 * this.arrowPadding + "px";
overlayRefElement.style.marginBottom = this.arrowSize + "px";
break;
case OverlayPanelClass.overlayTopRight:
overlayRefElement.style.marginLeft =
2 * this.arrowPadding + "px";
overlayRefElement.style.marginBottom = this.arrowSize + "px";
break;
case OverlayPanelClass.overlayCenterBottom:
overlayRefElement.style.marginTop = this.arrowSize + "px";
break;
case OverlayPanelClass.overlayBottomRight:
overlayRefElement.style.marginLeft =
2 * this.arrowPadding + "px";
overlayRefElement.style.marginTop = this.arrowSize + "px";
break;
case OverlayPanelClass.overlayBottomLeft:
overlayRefElement.style.marginRight =
2 * this.arrowPadding + "px";
overlayRefElement.style.marginTop = this.arrowSize + "px";
break;
case OverlayPanelClass.overlayCenterLeft:
overlayRefElement.style.marginRight = this.arrowSize + "px";
break;
case OverlayPanelClass.overlayLeftTop:
overlayRefElement.style.marginRight = this.arrowSize + "px";
break;
case OverlayPanelClass.overlayLeftBottom:
overlayRefElement.style.marginRight = this.arrowSize + "px";
break;
case OverlayPanelClass.overlayCenterRight:
overlayRefElement.style.marginLeft = this.arrowSize + "px";
break;
case OverlayPanelClass.overlayRightTop:
overlayRefElement.style.marginLeft = this.arrowSize + "px";
break;
case OverlayPanelClass.overlayRightBottom:
overlayRefElement.style.marginLeft = this.arrowSize + "px";
break;
}
}
getPossiblePositionsForPlacement(placement) {
const possiblePositions = [];
// add positions for the requested placement
possiblePositions.push(...this.getPositionsForPlacement(placement));
// add positions for the opposite placement in case the requested placement
// would be rendered outside the screen
switch (placement) {
case OverlayPlacement.Left:
possiblePositions.push(...this.getPositionsForPlacement(OverlayPlacement.Right), ...this.getPositionsForPlacement(OverlayPlacement.Top), ...this.getPositionsForPlacement(OverlayPlacement.Bottom));
break;
case OverlayPlacement.Right:
possiblePositions.push(...this.getPositionsForPlacement(OverlayPlacement.Left), ...this.getPositionsForPlacement(OverlayPlacement.Top), ...this.getPositionsForPlacement(OverlayPlacement.Bottom));
break;
case OverlayPlacement.Top:
possiblePositions.push(...this.getPositionsForPlacement(OverlayPlacement.Bottom), ...this.getPositionsForPlacement(OverlayPlacement.Left), ...this.getPositionsForPlacement(OverlayPlacement.Right));
break;
case OverlayPlacement.Bottom:
possiblePositions.push(...this.getPositionsForPlacement(OverlayPlacement.Top), ...this.getPositionsForPlacement(OverlayPlacement.Left), ...this.getPositionsForPlacement(OverlayPlacement.Right));
break;
}
return possiblePositions;
}
getOverlayPositionPanelClass(panelClass) {
let result;
for (const panelClassKey in OverlayPanelClass) {
if (OverlayPanelClass.hasOwnProperty(panelClassKey)) {
result = panelClass.find((i) => i === panelClassKey);
}
}
return result || "";
}
/**
* Returns all possible positions for a placement
* Eg: left => [OVERLAY_POSITIONS[centerLeft], OVERLAY_POSITIONS[topLeft], OVERLAY_POSITIONS[bottomLeft]]
*
* @param placement
* @returns ConnectedPosition[]
*/
getPositionsForPlacement(placement) {
let possiblePositionNames = [];
switch (placement) {
case OverlayPlacement.Left:
possiblePositionNames = [
OverlayPosition.centerLeft,
OverlayPosition.leftTop,
OverlayPosition.leftBottom,
];
break;
case OverlayPlacement.Right:
possiblePositionNames = [
OverlayPosition.centerRight,
OverlayPosition.rightTop,
OverlayPosition.rightBottom,
];
break;
case OverlayPlacement.Top:
possiblePositionNames = [
OverlayPosition.centerTop,
OverlayPosition.topLeft,
OverlayPosition.topRight,
];
break;
case OverlayPlacement.Bottom:
possiblePositionNames = [
OverlayPosition.centerBottom,
OverlayPosition.bottomLeft,
OverlayPosition.bottomRight,
];
break;
case OverlayPlacement.Custom:
throw new Error(`Custom position should be handled by user`);
}
return possiblePositionNames.map((positionName) => this.overlayPositions[positionName]);
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: OverlayPositionService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: OverlayPositionService }); }
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: OverlayPositionService, decorators: [{
type: Injectable
}] });
export function getOverlayPositions() {
return {
// TOP
[OverlayPosition.centerTop]: {
panelClass: "overlay-center-top",
originX: "center",
originY: "top",
overlayX: "center",
overlayY: "bottom",
},
[OverlayPosition.topLeft]: {
panelClass: "overlay-top-left",
originX: "end",
originY: "top",
overlayX: "end",
overlayY: "bottom",
},
[OverlayPosition.topRight]: {
panelClass: "overlay-top-right",
originX: "start",
originY: "top",
overlayX: "start",
overlayY: "bottom",
},
// BOTTOM
[OverlayPosition.centerBottom]: {
panelClass: "overlay-center-bottom",
originX: "center",
originY: "bottom",
overlayX: "center",
overlayY: "top",
},
[OverlayPosition.bottomRight]: {
panelClass: "overlay-bottom-right",
originX: "start",
originY: "bottom",
overlayX: "start",
overlayY: "top",
},
[OverlayPosition.bottomLeft]: {
panelClass: "overlay-bottom-left",
originX: "end",
originY: "bottom",
overlayX: "end",
overlayY: "top",
},
// LEFT
[OverlayPosition.centerLeft]: {
panelClass: "overlay-center-left",
originX: "start",
originY: "center",
overlayX: "end",
overlayY: "center",
},
[OverlayPosition.leftTop]: {
panelClass: "overlay-left-top",
originX: "start",
originY: "bottom",
overlayX: "end",
overlayY: "bottom",
},
[OverlayPosition.leftBottom]: {
panelClass: "overlay-left-bottom",
originX: "start",
originY: "top",
overlayX: "end",
overlayY: "top",
},
// RIGHT
[OverlayPosition.centerRight]: {
panelClass: "overlay-center-right",
originX: "end",
originY: "center",
overlayX: "start",
overlayY: "center",
},
[OverlayPosition.rightTop]: {
panelClass: "overlay-right-top",
originX: "end",
originY: "bottom",
overlayX: "start",
overlayY: "bottom",
},
[OverlayPosition.rightBottom]: {
panelClass: "overlay-right-bottom",
originX: "end",
originY: "top",
overlayX: "start",
overlayY: "top",
},
};
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"overlay-position.service.js","sourceRoot":"","sources":["../../../../src/lib/overlay/overlay-position.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 {\n    ConnectedOverlayPositionChange,\n    ConnectedPosition,\n    FlexibleConnectedPositionStrategy,\n    OverlayRef,\n} from \"@angular/cdk/overlay\";\nimport { Injectable } from \"@angular/core\";\nimport isNil from \"lodash/isNil\";\nimport { Subscription } from \"rxjs\";\n\nimport { OVERLAY_ARROW_SIZE } from \"./constants\";\nimport {\n    IOverlayPositionServiceConfig,\n    OverlayPlacement,\n    OverlayPosition,\n} from \"./types\";\n\nenum OverlayPanelClass {\n    overlayCenterTop = \"overlay-center-top\",\n    overlayTopLeft = \"overlay-top-left\",\n    overlayTopRight = \"overlay-top-right\",\n    overlayCenterBottom = \"overlay-center-bottom\",\n    overlayBottomRight = \"overlay-bottom-right\",\n    overlayBottomLeft = \"overlay-bottom-left\",\n    overlayCenterLeft = \"overlay-center-left\",\n    overlayLeftTop = \"overlay-left-top\",\n    overlayLeftBottom = \"overlay-left-bottom\",\n    overlayCenterRight = \"overlay-center-right\",\n    overlayRightTop = \"overlay-right-top\",\n    overlayRightBottom = \"overlay-right-bottom\",\n}\n\n@Injectable()\nexport class OverlayPositionService {\n    private overlayPositions: Record<OverlayPosition, ConnectedPosition>;\n\n    private arrowSize: number;\n    private arrowPadding: number;\n    public config: IOverlayPositionServiceConfig;\n\n    public setOverlayPositionConfig(\n        config?: IOverlayPositionServiceConfig\n    ): void {\n        this.arrowSize = !isNil(config?.arrowSize)\n            ? <number>config?.arrowSize\n            : OVERLAY_ARROW_SIZE;\n        this.arrowPadding = !isNil(config?.arrowPadding)\n            ? <number>config?.arrowPadding\n            : 0;\n        this.overlayPositions = getOverlayPositions();\n    }\n\n    public updateOffsetOnPositionChanges(\n        positionStrategy: FlexibleConnectedPositionStrategy,\n        getOverlayRef: () => OverlayRef\n    ): Subscription {\n        return positionStrategy.positionChanges.subscribe(\n            (connectedPosition: ConnectedOverlayPositionChange) => {\n                const overlayRefElement = getOverlayRef().overlayElement;\n                const panelClass = connectedPosition.connectionPair.panelClass;\n                if (!panelClass) {\n                    return;\n                }\n                this.setOverlayOffset(panelClass, overlayRefElement);\n            }\n        );\n    }\n\n    private setOverlayOffset(\n        panelClass: string | string[],\n        overlayRefElement: HTMLElement\n    ) {\n        if (Array.isArray(panelClass)) {\n            panelClass = this.getOverlayPositionPanelClass(panelClass);\n        }\n\n        if (!panelClass) {\n            return;\n        }\n\n        overlayRefElement.style.marginLeft = \"\";\n        overlayRefElement.style.marginTop = \"\";\n        overlayRefElement.style.marginBottom = \"\";\n        overlayRefElement.style.marginRight = \"\";\n\n        switch (panelClass) {\n            case OverlayPanelClass.overlayCenterTop:\n                overlayRefElement.style.marginBottom = this.arrowSize + \"px\";\n                break;\n            case OverlayPanelClass.overlayTopLeft:\n                overlayRefElement.style.marginRight =\n                    2 * this.arrowPadding + \"px\";\n                overlayRefElement.style.marginBottom = this.arrowSize + \"px\";\n                break;\n            case OverlayPanelClass.overlayTopRight:\n                overlayRefElement.style.marginLeft =\n                    2 * this.arrowPadding + \"px\";\n                overlayRefElement.style.marginBottom = this.arrowSize + \"px\";\n                break;\n            case OverlayPanelClass.overlayCenterBottom:\n                overlayRefElement.style.marginTop = this.arrowSize + \"px\";\n                break;\n            case OverlayPanelClass.overlayBottomRight:\n                overlayRefElement.style.marginLeft =\n                    2 * this.arrowPadding + \"px\";\n                overlayRefElement.style.marginTop = this.arrowSize + \"px\";\n                break;\n            case OverlayPanelClass.overlayBottomLeft:\n                overlayRefElement.style.marginRight =\n                    2 * this.arrowPadding + \"px\";\n                overlayRefElement.style.marginTop = this.arrowSize + \"px\";\n                break;\n            case OverlayPanelClass.overlayCenterLeft:\n                overlayRefElement.style.marginRight = this.arrowSize + \"px\";\n                break;\n            case OverlayPanelClass.overlayLeftTop:\n                overlayRefElement.style.marginRight = this.arrowSize + \"px\";\n                break;\n            case OverlayPanelClass.overlayLeftBottom:\n                overlayRefElement.style.marginRight = this.arrowSize + \"px\";\n                break;\n            case OverlayPanelClass.overlayCenterRight:\n                overlayRefElement.style.marginLeft = this.arrowSize + \"px\";\n                break;\n            case OverlayPanelClass.overlayRightTop:\n                overlayRefElement.style.marginLeft = this.arrowSize + \"px\";\n                break;\n            case OverlayPanelClass.overlayRightBottom:\n                overlayRefElement.style.marginLeft = this.arrowSize + \"px\";\n                break;\n        }\n    }\n\n    public getPossiblePositionsForPlacement(\n        placement: OverlayPlacement\n    ): ConnectedPosition[] {\n        const possiblePositions: ConnectedPosition[] = [];\n\n        // add positions for the requested placement\n        possiblePositions.push(...this.getPositionsForPlacement(placement));\n\n        // add positions for the opposite placement in case the requested placement\n        // would be rendered outside the screen\n        switch (placement) {\n            case OverlayPlacement.Left:\n                possiblePositions.push(\n                    ...this.getPositionsForPlacement(OverlayPlacement.Right),\n                    ...this.getPositionsForPlacement(OverlayPlacement.Top),\n                    ...this.getPositionsForPlacement(OverlayPlacement.Bottom)\n                );\n                break;\n            case OverlayPlacement.Right:\n                possiblePositions.push(\n                    ...this.getPositionsForPlacement(OverlayPlacement.Left),\n                    ...this.getPositionsForPlacement(OverlayPlacement.Top),\n                    ...this.getPositionsForPlacement(OverlayPlacement.Bottom)\n                );\n                break;\n            case OverlayPlacement.Top:\n                possiblePositions.push(\n                    ...this.getPositionsForPlacement(OverlayPlacement.Bottom),\n                    ...this.getPositionsForPlacement(OverlayPlacement.Left),\n                    ...this.getPositionsForPlacement(OverlayPlacement.Right)\n                );\n                break;\n            case OverlayPlacement.Bottom:\n                possiblePositions.push(\n                    ...this.getPositionsForPlacement(OverlayPlacement.Top),\n                    ...this.getPositionsForPlacement(OverlayPlacement.Left),\n                    ...this.getPositionsForPlacement(OverlayPlacement.Right)\n                );\n                break;\n        }\n\n        return possiblePositions;\n    }\n\n    private getOverlayPositionPanelClass(panelClass: string[]): string {\n        let result;\n        for (const panelClassKey in OverlayPanelClass) {\n            if (OverlayPanelClass.hasOwnProperty(panelClassKey)) {\n                result = panelClass.find((i) => i === panelClassKey);\n            }\n        }\n        return result || \"\";\n    }\n\n    /**\n     * Returns all possible positions for a placement\n     * Eg: left => [OVERLAY_POSITIONS[centerLeft], OVERLAY_POSITIONS[topLeft], OVERLAY_POSITIONS[bottomLeft]]\n     *\n     * @param placement\n     * @returns ConnectedPosition[]\n     */\n    private getPositionsForPlacement(\n        placement: OverlayPlacement\n    ): ConnectedPosition[] {\n        let possiblePositionNames: OverlayPosition[] = [];\n        switch (placement) {\n            case OverlayPlacement.Left:\n                possiblePositionNames = [\n                    OverlayPosition.centerLeft,\n                    OverlayPosition.leftTop,\n                    OverlayPosition.leftBottom,\n                ];\n                break;\n\n            case OverlayPlacement.Right:\n                possiblePositionNames = [\n                    OverlayPosition.centerRight,\n                    OverlayPosition.rightTop,\n                    OverlayPosition.rightBottom,\n                ];\n                break;\n\n            case OverlayPlacement.Top:\n                possiblePositionNames = [\n                    OverlayPosition.centerTop,\n                    OverlayPosition.topLeft,\n                    OverlayPosition.topRight,\n                ];\n                break;\n\n            case OverlayPlacement.Bottom:\n                possiblePositionNames = [\n                    OverlayPosition.centerBottom,\n                    OverlayPosition.bottomLeft,\n                    OverlayPosition.bottomRight,\n                ];\n                break;\n\n            case OverlayPlacement.Custom:\n                throw new Error(`Custom position should be handled by user`);\n        }\n\n        return possiblePositionNames.map(\n            (positionName: OverlayPosition) =>\n                this.overlayPositions[positionName]\n        );\n    }\n}\n\nexport function getOverlayPositions(): Record<\n    OverlayPosition,\n    ConnectedPosition\n> {\n    return {\n        // TOP\n        [OverlayPosition.centerTop]: {\n            panelClass: \"overlay-center-top\",\n            originX: \"center\",\n            originY: \"top\",\n            overlayX: \"center\",\n            overlayY: \"bottom\",\n        },\n        [OverlayPosition.topLeft]: {\n            panelClass: \"overlay-top-left\",\n            originX: \"end\",\n            originY: \"top\",\n            overlayX: \"end\",\n            overlayY: \"bottom\",\n        },\n        [OverlayPosition.topRight]: {\n            panelClass: \"overlay-top-right\",\n            originX: \"start\",\n            originY: \"top\",\n            overlayX: \"start\",\n            overlayY: \"bottom\",\n        },\n        // BOTTOM\n        [OverlayPosition.centerBottom]: {\n            panelClass: \"overlay-center-bottom\",\n            originX: \"center\",\n            originY: \"bottom\",\n            overlayX: \"center\",\n            overlayY: \"top\",\n        },\n        [OverlayPosition.bottomRight]: {\n            panelClass: \"overlay-bottom-right\",\n            originX: \"start\",\n            originY: \"bottom\",\n            overlayX: \"start\",\n            overlayY: \"top\",\n        },\n        [OverlayPosition.bottomLeft]: {\n            panelClass: \"overlay-bottom-left\",\n            originX: \"end\",\n            originY: \"bottom\",\n            overlayX: \"end\",\n            overlayY: \"top\",\n        },\n        // LEFT\n        [OverlayPosition.centerLeft]: {\n            panelClass: \"overlay-center-left\",\n            originX: \"start\",\n            originY: \"center\",\n            overlayX: \"end\",\n            overlayY: \"center\",\n        },\n        [OverlayPosition.leftTop]: {\n            panelClass: \"overlay-left-top\",\n            originX: \"start\",\n            originY: \"bottom\",\n            overlayX: \"end\",\n            overlayY: \"bottom\",\n        },\n        [OverlayPosition.leftBottom]: {\n            panelClass: \"overlay-left-bottom\",\n            originX: \"start\",\n            originY: \"top\",\n            overlayX: \"end\",\n            overlayY: \"top\",\n        },\n        // RIGHT\n        [OverlayPosition.centerRight]: {\n            panelClass: \"overlay-center-right\",\n            originX: \"end\",\n            originY: \"center\",\n            overlayX: \"start\",\n            overlayY: \"center\",\n        },\n        [OverlayPosition.rightTop]: {\n            panelClass: \"overlay-right-top\",\n            originX: \"end\",\n            originY: \"bottom\",\n            overlayX: \"start\",\n            overlayY: \"bottom\",\n        },\n        [OverlayPosition.rightBottom]: {\n            panelClass: \"overlay-right-bottom\",\n            originX: \"end\",\n            originY: \"top\",\n            overlayX: \"start\",\n            overlayY: \"top\",\n        },\n    };\n}\n"]}