ctt-babylon 0.1.233 → 0.1.234

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.
@@ -1,13 +1,18 @@
1
- import { Injectable, inject, signal } from '@angular/core';
1
+ import { isPlatformBrowser } from '@angular/common';
2
+ import { Injectable, PLATFORM_ID, inject, signal } from '@angular/core';
2
3
  import { debounceTime, distinctUntilChanged, fromEvent, map, startWith, } from 'rxjs';
3
4
  import { SCREEN_SIZER_PARAMS_TOKEN } from './screen-sizer.service.token';
4
5
  import * as i0 from "@angular/core";
5
6
  export class ScreenSizerService {
6
7
  get width() {
7
- if (window.innerWidth > window.outerWidth) {
8
- return window.outerWidth;
8
+ if (isPlatformBrowser(this.platformId)) {
9
+ if (window.innerWidth > window.outerWidth) {
10
+ return window.outerWidth;
11
+ }
12
+ return window.innerWidth;
9
13
  }
10
- return window.innerWidth;
14
+ else
15
+ return 0;
11
16
  }
12
17
  constructor() {
13
18
  this.mobile = signal(false);
@@ -26,37 +31,40 @@ export class ScreenSizerService {
26
31
  this.minMediumDesktop = signal(false);
27
32
  this.minFullDesktop = signal(false);
28
33
  this.minFullBigDesktop = signal(false);
34
+ this.platformId = inject(PLATFORM_ID);
29
35
  this.screenSizerParams = inject(SCREEN_SIZER_PARAMS_TOKEN)
30
36
  .pixelBreakpoints;
31
- fromEvent(window, 'resize')
32
- .pipe(debounceTime(200), map(() => this.width), distinctUntilChanged(), startWith(this.width))
33
- .subscribe((size) => {
34
- if (size) {
35
- this.mobile.set(size < this.screenSizerParams.mobile);
36
- this.smallTablet.set(size >= this.screenSizerParams.mobile &&
37
- size < this.screenSizerParams.smallTablet);
38
- this.mediumTablet.set(size >= this.screenSizerParams.smallTablet &&
39
- size < this.screenSizerParams.mediumTablet);
40
- this.fullTablet.set(size >= this.screenSizerParams.mediumTablet &&
41
- size < this.screenSizerParams.fullTablet);
42
- this.smallDesktop.set(size >= this.screenSizerParams.fullTablet &&
43
- size < this.screenSizerParams.smallDesktop);
44
- this.mediumDesktop.set(size >= this.screenSizerParams.smallDesktop &&
45
- size < this.screenSizerParams.mediumDesktop);
46
- this.fullDesktop.set(size >= this.screenSizerParams.mediumDesktop &&
47
- size < this.screenSizerParams.fullDesktop);
48
- this.fullBigDesktop.set(size >= this.screenSizerParams.fullDesktop &&
49
- size < this.screenSizerParams.fullBigDesktop);
50
- this.maxDesktop.set(size >= this.screenSizerParams.fullBigDesktop);
51
- this.minSmallTablet.set(size >= this.screenSizerParams.smallTablet);
52
- this.minMediumTablet.set(size >= this.screenSizerParams.mediumTablet);
53
- this.minFullTablet.set(size >= this.screenSizerParams.fullTablet);
54
- this.minSmallDesktop.set(size >= this.screenSizerParams.smallDesktop);
55
- this.minMediumDesktop.set(size >= this.screenSizerParams.mediumDesktop);
56
- this.minFullDesktop.set(size >= this.screenSizerParams.fullDesktop);
57
- this.minFullBigDesktop.set(size >= this.screenSizerParams.fullBigDesktop);
58
- }
59
- });
37
+ if (isPlatformBrowser(this.platformId)) {
38
+ fromEvent(window, 'resize')
39
+ .pipe(debounceTime(200), map(() => this.width), distinctUntilChanged(), startWith(this.width))
40
+ .subscribe((size) => {
41
+ if (size) {
42
+ this.mobile.set(size < this.screenSizerParams.mobile);
43
+ this.smallTablet.set(size >= this.screenSizerParams.mobile &&
44
+ size < this.screenSizerParams.smallTablet);
45
+ this.mediumTablet.set(size >= this.screenSizerParams.smallTablet &&
46
+ size < this.screenSizerParams.mediumTablet);
47
+ this.fullTablet.set(size >= this.screenSizerParams.mediumTablet &&
48
+ size < this.screenSizerParams.fullTablet);
49
+ this.smallDesktop.set(size >= this.screenSizerParams.fullTablet &&
50
+ size < this.screenSizerParams.smallDesktop);
51
+ this.mediumDesktop.set(size >= this.screenSizerParams.smallDesktop &&
52
+ size < this.screenSizerParams.mediumDesktop);
53
+ this.fullDesktop.set(size >= this.screenSizerParams.mediumDesktop &&
54
+ size < this.screenSizerParams.fullDesktop);
55
+ this.fullBigDesktop.set(size >= this.screenSizerParams.fullDesktop &&
56
+ size < this.screenSizerParams.fullBigDesktop);
57
+ this.maxDesktop.set(size >= this.screenSizerParams.fullBigDesktop);
58
+ this.minSmallTablet.set(size >= this.screenSizerParams.smallTablet);
59
+ this.minMediumTablet.set(size >= this.screenSizerParams.mediumTablet);
60
+ this.minFullTablet.set(size >= this.screenSizerParams.fullTablet);
61
+ this.minSmallDesktop.set(size >= this.screenSizerParams.smallDesktop);
62
+ this.minMediumDesktop.set(size >= this.screenSizerParams.mediumDesktop);
63
+ this.minFullDesktop.set(size >= this.screenSizerParams.fullDesktop);
64
+ this.minFullBigDesktop.set(size >= this.screenSizerParams.fullBigDesktop);
65
+ }
66
+ });
67
+ }
60
68
  }
61
69
  getBreakpoint(breakpoint) {
62
70
  return this.screenSizerParams[breakpoint];
@@ -118,4 +126,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
118
126
  providedIn: 'root',
119
127
  }]
120
128
  }], ctorParameters: () => [] });
121
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"screen-sizer.service.js","sourceRoot":"","sources":["../../../../../../projects/babylon/src/lib/services/screen-sizer/screen-sizer.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, inject, signal } from '@angular/core';\nimport {\n    debounceTime,\n    distinctUntilChanged,\n    fromEvent,\n    map,\n    startWith,\n} from 'rxjs';\nimport { SCREEN_SIZER_PARAMS_TOKEN } from './screen-sizer.service.token';\n\n@Injectable({\n    providedIn: 'root',\n})\nexport class ScreenSizerService {\n    readonly mobile = signal(false);\n    readonly smallTablet = signal(false);\n    readonly mediumTablet = signal(false);\n    readonly fullTablet = signal(false);\n    readonly smallDesktop = signal(false);\n    readonly mediumDesktop = signal(false);\n    readonly fullDesktop = signal(false);\n    readonly fullBigDesktop = signal(false);\n    readonly maxDesktop = signal(false);\n\n    readonly minSmallTablet = signal(false);\n    readonly minMediumTablet = signal(false);\n    readonly minFullTablet = signal(false);\n    readonly minSmallDesktop = signal(false);\n    readonly minMediumDesktop = signal(false);\n    readonly minFullDesktop = signal(false);\n    readonly minFullBigDesktop = signal(false);\n\n    get width(): number {\n        if (window.innerWidth > window.outerWidth) {\n            return window.outerWidth;\n        }\n        return window.innerWidth;\n    }\n\n    private readonly screenSizerParams = inject(SCREEN_SIZER_PARAMS_TOKEN)\n        .pixelBreakpoints;\n\n    constructor() {\n        fromEvent(window, 'resize')\n            .pipe(\n                debounceTime(200),\n                map(() => this.width),\n                distinctUntilChanged(),\n                startWith(this.width)\n            )\n            .subscribe((size) => {\n                if (size) {\n                    this.mobile.set(size < this.screenSizerParams.mobile);\n\n                    this.smallTablet.set(\n                        size >= this.screenSizerParams.mobile &&\n                            size < this.screenSizerParams.smallTablet\n                    );\n\n                    this.mediumTablet.set(\n                        size >= this.screenSizerParams.smallTablet &&\n                            size < this.screenSizerParams.mediumTablet\n                    );\n\n                    this.fullTablet.set(\n                        size >= this.screenSizerParams.mediumTablet &&\n                            size < this.screenSizerParams.fullTablet\n                    );\n\n                    this.smallDesktop.set(\n                        size >= this.screenSizerParams.fullTablet &&\n                            size < this.screenSizerParams.smallDesktop\n                    );\n\n                    this.mediumDesktop.set(\n                        size >= this.screenSizerParams.smallDesktop &&\n                            size < this.screenSizerParams.mediumDesktop\n                    );\n\n                    this.fullDesktop.set(\n                        size >= this.screenSizerParams.mediumDesktop &&\n                            size < this.screenSizerParams.fullDesktop\n                    );\n\n                    this.fullBigDesktop.set(\n                        size >= this.screenSizerParams.fullDesktop &&\n                            size < this.screenSizerParams.fullBigDesktop\n                    );\n\n                    this.maxDesktop.set(\n                        size >= this.screenSizerParams.fullBigDesktop\n                    );\n\n                    this.minSmallTablet.set(\n                        size >= this.screenSizerParams.smallTablet\n                    );\n\n                    this.minMediumTablet.set(\n                        size >= this.screenSizerParams.mediumTablet\n                    );\n\n                    this.minFullTablet.set(\n                        size >= this.screenSizerParams.fullTablet\n                    );\n\n                    this.minSmallDesktop.set(\n                        size >= this.screenSizerParams.smallDesktop\n                    );\n\n                    this.minMediumDesktop.set(\n                        size >= this.screenSizerParams.mediumDesktop\n                    );\n\n                    this.minFullDesktop.set(\n                        size >= this.screenSizerParams.fullDesktop\n                    );\n\n                    this.minFullBigDesktop.set(\n                        size >= this.screenSizerParams.fullBigDesktop\n                    );\n                }\n            });\n    }\n\n    getBreakpoint(breakpoint: keyof typeof this.screenSizerParams): number {\n        return this.screenSizerParams[breakpoint];\n    }\n\n    isMobileInstant(): boolean {\n        return this.mobile();\n    }\n\n    isSmallTabletInstant(): boolean {\n        return this.smallTablet();\n    }\n\n    isMediumTabletInstant(): boolean {\n        return this.mediumTablet();\n    }\n\n    isFullTabletInstant(): boolean {\n        return this.fullTablet();\n    }\n\n    isSmallDesktopInstant(): boolean {\n        return this.smallDesktop();\n    }\n\n    isMediumDesktopInstant(): boolean {\n        return this.mediumDesktop();\n    }\n\n    isFullDesktopInstant(): boolean {\n        return this.fullDesktop();\n    }\n\n    isFullBigDesktopInstant(): boolean {\n        return this.fullBigDesktop();\n    }\n\n    isMaxDesktopInstant(): boolean {\n        return this.maxDesktop();\n    }\n\n    minSmallTabletInstant(): boolean {\n        return this.minSmallTablet();\n    }\n\n    minMediumTabletInstant(): boolean {\n        return this.minMediumTablet();\n    }\n\n    minFullTabletInstant(): boolean {\n        return this.minFullTablet();\n    }\n\n    minSmallDesktopInstant(): boolean {\n        return this.minSmallDesktop();\n    }\n\n    minMediumDesktopInstant(): boolean {\n        return this.minMediumDesktop();\n    }\n\n    minFullDesktopInstant(): boolean {\n        return this.minFullDesktop();\n    }\n\n    minFullBigDesktopInstant(): boolean {\n        return this.minFullBigDesktop();\n    }\n}\n"]}
129
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"screen-sizer.service.js","sourceRoot":"","sources":["../../../../../../projects/babylon/src/lib/services/screen-sizer/screen-sizer.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { isPlatformBrowser } from '@angular/common';\nimport { Injectable, PLATFORM_ID, inject, signal } from '@angular/core';\nimport {\n    debounceTime,\n    distinctUntilChanged,\n    fromEvent,\n    map,\n    startWith,\n} from 'rxjs';\nimport { SCREEN_SIZER_PARAMS_TOKEN } from './screen-sizer.service.token';\n\n@Injectable({\n    providedIn: 'root',\n})\nexport class ScreenSizerService {\n    readonly mobile = signal(false);\n    readonly smallTablet = signal(false);\n    readonly mediumTablet = signal(false);\n    readonly fullTablet = signal(false);\n    readonly smallDesktop = signal(false);\n    readonly mediumDesktop = signal(false);\n    readonly fullDesktop = signal(false);\n    readonly fullBigDesktop = signal(false);\n    readonly maxDesktop = signal(false);\n\n    readonly minSmallTablet = signal(false);\n    readonly minMediumTablet = signal(false);\n    readonly minFullTablet = signal(false);\n    readonly minSmallDesktop = signal(false);\n    readonly minMediumDesktop = signal(false);\n    readonly minFullDesktop = signal(false);\n    readonly minFullBigDesktop = signal(false);\n\n    private platformId = inject(PLATFORM_ID);\n\n    get width(): number {\n        if (isPlatformBrowser(this.platformId)) {\n            if (window.innerWidth > window.outerWidth) {\n                return window.outerWidth;\n            }\n            return window.innerWidth;\n        } else return 0;\n    }\n\n    private readonly screenSizerParams = inject(SCREEN_SIZER_PARAMS_TOKEN)\n        .pixelBreakpoints;\n\n    constructor() {\n        if (isPlatformBrowser(this.platformId)) {\n            fromEvent(window, 'resize')\n                .pipe(\n                    debounceTime(200),\n                    map(() => this.width),\n                    distinctUntilChanged(),\n                    startWith(this.width)\n                )\n                .subscribe((size) => {\n                    if (size) {\n                        this.mobile.set(size < this.screenSizerParams.mobile);\n\n                        this.smallTablet.set(\n                            size >= this.screenSizerParams.mobile &&\n                                size < this.screenSizerParams.smallTablet\n                        );\n\n                        this.mediumTablet.set(\n                            size >= this.screenSizerParams.smallTablet &&\n                                size < this.screenSizerParams.mediumTablet\n                        );\n\n                        this.fullTablet.set(\n                            size >= this.screenSizerParams.mediumTablet &&\n                                size < this.screenSizerParams.fullTablet\n                        );\n\n                        this.smallDesktop.set(\n                            size >= this.screenSizerParams.fullTablet &&\n                                size < this.screenSizerParams.smallDesktop\n                        );\n\n                        this.mediumDesktop.set(\n                            size >= this.screenSizerParams.smallDesktop &&\n                                size < this.screenSizerParams.mediumDesktop\n                        );\n\n                        this.fullDesktop.set(\n                            size >= this.screenSizerParams.mediumDesktop &&\n                                size < this.screenSizerParams.fullDesktop\n                        );\n\n                        this.fullBigDesktop.set(\n                            size >= this.screenSizerParams.fullDesktop &&\n                                size < this.screenSizerParams.fullBigDesktop\n                        );\n\n                        this.maxDesktop.set(\n                            size >= this.screenSizerParams.fullBigDesktop\n                        );\n\n                        this.minSmallTablet.set(\n                            size >= this.screenSizerParams.smallTablet\n                        );\n\n                        this.minMediumTablet.set(\n                            size >= this.screenSizerParams.mediumTablet\n                        );\n\n                        this.minFullTablet.set(\n                            size >= this.screenSizerParams.fullTablet\n                        );\n\n                        this.minSmallDesktop.set(\n                            size >= this.screenSizerParams.smallDesktop\n                        );\n\n                        this.minMediumDesktop.set(\n                            size >= this.screenSizerParams.mediumDesktop\n                        );\n\n                        this.minFullDesktop.set(\n                            size >= this.screenSizerParams.fullDesktop\n                        );\n\n                        this.minFullBigDesktop.set(\n                            size >= this.screenSizerParams.fullBigDesktop\n                        );\n                    }\n                });\n        }\n    }\n\n    getBreakpoint(breakpoint: keyof typeof this.screenSizerParams): number {\n        return this.screenSizerParams[breakpoint];\n    }\n\n    isMobileInstant(): boolean {\n        return this.mobile();\n    }\n\n    isSmallTabletInstant(): boolean {\n        return this.smallTablet();\n    }\n\n    isMediumTabletInstant(): boolean {\n        return this.mediumTablet();\n    }\n\n    isFullTabletInstant(): boolean {\n        return this.fullTablet();\n    }\n\n    isSmallDesktopInstant(): boolean {\n        return this.smallDesktop();\n    }\n\n    isMediumDesktopInstant(): boolean {\n        return this.mediumDesktop();\n    }\n\n    isFullDesktopInstant(): boolean {\n        return this.fullDesktop();\n    }\n\n    isFullBigDesktopInstant(): boolean {\n        return this.fullBigDesktop();\n    }\n\n    isMaxDesktopInstant(): boolean {\n        return this.maxDesktop();\n    }\n\n    minSmallTabletInstant(): boolean {\n        return this.minSmallTablet();\n    }\n\n    minMediumTabletInstant(): boolean {\n        return this.minMediumTablet();\n    }\n\n    minFullTabletInstant(): boolean {\n        return this.minFullTablet();\n    }\n\n    minSmallDesktopInstant(): boolean {\n        return this.minSmallDesktop();\n    }\n\n    minMediumDesktopInstant(): boolean {\n        return this.minMediumDesktop();\n    }\n\n    minFullDesktopInstant(): boolean {\n        return this.minFullDesktop();\n    }\n\n    minFullBigDesktopInstant(): boolean {\n        return this.minFullBigDesktop();\n    }\n}\n"]}
@@ -1872,10 +1872,14 @@ const SCREEN_SIZER_PARAMS_TOKEN = new InjectionToken('ScreenSizerParams');
1872
1872
 
1873
1873
  class ScreenSizerService {
1874
1874
  get width() {
1875
- if (window.innerWidth > window.outerWidth) {
1876
- return window.outerWidth;
1875
+ if (isPlatformBrowser(this.platformId)) {
1876
+ if (window.innerWidth > window.outerWidth) {
1877
+ return window.outerWidth;
1878
+ }
1879
+ return window.innerWidth;
1877
1880
  }
1878
- return window.innerWidth;
1881
+ else
1882
+ return 0;
1879
1883
  }
1880
1884
  constructor() {
1881
1885
  this.mobile = signal(false);
@@ -1894,37 +1898,40 @@ class ScreenSizerService {
1894
1898
  this.minMediumDesktop = signal(false);
1895
1899
  this.minFullDesktop = signal(false);
1896
1900
  this.minFullBigDesktop = signal(false);
1901
+ this.platformId = inject(PLATFORM_ID);
1897
1902
  this.screenSizerParams = inject(SCREEN_SIZER_PARAMS_TOKEN)
1898
1903
  .pixelBreakpoints;
1899
- fromEvent(window, 'resize')
1900
- .pipe(debounceTime(200), map$1(() => this.width), distinctUntilChanged(), startWith(this.width))
1901
- .subscribe((size) => {
1902
- if (size) {
1903
- this.mobile.set(size < this.screenSizerParams.mobile);
1904
- this.smallTablet.set(size >= this.screenSizerParams.mobile &&
1905
- size < this.screenSizerParams.smallTablet);
1906
- this.mediumTablet.set(size >= this.screenSizerParams.smallTablet &&
1907
- size < this.screenSizerParams.mediumTablet);
1908
- this.fullTablet.set(size >= this.screenSizerParams.mediumTablet &&
1909
- size < this.screenSizerParams.fullTablet);
1910
- this.smallDesktop.set(size >= this.screenSizerParams.fullTablet &&
1911
- size < this.screenSizerParams.smallDesktop);
1912
- this.mediumDesktop.set(size >= this.screenSizerParams.smallDesktop &&
1913
- size < this.screenSizerParams.mediumDesktop);
1914
- this.fullDesktop.set(size >= this.screenSizerParams.mediumDesktop &&
1915
- size < this.screenSizerParams.fullDesktop);
1916
- this.fullBigDesktop.set(size >= this.screenSizerParams.fullDesktop &&
1917
- size < this.screenSizerParams.fullBigDesktop);
1918
- this.maxDesktop.set(size >= this.screenSizerParams.fullBigDesktop);
1919
- this.minSmallTablet.set(size >= this.screenSizerParams.smallTablet);
1920
- this.minMediumTablet.set(size >= this.screenSizerParams.mediumTablet);
1921
- this.minFullTablet.set(size >= this.screenSizerParams.fullTablet);
1922
- this.minSmallDesktop.set(size >= this.screenSizerParams.smallDesktop);
1923
- this.minMediumDesktop.set(size >= this.screenSizerParams.mediumDesktop);
1924
- this.minFullDesktop.set(size >= this.screenSizerParams.fullDesktop);
1925
- this.minFullBigDesktop.set(size >= this.screenSizerParams.fullBigDesktop);
1926
- }
1927
- });
1904
+ if (isPlatformBrowser(this.platformId)) {
1905
+ fromEvent(window, 'resize')
1906
+ .pipe(debounceTime(200), map$1(() => this.width), distinctUntilChanged(), startWith(this.width))
1907
+ .subscribe((size) => {
1908
+ if (size) {
1909
+ this.mobile.set(size < this.screenSizerParams.mobile);
1910
+ this.smallTablet.set(size >= this.screenSizerParams.mobile &&
1911
+ size < this.screenSizerParams.smallTablet);
1912
+ this.mediumTablet.set(size >= this.screenSizerParams.smallTablet &&
1913
+ size < this.screenSizerParams.mediumTablet);
1914
+ this.fullTablet.set(size >= this.screenSizerParams.mediumTablet &&
1915
+ size < this.screenSizerParams.fullTablet);
1916
+ this.smallDesktop.set(size >= this.screenSizerParams.fullTablet &&
1917
+ size < this.screenSizerParams.smallDesktop);
1918
+ this.mediumDesktop.set(size >= this.screenSizerParams.smallDesktop &&
1919
+ size < this.screenSizerParams.mediumDesktop);
1920
+ this.fullDesktop.set(size >= this.screenSizerParams.mediumDesktop &&
1921
+ size < this.screenSizerParams.fullDesktop);
1922
+ this.fullBigDesktop.set(size >= this.screenSizerParams.fullDesktop &&
1923
+ size < this.screenSizerParams.fullBigDesktop);
1924
+ this.maxDesktop.set(size >= this.screenSizerParams.fullBigDesktop);
1925
+ this.minSmallTablet.set(size >= this.screenSizerParams.smallTablet);
1926
+ this.minMediumTablet.set(size >= this.screenSizerParams.mediumTablet);
1927
+ this.minFullTablet.set(size >= this.screenSizerParams.fullTablet);
1928
+ this.minSmallDesktop.set(size >= this.screenSizerParams.smallDesktop);
1929
+ this.minMediumDesktop.set(size >= this.screenSizerParams.mediumDesktop);
1930
+ this.minFullDesktop.set(size >= this.screenSizerParams.fullDesktop);
1931
+ this.minFullBigDesktop.set(size >= this.screenSizerParams.fullBigDesktop);
1932
+ }
1933
+ });
1934
+ }
1928
1935
  }
1929
1936
  getBreakpoint(breakpoint) {
1930
1937
  return this.screenSizerParams[breakpoint];