ctt-babylon 0.1.234 → 0.1.235

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.
@@ -34,38 +34,43 @@ export class ScreenSizerService {
34
34
  this.platformId = inject(PLATFORM_ID);
35
35
  this.screenSizerParams = inject(SCREEN_SIZER_PARAMS_TOKEN)
36
36
  .pixelBreakpoints;
37
+ }
38
+ init() {
37
39
  if (isPlatformBrowser(this.platformId)) {
38
40
  fromEvent(window, 'resize')
39
41
  .pipe(debounceTime(200), map(() => this.width), distinctUntilChanged(), startWith(this.width))
40
42
  .subscribe((size) => {
41
43
  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);
44
+ this.updateSignals(size);
65
45
  }
66
46
  });
67
47
  }
68
48
  }
49
+ updateSignals(size) {
50
+ this.mobile.set(size < this.screenSizerParams.mobile);
51
+ this.smallTablet.set(size >= this.screenSizerParams.mobile &&
52
+ size < this.screenSizerParams.smallTablet);
53
+ this.mediumTablet.set(size >= this.screenSizerParams.smallTablet &&
54
+ size < this.screenSizerParams.mediumTablet);
55
+ this.fullTablet.set(size >= this.screenSizerParams.mediumTablet &&
56
+ size < this.screenSizerParams.fullTablet);
57
+ this.smallDesktop.set(size >= this.screenSizerParams.fullTablet &&
58
+ size < this.screenSizerParams.smallDesktop);
59
+ this.mediumDesktop.set(size >= this.screenSizerParams.smallDesktop &&
60
+ size < this.screenSizerParams.mediumDesktop);
61
+ this.fullDesktop.set(size >= this.screenSizerParams.mediumDesktop &&
62
+ size < this.screenSizerParams.fullDesktop);
63
+ this.fullBigDesktop.set(size >= this.screenSizerParams.fullDesktop &&
64
+ size < this.screenSizerParams.fullBigDesktop);
65
+ this.maxDesktop.set(size >= this.screenSizerParams.fullBigDesktop);
66
+ this.minSmallTablet.set(size >= this.screenSizerParams.smallTablet);
67
+ this.minMediumTablet.set(size >= this.screenSizerParams.mediumTablet);
68
+ this.minFullTablet.set(size >= this.screenSizerParams.fullTablet);
69
+ this.minSmallDesktop.set(size >= this.screenSizerParams.smallDesktop);
70
+ this.minMediumDesktop.set(size >= this.screenSizerParams.mediumDesktop);
71
+ this.minFullDesktop.set(size >= this.screenSizerParams.fullDesktop);
72
+ this.minFullBigDesktop.set(size >= this.screenSizerParams.fullBigDesktop);
73
+ }
69
74
  getBreakpoint(breakpoint) {
70
75
  return this.screenSizerParams[breakpoint];
71
76
  }
@@ -126,4 +131,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
126
131
  providedIn: 'root',
127
132
  }]
128
133
  }], ctorParameters: () => [] });
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"]}
134
+ //# 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\n    init(): void {\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.updateSignals(size);\n                    }\n                });\n        }\n    }\n\n    private updateSignals(size: number): void {\n        this.mobile.set(size < this.screenSizerParams.mobile);\n        this.smallTablet.set(\n            size >= this.screenSizerParams.mobile &&\n                size < this.screenSizerParams.smallTablet\n        );\n        this.mediumTablet.set(\n            size >= this.screenSizerParams.smallTablet &&\n                size < this.screenSizerParams.mediumTablet\n        );\n        this.fullTablet.set(\n            size >= this.screenSizerParams.mediumTablet &&\n                size < this.screenSizerParams.fullTablet\n        );\n        this.smallDesktop.set(\n            size >= this.screenSizerParams.fullTablet &&\n                size < this.screenSizerParams.smallDesktop\n        );\n        this.mediumDesktop.set(\n            size >= this.screenSizerParams.smallDesktop &&\n                size < this.screenSizerParams.mediumDesktop\n        );\n        this.fullDesktop.set(\n            size >= this.screenSizerParams.mediumDesktop &&\n                size < this.screenSizerParams.fullDesktop\n        );\n        this.fullBigDesktop.set(\n            size >= this.screenSizerParams.fullDesktop &&\n                size < this.screenSizerParams.fullBigDesktop\n        );\n        this.maxDesktop.set(size >= this.screenSizerParams.fullBigDesktop);\n\n        this.minSmallTablet.set(size >= this.screenSizerParams.smallTablet);\n        this.minMediumTablet.set(size >= this.screenSizerParams.mediumTablet);\n        this.minFullTablet.set(size >= this.screenSizerParams.fullTablet);\n        this.minSmallDesktop.set(size >= this.screenSizerParams.smallDesktop);\n        this.minMediumDesktop.set(size >= this.screenSizerParams.mediumDesktop);\n        this.minFullDesktop.set(size >= this.screenSizerParams.fullDesktop);\n        this.minFullBigDesktop.set(\n            size >= this.screenSizerParams.fullBigDesktop\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"]}
@@ -1901,38 +1901,43 @@ class ScreenSizerService {
1901
1901
  this.platformId = inject(PLATFORM_ID);
1902
1902
  this.screenSizerParams = inject(SCREEN_SIZER_PARAMS_TOKEN)
1903
1903
  .pixelBreakpoints;
1904
+ }
1905
+ init() {
1904
1906
  if (isPlatformBrowser(this.platformId)) {
1905
1907
  fromEvent(window, 'resize')
1906
1908
  .pipe(debounceTime(200), map$1(() => this.width), distinctUntilChanged(), startWith(this.width))
1907
1909
  .subscribe((size) => {
1908
1910
  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);
1911
+ this.updateSignals(size);
1932
1912
  }
1933
1913
  });
1934
1914
  }
1935
1915
  }
1916
+ updateSignals(size) {
1917
+ this.mobile.set(size < this.screenSizerParams.mobile);
1918
+ this.smallTablet.set(size >= this.screenSizerParams.mobile &&
1919
+ size < this.screenSizerParams.smallTablet);
1920
+ this.mediumTablet.set(size >= this.screenSizerParams.smallTablet &&
1921
+ size < this.screenSizerParams.mediumTablet);
1922
+ this.fullTablet.set(size >= this.screenSizerParams.mediumTablet &&
1923
+ size < this.screenSizerParams.fullTablet);
1924
+ this.smallDesktop.set(size >= this.screenSizerParams.fullTablet &&
1925
+ size < this.screenSizerParams.smallDesktop);
1926
+ this.mediumDesktop.set(size >= this.screenSizerParams.smallDesktop &&
1927
+ size < this.screenSizerParams.mediumDesktop);
1928
+ this.fullDesktop.set(size >= this.screenSizerParams.mediumDesktop &&
1929
+ size < this.screenSizerParams.fullDesktop);
1930
+ this.fullBigDesktop.set(size >= this.screenSizerParams.fullDesktop &&
1931
+ size < this.screenSizerParams.fullBigDesktop);
1932
+ this.maxDesktop.set(size >= this.screenSizerParams.fullBigDesktop);
1933
+ this.minSmallTablet.set(size >= this.screenSizerParams.smallTablet);
1934
+ this.minMediumTablet.set(size >= this.screenSizerParams.mediumTablet);
1935
+ this.minFullTablet.set(size >= this.screenSizerParams.fullTablet);
1936
+ this.minSmallDesktop.set(size >= this.screenSizerParams.smallDesktop);
1937
+ this.minMediumDesktop.set(size >= this.screenSizerParams.mediumDesktop);
1938
+ this.minFullDesktop.set(size >= this.screenSizerParams.fullDesktop);
1939
+ this.minFullBigDesktop.set(size >= this.screenSizerParams.fullBigDesktop);
1940
+ }
1936
1941
  getBreakpoint(breakpoint) {
1937
1942
  return this.screenSizerParams[breakpoint];
1938
1943
  }