@sbb-esta/lyne-elements 3.10.0 → 3.11.0
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/calendar/calendar.component.d.ts +2 -1
- package/calendar/calendar.component.d.ts.map +1 -1
- package/core/controllers/escapable-overlay-controller.d.ts +3 -0
- package/core/controllers/escapable-overlay-controller.d.ts.map +1 -1
- package/core/controllers/overlay-position-controller.d.ts +60 -0
- package/core/controllers/overlay-position-controller.d.ts.map +1 -0
- package/core/controllers/overlay-position-controller.js +224 -0
- package/core/controllers.d.ts +1 -0
- package/core/controllers.d.ts.map +1 -1
- package/core/controllers.js +12 -10
- package/core/styles/core.scss +27 -2
- package/core.css +21 -2
- package/custom-elements.json +1996 -544
- package/development/calendar/calendar.component.d.ts +2 -1
- package/development/calendar/calendar.component.d.ts.map +1 -1
- package/development/calendar/calendar.component.js +1 -1
- package/development/core/controllers/escapable-overlay-controller.d.ts +3 -0
- package/development/core/controllers/escapable-overlay-controller.d.ts.map +1 -1
- package/development/core/controllers/escapable-overlay-controller.js +1 -1
- package/development/core/controllers/overlay-position-controller.d.ts +60 -0
- package/development/core/controllers/overlay-position-controller.d.ts.map +1 -0
- package/development/core/controllers/overlay-position-controller.js +306 -0
- package/development/core/controllers.d.ts +1 -0
- package/development/core/controllers.d.ts.map +1 -1
- package/development/core/controllers.js +3 -1
- package/development/mini-calendar/mini-calendar/mini-calendar.component.d.ts +35 -0
- package/development/mini-calendar/mini-calendar/mini-calendar.component.d.ts.map +1 -0
- package/development/mini-calendar/mini-calendar/mini-calendar.component.js +201 -0
- package/development/mini-calendar/mini-calendar-day/mini-calendar-day.component.d.ts +23 -0
- package/development/mini-calendar/mini-calendar-day/mini-calendar-day.component.d.ts.map +1 -0
- package/development/mini-calendar/mini-calendar-day/mini-calendar-day.component.js +181 -0
- package/development/mini-calendar/mini-calendar-day.d.ts +5 -0
- package/development/mini-calendar/mini-calendar-day.d.ts.map +1 -0
- package/development/mini-calendar/mini-calendar-day.js +5 -0
- package/development/mini-calendar/mini-calendar-month/mini-calendar-month.component.d.ts +25 -0
- package/development/mini-calendar/mini-calendar-month/mini-calendar-month.component.d.ts.map +1 -0
- package/development/mini-calendar/mini-calendar-month/mini-calendar-month.component.js +123 -0
- package/development/mini-calendar/mini-calendar-month.d.ts +5 -0
- package/development/mini-calendar/mini-calendar-month.d.ts.map +1 -0
- package/development/mini-calendar/mini-calendar-month.js +5 -0
- package/development/mini-calendar/mini-calendar.d.ts +5 -0
- package/development/mini-calendar/mini-calendar.d.ts.map +1 -0
- package/development/mini-calendar/mini-calendar.js +5 -0
- package/development/mini-calendar.d.ts +7 -0
- package/development/mini-calendar.d.ts.map +1 -0
- package/development/mini-calendar.js +9 -0
- package/development/sidebar/icon-sidebar-button/icon-sidebar-button.component.d.ts +4 -1
- package/development/sidebar/icon-sidebar-button/icon-sidebar-button.component.d.ts.map +1 -1
- package/development/sidebar/icon-sidebar-button/icon-sidebar-button.component.js +5 -1
- package/development/sidebar/icon-sidebar-link/icon-sidebar-link.component.d.ts +4 -1
- package/development/sidebar/icon-sidebar-link/icon-sidebar-link.component.d.ts.map +1 -1
- package/development/sidebar/icon-sidebar-link/icon-sidebar-link.component.js +5 -1
- package/development/tabs/tab/tab.component.d.ts +9 -0
- package/development/tabs/tab/tab.component.d.ts.map +1 -1
- package/development/tabs/tab/tab.component.js +48 -7
- package/development/tabs/tab-group/tab-group.component.d.ts +7 -3
- package/development/tabs/tab-group/tab-group.component.d.ts.map +1 -1
- package/development/tabs/tab-group/tab-group.component.js +19 -39
- package/development/tabs/tab-label/tab-label.component.d.ts.map +1 -1
- package/development/tabs/tab-label/tab-label.component.js +4 -3
- package/development/tooltip/tooltip.component.d.ts +11 -4
- package/development/tooltip/tooltip.component.d.ts.map +1 -1
- package/development/tooltip/tooltip.component.js +57 -78
- package/index.d.ts +6 -0
- package/index.js +6 -0
- package/mini-calendar/mini-calendar/mini-calendar.component.d.ts +35 -0
- package/mini-calendar/mini-calendar/mini-calendar.component.d.ts.map +1 -0
- package/mini-calendar/mini-calendar/mini-calendar.component.js +133 -0
- package/mini-calendar/mini-calendar-day/mini-calendar-day.component.d.ts +23 -0
- package/mini-calendar/mini-calendar-day/mini-calendar-day.component.d.ts.map +1 -0
- package/mini-calendar/mini-calendar-day/mini-calendar-day.component.js +66 -0
- package/mini-calendar/mini-calendar-day.d.ts +5 -0
- package/mini-calendar/mini-calendar-day.d.ts.map +1 -0
- package/mini-calendar/mini-calendar-day.js +4 -0
- package/mini-calendar/mini-calendar-month/mini-calendar-month.component.d.ts +25 -0
- package/mini-calendar/mini-calendar-month/mini-calendar-month.component.d.ts.map +1 -0
- package/mini-calendar/mini-calendar-month/mini-calendar-month.component.js +59 -0
- package/mini-calendar/mini-calendar-month.d.ts +5 -0
- package/mini-calendar/mini-calendar-month.d.ts.map +1 -0
- package/mini-calendar/mini-calendar-month.js +4 -0
- package/mini-calendar/mini-calendar.d.ts +5 -0
- package/mini-calendar/mini-calendar.d.ts.map +1 -0
- package/mini-calendar/mini-calendar.js +4 -0
- package/mini-calendar.d.ts +7 -0
- package/mini-calendar.d.ts.map +1 -0
- package/mini-calendar.js +8 -0
- package/off-brand-theme.css +21 -2
- package/package.json +21 -1
- package/safety-theme.css +21 -2
- package/sidebar/icon-sidebar-button/icon-sidebar-button.component.d.ts +4 -1
- package/sidebar/icon-sidebar-button/icon-sidebar-button.component.d.ts.map +1 -1
- package/sidebar/icon-sidebar-button/icon-sidebar-button.component.js +9 -6
- package/sidebar/icon-sidebar-link/icon-sidebar-link.component.d.ts +4 -1
- package/sidebar/icon-sidebar-link/icon-sidebar-link.component.d.ts.map +1 -1
- package/sidebar/icon-sidebar-link/icon-sidebar-link.component.js +13 -10
- package/standard-theme.css +21 -2
- package/tabs/tab/tab.component.d.ts +9 -0
- package/tabs/tab/tab.component.d.ts.map +1 -1
- package/tabs/tab/tab.component.js +37 -18
- package/tabs/tab-group/tab-group.component.d.ts +7 -3
- package/tabs/tab-group/tab-group.component.d.ts.map +1 -1
- package/tabs/tab-group/tab-group.component.js +51 -52
- package/tabs/tab-label/tab-label.component.d.ts.map +1 -1
- package/tabs/tab-label/tab-label.component.js +12 -12
- package/tooltip/tooltip.component.d.ts +11 -4
- package/tooltip/tooltip.component.d.ts.map +1 -1
- package/tooltip/tooltip.component.js +60 -84
|
@@ -1,5 +1,8 @@
|
|
|
1
1
|
import { ReactiveController, ReactiveControllerHost } from 'lit';
|
|
2
2
|
import { SbbOpenCloseBaseElement } from '../base-elements/open-close-base-element.js';
|
|
3
|
+
/**
|
|
4
|
+
* Handles the stack of overlays and closes the last opened one when pressing Escape.
|
|
5
|
+
*/
|
|
3
6
|
export declare class SbbEscapableOverlayController implements ReactiveController {
|
|
4
7
|
private _host;
|
|
5
8
|
private _overlayStack;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"escapable-overlay-controller.d.ts","sourceRoot":"","sources":["../../../../../src/elements/core/controllers/escapable-overlay-controller.ts"],"names":[],"mappings":"AAAA,OAAO,EAAY,KAAK,kBAAkB,EAAE,KAAK,sBAAsB,EAAE,MAAM,KAAK,CAAC;AAErF,OAAO,KAAK,EAAE,uBAAuB,EAAE,MAAM,6CAA6C,CAAC;AAa3F,qBAAa,6BAA8B,YAAW,kBAAkB;IAEpE,OAAO,CAAC,KAAK;IACb,OAAO,CAAC,aAAa;gBADb,KAAK,EAAE,sBAAsB,GAAG,uBAAuB,EACvD,aAAa,GAAE,uBAAuB,EAAiB;IAK1D,gBAAgB,IAAI,IAAI;IAKxB,OAAO,IAAI,IAAI;IAQf,UAAU,IAAI,IAAI;CAQ1B"}
|
|
1
|
+
{"version":3,"file":"escapable-overlay-controller.d.ts","sourceRoot":"","sources":["../../../../../src/elements/core/controllers/escapable-overlay-controller.ts"],"names":[],"mappings":"AAAA,OAAO,EAAY,KAAK,kBAAkB,EAAE,KAAK,sBAAsB,EAAE,MAAM,KAAK,CAAC;AAErF,OAAO,KAAK,EAAE,uBAAuB,EAAE,MAAM,6CAA6C,CAAC;AAa3F;;GAEG;AACH,qBAAa,6BAA8B,YAAW,kBAAkB;IAEpE,OAAO,CAAC,KAAK;IACb,OAAO,CAAC,aAAa;gBADb,KAAK,EAAE,sBAAsB,GAAG,uBAAuB,EACvD,aAAa,GAAE,uBAAuB,EAAiB;IAK1D,gBAAgB,IAAI,IAAI;IAKxB,OAAO,IAAI,IAAI;IAQf,UAAU,IAAI,IAAI;CAQ1B"}
|
|
@@ -35,4 +35,4 @@ class SbbEscapableOverlayController {
|
|
|
35
35
|
export {
|
|
36
36
|
SbbEscapableOverlayController
|
|
37
37
|
};
|
|
38
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
38
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXNjYXBhYmxlLW92ZXJsYXktY29udHJvbGxlci5qcyIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vc3JjL2VsZW1lbnRzL2NvcmUvY29udHJvbGxlcnMvZXNjYXBhYmxlLW92ZXJsYXktY29udHJvbGxlci50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBpc1NlcnZlciwgdHlwZSBSZWFjdGl2ZUNvbnRyb2xsZXIsIHR5cGUgUmVhY3RpdmVDb250cm9sbGVySG9zdCB9IGZyb20gJ2xpdCc7XG5cbmltcG9ydCB0eXBlIHsgU2JiT3BlbkNsb3NlQmFzZUVsZW1lbnQgfSBmcm9tICcuLi9iYXNlLWVsZW1lbnRzL29wZW4tY2xvc2UtYmFzZS1lbGVtZW50LmpzJztcblxuY29uc3Qgb3ZlcmxheVN0YWNrID0gbmV3IEFycmF5PFNiYk9wZW5DbG9zZUJhc2VFbGVtZW50PigpO1xuXG5pZiAoIWlzU2VydmVyKSB7XG4gIHdpbmRvdy5hZGRFdmVudExpc3RlbmVyKCdrZXlkb3duJywgKGV2ZW50OiBLZXlib2FyZEV2ZW50KSA9PiB7XG4gICAgaWYgKGV2ZW50LmtleSA9PT0gJ0VzY2FwZScgJiYgIWV2ZW50LmRlZmF1bHRQcmV2ZW50ZWQpIHtcbiAgICAgIGV2ZW50LnByZXZlbnREZWZhdWx0KCk7XG4gICAgICBvdmVybGF5U3RhY2suYXQoLTEpPy5lc2NhcGVTdHJhdGVneSgpO1xuICAgIH1cbiAgfSk7XG59XG5cbi8qKlxuICogSGFuZGxlcyB0aGUgc3RhY2sgb2Ygb3ZlcmxheXMgYW5kIGNsb3NlcyB0aGUgbGFzdCBvcGVuZWQgb25lIHdoZW4gcHJlc3NpbmcgRXNjYXBlLlxuICovXG5leHBvcnQgY2xhc3MgU2JiRXNjYXBhYmxlT3ZlcmxheUNvbnRyb2xsZXIgaW1wbGVtZW50cyBSZWFjdGl2ZUNvbnRyb2xsZXIge1xuICBwdWJsaWMgY29uc3RydWN0b3IoXG4gICAgcHJpdmF0ZSBfaG9zdDogUmVhY3RpdmVDb250cm9sbGVySG9zdCAmIFNiYk9wZW5DbG9zZUJhc2VFbGVtZW50LFxuICAgIHByaXZhdGUgX292ZXJsYXlTdGFjazogU2JiT3BlbkNsb3NlQmFzZUVsZW1lbnRbXSA9IG92ZXJsYXlTdGFjayxcbiAgKSB7XG4gICAgdGhpcy5faG9zdC5hZGRDb250cm9sbGVyPy4odGhpcyk7XG4gIH1cblxuICBwdWJsaWMgaG9zdERpc2Nvbm5lY3RlZCgpOiB2b2lkIHtcbiAgICB0aGlzLmRpc2Nvbm5lY3QoKTtcbiAgfVxuXG4gIC8vIFRoaXMgbXVzdCBiZSBjYWxsZWQgd2hlbiB0aGUgb3ZlcmxheSBpcyBvcGVuZWRcbiAgcHVibGljIGNvbm5lY3QoKTogdm9pZCB7XG4gICAgLy8gRHVlIHRvIGNvbm5lY3QoKSBjYW4gYmUgY2FsbGVkIG11bHRpcGxlIHRpbWVzIGZvciB0aGUgc2FtZSBob3N0LFxuICAgIC8vIHdlIGhhdmUgdG8gcmVtb3ZlIGEgcG90ZW50aWFsIGVudHJ5IG9mIHRoZSBob3N0IGZyb20gdGhlIHN0YWNrLlxuICAgIHRoaXMuZGlzY29ubmVjdCgpO1xuICAgIHRoaXMuX292ZXJsYXlTdGFjay5wdXNoKHRoaXMuX2hvc3QpO1xuICB9XG5cbiAgLy8gVGhpcyBtdXN0IGJlIGNhbGxlZCB3aGVuIHRoZSBvdmVybGF5IGlzIGNsb3NlZFxuICBwdWJsaWMgZGlzY29ubmVjdCgpOiB2b2lkIHtcbiAgICBpZiAodGhpcy5fb3ZlcmxheVN0YWNrLmxlbmd0aCkge1xuICAgICAgY29uc3QgZmluZEVsSW5kZXggPSB0aGlzLl9vdmVybGF5U3RhY2suZmluZEluZGV4KChlKSA9PiBlID09PSB0aGlzLl9ob3N0KTtcbiAgICAgIGlmIChmaW5kRWxJbmRleCAhPT0gLTEpIHtcbiAgICAgICAgdGhpcy5fb3ZlcmxheVN0YWNrLnNwbGljZShmaW5kRWxJbmRleCwgMSk7XG4gICAgICB9XG4gICAgfVxuICB9XG59XG4iXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUlBLE1BQU0sZUFBZSxJQUFJLE1BQUE7QUFFekIsSUFBSSxDQUFDLFVBQVU7QUFDYixTQUFPLGlCQUFpQixXQUFXLENBQUMsVUFBd0I7QUFDMUQsUUFBSSxNQUFNLFFBQVEsWUFBWSxDQUFDLE1BQU0sa0JBQWtCO0FBQ3JELFlBQU0sZUFBQTtBQUNOLG1CQUFhLEdBQUcsRUFBRSxHQUFHLGVBQUE7QUFBQSxJQUN2QjtBQUFBLEVBQ0YsQ0FBQztBQUNIO01BS2EsOEJBQTZCO0FBQUEsRUFDeEMsWUFDVSxPQUNBLGdCQUEyQyxjQUFZO0FBRHZELFNBQUEsUUFBQTtBQUNBLFNBQUEsZ0JBQUE7QUFFUixTQUFLLE1BQU0sZ0JBQWdCLElBQUk7QUFBQSxFQUNqQztBQUFBLEVBRU8sbUJBQWdCO0FBQ3JCLFNBQUssV0FBQTtBQUFBLEVBQ1A7QUFBQTtBQUFBLEVBR08sVUFBTztBQUdaLFNBQUssV0FBQTtBQUNMLFNBQUssY0FBYyxLQUFLLEtBQUssS0FBSztBQUFBLEVBQ3BDO0FBQUE7QUFBQSxFQUdPLGFBQVU7QUFDZixRQUFJLEtBQUssY0FBYyxRQUFRO0FBQzdCLFlBQU0sY0FBYyxLQUFLLGNBQWMsVUFBVSxDQUFDLE1BQU0sTUFBTSxLQUFLLEtBQUs7QUFDeEUsVUFBSSxnQkFBZ0IsSUFBSTtBQUN0QixhQUFLLGNBQWMsT0FBTyxhQUFhLENBQUM7QUFBQSxNQUMxQztBQUFBLElBQ0Y7QUFBQSxFQUNGO0FBQ0Q7In0=
|
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
import { ReactiveController, ReactiveControllerHost } from 'lit';
|
|
2
|
+
/**
|
|
3
|
+
* Controller for managing overlays positioning. Also acts as a polyfill when native
|
|
4
|
+
* CSS Anchor Positioning is not supported (enough).
|
|
5
|
+
* Applies unique anchor names when using native CSS Anchor Positioning
|
|
6
|
+
* or calculates and applies correct positions in polyfill mode.
|
|
7
|
+
*
|
|
8
|
+
* Also, the controller sets the 'data-overlay-position' attribute on the overlay element.
|
|
9
|
+
* This can be used to apply specific styles based on the current position of the overlay.
|
|
10
|
+
*
|
|
11
|
+
* ### Implementation
|
|
12
|
+
* Define and apply the following CSS variables on the overlay element:
|
|
13
|
+
* ```scss
|
|
14
|
+
* --sbb-overlay-position-area: block-end; // Default
|
|
15
|
+
* --sbb-overlay-position-try-fallbacks: block-start, inline-end, inline-start; // Fallbacks
|
|
16
|
+
*
|
|
17
|
+
* position-area: var(--sbb-overlay-position-area);
|
|
18
|
+
* position-try-fallbacks: var(--sbb-overlay-position-try-fallbacks);
|
|
19
|
+
* ```
|
|
20
|
+
*/
|
|
21
|
+
export declare class SbbOverlayPositionController implements ReactiveController {
|
|
22
|
+
private _usePolyfill;
|
|
23
|
+
private readonly _resizeObserver;
|
|
24
|
+
private readonly _overlay;
|
|
25
|
+
private _abortController?;
|
|
26
|
+
private _anchor?;
|
|
27
|
+
private _overlayStyles?;
|
|
28
|
+
private _frame?;
|
|
29
|
+
private _anchorName;
|
|
30
|
+
private _positions;
|
|
31
|
+
private _lastPosition?;
|
|
32
|
+
/** Get the current position. (e.g. block-end, block-start, etc.) */
|
|
33
|
+
get currentPosition(): string;
|
|
34
|
+
constructor(host: ReactiveControllerHost & HTMLElement, overlay?: HTMLElement, _usePolyfill?: boolean);
|
|
35
|
+
hostConnected(): void;
|
|
36
|
+
hostUpdate(): void;
|
|
37
|
+
/**
|
|
38
|
+
* Connects the overlay to the given trigger element and determines the optimal position.
|
|
39
|
+
* Usually, this is called when the overlay is opened.
|
|
40
|
+
* @param anchor The anchor element.
|
|
41
|
+
*/
|
|
42
|
+
connect(anchor: HTMLElement): void;
|
|
43
|
+
disconnect(): void;
|
|
44
|
+
private _requestCalculatePosition;
|
|
45
|
+
private _calculatePosition;
|
|
46
|
+
/**
|
|
47
|
+
* Calculates the optimal position that fits the overlay.
|
|
48
|
+
* @param positions The list of positions to check.
|
|
49
|
+
* @private
|
|
50
|
+
*/
|
|
51
|
+
private _getOptimalPosition;
|
|
52
|
+
private _applyOverlayPosition;
|
|
53
|
+
/**
|
|
54
|
+
* Only used in polyfill mode.
|
|
55
|
+
* Reads the list of the configured positions from the CSS variables.
|
|
56
|
+
* @private
|
|
57
|
+
*/
|
|
58
|
+
private _readPositionsFromCss;
|
|
59
|
+
}
|
|
60
|
+
//# sourceMappingURL=overlay-position-controller.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"overlay-position-controller.d.ts","sourceRoot":"","sources":["../../../../../src/elements/core/controllers/overlay-position-controller.ts"],"names":[],"mappings":"AAAA,OAAO,EAAY,KAAK,kBAAkB,EAAE,KAAK,sBAAsB,EAAE,MAAM,KAAK,CAAC;AAqDrF;;;;;;;;;;;;;;;;;;GAkBG;AACH,qBAAa,4BAA6B,YAAW,kBAAkB;IA0BnE,OAAO,CAAC,YAAY;IAzBtB,OAAO,CAAC,QAAQ,CAAC,eAAe,CAEtB;IACV,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAc;IACvC,OAAO,CAAC,gBAAgB,CAAC,CAAkB;IAC3C,OAAO,CAAC,OAAO,CAAC,CAAc;IAC9B,OAAO,CAAC,cAAc,CAAC,CAAsB;IAC7C,OAAO,CAAC,MAAM,CAAC,CAA2C;IAC1D,OAAO,CAAC,WAAW,CAAsC;IACzD,OAAO,CAAC,UAAU,CAAgB;IAClC,OAAO,CAAC,aAAa,CAAC,CAAS;IAE/B,oEAAoE;IACpE,IAAW,eAAe,IAAI,MAAM,CAOnC;gBAGC,IAAI,EAAE,sBAAsB,GAAG,WAAW,EAC1C,OAAO,CAAC,EAAE,WAAW,EACb,YAAY,UAA8B;IAM7C,aAAa,IAAI,IAAI;IASrB,UAAU,IAAI,IAAI;IAOzB;;;;OAIG;IACI,OAAO,CAAC,MAAM,EAAE,WAAW,GAAG,IAAI;IAmClC,UAAU,IAAI,IAAI;IAOzB,OAAO,CAAC,yBAAyB;IAOjC,OAAO,CAAC,kBAAkB;IAY1B;;;;OAIG;IACH,OAAO,CAAC,mBAAmB;IAiL3B,OAAO,CAAC,qBAAqB;IAM7B;;;;OAIG;IACH,OAAO,CAAC,qBAAqB;CA6B9B"}
|
|
@@ -0,0 +1,306 @@
|
|
|
1
|
+
import { isServer } from "lit";
|
|
2
|
+
const cssAnchorPositionSupported = !isServer && CSS.supports("anchor-name", "--test");
|
|
3
|
+
const physicalSupportedPositions = [
|
|
4
|
+
"top",
|
|
5
|
+
"bottom",
|
|
6
|
+
"left",
|
|
7
|
+
"right",
|
|
8
|
+
"top span-left",
|
|
9
|
+
"top span-right",
|
|
10
|
+
"bottom span-left",
|
|
11
|
+
"bottom span-right",
|
|
12
|
+
"left span-top",
|
|
13
|
+
"left span-bottom",
|
|
14
|
+
"right span-top",
|
|
15
|
+
"right span-bottom"
|
|
16
|
+
];
|
|
17
|
+
const logicalSupportedPositions = [
|
|
18
|
+
"block-start",
|
|
19
|
+
"block-end",
|
|
20
|
+
"inline-start",
|
|
21
|
+
"inline-end",
|
|
22
|
+
"block-start span-inline-start",
|
|
23
|
+
"block-start span-inline-end",
|
|
24
|
+
"block-end span-inline-start",
|
|
25
|
+
"block-end span-inline-end",
|
|
26
|
+
"inline-start span-block-start",
|
|
27
|
+
"inline-start span-block-end",
|
|
28
|
+
"inline-end span-block-start",
|
|
29
|
+
"inline-end span-block-end"
|
|
30
|
+
];
|
|
31
|
+
const rtlPositionMapping = {
|
|
32
|
+
"block-start": "block-start",
|
|
33
|
+
"block-end": "block-end",
|
|
34
|
+
"inline-start": "inline-end",
|
|
35
|
+
"inline-end": "inline-start",
|
|
36
|
+
"block-start span-inline-start": "block-start span-inline-end",
|
|
37
|
+
"block-start span-inline-end": "block-start span-inline-start",
|
|
38
|
+
"block-end span-inline-start": "block-end span-inline-end",
|
|
39
|
+
"block-end span-inline-end": "block-end span-inline-start",
|
|
40
|
+
"inline-start span-block-start": "inline-end span-block-start",
|
|
41
|
+
"inline-start span-block-end": "inline-end span-block-end",
|
|
42
|
+
"inline-end span-block-start": "inline-start span-block-start",
|
|
43
|
+
"inline-end span-block-end": "inline-start span-block-end"
|
|
44
|
+
};
|
|
45
|
+
const supportedPositions = [...physicalSupportedPositions, ...logicalSupportedPositions];
|
|
46
|
+
let nextId = 0;
|
|
47
|
+
class SbbOverlayPositionController {
|
|
48
|
+
/** Get the current position. (e.g. block-end, block-start, etc.) */
|
|
49
|
+
get currentPosition() {
|
|
50
|
+
if (this._usePolyfill) {
|
|
51
|
+
return this._lastPosition ?? this._positions[0] ?? "";
|
|
52
|
+
} else {
|
|
53
|
+
this._overlayStyles ??= getComputedStyle(this._overlay);
|
|
54
|
+
return this._overlayStyles.getPropertyValue("position-area");
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
constructor(host, overlay, _usePolyfill = !cssAnchorPositionSupported) {
|
|
58
|
+
this._usePolyfill = _usePolyfill;
|
|
59
|
+
this._resizeObserver = !isServer ? new ResizeObserver(() => this._requestCalculatePosition()) : null;
|
|
60
|
+
this._anchorName = `--sbb-overlay-anchor-${++nextId}`;
|
|
61
|
+
this._positions = [];
|
|
62
|
+
host.addController(this);
|
|
63
|
+
this._overlay = overlay ?? host;
|
|
64
|
+
}
|
|
65
|
+
hostConnected() {
|
|
66
|
+
if (!this._usePolyfill) {
|
|
67
|
+
this._overlay.style.setProperty("position-anchor", this._anchorName);
|
|
68
|
+
} else {
|
|
69
|
+
this._overlay.style.setProperty("position-area", "initial");
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
hostUpdate() {
|
|
73
|
+
if (isServer) {
|
|
74
|
+
return;
|
|
75
|
+
}
|
|
76
|
+
this._readPositionsFromCss();
|
|
77
|
+
}
|
|
78
|
+
/**
|
|
79
|
+
* Connects the overlay to the given trigger element and determines the optimal position.
|
|
80
|
+
* Usually, this is called when the overlay is opened.
|
|
81
|
+
* @param anchor The anchor element.
|
|
82
|
+
*/
|
|
83
|
+
connect(anchor) {
|
|
84
|
+
if (isServer) {
|
|
85
|
+
return;
|
|
86
|
+
}
|
|
87
|
+
if (this._anchor) {
|
|
88
|
+
this.disconnect();
|
|
89
|
+
}
|
|
90
|
+
this._anchor = anchor;
|
|
91
|
+
if (!this._usePolyfill) {
|
|
92
|
+
this._anchor.style.setProperty("anchor-name", this._anchorName);
|
|
93
|
+
}
|
|
94
|
+
this._readPositionsFromCss();
|
|
95
|
+
this._calculatePosition();
|
|
96
|
+
this._abortController?.abort();
|
|
97
|
+
this._abortController = new AbortController();
|
|
98
|
+
document.addEventListener("scroll", () => this._requestCalculatePosition(), {
|
|
99
|
+
capture: true,
|
|
100
|
+
passive: true,
|
|
101
|
+
signal: this._abortController.signal
|
|
102
|
+
});
|
|
103
|
+
window.addEventListener("resize", () => this._requestCalculatePosition(), {
|
|
104
|
+
passive: true,
|
|
105
|
+
signal: this._abortController.signal
|
|
106
|
+
});
|
|
107
|
+
this._resizeObserver.observe(anchor, { box: "border-box" });
|
|
108
|
+
this._resizeObserver.observe(this._overlay, { box: "border-box" });
|
|
109
|
+
}
|
|
110
|
+
disconnect() {
|
|
111
|
+
this._anchor?.style.removeProperty("anchor-name");
|
|
112
|
+
this._anchor = void 0;
|
|
113
|
+
this._abortController?.abort();
|
|
114
|
+
this._resizeObserver.disconnect();
|
|
115
|
+
}
|
|
116
|
+
_requestCalculatePosition() {
|
|
117
|
+
this._frame ??= requestAnimationFrame(() => {
|
|
118
|
+
this._calculatePosition();
|
|
119
|
+
this._frame = void 0;
|
|
120
|
+
});
|
|
121
|
+
}
|
|
122
|
+
_calculatePosition() {
|
|
123
|
+
if (!this._anchor) {
|
|
124
|
+
return;
|
|
125
|
+
}
|
|
126
|
+
if (this._usePolyfill) {
|
|
127
|
+
const position = this._getOptimalPosition(this._positions);
|
|
128
|
+
this._applyOverlayPosition(position.position, position.left, position.top);
|
|
129
|
+
}
|
|
130
|
+
this._overlay.setAttribute("data-position", this.currentPosition);
|
|
131
|
+
}
|
|
132
|
+
/**
|
|
133
|
+
* Calculates the optimal position that fits the overlay.
|
|
134
|
+
* @param positions The list of positions to check.
|
|
135
|
+
* @private
|
|
136
|
+
*/
|
|
137
|
+
_getOptimalPosition(positions) {
|
|
138
|
+
const { offsetHeight: overlayHeight, offsetWidth: overlayWidth } = this._overlay;
|
|
139
|
+
const { innerHeight: viewportHeight, innerWidth: viewportWidth } = window;
|
|
140
|
+
const { top: triggerOffsetTop, left: triggerOffsetLeft, height: triggerHeight, width: triggerWidth } = this._anchor.getBoundingClientRect();
|
|
141
|
+
const isRtl = this._overlay.matches(":dir(rtl)");
|
|
142
|
+
const topSpace = triggerOffsetTop;
|
|
143
|
+
const bottomSpace = viewportHeight - triggerHeight - triggerOffsetTop;
|
|
144
|
+
const leftSpace = triggerOffsetLeft;
|
|
145
|
+
const rightSpace = viewportWidth - triggerWidth - triggerOffsetLeft;
|
|
146
|
+
const overlayWidthNet = overlayWidth - triggerWidth;
|
|
147
|
+
const overlayHeightNet = overlayHeight - triggerHeight;
|
|
148
|
+
const overlayWidthOverlap = overlayWidthNet / 2;
|
|
149
|
+
const overlayHeightOverlap = overlayHeightNet / 2;
|
|
150
|
+
this._overlay.style.setProperty("--sbb-overlay-controller-trigger-height", `${triggerHeight}px`);
|
|
151
|
+
this._overlay.style.setProperty("--sbb-overlay-controller-trigger-width", `${triggerWidth}px`);
|
|
152
|
+
let result = { left: 0, top: 0, position: "" };
|
|
153
|
+
let firstPosition = void 0;
|
|
154
|
+
for (const position of positions) {
|
|
155
|
+
const physicalPosition = isRtl && logicalSupportedPositions.includes(position) ? rtlPositionMapping[position] : position;
|
|
156
|
+
switch (physicalPosition) {
|
|
157
|
+
default:
|
|
158
|
+
case "bottom":
|
|
159
|
+
case "block-end":
|
|
160
|
+
result = {
|
|
161
|
+
position,
|
|
162
|
+
left: triggerOffsetLeft - overlayWidthOverlap,
|
|
163
|
+
top: triggerOffsetTop + triggerHeight,
|
|
164
|
+
fits: overlayHeight <= bottomSpace && overlayWidthOverlap <= leftSpace && overlayWidthOverlap <= rightSpace
|
|
165
|
+
};
|
|
166
|
+
break;
|
|
167
|
+
case "top":
|
|
168
|
+
case "block-start":
|
|
169
|
+
result = {
|
|
170
|
+
position,
|
|
171
|
+
left: triggerOffsetLeft - overlayWidthOverlap,
|
|
172
|
+
top: triggerOffsetTop - overlayHeight,
|
|
173
|
+
fits: overlayHeight <= topSpace && overlayWidthOverlap <= leftSpace && overlayWidthOverlap <= rightSpace
|
|
174
|
+
};
|
|
175
|
+
break;
|
|
176
|
+
case "right":
|
|
177
|
+
case "inline-end":
|
|
178
|
+
result = {
|
|
179
|
+
position,
|
|
180
|
+
left: triggerOffsetLeft + triggerWidth,
|
|
181
|
+
top: triggerOffsetTop - overlayHeightOverlap,
|
|
182
|
+
fits: overlayWidth <= rightSpace && overlayHeightOverlap <= topSpace && overlayHeightOverlap <= bottomSpace
|
|
183
|
+
};
|
|
184
|
+
break;
|
|
185
|
+
case "left":
|
|
186
|
+
case "inline-start":
|
|
187
|
+
result = {
|
|
188
|
+
position,
|
|
189
|
+
left: triggerOffsetLeft - overlayWidth,
|
|
190
|
+
top: triggerOffsetTop - overlayHeightOverlap,
|
|
191
|
+
fits: overlayWidth <= leftSpace && overlayHeightOverlap <= topSpace && overlayHeightOverlap <= bottomSpace
|
|
192
|
+
};
|
|
193
|
+
break;
|
|
194
|
+
case "top span-left":
|
|
195
|
+
case "block-start span-inline-start":
|
|
196
|
+
result = {
|
|
197
|
+
position,
|
|
198
|
+
left: triggerOffsetLeft - overlayWidthNet,
|
|
199
|
+
top: triggerOffsetTop - overlayHeight,
|
|
200
|
+
fits: overlayHeight <= topSpace && overlayWidthNet <= leftSpace
|
|
201
|
+
};
|
|
202
|
+
break;
|
|
203
|
+
case "top span-right":
|
|
204
|
+
case "block-start span-inline-end":
|
|
205
|
+
result = {
|
|
206
|
+
position,
|
|
207
|
+
left: triggerOffsetLeft,
|
|
208
|
+
top: triggerOffsetTop - overlayHeight,
|
|
209
|
+
fits: overlayHeight <= topSpace && overlayWidthNet <= rightSpace
|
|
210
|
+
};
|
|
211
|
+
break;
|
|
212
|
+
case "bottom span-left":
|
|
213
|
+
case "block-end span-inline-start":
|
|
214
|
+
result = {
|
|
215
|
+
position,
|
|
216
|
+
left: triggerOffsetLeft - overlayWidthNet,
|
|
217
|
+
top: triggerOffsetTop + triggerHeight,
|
|
218
|
+
fits: overlayHeight <= bottomSpace && overlayWidthNet <= leftSpace
|
|
219
|
+
};
|
|
220
|
+
break;
|
|
221
|
+
case "bottom span-right":
|
|
222
|
+
case "block-end span-inline-end":
|
|
223
|
+
result = {
|
|
224
|
+
position,
|
|
225
|
+
left: triggerOffsetLeft,
|
|
226
|
+
top: triggerOffsetTop + triggerHeight,
|
|
227
|
+
fits: overlayHeight <= bottomSpace && overlayWidthNet <= rightSpace
|
|
228
|
+
};
|
|
229
|
+
break;
|
|
230
|
+
case "left span-top":
|
|
231
|
+
case "inline-start span-block-start":
|
|
232
|
+
result = {
|
|
233
|
+
position,
|
|
234
|
+
left: triggerOffsetLeft - overlayWidth,
|
|
235
|
+
top: triggerOffsetTop + triggerHeight - overlayHeight,
|
|
236
|
+
fits: overlayWidth <= leftSpace && overlayHeightNet <= topSpace
|
|
237
|
+
};
|
|
238
|
+
break;
|
|
239
|
+
case "left span-bottom":
|
|
240
|
+
case "inline-start span-block-end":
|
|
241
|
+
result = {
|
|
242
|
+
position,
|
|
243
|
+
left: triggerOffsetLeft - overlayWidth,
|
|
244
|
+
top: triggerOffsetTop,
|
|
245
|
+
fits: overlayWidth <= leftSpace && overlayHeightNet <= bottomSpace
|
|
246
|
+
};
|
|
247
|
+
break;
|
|
248
|
+
case "right span-top":
|
|
249
|
+
case "inline-end span-block-start":
|
|
250
|
+
result = {
|
|
251
|
+
position,
|
|
252
|
+
left: triggerOffsetLeft + triggerWidth,
|
|
253
|
+
top: triggerOffsetTop + triggerHeight - overlayHeight,
|
|
254
|
+
fits: overlayWidth <= rightSpace && overlayHeightNet <= topSpace
|
|
255
|
+
};
|
|
256
|
+
break;
|
|
257
|
+
case "right span-bottom":
|
|
258
|
+
case "inline-end span-block-end":
|
|
259
|
+
result = {
|
|
260
|
+
position,
|
|
261
|
+
left: triggerOffsetLeft + triggerWidth,
|
|
262
|
+
top: triggerOffsetTop,
|
|
263
|
+
fits: overlayWidth <= rightSpace && overlayHeightNet <= bottomSpace
|
|
264
|
+
};
|
|
265
|
+
break;
|
|
266
|
+
}
|
|
267
|
+
if (result.fits) {
|
|
268
|
+
return result;
|
|
269
|
+
}
|
|
270
|
+
firstPosition ??= result;
|
|
271
|
+
}
|
|
272
|
+
return firstPosition;
|
|
273
|
+
}
|
|
274
|
+
_applyOverlayPosition(position, left, top) {
|
|
275
|
+
this._lastPosition = position;
|
|
276
|
+
this._overlay.style.left = `${left}px`;
|
|
277
|
+
this._overlay.style.top = `${top}px`;
|
|
278
|
+
}
|
|
279
|
+
/**
|
|
280
|
+
* Only used in polyfill mode.
|
|
281
|
+
* Reads the list of the configured positions from the CSS variables.
|
|
282
|
+
* @private
|
|
283
|
+
*/
|
|
284
|
+
_readPositionsFromCss() {
|
|
285
|
+
if (!this._usePolyfill) {
|
|
286
|
+
return;
|
|
287
|
+
}
|
|
288
|
+
this._overlayStyles ??= getComputedStyle(this._overlay);
|
|
289
|
+
const positions = [
|
|
290
|
+
this._overlayStyles.getPropertyValue("--sbb-overlay-position-area") || "block-end",
|
|
291
|
+
...this._overlayStyles.getPropertyValue("--sbb-overlay-position-try-fallbacks").split(",").map((f) => f.trim()).filter((f) => !!f)
|
|
292
|
+
];
|
|
293
|
+
if (positions.some((p) => !supportedPositions.includes(p))) {
|
|
294
|
+
const unsupportedPositions = positions.filter((p) => !supportedPositions.includes(p)).sort().join(", ");
|
|
295
|
+
throw new Error(`Unsupported position-try-fallbacks ${unsupportedPositions} (Supported: ${supportedPositions.join(", ")})`);
|
|
296
|
+
}
|
|
297
|
+
this._positions = positions;
|
|
298
|
+
if (this._lastPosition && !this._positions.includes(this._lastPosition)) {
|
|
299
|
+
this._lastPosition = void 0;
|
|
300
|
+
}
|
|
301
|
+
}
|
|
302
|
+
}
|
|
303
|
+
export {
|
|
304
|
+
SbbOverlayPositionController
|
|
305
|
+
};
|
|
306
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"overlay-position-controller.js","sources":["../../../../../src/elements/core/controllers/overlay-position-controller.ts"],"sourcesContent":["import { isServer, type ReactiveController, type ReactiveControllerHost } from 'lit';\n\nconst cssAnchorPositionSupported = !isServer && CSS.supports('anchor-name', '--test');\n\nconst physicalSupportedPositions = [\n  'top',\n  'bottom',\n  'left',\n  'right',\n  'top span-left',\n  'top span-right',\n  'bottom span-left',\n  'bottom span-right',\n  'left span-top',\n  'left span-bottom',\n  'right span-top',\n  'right span-bottom',\n];\n\n// Note: if you add new logical supported positions, update also the 'rtlPositionMapping'\nconst logicalSupportedPositions = [\n  'block-start',\n  'block-end',\n  'inline-start',\n  'inline-end',\n  'block-start span-inline-start',\n  'block-start span-inline-end',\n  'block-end span-inline-start',\n  'block-end span-inline-end',\n  'inline-start span-block-start',\n  'inline-start span-block-end',\n  'inline-end span-block-start',\n  'inline-end span-block-end',\n];\n\nconst rtlPositionMapping: { [key: string]: string } = {\n  'block-start': 'block-start',\n  'block-end': 'block-end',\n  'inline-start': 'inline-end',\n  'inline-end': 'inline-start',\n  'block-start span-inline-start': 'block-start span-inline-end',\n  'block-start span-inline-end': 'block-start span-inline-start',\n  'block-end span-inline-start': 'block-end span-inline-end',\n  'block-end span-inline-end': 'block-end span-inline-start',\n  'inline-start span-block-start': 'inline-end span-block-start',\n  'inline-start span-block-end': 'inline-end span-block-end',\n  'inline-end span-block-start': 'inline-start span-block-start',\n  'inline-end span-block-end': 'inline-start span-block-end',\n};\n\nconst supportedPositions = [...physicalSupportedPositions, ...logicalSupportedPositions];\nlet nextId = 0;\n\n/**\n * Controller for managing overlays positioning. Also acts as a polyfill when native\n * CSS Anchor Positioning is not supported (enough).\n * Applies unique anchor names when using native CSS Anchor Positioning\n * or calculates and applies correct positions in polyfill mode.\n *\n * Also, the controller sets the 'data-overlay-position' attribute on the overlay element.\n * This can be used to apply specific styles based on the current position of the overlay.\n *\n * ### Implementation\n * Define and apply the following CSS variables on the overlay element:\n * ```scss\n *   --sbb-overlay-position-area: block-end; // Default\n *   --sbb-overlay-position-try-fallbacks: block-start, inline-end, inline-start; // Fallbacks\n *\n *   position-area: var(--sbb-overlay-position-area);\n *   position-try-fallbacks: var(--sbb-overlay-position-try-fallbacks);\n * ```\n */\nexport class SbbOverlayPositionController implements ReactiveController {\n  private readonly _resizeObserver = !isServer\n    ? new ResizeObserver(() => this._requestCalculatePosition())\n    : null!;\n  private readonly _overlay: HTMLElement;\n  private _abortController?: AbortController;\n  private _anchor?: HTMLElement;\n  private _overlayStyles?: CSSStyleDeclaration;\n  private _frame?: ReturnType<typeof requestAnimationFrame>;\n  private _anchorName = `--sbb-overlay-anchor-${++nextId}`;\n  private _positions: string[] = [];\n  private _lastPosition?: string;\n\n  /** Get the current position. (e.g. block-end, block-start, etc.) */\n  public get currentPosition(): string {\n    if (this._usePolyfill) {\n      return this._lastPosition ?? this._positions[0] ?? '';\n    } else {\n      this._overlayStyles ??= getComputedStyle(this._overlay);\n      return this._overlayStyles.getPropertyValue('position-area');\n    }\n  }\n\n  public constructor(\n    host: ReactiveControllerHost & HTMLElement,\n    overlay?: HTMLElement,\n    private _usePolyfill = !cssAnchorPositionSupported,\n  ) {\n    host.addController(this);\n    this._overlay = overlay ?? host;\n  }\n\n  public hostConnected(): void {\n    if (!this._usePolyfill) {\n      this._overlay.style.setProperty('position-anchor', this._anchorName);\n    } else {\n      // Reset the 'position-area' value to avoid any unwanted side effect when using the polyfill.\n      this._overlay.style.setProperty('position-area', 'initial');\n    }\n  }\n\n  public hostUpdate(): void {\n    if (isServer) {\n      return;\n    }\n    this._readPositionsFromCss();\n  }\n\n  /**\n   * Connects the overlay to the given trigger element and determines the optimal position.\n   * Usually, this is called when the overlay is opened.\n   * @param anchor The anchor element.\n   */\n  public connect(anchor: HTMLElement): void {\n    if (isServer) {\n      return;\n    }\n\n    if (this._anchor) {\n      this.disconnect();\n    }\n    this._anchor = anchor;\n\n    if (!this._usePolyfill) {\n      this._anchor.style.setProperty('anchor-name', this._anchorName!);\n    }\n\n    this._readPositionsFromCss();\n    this._calculatePosition();\n    this._abortController?.abort();\n    this._abortController = new AbortController();\n\n    // We need to use capture here to react to all scroll events.\n    // If capture was not used, then scroll events inside separate scroll\n    // containers would not be caught.\n    document.addEventListener('scroll', () => this._requestCalculatePosition(), {\n      capture: true,\n      passive: true,\n      signal: this._abortController.signal,\n    });\n    window.addEventListener('resize', () => this._requestCalculatePosition(), {\n      passive: true,\n      signal: this._abortController.signal,\n    });\n    this._resizeObserver.observe(anchor, { box: 'border-box' });\n    this._resizeObserver.observe(this._overlay, { box: 'border-box' });\n  }\n\n  public disconnect(): void {\n    this._anchor?.style.removeProperty('anchor-name');\n    this._anchor = undefined;\n    this._abortController?.abort();\n    this._resizeObserver.disconnect();\n  }\n\n  private _requestCalculatePosition(): void {\n    this._frame ??= requestAnimationFrame(() => {\n      this._calculatePosition();\n      this._frame = undefined;\n    });\n  }\n\n  private _calculatePosition(): void {\n    if (!this._anchor) {\n      return;\n    }\n\n    if (this._usePolyfill) {\n      const position = this._getOptimalPosition(this._positions);\n      this._applyOverlayPosition(position.position, position.left, position.top);\n    }\n    this._overlay.setAttribute('data-position', this.currentPosition);\n  }\n\n  /**\n   * Calculates the optimal position that fits the overlay.\n   * @param positions The list of positions to check.\n   * @private\n   */\n  private _getOptimalPosition(positions: string[]): {\n    left: number;\n    top: number;\n    position: string;\n    fits?: boolean;\n  } {\n    const { offsetHeight: overlayHeight, offsetWidth: overlayWidth } = this._overlay;\n    const { innerHeight: viewportHeight, innerWidth: viewportWidth } = window;\n    const {\n      top: triggerOffsetTop,\n      left: triggerOffsetLeft,\n      height: triggerHeight,\n      width: triggerWidth,\n    } = this._anchor!.getBoundingClientRect();\n\n    const isRtl = this._overlay.matches(':dir(rtl)');\n    const topSpace = triggerOffsetTop;\n    const bottomSpace = viewportHeight - triggerHeight - triggerOffsetTop;\n    const leftSpace = triggerOffsetLeft;\n    const rightSpace = viewportWidth - triggerWidth - triggerOffsetLeft;\n\n    // The difference between the overlay and the trigger width/height.\n    const overlayWidthNet = overlayWidth - triggerWidth;\n    const overlayHeightNet = overlayHeight - triggerHeight;\n\n    // The amount that would exceed the trigger if the overlay were centered on it.\n    const overlayWidthOverlap = overlayWidthNet / 2;\n    const overlayHeightOverlap = overlayHeightNet / 2;\n\n    this._overlay.style.setProperty(\n      '--sbb-overlay-controller-trigger-height',\n      `${triggerHeight}px`,\n    );\n    this._overlay.style.setProperty('--sbb-overlay-controller-trigger-width', `${triggerWidth}px`);\n\n    let result: ReturnType<typeof this._getOptimalPosition> = { left: 0, top: 0, position: '' };\n    let firstPosition: ReturnType<typeof this._getOptimalPosition> | undefined = undefined;\n    for (const position of positions) {\n      // If rtl is enabled, we map the logical position to their RTL equivalent. (e.g. 'inline-start' -> 'inline-end')\n      const physicalPosition =\n        isRtl && logicalSupportedPositions.includes(position)\n          ? rtlPositionMapping[position]\n          : position;\n\n      switch (physicalPosition) {\n        default:\n        case 'bottom':\n        case 'block-end':\n          result = {\n            position,\n            left: triggerOffsetLeft - overlayWidthOverlap,\n            top: triggerOffsetTop + triggerHeight,\n            fits:\n              overlayHeight <= bottomSpace &&\n              overlayWidthOverlap <= leftSpace &&\n              overlayWidthOverlap <= rightSpace,\n          };\n          break;\n        case 'top':\n        case 'block-start':\n          result = {\n            position,\n            left: triggerOffsetLeft - overlayWidthOverlap,\n            top: triggerOffsetTop - overlayHeight,\n            fits:\n              overlayHeight <= topSpace &&\n              overlayWidthOverlap <= leftSpace &&\n              overlayWidthOverlap <= rightSpace,\n          };\n          break;\n        case 'right':\n        case 'inline-end':\n          result = {\n            position,\n            left: triggerOffsetLeft + triggerWidth,\n            top: triggerOffsetTop - overlayHeightOverlap,\n            fits:\n              overlayWidth <= rightSpace &&\n              overlayHeightOverlap <= topSpace &&\n              overlayHeightOverlap <= bottomSpace,\n          };\n          break;\n        case 'left':\n        case 'inline-start':\n          result = {\n            position,\n            left: triggerOffsetLeft - overlayWidth,\n            top: triggerOffsetTop - overlayHeightOverlap,\n            fits:\n              overlayWidth <= leftSpace &&\n              overlayHeightOverlap <= topSpace &&\n              overlayHeightOverlap <= bottomSpace,\n          };\n          break;\n        case 'top span-left':\n        case 'block-start span-inline-start':\n          result = {\n            position,\n            left: triggerOffsetLeft - overlayWidthNet,\n            top: triggerOffsetTop - overlayHeight,\n            fits: overlayHeight <= topSpace && overlayWidthNet <= leftSpace,\n          };\n          break;\n        case 'top span-right':\n        case 'block-start span-inline-end':\n          result = {\n            position,\n            left: triggerOffsetLeft,\n            top: triggerOffsetTop - overlayHeight,\n            fits: overlayHeight <= topSpace && overlayWidthNet <= rightSpace,\n          };\n          break;\n        case 'bottom span-left':\n        case 'block-end span-inline-start':\n          result = {\n            position,\n            left: triggerOffsetLeft - overlayWidthNet,\n            top: triggerOffsetTop + triggerHeight,\n            fits: overlayHeight <= bottomSpace && overlayWidthNet <= leftSpace,\n          };\n          break;\n        case 'bottom span-right':\n        case 'block-end span-inline-end':\n          result = {\n            position,\n            left: triggerOffsetLeft,\n            top: triggerOffsetTop + triggerHeight,\n            fits: overlayHeight <= bottomSpace && overlayWidthNet <= rightSpace,\n          };\n          break;\n        case 'left span-top':\n        case 'inline-start span-block-start':\n          result = {\n            position,\n            left: triggerOffsetLeft - overlayWidth,\n            top: triggerOffsetTop + triggerHeight - overlayHeight,\n            fits: overlayWidth <= leftSpace && overlayHeightNet <= topSpace,\n          };\n          break;\n        case 'left span-bottom':\n        case 'inline-start span-block-end':\n          result = {\n            position,\n            left: triggerOffsetLeft - overlayWidth,\n            top: triggerOffsetTop,\n            fits: overlayWidth <= leftSpace && overlayHeightNet <= bottomSpace,\n          };\n          break;\n        case 'right span-top':\n        case 'inline-end span-block-start':\n          result = {\n            position,\n            left: triggerOffsetLeft + triggerWidth,\n            top: triggerOffsetTop + triggerHeight - overlayHeight,\n            fits: overlayWidth <= rightSpace && overlayHeightNet <= topSpace,\n          };\n          break;\n        case 'right span-bottom':\n        case 'inline-end span-block-end':\n          result = {\n            position,\n            left: triggerOffsetLeft + triggerWidth,\n            top: triggerOffsetTop,\n            fits: overlayWidth <= rightSpace && overlayHeightNet <= bottomSpace,\n          };\n          break;\n      }\n      if (result.fits) {\n        return result;\n      }\n      firstPosition ??= result;\n    }\n\n    // If no position fits, we return the first one.\n    return firstPosition!;\n  }\n\n  private _applyOverlayPosition(position: string, left: number, top: number): void {\n    this._lastPosition = position;\n    this._overlay.style.left = `${left}px`;\n    this._overlay.style.top = `${top}px`;\n  }\n\n  /**\n   * Only used in polyfill mode.\n   * Reads the list of the configured positions from the CSS variables.\n   * @private\n   */\n  private _readPositionsFromCss(): void {\n    if (!this._usePolyfill) {\n      return;\n    }\n    this._overlayStyles ??= getComputedStyle(this._overlay);\n    const positions = [\n      this._overlayStyles.getPropertyValue('--sbb-overlay-position-area') || 'block-end',\n      ...this._overlayStyles\n        .getPropertyValue('--sbb-overlay-position-try-fallbacks')\n        .split(',')\n        .map((f) => f.trim())\n        .filter((f) => !!f),\n    ];\n\n    if (import.meta.env.DEV && positions.some((p) => !supportedPositions.includes(p))) {\n      const unsupportedPositions = positions\n        .filter((p) => !supportedPositions.includes(p))\n        .sort()\n        .join(', ');\n      throw new Error(\n        `Unsupported position-try-fallbacks ${unsupportedPositions} (Supported: ${supportedPositions.join(', ')})`,\n      );\n    }\n\n    this._positions = positions;\n    if (this._lastPosition && !this._positions.includes(this._lastPosition)) {\n      this._lastPosition = undefined;\n    }\n  }\n}\n"],"names":[],"mappings":"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"}
|
|
@@ -7,4 +7,5 @@ export * from './controllers/inert-controller.js';
|
|
|
7
7
|
export * from './controllers/language-controller.js';
|
|
8
8
|
export * from './controllers/media-matchers-controller.js';
|
|
9
9
|
export * from './controllers/slot-state-controller.js';
|
|
10
|
+
export * from './controllers/overlay-position-controller.js';
|
|
10
11
|
//# sourceMappingURL=controllers.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"controllers.d.ts","sourceRoot":"","sources":["../../../../src/elements/core/controllers.ts"],"names":[],"mappings":"AAAA;;GAEG;AACH,cAAc,+CAA+C,CAAC;AAC9D,cAAc,0CAA0C,CAAC;AACzD,cAAc,mCAAmC,CAAC;AAClD,cAAc,sCAAsC,CAAC;AACrD,cAAc,4CAA4C,CAAC;AAC3D,cAAc,wCAAwC,CAAC"}
|
|
1
|
+
{"version":3,"file":"controllers.d.ts","sourceRoot":"","sources":["../../../../src/elements/core/controllers.ts"],"names":[],"mappings":"AAAA;;GAEG;AACH,cAAc,+CAA+C,CAAC;AAC9D,cAAc,0CAA0C,CAAC;AACzD,cAAc,mCAAmC,CAAC;AAClD,cAAc,sCAAsC,CAAC;AACrD,cAAc,4CAA4C,CAAC;AAC3D,cAAc,wCAAwC,CAAC;AACvD,cAAc,8CAA8C,CAAC"}
|
|
@@ -4,6 +4,7 @@ import { SbbInertController } from "./controllers/inert-controller.js";
|
|
|
4
4
|
import { SbbLanguageController } from "./controllers/language-controller.js";
|
|
5
5
|
import { SbbDarkModeController, SbbMediaMatcherController, SbbMediaQueryBreakpointMediumAndAbove, SbbMediaQueryBreakpointMediumAndBelow, SbbMediaQueryBreakpointSmallAndBelow, SbbMediaQueryDarkMode, SbbMediaQueryForcedColors, SbbMediaQueryHover, SbbMediaQueryPointerCoarse } from "./controllers/media-matchers-controller.js";
|
|
6
6
|
import { SbbSlotStateController } from "./controllers/slot-state-controller.js";
|
|
7
|
+
import { SbbOverlayPositionController } from "./controllers/overlay-position-controller.js";
|
|
7
8
|
export {
|
|
8
9
|
SbbDarkModeController,
|
|
9
10
|
SbbEscapableOverlayController,
|
|
@@ -18,6 +19,7 @@ export {
|
|
|
18
19
|
SbbMediaQueryForcedColors,
|
|
19
20
|
SbbMediaQueryHover,
|
|
20
21
|
SbbMediaQueryPointerCoarse,
|
|
22
|
+
SbbOverlayPositionController,
|
|
21
23
|
SbbSlotStateController
|
|
22
24
|
};
|
|
23
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
25
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29udHJvbGxlcnMuanMiLCJzb3VyY2VzIjpbXSwic291cmNlc0NvbnRlbnQiOltdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7OyJ9
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import { CSSResultGroup, TemplateResult, LitElement } from 'lit';
|
|
2
|
+
import { SbbOrientation } from '../../core/interfaces.js';
|
|
3
|
+
/**
|
|
4
|
+
* It displays a minimal calendar, together with the `sbb-mini-calendar-month` and `sbb-mini-calendar-day`.
|
|
5
|
+
*
|
|
6
|
+
* @slot - Use the unnamed slot to add `sbb-mini-calendar-month` elements.
|
|
7
|
+
*/
|
|
8
|
+
export declare class SbbMiniCalendarElement<T = Date> extends LitElement {
|
|
9
|
+
static styles: CSSResultGroup;
|
|
10
|
+
/** The orientation of days in the calendar. */
|
|
11
|
+
accessor orientation: SbbOrientation;
|
|
12
|
+
private _keydownAbortController;
|
|
13
|
+
private _dateAdapter;
|
|
14
|
+
constructor();
|
|
15
|
+
private _getMiniCalendarMonths;
|
|
16
|
+
private _getMiniCalendarDays;
|
|
17
|
+
private _setMonthsShowYear;
|
|
18
|
+
private _handleKeydownCalendarDay;
|
|
19
|
+
private _navigateByKeyboardDayView;
|
|
20
|
+
private _findDayArrowKeys;
|
|
21
|
+
private _findDaySpecialKeys;
|
|
22
|
+
private _handleSlotchange;
|
|
23
|
+
private _setupKeydownListener;
|
|
24
|
+
/** @internal */
|
|
25
|
+
focus(): void;
|
|
26
|
+
connectedCallback(): void;
|
|
27
|
+
disconnectedCallback(): void;
|
|
28
|
+
protected render(): TemplateResult;
|
|
29
|
+
}
|
|
30
|
+
declare global {
|
|
31
|
+
interface HTMLElementTagNameMap {
|
|
32
|
+
'sbb-mini-calendar': SbbMiniCalendarElement;
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
//# sourceMappingURL=mini-calendar.component.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mini-calendar.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements/mini-calendar/mini-calendar/mini-calendar.component.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;AAC1D,OAAO,EAAQ,UAAU,EAAE,MAAM,KAAK,CAAC;AAOvC,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,0BAA0B,CAAC;AAM/D;;;;GAIG;AACH,qBAEM,sBAAsB,CAAC,CAAC,GAAG,IAAI,CAAE,SAAQ,UAAU;IACvD,OAAuB,MAAM,EAAE,cAAc,CAAS;IAEtD,+CAA+C;IAC/C,SACgB,WAAW,EAAE,cAAc,CAAgB;IAE3D,OAAO,CAAC,uBAAuB,CAAgC;IAC/D,OAAO,CAAC,YAAY,CAA4E;;IAahG,OAAO,CAAC,sBAAsB;IAI9B,OAAO,CAAC,oBAAoB;IAQ5B,OAAO,CAAC,kBAAkB;IAe1B,OAAO,CAAC,yBAAyB;IAgBjC,OAAO,CAAC,0BAA0B;IAwDlC,OAAO,CAAC,iBAAiB;IAiBzB,OAAO,CAAC,mBAAmB;IAkB3B,OAAO,CAAC,iBAAiB;IAIzB,OAAO,CAAC,qBAAqB;IAa7B,gBAAgB;IACA,KAAK,IAAI,IAAI;IAMb,iBAAiB,IAAI,IAAI;IAKzB,oBAAoB,IAAI,IAAI;cAKzB,MAAM,IAAI,cAAc;CAO5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,mBAAmB,EAAE,sBAAsB,CAAC;KAC7C;CACF"}
|