@yuuvis/client-core 0.6.5
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/README.md +111 -0
- package/esm2022/index.mjs +65 -0
- package/esm2022/lib/client-core.module.mjs +117 -0
- package/esm2022/lib/client-core.shared.module.mjs +18 -0
- package/esm2022/lib/common/pipes/filesize.pipe.mjs +37 -0
- package/esm2022/lib/common/pipes/index.mjs +6 -0
- package/esm2022/lib/common/pipes/keys.pipe.mjs +17 -0
- package/esm2022/lib/common/pipes/locale-date.pipe.mjs +45 -0
- package/esm2022/lib/common/pipes/locale-number.pipe.mjs +115 -0
- package/esm2022/lib/common/pipes/safe-html.pipe.mjs +44 -0
- package/esm2022/lib/common/services/native-notifications.interface.mjs +2 -0
- package/esm2022/lib/common/services/native-notifications.mjs +40 -0
- package/esm2022/lib/model/dms-object.interface.mjs +2 -0
- package/esm2022/lib/model/dms-object.model.mjs +79 -0
- package/esm2022/lib/model/object-flavor.interface.mjs +2 -0
- package/esm2022/lib/model/range-value.interface.mjs +2 -0
- package/esm2022/lib/model/yuv-error.model.mjs +37 -0
- package/esm2022/lib/model/yuv-user.model.mjs +38 -0
- package/esm2022/lib/service/audit/audit.interface.mjs +2 -0
- package/esm2022/lib/service/audit/audit.service.mjs +135 -0
- package/esm2022/lib/service/auth/auth.interceptor.mjs +50 -0
- package/esm2022/lib/service/auth/auth.interface.mjs +7 -0
- package/esm2022/lib/service/auth/auth.service.mjs +130 -0
- package/esm2022/lib/service/auth/oidc.service.mjs +81 -0
- package/esm2022/lib/service/backend/api.enum.mjs +11 -0
- package/esm2022/lib/service/backend/backend.interface.mjs +2 -0
- package/esm2022/lib/service/backend/backend.service.mjs +206 -0
- package/esm2022/lib/service/bpm/bpm.interface.mjs +8 -0
- package/esm2022/lib/service/bpm/bpm.service.mjs +51 -0
- package/esm2022/lib/service/cache/app-cache.service.mjs +51 -0
- package/esm2022/lib/service/catalog/catalog.interface.mjs +2 -0
- package/esm2022/lib/service/catalog/catalog.service.mjs +13 -0
- package/esm2022/lib/service/clipboard/clipboard.interface.mjs +2 -0
- package/esm2022/lib/service/clipboard/clipboard.service.mjs +90 -0
- package/esm2022/lib/service/config/config.interface.mjs +6 -0
- package/esm2022/lib/service/config/config.service.mjs +115 -0
- package/esm2022/lib/service/config/core-config.mjs +20 -0
- package/esm2022/lib/service/config/core-config.tokens.mjs +9 -0
- package/esm2022/lib/service/connection/connection.service.mjs +36 -0
- package/esm2022/lib/service/connection/offline.interceptor.mjs +28 -0
- package/esm2022/lib/service/core-init/core-init.service.mjs +29 -0
- package/esm2022/lib/service/core-init/missing-translation-handler.mjs +10 -0
- package/esm2022/lib/service/core-init/translate-json-loader.mjs +117 -0
- package/esm2022/lib/service/device/device.interface.mjs +6 -0
- package/esm2022/lib/service/device/device.service.mjs +144 -0
- package/esm2022/lib/service/dms/dms.service.interface.mjs +2 -0
- package/esm2022/lib/service/dms/dms.service.mjs +440 -0
- package/esm2022/lib/service/event/event.interface.mjs +2 -0
- package/esm2022/lib/service/event/event.service.mjs +38 -0
- package/esm2022/lib/service/event/events.mjs +14 -0
- package/esm2022/lib/service/idm/idm.interface.mjs +2 -0
- package/esm2022/lib/service/idm/idm.service.mjs +34 -0
- package/esm2022/lib/service/logger/logger-console.service.mjs +73 -0
- package/esm2022/lib/service/logger/logger.interface.mjs +2 -0
- package/esm2022/lib/service/logger/logger.mjs +27 -0
- package/esm2022/lib/service/notification/notification.service.mjs +131 -0
- package/esm2022/lib/service/object-config/object-config.interface.mjs +2 -0
- package/esm2022/lib/service/object-config/object-config.service.mjs +229 -0
- package/esm2022/lib/service/pending-changes/pending-changes-component.interface.mjs +5 -0
- package/esm2022/lib/service/pending-changes/pending-changes-guard.service.mjs +25 -0
- package/esm2022/lib/service/pending-changes/pending-changes.service.mjs +123 -0
- package/esm2022/lib/service/prediction/prediction.interface.mjs +2 -0
- package/esm2022/lib/service/prediction/prediction.service.mjs +60 -0
- package/esm2022/lib/service/search/search.service.interface.mjs +39 -0
- package/esm2022/lib/service/search/search.service.mjs +178 -0
- package/esm2022/lib/service/session-storage/session-storage.service.mjs +50 -0
- package/esm2022/lib/service/system/object-form.interface.mjs +2 -0
- package/esm2022/lib/service/system/system.enum.mjs +179 -0
- package/esm2022/lib/service/system/system.interface.mjs +2 -0
- package/esm2022/lib/service/system/system.service.mjs +597 -0
- package/esm2022/lib/service/upload/upload.interface.mjs +2 -0
- package/esm2022/lib/service/upload/upload.service.mjs +228 -0
- package/esm2022/lib/service/user/user.service.mjs +211 -0
- package/esm2022/lib/util/utils.helper.enum.mjs +15 -0
- package/esm2022/lib/util/utils.mjs +373 -0
- package/esm2022/yuuvis-client-core.mjs +5 -0
- package/fesm2022/yuuvis-client-core.mjs +4775 -0
- package/fesm2022/yuuvis-client-core.mjs.map +1 -0
- package/index.d.ts +61 -0
- package/lib/client-core.module.d.ts +20 -0
- package/lib/client-core.shared.module.d.ts +10 -0
- package/lib/common/pipes/filesize.pipe.d.ts +18 -0
- package/lib/common/pipes/index.d.ts +5 -0
- package/lib/common/pipes/keys.pipe.d.ts +10 -0
- package/lib/common/pipes/locale-date.pipe.d.ts +12 -0
- package/lib/common/pipes/locale-number.pipe.d.ts +47 -0
- package/lib/common/pipes/safe-html.pipe.d.ts +28 -0
- package/lib/common/services/native-notifications.d.ts +8 -0
- package/lib/common/services/native-notifications.interface.d.ts +5 -0
- package/lib/model/dms-object.interface.d.ts +16 -0
- package/lib/model/dms-object.model.d.ts +26 -0
- package/lib/model/object-flavor.interface.d.ts +30 -0
- package/lib/model/range-value.interface.d.ts +9 -0
- package/lib/model/yuv-error.model.d.ts +18 -0
- package/lib/model/yuv-user.model.d.ts +44 -0
- package/lib/service/audit/audit.interface.d.ts +47 -0
- package/lib/service/audit/audit.service.d.ts +35 -0
- package/lib/service/auth/auth.interceptor.d.ts +12 -0
- package/lib/service/auth/auth.interface.d.ts +34 -0
- package/lib/service/auth/auth.service.d.ts +50 -0
- package/lib/service/auth/oidc.service.d.ts +16 -0
- package/lib/service/backend/api.enum.d.ts +7 -0
- package/lib/service/backend/backend.interface.d.ts +29 -0
- package/lib/service/backend/backend.service.d.ts +118 -0
- package/lib/service/bpm/bpm.interface.d.ts +86 -0
- package/lib/service/bpm/bpm.service.d.ts +19 -0
- package/lib/service/cache/app-cache.service.d.ts +18 -0
- package/lib/service/catalog/catalog.interface.d.ts +12 -0
- package/lib/service/catalog/catalog.service.d.ts +5 -0
- package/lib/service/clipboard/clipboard.interface.d.ts +11 -0
- package/lib/service/clipboard/clipboard.service.d.ts +23 -0
- package/lib/service/config/config.interface.d.ts +34 -0
- package/lib/service/config/config.service.d.ts +45 -0
- package/lib/service/config/core-config.d.ts +14 -0
- package/lib/service/config/core-config.tokens.d.ts +7 -0
- package/lib/service/connection/connection.service.d.ts +25 -0
- package/lib/service/connection/offline.interceptor.d.ts +15 -0
- package/lib/service/core-init/core-init.service.d.ts +11 -0
- package/lib/service/core-init/missing-translation-handler.d.ts +8 -0
- package/lib/service/core-init/translate-json-loader.d.ts +20 -0
- package/lib/service/device/device.interface.d.ts +15 -0
- package/lib/service/device/device.service.d.ts +54 -0
- package/lib/service/dms/dms.service.d.ts +153 -0
- package/lib/service/dms/dms.service.interface.d.ts +59 -0
- package/lib/service/event/event.interface.d.ts +13 -0
- package/lib/service/event/event.service.d.ts +23 -0
- package/lib/service/event/events.d.ts +12 -0
- package/lib/service/idm/idm.interface.d.ts +5 -0
- package/lib/service/idm/idm.service.d.ts +9 -0
- package/lib/service/logger/logger-console.service.d.ts +20 -0
- package/lib/service/logger/logger.d.ts +17 -0
- package/lib/service/logger/logger.interface.d.ts +10 -0
- package/lib/service/notification/notification.service.d.ts +71 -0
- package/lib/service/object-config/object-config.interface.d.ts +62 -0
- package/lib/service/object-config/object-config.service.d.ts +38 -0
- package/lib/service/pending-changes/pending-changes-component.interface.d.ts +6 -0
- package/lib/service/pending-changes/pending-changes-guard.service.d.ts +14 -0
- package/lib/service/pending-changes/pending-changes.service.d.ts +57 -0
- package/lib/service/prediction/prediction.interface.d.ts +18 -0
- package/lib/service/prediction/prediction.service.d.ts +15 -0
- package/lib/service/search/search.service.d.ts +46 -0
- package/lib/service/search/search.service.interface.d.ts +119 -0
- package/lib/service/session-storage/session-storage.service.d.ts +15 -0
- package/lib/service/system/object-form.interface.d.ts +46 -0
- package/lib/service/system/system.enum.d.ts +141 -0
- package/lib/service/system/system.interface.d.ts +146 -0
- package/lib/service/system/system.service.d.ts +168 -0
- package/lib/service/upload/upload.interface.d.ts +55 -0
- package/lib/service/upload/upload.service.d.ts +34 -0
- package/lib/service/user/user.service.d.ts +69 -0
- package/lib/util/utils.d.ts +118 -0
- package/lib/util/utils.helper.enum.d.ts +13 -0
- package/package.json +33 -0
|
@@ -0,0 +1,144 @@
|
|
|
1
|
+
import { inject, Injectable } from '@angular/core';
|
|
2
|
+
import { DeviceDetectorService } from 'ngx-device-detector';
|
|
3
|
+
import { debounceTime, fromEvent, ReplaySubject } from 'rxjs';
|
|
4
|
+
import { DeviceScreenOrientation } from './device.interface';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
/**
|
|
7
|
+
* This service is used to adapt styles and designs of the client to
|
|
8
|
+
* different devices and screen sizes.
|
|
9
|
+
*
|
|
10
|
+
* Using `screenChange$` observable you are able to monitor changes to
|
|
11
|
+
* the screen size and act upon it.
|
|
12
|
+
*
|
|
13
|
+
* This service will also adds attributes to the body tag that reflect the
|
|
14
|
+
* current screen/device state. This way you can apply secific styles in your
|
|
15
|
+
* css files for different screen resolutions and orientations.
|
|
16
|
+
*
|
|
17
|
+
* Attributes applied to the body tag are:
|
|
18
|
+
*
|
|
19
|
+
* - `data-screen` - [s, m, l, xl] - for different screen sizes
|
|
20
|
+
* (s: for mobile phone like screen sizes, m: for tablet like screen
|
|
21
|
+
* sizes, 'l': for desktop like screen sizes, 'xl': for screen sizes exceeding
|
|
22
|
+
* the desktop screen size).
|
|
23
|
+
*
|
|
24
|
+
* - `data-orientation` - [portrait, landscape] - for the current screen orientation
|
|
25
|
+
*
|
|
26
|
+
* - `data-touch-enabled` - [true] - if the device has touch capabilities (won't be added if the device doesn't have touch capabilities)
|
|
27
|
+
*
|
|
28
|
+
* ```html
|
|
29
|
+
* <body data-screen-size="s" data-screen-orientation="portrait" data-touch-enabled="true">
|
|
30
|
+
* ...
|
|
31
|
+
* </body>
|
|
32
|
+
* ```
|
|
33
|
+
*/
|
|
34
|
+
export class DeviceService {
|
|
35
|
+
#deviceDetectorService;
|
|
36
|
+
#upperScreenBoundary;
|
|
37
|
+
#resize$;
|
|
38
|
+
#screen;
|
|
39
|
+
#screenSource;
|
|
40
|
+
constructor() {
|
|
41
|
+
this.#deviceDetectorService = inject(DeviceDetectorService);
|
|
42
|
+
this.#upperScreenBoundary = {
|
|
43
|
+
small: 600,
|
|
44
|
+
mediumPortrait: 900,
|
|
45
|
+
mediumLandscape: 1200,
|
|
46
|
+
large: 1800
|
|
47
|
+
};
|
|
48
|
+
this.#resize$ = fromEvent(window, 'resize').pipe(debounceTime(this.#getDebounceTime()));
|
|
49
|
+
this.#screenSource = new ReplaySubject(1);
|
|
50
|
+
this.screenChange$ = this.#screenSource.asObservable();
|
|
51
|
+
/**
|
|
52
|
+
* if the device is a mobile device (android / iPhone / windows-phone etc)
|
|
53
|
+
*/
|
|
54
|
+
this.isMobile = this.#deviceDetectorService.isMobile();
|
|
55
|
+
/**
|
|
56
|
+
* if the device us a tablet (iPad etc)
|
|
57
|
+
*/
|
|
58
|
+
this.isTablet = this.#deviceDetectorService.isTablet();
|
|
59
|
+
/**
|
|
60
|
+
* if the app is running on a Desktop browser
|
|
61
|
+
*/
|
|
62
|
+
this.isDesktop = this.#deviceDetectorService.isDesktop();
|
|
63
|
+
this.info = this.#deviceDetectorService.getDeviceInfo();
|
|
64
|
+
this.isTouchEnabled = this.#isTouchEnabled();
|
|
65
|
+
this.#resize$.subscribe((e) => {
|
|
66
|
+
this.#setScreen();
|
|
67
|
+
});
|
|
68
|
+
}
|
|
69
|
+
init() {
|
|
70
|
+
this.#setScreen();
|
|
71
|
+
}
|
|
72
|
+
#isTouchEnabled() {
|
|
73
|
+
return 'ontouchstart' in window || navigator.maxTouchPoints > 0;
|
|
74
|
+
}
|
|
75
|
+
#setScreen() {
|
|
76
|
+
const bounds = {
|
|
77
|
+
width: window.innerWidth,
|
|
78
|
+
height: window.innerHeight
|
|
79
|
+
};
|
|
80
|
+
let orientation = bounds.width >= bounds.height ? DeviceScreenOrientation.LANDSCAPE : DeviceScreenOrientation.PORTRAIT;
|
|
81
|
+
if (this.isMobile && window.screen['orientation']) {
|
|
82
|
+
const screenOrientation = window.screen['orientation'].type;
|
|
83
|
+
if (screenOrientation === 'landscape-primary' || screenOrientation === 'landscape-secondary') {
|
|
84
|
+
orientation = DeviceScreenOrientation.LANDSCAPE;
|
|
85
|
+
}
|
|
86
|
+
else if (screenOrientation === 'portrait-primary' || screenOrientation === 'portrait-secondary') {
|
|
87
|
+
orientation = DeviceScreenOrientation.PORTRAIT;
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
this.#screen = {
|
|
91
|
+
size: this.#getScreenSize(bounds, orientation),
|
|
92
|
+
orientation,
|
|
93
|
+
width: bounds.width,
|
|
94
|
+
height: bounds.height
|
|
95
|
+
};
|
|
96
|
+
this.#screenSource.next(this.#screen);
|
|
97
|
+
this.#setupDOM(this.#screen);
|
|
98
|
+
// force change detection because resize will not be recognized by Angular in some cases
|
|
99
|
+
// TODO: check: causes recursive ticks in some cases ...
|
|
100
|
+
// eslint-disable-next-line @typescript-eslint/no-empty-function
|
|
101
|
+
setTimeout(() => { }, 0);
|
|
102
|
+
}
|
|
103
|
+
#setupDOM(screen) {
|
|
104
|
+
const body = document.querySelector('body');
|
|
105
|
+
body.setAttribute('data-screen-size', screen.size);
|
|
106
|
+
body.setAttribute('data-screen-orientation', screen.orientation);
|
|
107
|
+
if (this.isTouchEnabled)
|
|
108
|
+
body.setAttribute('data-touch-enabled', 'true');
|
|
109
|
+
else
|
|
110
|
+
body.removeAttribute('data-touch-enabled');
|
|
111
|
+
}
|
|
112
|
+
#getScreenSize(bounds, orientation) {
|
|
113
|
+
if (this.#isBelow(this.#upperScreenBoundary.small, bounds)) {
|
|
114
|
+
return 's';
|
|
115
|
+
}
|
|
116
|
+
else if (this.#isBelow(orientation === 'landscape' ? this.#upperScreenBoundary.mediumLandscape : this.#upperScreenBoundary.mediumPortrait, bounds)) {
|
|
117
|
+
return 'm';
|
|
118
|
+
}
|
|
119
|
+
else if (this.#isBelow(this.#upperScreenBoundary.large, bounds)) {
|
|
120
|
+
return 'l';
|
|
121
|
+
}
|
|
122
|
+
else {
|
|
123
|
+
return 'xl';
|
|
124
|
+
}
|
|
125
|
+
}
|
|
126
|
+
#isBelow(size, bounds) {
|
|
127
|
+
const landscape = bounds.width < this.#upperScreenBoundary.large ? bounds.width >= bounds.height : false;
|
|
128
|
+
return (landscape && bounds.height < size) || (!landscape && bounds.width < size);
|
|
129
|
+
}
|
|
130
|
+
#getDebounceTime() {
|
|
131
|
+
// on mobile devices resize only happens when rotating the device or when
|
|
132
|
+
// keyboard appears, so we dont't need to debounce
|
|
133
|
+
return this.isMobile ? 0 : 500;
|
|
134
|
+
}
|
|
135
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DeviceService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
136
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DeviceService, providedIn: 'root' }); }
|
|
137
|
+
}
|
|
138
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: DeviceService, decorators: [{
|
|
139
|
+
type: Injectable,
|
|
140
|
+
args: [{
|
|
141
|
+
providedIn: 'root'
|
|
142
|
+
}]
|
|
143
|
+
}], ctorParameters: () => [] });
|
|
144
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"device.service.js","sourceRoot":"","sources":["../../../../../../../../libs/yuuvis/client-core/src/lib/service/device/device.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { inject, Injectable } from '@angular/core';\nimport { DeviceDetectorService, DeviceInfo } from 'ngx-device-detector';\nimport { debounceTime, fromEvent, Observable, ReplaySubject } from 'rxjs';\nimport { DeviceScreen, DeviceScreenBounds, DeviceScreenOrientation, ScreenSize } from './device.interface';\n/**\n * This service is used to adapt styles and designs of the client to \n * different devices and screen sizes.\n * \n * Using `screenChange$` observable you are able to monitor changes to \n * the screen size and act upon it.\n *\n * This service will also adds attributes to the body tag that reflect the \n * current screen/device state. This way you can apply secific styles in your \n * css files for different screen resolutions and orientations.\n *\n * Attributes applied to the body tag are:\n *\n * - `data-screen` - [s, m, l, xl] - for different screen sizes \n * (s: for mobile phone like screen sizes, m: for tablet like screen \n * sizes, 'l': for desktop like screen sizes, 'xl': for screen sizes exceeding \n * the desktop screen size). \n *\n * - `data-orientation` - [portrait, landscape] - for the current screen orientation\n * \n * - `data-touch-enabled` - [true] - if the device has touch capabilities (won't be added if the device doesn't have touch capabilities)  \n * \n * ```html\n * <body data-screen-size=\"s\" data-screen-orientation=\"portrait\" data-touch-enabled=\"true\">\n * ...\n * </body>\n * ```\n */\n@Injectable({\n  providedIn: 'root'\n})\nexport class DeviceService {\n  #deviceDetectorService = inject(DeviceDetectorService);\n\n  #upperScreenBoundary = {\n    small: 600,\n    mediumPortrait: 900,\n    mediumLandscape: 1200,\n    large: 1800\n  };\n\n  #resize$ = fromEvent(window, 'resize').pipe(debounceTime(this.#getDebounceTime()));\n  #screen?: DeviceScreen;\n  #screenSource = new ReplaySubject<DeviceScreen>(1);\n  screenChange$: Observable<DeviceScreen> = this.#screenSource.asObservable();\n\n  /**\n   * if the device is a mobile device (android / iPhone / windows-phone etc)\n   */\n  isMobile: boolean = this.#deviceDetectorService.isMobile();\n  /**\n   *  if the device us a tablet (iPad etc)\n   */\n  isTablet: boolean = this.#deviceDetectorService.isTablet();\n  /**\n   * if the app is running on a Desktop browser\n   */\n  isDesktop: boolean = this.#deviceDetectorService.isDesktop();\n  info?: DeviceInfo = this.#deviceDetectorService.getDeviceInfo();\n  isTouchEnabled = this.#isTouchEnabled();\n\n  constructor() {\n    this.#resize$.subscribe((e: Event) => {\n      this.#setScreen();\n    });\n  }\n\n  init() {\n    this.#setScreen();\n  }\n\n  #isTouchEnabled() {\n    return 'ontouchstart' in window || navigator.maxTouchPoints > 0;\n  }\n\n  #setScreen(): void {\n    const bounds: DeviceScreenBounds = {\n      width: window.innerWidth,\n      height: window.innerHeight\n    };\n    let orientation: DeviceScreenOrientation = bounds.width >= bounds.height ? DeviceScreenOrientation.LANDSCAPE : DeviceScreenOrientation.PORTRAIT;\n\n    if (this.isMobile && window.screen['orientation']) {\n      const screenOrientation = window.screen['orientation'].type;\n      if (screenOrientation === 'landscape-primary' || screenOrientation === 'landscape-secondary') {\n        orientation = DeviceScreenOrientation.LANDSCAPE;\n      } else if (screenOrientation === 'portrait-primary' || screenOrientation === 'portrait-secondary') {\n        orientation = DeviceScreenOrientation.PORTRAIT;\n      }\n    }\n    this.#screen = {\n      size: this.#getScreenSize(bounds, orientation),\n      orientation,\n      width: bounds.width,\n      height: bounds.height\n    };\n    this.#screenSource.next(this.#screen);\n    this.#setupDOM(this.#screen);\n    // force change detection because resize will not be recognized by Angular in some cases\n    // TODO: check: causes recursive ticks in some cases ...\n\n    // eslint-disable-next-line @typescript-eslint/no-empty-function\n    setTimeout(() => {}, 0);\n\n  }\n\n  #setupDOM(screen: DeviceScreen) {\n    const body: HTMLBodyElement = document.querySelector('body') as HTMLBodyElement;\n    body.setAttribute('data-screen-size', screen.size);\n    body.setAttribute('data-screen-orientation', screen.orientation);\n    if (this.isTouchEnabled) body.setAttribute('data-touch-enabled', 'true');\n    else body.removeAttribute('data-touch-enabled');\n  }\n\n  #getScreenSize(bounds: DeviceScreenBounds, orientation: DeviceScreenOrientation): ScreenSize {\n    if (this.#isBelow(this.#upperScreenBoundary.small, bounds)) {\n      return 's';\n    } else if (this.#isBelow(orientation === 'landscape' ? this.#upperScreenBoundary.mediumLandscape : this.#upperScreenBoundary.mediumPortrait, bounds)) {\n      return 'm';\n    } else if (this.#isBelow(this.#upperScreenBoundary.large, bounds)) {\n      return 'l';\n    } else {\n      return 'xl';\n    }\n  }\n\n  #isBelow(size: number, bounds: DeviceScreenBounds): boolean {\n    const landscape = bounds.width < this.#upperScreenBoundary.large ? bounds.width >= bounds.height : false;\n    return (landscape && bounds.height < size) || (!landscape && bounds.width < size);\n  }\n\n  #getDebounceTime() {\n    // on mobile devices resize only happens when rotating the device or when\n    // keyboard appears, so we dont't need to debounce\n    return this.isMobile ? 0 : 500;\n  }\n}\n"]}
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZG1zLnNlcnZpY2UuaW50ZXJmYWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy95dXV2aXMvY2xpZW50LWNvcmUvc3JjL2xpYi9zZXJ2aWNlL2Rtcy9kbXMuc2VydmljZS5pbnRlcmZhY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBpbnRlcmZhY2UgT2JqZWN0RGVsZXRlT3B0aW9ucyB7XG4gIC8vIHdoZXRoZXIgdG8gZW1pdCB0aGUgcmVzdWx0IG9mIHRoZSBkZWxldGUgb3BlcmF0aW9uIGludG8gdGhlIGFwcC4gSWYgc2V0IHRvIHRydWUsXG4gIC8vIHRoZSByZXN1bHQgd2lsbCBub3QgYmUgZW1pdHRlZCB2aWEgdGhlIGBvYmplY3REZWxldGVkYCBldmVudFxuICBzaWxlbnQ/OiBib29sZWFuO1xuICAvLyB3aGV0ZXIgdG8gd2FpdCBmb3IgdGhlIHNlYXJjaCBpbmRleCB0byBiZSBjb25zaXN0ZW50IGFmdGVyIHRoZSBkZWxldGUgb3BlcmF0aW9uXG4gIHdhaXRGb3JTZWFyY2hDb25zaXN0ZW5jeT86IGJvb2xlYW47XG4gIC8vIHdoZXRoZXIgdGhlIHdob2xlIGRlbGV0ZSBvcGVyYXRpb24gc2hvdWxkIGZhaWwgaWYgb25lIG9mIHRoZSBvYmplY3RzIGNvdWxkIG5vdCBiZSBkZWxldGVkXG4gIGdyZWVkeT86IGJvb2xlYW47XG59XG5leHBvcnQgaW50ZXJmYWNlIE9iamVjdERlbGV0ZVJlc3VsdCB7XG4gIC8vIElEIG9mIHRoZSBvYmplY3Qgc3VwcG9zZWQgdG8gYmUgZGVsZXRlZFxuICBpZDogc3RyaW5nO1xuICAvLyBwcm9wZXJ0aWVzIG9mIHRoZSBvYmplY3Qgc3VwcG9zZWQgdG8gYmUgZGVsZXRlZFxuICBwcm9wZXJ0aWVzPzogeyBba2V5OiBzdHJpbmddOiB7IHZhbHVlOiBhbnkgfSB9O1xuICAvLyBlcnJvciB0aGF0IG9jY3VyZWQgZHVyaW5nIHRoZSBkZWxldGUgb3BlcmF0aW9uXG4gIF9lcnJvcj86IE9iamVjdERlbGV0ZUVycm9yO1xufVxuZXhwb3J0IGludGVyZmFjZSBPYmplY3REZWxldGVFcnJvciB7XG4gIHN0YXR1czogbnVtYmVyO1xuICBtZXNzYWdlOiBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgT2JqZWN0TW92ZU9wdGlvbnMge1xuICAvLyBJZiB0cnVlLCB0aGUgb2JzZXJ2YWJsZSB3aWxsIHJlc29sdmUgYWZ0ZXIgdGhlIHNlYXJjaCBpbmRleCBpcyB1cGRhdGVkIGFzIHdlbGxcbiAgd2FpdEZvclNlYXJjaENvbnNpc3RlbmN5PzogYm9vbGVhbjtcbiAgc2lsZW50PzogYm9vbGVhbjtcbn1cbmV4cG9ydCBpbnRlcmZhY2UgT2JqZWN0Q29weU9wdGlvbnMge1xuICAvLyBJZiB0cnVlLCB0aGUgb2JzZXJ2YWJsZSB3aWxsIHJlc29sdmUgYWZ0ZXIgdGhlIHNlYXJjaCBpbmRleCBpcyB1cGRhdGVkIGFzIHdlbGxcbiAgd2FpdEZvclNlYXJjaENvbnNpc3RlbmN5PzogYm9vbGVhbjtcbn1cblxuLy8gaW50ZXJmYWNlcyBmb3IgaW50ZXJhY3Rpbmcgd2l0aCBDb3JlLUFQSVxuZXhwb3J0IGludGVyZmFjZSBDb3JlQXBpT2JqZWN0IHtcbiAgcHJvcGVydGllczogUmVjb3JkPHN0cmluZywgQ29yZUFwaU9iamVjdFByb3BlcnR5PjtcbiAgY29udGVudFN0cmVhbXM/OiBQYXJ0aWFsPENvbnRlbnRTdHJlYW0+W107XG59XG5leHBvcnQgaW50ZXJmYWNlIENvcmVBcGlPYmplY3RQcm9wZXJ0eSB7XG4gIHZhbHVlOiB1bmtub3duO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIENvbnRlbnRTdHJlYW0ge1xuICBjb250ZW50U3RyZWFtSWQ6IHN0cmluZztcbiAgcmVwb3NpdG9yeUlkOiBzdHJpbmc7XG4gIGRpZ2VzdDogc3RyaW5nO1xuICBmaWxlTmFtZTogc3RyaW5nO1xuICBzaXplOiBudW1iZXI7XG4gIGFyY2hpdmVQYXRoPzogc3RyaW5nO1xuICByYW5nZT86IHN0cmluZztcbiAgbWltZVR5cGU6IHN0cmluZztcbn1cblxuZXhwb3J0IGludGVyZmFjZSBDb3JlQXBpQmF0Y2hSZXNwb25zZSB7XG4gIGhhc01vcmVJdGVtczogYm9vbGVhbjtcbiAgbnVtSXRlbXM6IG51bWJlcjtcbiAgb2JqZWN0czogQ29yZUFwaVJlc3BvbnNlW107XG4gIHRvdGFsTnVtSXRlbXM6IG51bWJlcjtcbn1cbmV4cG9ydCBpbnRlcmZhY2UgQ29yZUFwaVJlc3BvbnNlIHtcbiAgcHJvcGVydGllczogUmVjb3JkPHN0cmluZywgQ29yZUFwaU9iamVjdFByb3BlcnR5PjtcbiAgY29udGVudFN0cmVhbXM/OiBDb250ZW50U3RyZWFtW107XG4gIG9wdGlvbnM6IHtcbiAgICAnc3lzdGVtOnJlc3BvbnNlJzoge1xuICAgICAgaHR0cFN0YXR1c0NvZGU6IG51bWJlcjtcbiAgICAgIHNlcnZpY2VFcnJvckNvZGU/OiBudW1iZXI7XG4gICAgICBtZXNzYWdlOiBzdHJpbmc7XG4gICAgfTtcbiAgfTtcbn1cbiJdfQ==
|