angular-toolbox 0.0.6 → 0.0.8
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/esm2020/lib/service/index.mjs +2 -1
- package/esm2020/lib/service/ui/dark-mode.service.mjs +25 -11
- package/esm2020/lib/service/ui/scroll.service.mjs +79 -0
- package/fesm2015/angular-toolbox.mjs +103 -11
- package/fesm2015/angular-toolbox.mjs.map +1 -1
- package/fesm2020/angular-toolbox.mjs +101 -11
- package/fesm2020/angular-toolbox.mjs.map +1 -1
- package/lib/service/index.d.ts +1 -0
- package/lib/service/ui/dark-mode.service.d.ts +13 -3
- package/lib/service/ui/scroll.service.d.ts +52 -0
- package/package.json +1 -1
|
@@ -1,3 +1,4 @@
|
|
|
1
1
|
export * from './subscription/subscription.service';
|
|
2
2
|
export * from './ui/dark-mode.service';
|
|
3
|
-
|
|
3
|
+
export * from './ui/scroll.service';
|
|
4
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hbmd1bGFyLXRvb2xib3gvc3JjL2xpYi9zZXJ2aWNlL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMscUNBQXFDLENBQUM7QUFDcEQsY0FBYyx3QkFBd0IsQ0FBQztBQUN2QyxjQUFjLHFCQUFxQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9zdWJzY3JpcHRpb24vc3Vic2NyaXB0aW9uLnNlcnZpY2UnO1xyXG5leHBvcnQgKiBmcm9tICcuL3VpL2RhcmstbW9kZS5zZXJ2aWNlJztcclxuZXhwb3J0ICogZnJvbSAnLi91aS9zY3JvbGwuc2VydmljZSc7Il19
|
|
@@ -23,7 +23,7 @@ export const DARK_MODE_CONFIG = {
|
|
|
23
23
|
* Indicates whether the dark mode uses browser settings (true), or not (false).
|
|
24
24
|
* Default value is false.
|
|
25
25
|
*/
|
|
26
|
-
|
|
26
|
+
darkModeEnabled: false,
|
|
27
27
|
/**
|
|
28
28
|
* Indicates whether the dark mode uses browser settings (true), or not (false).
|
|
29
29
|
* Default value is false.
|
|
@@ -52,7 +52,7 @@ export class DarkModeService {
|
|
|
52
52
|
constructor(_document, config) {
|
|
53
53
|
this._document = _document;
|
|
54
54
|
// --> Private properties
|
|
55
|
-
this.
|
|
55
|
+
this._darkModeEnabled = false;
|
|
56
56
|
this._cssProperty = CSS_PROP;
|
|
57
57
|
this._storageKey = STORAGE_KEY;
|
|
58
58
|
/**
|
|
@@ -66,7 +66,7 @@ export class DarkModeService {
|
|
|
66
66
|
* Toogles the dark mode state.
|
|
67
67
|
*/
|
|
68
68
|
toggleDarkMode() {
|
|
69
|
-
this.
|
|
69
|
+
this._darkModeEnabled ? this.disableDarkMode() : this.enableDarkMode();
|
|
70
70
|
}
|
|
71
71
|
/**
|
|
72
72
|
* Sets the dark mode state to active.
|
|
@@ -87,7 +87,21 @@ export class DarkModeService {
|
|
|
87
87
|
* @returns true whether the dark mode state is active; false otherwise.
|
|
88
88
|
*/
|
|
89
89
|
darkModeEnabled() {
|
|
90
|
-
return this.
|
|
90
|
+
return this._darkModeEnabled;
|
|
91
|
+
}
|
|
92
|
+
/**
|
|
93
|
+
* Returns the value of the CSS property as defined by the config provider.
|
|
94
|
+
* @returns the value of the CSS property.
|
|
95
|
+
*/
|
|
96
|
+
getCssProperty() {
|
|
97
|
+
return this._cssProperty;
|
|
98
|
+
}
|
|
99
|
+
/**
|
|
100
|
+
* Returns the value of the storage key as defined by the config provider.
|
|
101
|
+
* @returns the value of the storage key.
|
|
102
|
+
*/
|
|
103
|
+
getStorageKey() {
|
|
104
|
+
return this._storageKey;
|
|
91
105
|
}
|
|
92
106
|
/**
|
|
93
107
|
* Removes the dark mode information from local storage.
|
|
@@ -97,10 +111,10 @@ export class DarkModeService {
|
|
|
97
111
|
}
|
|
98
112
|
// --> Private methods
|
|
99
113
|
initDarkMode(config) {
|
|
100
|
-
this.
|
|
114
|
+
this._darkModeEnabled = config.darkModeEnabled || false;
|
|
101
115
|
this._cssProperty = config.cssProperty || CSS_PROP;
|
|
102
116
|
this._storageKey = config.storageKey || STORAGE_KEY;
|
|
103
|
-
if (this.
|
|
117
|
+
if (this._darkModeEnabled) {
|
|
104
118
|
this.enableDarkMode();
|
|
105
119
|
}
|
|
106
120
|
else {
|
|
@@ -115,20 +129,20 @@ export class DarkModeService {
|
|
|
115
129
|
this.enableDarkMode();
|
|
116
130
|
}
|
|
117
131
|
setStoredDarkMode() {
|
|
118
|
-
const data = String(this.
|
|
132
|
+
const data = String(this._darkModeEnabled);
|
|
119
133
|
localStorage.setItem(this._storageKey, data);
|
|
120
134
|
}
|
|
121
135
|
setDarkMode(action) {
|
|
122
136
|
const classList = this._document.body.classList;
|
|
123
137
|
if (action === ADD_ACTION) {
|
|
124
138
|
classList.add(this._cssProperty);
|
|
125
|
-
this.
|
|
139
|
+
this._darkModeEnabled = true;
|
|
126
140
|
}
|
|
127
141
|
else if (action === REMOVE_ACTION) {
|
|
128
142
|
classList.remove(this._cssProperty);
|
|
129
|
-
this.
|
|
143
|
+
this._darkModeEnabled = false;
|
|
130
144
|
}
|
|
131
|
-
this.change.emit(this.
|
|
145
|
+
this.change.emit(this._darkModeEnabled);
|
|
132
146
|
}
|
|
133
147
|
initBrowserMode() {
|
|
134
148
|
if (window.matchMedia && window.matchMedia('(prefers-color-scheme: dark)').matches) {
|
|
@@ -150,4 +164,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImpor
|
|
|
150
164
|
type: Inject,
|
|
151
165
|
args: [DARK_MODE_CONFIG]
|
|
152
166
|
}] }]; } });
|
|
153
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dark-mode.service.js","sourceRoot":"","sources":["../../../../../../projects/angular-toolbox/src/lib/service/ui/dark-mode.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Inject, Injectable, EventEmitter } from '@angular/core';\nimport { DOCUMENT } from '@angular/common';\n\n// --> Internal constants\nconst STORAGE_KEY: string = \"dark-mode-key\";\nconst CSS_PROP: string = \"dark-mode\";\nconst ADD_ACTION: string = \"add\";\nconst REMOVE_ACTION: string = \"remove\";\n\n/**\n * Defines properties for the DarkModeService configuration.\n */\nexport interface DarkModeConfig {\n\n    /**\n     * Indicates whether the dark mode is activated by default (true), or not (false).\n     */\n    darkModeEnbled?: boolean;\n    \n    /**\n     * Indicates whether the dark mode uses browser settings (true), or not (false).\n     * When true, this property overrides the darkModeEnbled property.\n     */\n    detectBrowserSettings?: boolean;\n\n    /**\n     * CSS property name used to set the dark mode look and feel.\n     */\n    cssProperty?: string;\n\n    /**\n     * Reference to the key value used to persist the dark mode state to local storage.\n     */\n    storageKey?: string;\n}\n\n/**\n * The default provider for the DarkModeService configuration. You typically define\n * the custom properties in the main NgModule declaration to initialize the app dark mode:\n * \n * @NgModule({\n * ...\n * providers: [\n *   { provide: DARK_MODE_CONFIG, useValue: { enableDarkMode: true} }\n * ],\n * ...\n * s);\n */\nexport const DARK_MODE_CONFIG: DarkModeConfig = {\n    \n    /**\n     * Indicates whether the dark mode uses browser settings (true), or not (false).\n     * Default value is false.\n     */\n    darkModeEnbled: false,\n    \n    /**\n     * Indicates whether the dark mode uses browser settings (true), or not (false).\n     * Default value is false.\n     */\n    detectBrowserSettings: false,\n    \n    /**\n     * CSS property name used to set the dark mode look and feel.\n     * Default value is 'dark-mode'.\n     */\n    cssProperty: CSS_PROP,\n    \n    /**\n     * Reference to the key value used to persist the dark mode state to local storage.\n     * Default value is 'dark-mode-key'.\n     */\n    storageKey: STORAGE_KEY\n};\n\n@Injectable({\n    providedIn: 'root'\n})\n/**\n * A lightweight service that provides Dark Mode implementation for your Angular application.\n */\nexport class DarkModeService {\n\n    // --> Private properties\n    private _darkModeEnbled: boolean = false;\n    private _cssProperty: string = CSS_PROP;\n    private _storageKey: string = STORAGE_KEY;\n\n    /**\n     * The callback function that is triggered when the dark mode changes.\n     * @typeParam EventEmitter<boolean> the value returned by the darkModeEnabled() property.\n     */\n    public readonly change: EventEmitter<boolean> = new EventEmitter<boolean>(true);\n\n    /**\n     * Creates a new DarkModeService instance.\n     * @param _document the reference to the Document singleton.\n     * @param config the reference to the DarkModeConfig provider.\n     */\n    constructor(@Inject(DOCUMENT) private _document: Document, @Inject(DARK_MODE_CONFIG) config: DarkModeConfig) {\n        this.initDarkMode(config);\n    }\n\n    /**\n     * Toogles the dark mode state.\n     */\n    public toggleDarkMode(): void {\n        this._darkModeEnbled ? this.disableDarkMode() : this.enableDarkMode();\n    }\n\n    /**\n     * Sets the dark mode state to active.\n     */\n    public enableDarkMode(): void {\n        this.setDarkMode(ADD_ACTION);\n        this.setStoredDarkMode();\n    }\n\n    /**\n     * Sets the dark mode state to inactive.\n     */\n    public disableDarkMode(): void {\n        this.setDarkMode(REMOVE_ACTION);\n        this.setStoredDarkMode();\n    }\n\n    /**\n     * Returns a boolean value that indicates the dark mode state is active (true), or not (false).\n     * @returns true whether the dark mode state is active; false otherwise.\n     */\n    public darkModeEnabled(): boolean {\n        return this._darkModeEnbled;\n    }\n\n    /**\n     * Removes the dark mode information from local storage.\n     */\n    public invalidateStorage(): void {\n        localStorage.removeItem(this._storageKey);\n    }\n\n    // --> Private methods\n    private initDarkMode(config: DarkModeConfig): void {\n        this._darkModeEnbled = config.darkModeEnbled || false;\n        this._cssProperty = config.cssProperty || CSS_PROP;\n        this._storageKey = config.storageKey || STORAGE_KEY;\n        if (this._darkModeEnbled) {\n            this.enableDarkMode();\n        } else {\n            this.initStoredDarkMode();\n        }\n        if (config.detectBrowserSettings) this.initBrowserMode();\n    }\n    \n    private initStoredDarkMode(): void {\n        const result: string | null = localStorage.getItem(this._storageKey);\n        if (result === \"true\") this.enableDarkMode();\n    }\n\n    private setStoredDarkMode(): void {\n        const data: string = String(this._darkModeEnbled);\n        localStorage.setItem(this._storageKey, data);\n    }\n\n    private setDarkMode(action: string): void {\n        const classList: DOMTokenList = this._document.body.classList;\n        if (action === ADD_ACTION) {\n            classList.add(this._cssProperty);\n            this._darkModeEnbled = true;\n        } else if (action === REMOVE_ACTION) {\n            classList.remove(this._cssProperty);\n            this._darkModeEnbled = false;\n        }\n        this.change.emit(this._darkModeEnbled);\n    }\n\n    private initBrowserMode(): void {\n        if (window.matchMedia && window.matchMedia('(prefers-color-scheme: dark)').matches) {\n            this.enableDarkMode();\n        }\n    }\n}\n\n"]}
|
|
167
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dark-mode.service.js","sourceRoot":"","sources":["../../../../../../projects/angular-toolbox/src/lib/service/ui/dark-mode.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Inject, Injectable, EventEmitter } from '@angular/core';\nimport { DOCUMENT } from '@angular/common';\n\n// --> Internal constants\nconst STORAGE_KEY: string = \"dark-mode-key\";\nconst CSS_PROP: string = \"dark-mode\";\nconst ADD_ACTION: string = \"add\";\nconst REMOVE_ACTION: string = \"remove\";\n\n/**\n * Defines properties for the DarkModeService configuration.\n */\nexport interface DarkModeConfig {\n\n    /**\n     * Indicates whether the dark mode is activated by default (true), or not (false).\n     */\n    darkModeEnabled?: boolean;\n    \n    /**\n     * Indicates whether the dark mode uses browser settings (true), or not (false).\n     * When true, this property overrides the darkModeEnabled property.\n     */\n    detectBrowserSettings?: boolean;\n\n    /**\n     * CSS property name used to set the dark mode look and feel.\n     */\n    cssProperty?: string;\n\n    /**\n     * Reference to the key value used to persist the dark mode state to local storage.\n     */\n    storageKey?: string;\n}\n\n/**\n * The default provider for the DarkModeService configuration. You typically define\n * the custom properties in the main NgModule declaration to initialize the app dark mode:\n * \n * @NgModule({\n * ...\n * providers: [\n *   { provide: DARK_MODE_CONFIG, useValue: { enableDarkMode: true} }\n * ],\n * ...\n * s);\n */\nexport const DARK_MODE_CONFIG: DarkModeConfig = {\n    \n    /**\n     * Indicates whether the dark mode uses browser settings (true), or not (false).\n     * Default value is false.\n     */\n    darkModeEnabled: false,\n    \n    /**\n     * Indicates whether the dark mode uses browser settings (true), or not (false).\n     * Default value is false.\n     */\n    detectBrowserSettings: false,\n    \n    /**\n     * CSS property name used to set the dark mode look and feel.\n     * Default value is 'dark-mode'.\n     */\n    cssProperty: CSS_PROP,\n    \n    /**\n     * Reference to the key value used to persist the dark mode state to local storage.\n     * Default value is 'dark-mode-key'.\n     */\n    storageKey: STORAGE_KEY\n};\n\n@Injectable({\n    providedIn: 'root'\n})\n/**\n * A lightweight service that provides Dark Mode implementation for your Angular application.\n */\nexport class DarkModeService {\n\n    // --> Private properties\n    private _darkModeEnabled: boolean = false;\n    private _cssProperty: string = CSS_PROP;\n    private _storageKey: string = STORAGE_KEY;\n\n    /**\n     * The callback function that is triggered when the dark mode changes.\n     * @typeParam EventEmitter<boolean> the value returned by the darkModeEnabled() property.\n     */\n    public readonly change: EventEmitter<boolean> = new EventEmitter<boolean>(true);\n\n    /**\n     * Creates a new DarkModeService instance.\n     * @param _document the reference to the Document singleton.\n     * @param config the reference to the DarkModeConfig provider.\n     */\n    constructor(@Inject(DOCUMENT) private _document: Document, @Inject(DARK_MODE_CONFIG) config: DarkModeConfig) {\n        this.initDarkMode(config);\n    }\n\n    /**\n     * Toogles the dark mode state.\n     */\n    public toggleDarkMode(): void {\n        this._darkModeEnabled ? this.disableDarkMode() : this.enableDarkMode();\n    }\n\n    /**\n     * Sets the dark mode state to active.\n     */\n    public enableDarkMode(): void {\n        this.setDarkMode(ADD_ACTION);\n        this.setStoredDarkMode();\n    }\n\n    /**\n     * Sets the dark mode state to inactive.\n     */\n    public disableDarkMode(): void {\n        this.setDarkMode(REMOVE_ACTION);\n        this.setStoredDarkMode();\n    }\n\n    /**\n     * Returns a boolean value that indicates the dark mode state is active (true), or not (false).\n     * @returns true whether the dark mode state is active; false otherwise.\n     */\n    public darkModeEnabled(): boolean {\n        return this._darkModeEnabled;\n    }\n\n    /**\n     * Returns the value of the CSS property as defined by the config provider.\n     * @returns the value of the CSS property.\n     */\n    public getCssProperty(): string {\n        return this._cssProperty;\n    }\n\n    /**\n     * Returns the value of the storage key as defined by the config provider.\n     * @returns the value of the storage key.\n     */\n    public getStorageKey(): string {\n        return this._storageKey;\n    }\n    \n    /**\n     * Removes the dark mode information from local storage.\n     */\n    public invalidateStorage(): void {\n        localStorage.removeItem(this._storageKey);\n    }\n\n    // --> Private methods\n    private initDarkMode(config: DarkModeConfig): void {\n        this._darkModeEnabled = config.darkModeEnabled || false;\n        this._cssProperty = config.cssProperty || CSS_PROP;\n        this._storageKey = config.storageKey || STORAGE_KEY;\n        if (this._darkModeEnabled) {\n            this.enableDarkMode();\n        } else {\n            this.initStoredDarkMode();\n        }\n        if (config.detectBrowserSettings) this.initBrowserMode();\n    }\n    \n    private initStoredDarkMode(): void {\n        const result: string | null = localStorage.getItem(this._storageKey);\n        if (result === \"true\") this.enableDarkMode();\n    }\n\n    private setStoredDarkMode(): void {\n        const data: string = String(this._darkModeEnabled);\n        localStorage.setItem(this._storageKey, data);\n    }\n\n    private setDarkMode(action: string): void {\n        const classList: DOMTokenList = this._document.body.classList;\n        if (action === ADD_ACTION) {\n            classList.add(this._cssProperty);\n            this._darkModeEnabled = true;\n        } else if (action === REMOVE_ACTION) {\n            classList.remove(this._cssProperty);\n            this._darkModeEnabled = false;\n        }\n        this.change.emit(this._darkModeEnabled);\n    }\n\n    private initBrowserMode(): void {\n        if (window.matchMedia && window.matchMedia('(prefers-color-scheme: dark)').matches) {\n            this.enableDarkMode();\n        }\n    }\n}\n\n"]}
|
|
@@ -0,0 +1,79 @@
|
|
|
1
|
+
import { DOCUMENT } from '@angular/common';
|
|
2
|
+
import { EventEmitter, Inject, Injectable } from '@angular/core';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
/**
|
|
5
|
+
* A lightweight service that provides scrolling capabilities to your Angular application.
|
|
6
|
+
*/
|
|
7
|
+
export class ScrollService {
|
|
8
|
+
/**
|
|
9
|
+
* Creates a new ScrollService instance.
|
|
10
|
+
* @param _document the reference to the Document singleton.
|
|
11
|
+
*/
|
|
12
|
+
constructor(_document) {
|
|
13
|
+
this._document = _document;
|
|
14
|
+
/**
|
|
15
|
+
* The callback function that is triggered when a scroll operation is performed.
|
|
16
|
+
* @typeParam EventEmitter<Event> the reference to the original scroll event.
|
|
17
|
+
*/
|
|
18
|
+
this.onScroll = new EventEmitter();
|
|
19
|
+
window.addEventListener("scroll", (e) => {
|
|
20
|
+
this.onScroll.next(e);
|
|
21
|
+
});
|
|
22
|
+
}
|
|
23
|
+
/**
|
|
24
|
+
* Scrolls the ancestor containers of the element with the specified selector such that
|
|
25
|
+
* this element is visible to the user.
|
|
26
|
+
* @param selector the selector of the target element.
|
|
27
|
+
* @param arg a boolean value:
|
|
28
|
+
* If true, the top of the element will be aligned to the top of the visible area of the
|
|
29
|
+
* scrollable ancestor.
|
|
30
|
+
* If false, the bottom of the element will be aligned to the bottom of the visible area
|
|
31
|
+
* of the scrollable ancestor.
|
|
32
|
+
* @param arg a dictionary containing the scroll parameters.
|
|
33
|
+
*/
|
|
34
|
+
scrollIntoView(selector, arg) {
|
|
35
|
+
const elm = this._document.querySelector(selector);
|
|
36
|
+
if (elm)
|
|
37
|
+
elm.scrollIntoView(arg);
|
|
38
|
+
}
|
|
39
|
+
/**
|
|
40
|
+
* Scrolls the app viewport to the top of the browser window.
|
|
41
|
+
* @param behavior Specifies whether the scrolling should animate smoothly (smooth),
|
|
42
|
+
* happen instantly in a single jump (instant), or let the browser
|
|
43
|
+
* choose (auto, default).
|
|
44
|
+
*/
|
|
45
|
+
gotoTop(behavior = 'smooth') {
|
|
46
|
+
const options = {
|
|
47
|
+
top: 0,
|
|
48
|
+
behavior: behavior
|
|
49
|
+
};
|
|
50
|
+
this.scroll(options);
|
|
51
|
+
}
|
|
52
|
+
/**
|
|
53
|
+
* Scrolls the app viewport according to the specified options, into the browser window.
|
|
54
|
+
* @param options A dictionary containing the scroll parameters.
|
|
55
|
+
*/
|
|
56
|
+
scroll(options) {
|
|
57
|
+
window.scroll(options);
|
|
58
|
+
}
|
|
59
|
+
/**
|
|
60
|
+
* Scrolls the app viewport to the specified x/y coordinates, into the browser window.
|
|
61
|
+
* @param x the horizontal pixel value that you want to scroll by.
|
|
62
|
+
* @param y the vertical pixel value that you want to scroll by.
|
|
63
|
+
*/
|
|
64
|
+
scrollTo(x, y) {
|
|
65
|
+
window.scrollBy(x, y);
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
ScrollService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: ScrollService, deps: [{ token: DOCUMENT }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
69
|
+
ScrollService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: ScrollService, providedIn: 'root' });
|
|
70
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: ScrollService, decorators: [{
|
|
71
|
+
type: Injectable,
|
|
72
|
+
args: [{
|
|
73
|
+
providedIn: 'root'
|
|
74
|
+
}]
|
|
75
|
+
}], ctorParameters: function () { return [{ type: Document, decorators: [{
|
|
76
|
+
type: Inject,
|
|
77
|
+
args: [DOCUMENT]
|
|
78
|
+
}] }]; } });
|
|
79
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2Nyb2xsLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hbmd1bGFyLXRvb2xib3gvc3JjL2xpYi9zZXJ2aWNlL3VpL3Njcm9sbC5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMzQyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBVWpFOztHQUVHO0FBQ0gsTUFBTSxPQUFPLGFBQWE7SUFRdEI7OztPQUdHO0lBQ0wsWUFBc0MsU0FBbUI7UUFBbkIsY0FBUyxHQUFULFNBQVMsQ0FBVTtRQVZ2RDs7O1dBR0c7UUFDVyxhQUFRLEdBQXdCLElBQUksWUFBWSxFQUFTLENBQUM7UUFPeEUsTUFBTSxDQUFDLGdCQUFnQixDQUFDLFFBQVEsRUFBRSxDQUFDLENBQVEsRUFBRSxFQUFFO1lBQzdDLElBQUksQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDO1FBQ3hCLENBQUMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztJQUVEOzs7Ozs7Ozs7O09BVUc7SUFDSSxjQUFjLENBQUMsUUFBZ0IsRUFBRSxHQUFpRDtRQUN2RixNQUFNLEdBQUcsR0FBbUIsSUFBSSxDQUFDLFNBQVMsQ0FBQyxhQUFhLENBQUMsUUFBUSxDQUFDLENBQUM7UUFDbkUsSUFBSSxHQUFHO1lBQUUsR0FBRyxDQUFDLGNBQWMsQ0FBQyxHQUFHLENBQUMsQ0FBQztJQUNuQyxDQUFDO0lBRUQ7Ozs7O09BS0c7SUFDSSxPQUFPLENBQUMsV0FBMkIsUUFBUTtRQUNoRCxNQUFNLE9BQU8sR0FBb0I7WUFDL0IsR0FBRyxFQUFFLENBQUM7WUFDTixRQUFRLEVBQUUsUUFBZTtTQUMxQixDQUFDO1FBQ0YsSUFBSSxDQUFDLE1BQU0sQ0FBQyxPQUFPLENBQUMsQ0FBQztJQUN2QixDQUFDO0lBRUQ7OztPQUdHO0lBQ0ksTUFBTSxDQUFDLE9BQXlCO1FBQ3JDLE1BQU0sQ0FBQyxNQUFNLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDekIsQ0FBQztJQUVEOzs7O09BSUc7SUFDSSxRQUFRLENBQUMsQ0FBUyxFQUFFLENBQVM7UUFDbEMsTUFBTSxDQUFDLFFBQVEsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUM7SUFDeEIsQ0FBQzs7MEdBL0RVLGFBQWEsa0JBWUosUUFBUTs4R0FaakIsYUFBYSxjQUxaLE1BQU07MkZBS1AsYUFBYTtrQkFOekIsVUFBVTttQkFBQztvQkFDVixVQUFVLEVBQUUsTUFBTTtpQkFDbkI7OzBCQWdCYyxNQUFNOzJCQUFDLFFBQVEiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBET0NVTUVOVCB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBFdmVudEVtaXR0ZXIsIEluamVjdCwgSW5qZWN0YWJsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG4vKipcbiAqIFdvcmthcm91bmQgZm9yIHRoZSB0eXBlc2NyaXB0IFNjcm9sbEJlaGF2aW9yIGRlY2xhcmF0aW9uLlxuICovXG5kZWNsYXJlIHR5cGUgU2Nyb2xsQmVoYXZpb3IgPSBcImF1dG9cIiB8IFwiaW5zdGFudFwiIHwgXCJzbW9vdGhcIjtcblxuQEluamVjdGFibGUoe1xuICBwcm92aWRlZEluOiAncm9vdCdcbn0pXG4vKipcbiAqIEEgbGlnaHR3ZWlnaHQgc2VydmljZSB0aGF0IHByb3ZpZGVzIHNjcm9sbGluZyBjYXBhYmlsaXRpZXMgdG8geW91ciBBbmd1bGFyIGFwcGxpY2F0aW9uLlxuICovXG5leHBvcnQgY2xhc3MgU2Nyb2xsU2VydmljZSB7XG5cbiAgICAvKipcbiAgICAgKiBUaGUgY2FsbGJhY2sgZnVuY3Rpb24gdGhhdCBpcyB0cmlnZ2VyZWQgd2hlbiBhIHNjcm9sbCBvcGVyYXRpb24gaXMgcGVyZm9ybWVkLlxuICAgICAqIEB0eXBlUGFyYW0gRXZlbnRFbWl0dGVyPEV2ZW50PiB0aGUgcmVmZXJlbmNlIHRvIHRoZSBvcmlnaW5hbCBzY3JvbGwgZXZlbnQuXG4gICAgICovXG4gIHB1YmxpYyByZWFkb25seSBvblNjcm9sbDogRXZlbnRFbWl0dGVyPEV2ZW50PiA9IG5ldyBFdmVudEVtaXR0ZXI8RXZlbnQ+KCk7XG5cbiAgICAvKipcbiAgICAgKiBDcmVhdGVzIGEgbmV3IFNjcm9sbFNlcnZpY2UgaW5zdGFuY2UuXG4gICAgICogQHBhcmFtIF9kb2N1bWVudCB0aGUgcmVmZXJlbmNlIHRvIHRoZSBEb2N1bWVudCBzaW5nbGV0b24uXG4gICAgICovXG4gIGNvbnN0cnVjdG9yKEBJbmplY3QoRE9DVU1FTlQpIHByaXZhdGUgX2RvY3VtZW50OiBEb2N1bWVudCkge1xuICAgIHdpbmRvdy5hZGRFdmVudExpc3RlbmVyKFwic2Nyb2xsXCIsIChlOiBFdmVudCkgPT4ge1xuICAgICAgdGhpcy5vblNjcm9sbC5uZXh0KGUpO1xuICAgIH0pO1xuICB9XG5cbiAgLyoqXG4gICAqIFNjcm9sbHMgdGhlIGFuY2VzdG9yIGNvbnRhaW5lcnMgb2YgdGhlIGVsZW1lbnQgd2l0aCB0aGUgc3BlY2lmaWVkIHNlbGVjdG9yIHN1Y2ggdGhhdCBcbiAgICogdGhpcyBlbGVtZW50ICBpcyB2aXNpYmxlIHRvIHRoZSB1c2VyLlxuICAgKiBAcGFyYW0gc2VsZWN0b3IgdGhlIHNlbGVjdG9yIG9mIHRoZSB0YXJnZXQgZWxlbWVudC5cbiAgICogQHBhcmFtIGFyZyBhIGJvb2xlYW4gdmFsdWU6XG4gICAqIElmIHRydWUsIHRoZSB0b3Agb2YgdGhlIGVsZW1lbnQgd2lsbCBiZSBhbGlnbmVkIHRvIHRoZSB0b3Agb2YgdGhlIHZpc2libGUgYXJlYSBvZiB0aGVcbiAgICogc2Nyb2xsYWJsZSBhbmNlc3Rvci5cbiAgICogSWYgZmFsc2UsIHRoZSBib3R0b20gb2YgdGhlIGVsZW1lbnQgd2lsbCBiZSBhbGlnbmVkIHRvIHRoZSBib3R0b20gb2YgdGhlIHZpc2libGUgYXJlYVxuICAgKiBvZiB0aGUgc2Nyb2xsYWJsZSBhbmNlc3Rvci4gXG4gICAqIEBwYXJhbSBhcmcgYSBkaWN0aW9uYXJ5IGNvbnRhaW5pbmcgdGhlIHNjcm9sbCBwYXJhbWV0ZXJzLlxuICAgKi9cbiAgcHVibGljIHNjcm9sbEludG9WaWV3KHNlbGVjdG9yOiBzdHJpbmcsIGFyZz86IGJvb2xlYW4gfCBTY3JvbGxJbnRvVmlld09wdGlvbnMgfCB1bmRlZmluZWQpOiB2b2lkIHtcbiAgICBjb25zdCBlbG06IEVsZW1lbnQgfCBudWxsID0gdGhpcy5fZG9jdW1lbnQucXVlcnlTZWxlY3RvcihzZWxlY3Rvcik7XG4gICAgaWYgKGVsbSkgZWxtLnNjcm9sbEludG9WaWV3KGFyZyk7XG4gIH1cblxuICAvKipcbiAgICogU2Nyb2xscyB0aGUgYXBwIHZpZXdwb3J0IHRvIHRoZSB0b3Agb2YgdGhlIGJyb3dzZXIgd2luZG93LlxuICAgKiBAcGFyYW0gYmVoYXZpb3IgU3BlY2lmaWVzIHdoZXRoZXIgdGhlIHNjcm9sbGluZyBzaG91bGQgYW5pbWF0ZSBzbW9vdGhseSAoc21vb3RoKSxcbiAgICogICAgICAgICAgICAgICAgIGhhcHBlbiBpbnN0YW50bHkgaW4gYSBzaW5nbGUganVtcCAoaW5zdGFudCksIG9yIGxldCB0aGUgYnJvd3NlclxuICAgKiAgICAgICAgICAgICAgICAgY2hvb3NlIChhdXRvLCBkZWZhdWx0KS5cbiAgICovXG4gIHB1YmxpYyBnb3RvVG9wKGJlaGF2aW9yOiBTY3JvbGxCZWhhdmlvciA9ICdzbW9vdGgnKTogdm9pZCB7XG4gICAgY29uc3Qgb3B0aW9uczogU2Nyb2xsVG9PcHRpb25zID0ge1xuICAgICAgdG9wOiAwLFxuICAgICAgYmVoYXZpb3I6IGJlaGF2aW9yIGFzIGFueVxuICAgIH07XG4gICAgdGhpcy5zY3JvbGwob3B0aW9ucyk7XG4gIH1cblxuICAvKipcbiAgICogU2Nyb2xscyB0aGUgYXBwIHZpZXdwb3J0IGFjY29yZGluZyB0byB0aGUgc3BlY2lmaWVkIG9wdGlvbnMsIGludG8gdGhlIGJyb3dzZXIgd2luZG93LlxuICAgKiBAcGFyYW0gb3B0aW9ucyBBIGRpY3Rpb25hcnkgY29udGFpbmluZyB0aGUgc2Nyb2xsIHBhcmFtZXRlcnMuXG4gICAqL1xuICBwdWJsaWMgc2Nyb2xsKG9wdGlvbnM/OiBTY3JvbGxUb09wdGlvbnMpOiB2b2lkIHtcbiAgICB3aW5kb3cuc2Nyb2xsKG9wdGlvbnMpO1xuICB9XG4gIFxuICAvKipcbiAgICogU2Nyb2xscyB0aGUgYXBwIHZpZXdwb3J0IHRvIHRoZSBzcGVjaWZpZWQgeC95IGNvb3JkaW5hdGVzLCBpbnRvIHRoZSBicm93c2VyIHdpbmRvdy5cbiAgICogQHBhcmFtIHggdGhlIGhvcml6b250YWwgcGl4ZWwgdmFsdWUgdGhhdCB5b3Ugd2FudCB0byBzY3JvbGwgYnkuXG4gICAqIEBwYXJhbSB5IHRoZSB2ZXJ0aWNhbCAgcGl4ZWwgdmFsdWUgdGhhdCB5b3Ugd2FudCB0byBzY3JvbGwgYnkuXG4gICAqL1xuICBwdWJsaWMgc2Nyb2xsVG8oeDogbnVtYmVyLCB5OiBudW1iZXIpOiB2b2lkIHtcbiAgICB3aW5kb3cuc2Nyb2xsQnkoeCwgeSk7XG4gIH1cbn1cbiJdfQ==
|
|
@@ -40,7 +40,7 @@ const DARK_MODE_CONFIG = {
|
|
|
40
40
|
* Indicates whether the dark mode uses browser settings (true), or not (false).
|
|
41
41
|
* Default value is false.
|
|
42
42
|
*/
|
|
43
|
-
|
|
43
|
+
darkModeEnabled: false,
|
|
44
44
|
/**
|
|
45
45
|
* Indicates whether the dark mode uses browser settings (true), or not (false).
|
|
46
46
|
* Default value is false.
|
|
@@ -69,7 +69,7 @@ class DarkModeService {
|
|
|
69
69
|
constructor(_document, config) {
|
|
70
70
|
this._document = _document;
|
|
71
71
|
// --> Private properties
|
|
72
|
-
this.
|
|
72
|
+
this._darkModeEnabled = false;
|
|
73
73
|
this._cssProperty = CSS_PROP;
|
|
74
74
|
this._storageKey = STORAGE_KEY;
|
|
75
75
|
/**
|
|
@@ -83,7 +83,7 @@ class DarkModeService {
|
|
|
83
83
|
* Toogles the dark mode state.
|
|
84
84
|
*/
|
|
85
85
|
toggleDarkMode() {
|
|
86
|
-
this.
|
|
86
|
+
this._darkModeEnabled ? this.disableDarkMode() : this.enableDarkMode();
|
|
87
87
|
}
|
|
88
88
|
/**
|
|
89
89
|
* Sets the dark mode state to active.
|
|
@@ -104,7 +104,21 @@ class DarkModeService {
|
|
|
104
104
|
* @returns true whether the dark mode state is active; false otherwise.
|
|
105
105
|
*/
|
|
106
106
|
darkModeEnabled() {
|
|
107
|
-
return this.
|
|
107
|
+
return this._darkModeEnabled;
|
|
108
|
+
}
|
|
109
|
+
/**
|
|
110
|
+
* Returns the value of the CSS property as defined by the config provider.
|
|
111
|
+
* @returns the value of the CSS property.
|
|
112
|
+
*/
|
|
113
|
+
getCssProperty() {
|
|
114
|
+
return this._cssProperty;
|
|
115
|
+
}
|
|
116
|
+
/**
|
|
117
|
+
* Returns the value of the storage key as defined by the config provider.
|
|
118
|
+
* @returns the value of the storage key.
|
|
119
|
+
*/
|
|
120
|
+
getStorageKey() {
|
|
121
|
+
return this._storageKey;
|
|
108
122
|
}
|
|
109
123
|
/**
|
|
110
124
|
* Removes the dark mode information from local storage.
|
|
@@ -114,10 +128,10 @@ class DarkModeService {
|
|
|
114
128
|
}
|
|
115
129
|
// --> Private methods
|
|
116
130
|
initDarkMode(config) {
|
|
117
|
-
this.
|
|
131
|
+
this._darkModeEnabled = config.darkModeEnabled || false;
|
|
118
132
|
this._cssProperty = config.cssProperty || CSS_PROP;
|
|
119
133
|
this._storageKey = config.storageKey || STORAGE_KEY;
|
|
120
|
-
if (this.
|
|
134
|
+
if (this._darkModeEnabled) {
|
|
121
135
|
this.enableDarkMode();
|
|
122
136
|
}
|
|
123
137
|
else {
|
|
@@ -132,20 +146,20 @@ class DarkModeService {
|
|
|
132
146
|
this.enableDarkMode();
|
|
133
147
|
}
|
|
134
148
|
setStoredDarkMode() {
|
|
135
|
-
const data = String(this.
|
|
149
|
+
const data = String(this._darkModeEnabled);
|
|
136
150
|
localStorage.setItem(this._storageKey, data);
|
|
137
151
|
}
|
|
138
152
|
setDarkMode(action) {
|
|
139
153
|
const classList = this._document.body.classList;
|
|
140
154
|
if (action === ADD_ACTION) {
|
|
141
155
|
classList.add(this._cssProperty);
|
|
142
|
-
this.
|
|
156
|
+
this._darkModeEnabled = true;
|
|
143
157
|
}
|
|
144
158
|
else if (action === REMOVE_ACTION) {
|
|
145
159
|
classList.remove(this._cssProperty);
|
|
146
|
-
this.
|
|
160
|
+
this._darkModeEnabled = false;
|
|
147
161
|
}
|
|
148
|
-
this.change.emit(this.
|
|
162
|
+
this.change.emit(this._darkModeEnabled);
|
|
149
163
|
}
|
|
150
164
|
initBrowserMode() {
|
|
151
165
|
if (window.matchMedia && window.matchMedia('(prefers-color-scheme: dark)').matches) {
|
|
@@ -252,6 +266,84 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImpor
|
|
|
252
266
|
}]
|
|
253
267
|
}] });
|
|
254
268
|
|
|
269
|
+
/**
|
|
270
|
+
* A lightweight service that provides scrolling capabilities to your Angular application.
|
|
271
|
+
*/
|
|
272
|
+
class ScrollService {
|
|
273
|
+
/**
|
|
274
|
+
* Creates a new ScrollService instance.
|
|
275
|
+
* @param _document the reference to the Document singleton.
|
|
276
|
+
*/
|
|
277
|
+
constructor(_document) {
|
|
278
|
+
this._document = _document;
|
|
279
|
+
/**
|
|
280
|
+
* The callback function that is triggered when a scroll operation is performed.
|
|
281
|
+
* @typeParam EventEmitter<Event> the reference to the original scroll event.
|
|
282
|
+
*/
|
|
283
|
+
this.onScroll = new EventEmitter();
|
|
284
|
+
window.addEventListener("scroll", (e) => {
|
|
285
|
+
this.onScroll.next(e);
|
|
286
|
+
});
|
|
287
|
+
}
|
|
288
|
+
/**
|
|
289
|
+
* Scrolls the ancestor containers of the element with the specified selector such that
|
|
290
|
+
* this element is visible to the user.
|
|
291
|
+
* @param selector the selector of the target element.
|
|
292
|
+
* @param arg a boolean value:
|
|
293
|
+
* If true, the top of the element will be aligned to the top of the visible area of the
|
|
294
|
+
* scrollable ancestor.
|
|
295
|
+
* If false, the bottom of the element will be aligned to the bottom of the visible area
|
|
296
|
+
* of the scrollable ancestor.
|
|
297
|
+
* @param arg a dictionary containing the scroll parameters.
|
|
298
|
+
*/
|
|
299
|
+
scrollIntoView(selector, arg) {
|
|
300
|
+
const elm = this._document.querySelector(selector);
|
|
301
|
+
if (elm)
|
|
302
|
+
elm.scrollIntoView(arg);
|
|
303
|
+
}
|
|
304
|
+
/**
|
|
305
|
+
* Scrolls the app viewport to the top of the browser window.
|
|
306
|
+
* @param behavior Specifies whether the scrolling should animate smoothly (smooth),
|
|
307
|
+
* happen instantly in a single jump (instant), or let the browser
|
|
308
|
+
* choose (auto, default).
|
|
309
|
+
*/
|
|
310
|
+
gotoTop(behavior = 'smooth') {
|
|
311
|
+
const options = {
|
|
312
|
+
top: 0,
|
|
313
|
+
behavior: behavior
|
|
314
|
+
};
|
|
315
|
+
this.scroll(options);
|
|
316
|
+
}
|
|
317
|
+
/**
|
|
318
|
+
* Scrolls the app viewport according to the specified options, into the browser window.
|
|
319
|
+
* @param options A dictionary containing the scroll parameters.
|
|
320
|
+
*/
|
|
321
|
+
scroll(options) {
|
|
322
|
+
window.scroll(options);
|
|
323
|
+
}
|
|
324
|
+
/**
|
|
325
|
+
* Scrolls the app viewport to the specified x/y coordinates, into the browser window.
|
|
326
|
+
* @param x the horizontal pixel value that you want to scroll by.
|
|
327
|
+
* @param y the vertical pixel value that you want to scroll by.
|
|
328
|
+
*/
|
|
329
|
+
scrollTo(x, y) {
|
|
330
|
+
window.scrollBy(x, y);
|
|
331
|
+
}
|
|
332
|
+
}
|
|
333
|
+
ScrollService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: ScrollService, deps: [{ token: DOCUMENT }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
334
|
+
ScrollService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: ScrollService, providedIn: 'root' });
|
|
335
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: ScrollService, decorators: [{
|
|
336
|
+
type: Injectable,
|
|
337
|
+
args: [{
|
|
338
|
+
providedIn: 'root'
|
|
339
|
+
}]
|
|
340
|
+
}], ctorParameters: function () {
|
|
341
|
+
return [{ type: Document, decorators: [{
|
|
342
|
+
type: Inject,
|
|
343
|
+
args: [DOCUMENT]
|
|
344
|
+
}] }];
|
|
345
|
+
} });
|
|
346
|
+
|
|
255
347
|
/*
|
|
256
348
|
* Public API Surface of angular-toolbox
|
|
257
349
|
*/
|
|
@@ -260,5 +352,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImpor
|
|
|
260
352
|
* Generated bundle index. Do not edit.
|
|
261
353
|
*/
|
|
262
354
|
|
|
263
|
-
export { AngularToolboxModule, DARK_MODE_CONFIG, DarkModeService, SafeHtmlPipe, SubscriptionService };
|
|
355
|
+
export { AngularToolboxModule, DARK_MODE_CONFIG, DarkModeService, SafeHtmlPipe, ScrollService, SubscriptionService };
|
|
264
356
|
//# sourceMappingURL=angular-toolbox.mjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"angular-toolbox.mjs","sources":["../../../projects/angular-toolbox/src/lib/pipe/safe/safe-html.pipe.ts","../../../projects/angular-toolbox/src/lib/service/ui/dark-mode.service.ts","../../../projects/angular-toolbox/src/lib/angular-toolbox.module.ts","../../../projects/angular-toolbox/src/lib/service/subscription/subscription.service.ts","../../../projects/angular-toolbox/src/public-api.ts","../../../projects/angular-toolbox/src/angular-toolbox.ts"],"sourcesContent":["import { DomSanitizer, SafeHtml } from '@angular/platform-browser'\r\nimport { PipeTransform, Pipe } from \"@angular/core\";\r\n\r\n@Pipe({ name: 'safeHtml'})\r\nexport class SafeHtmlPipe implements PipeTransform {\r\n\r\n constructor(private _sanitizer: DomSanitizer) {}\r\n\r\n public transform(value: string): SafeHtml {\r\n return this._sanitizer.bypassSecurityTrustHtml(value);\r\n }\r\n}","import { Inject, Injectable, EventEmitter } from '@angular/core';\nimport { DOCUMENT } from '@angular/common';\n\n// --> Internal constants\nconst STORAGE_KEY: string = \"dark-mode-key\";\nconst CSS_PROP: string = \"dark-mode\";\nconst ADD_ACTION: string = \"add\";\nconst REMOVE_ACTION: string = \"remove\";\n\n/**\n * Defines properties for the DarkModeService configuration.\n */\nexport interface DarkModeConfig {\n\n /**\n * Indicates whether the dark mode is activated by default (true), or not (false).\n */\n darkModeEnbled?: boolean;\n \n /**\n * Indicates whether the dark mode uses browser settings (true), or not (false).\n * When true, this property overrides the darkModeEnbled property.\n */\n detectBrowserSettings?: boolean;\n\n /**\n * CSS property name used to set the dark mode look and feel.\n */\n cssProperty?: string;\n\n /**\n * Reference to the key value used to persist the dark mode state to local storage.\n */\n storageKey?: string;\n}\n\n/**\n * The default provider for the DarkModeService configuration. You typically define\n * the custom properties in the main NgModule declaration to initialize the app dark mode:\n * \n * @NgModule({\n * ...\n * providers: [\n * { provide: DARK_MODE_CONFIG, useValue: { enableDarkMode: true} }\n * ],\n * ...\n * s);\n */\nexport const DARK_MODE_CONFIG: DarkModeConfig = {\n \n /**\n * Indicates whether the dark mode uses browser settings (true), or not (false).\n * Default value is false.\n */\n darkModeEnbled: false,\n \n /**\n * Indicates whether the dark mode uses browser settings (true), or not (false).\n * Default value is false.\n */\n detectBrowserSettings: false,\n \n /**\n * CSS property name used to set the dark mode look and feel.\n * Default value is 'dark-mode'.\n */\n cssProperty: CSS_PROP,\n \n /**\n * Reference to the key value used to persist the dark mode state to local storage.\n * Default value is 'dark-mode-key'.\n */\n storageKey: STORAGE_KEY\n};\n\n@Injectable({\n providedIn: 'root'\n})\n/**\n * A lightweight service that provides Dark Mode implementation for your Angular application.\n */\nexport class DarkModeService {\n\n // --> Private properties\n private _darkModeEnbled: boolean = false;\n private _cssProperty: string = CSS_PROP;\n private _storageKey: string = STORAGE_KEY;\n\n /**\n * The callback function that is triggered when the dark mode changes.\n * @typeParam EventEmitter<boolean> the value returned by the darkModeEnabled() property.\n */\n public readonly change: EventEmitter<boolean> = new EventEmitter<boolean>(true);\n\n /**\n * Creates a new DarkModeService instance.\n * @param _document the reference to the Document singleton.\n * @param config the reference to the DarkModeConfig provider.\n */\n constructor(@Inject(DOCUMENT) private _document: Document, @Inject(DARK_MODE_CONFIG) config: DarkModeConfig) {\n this.initDarkMode(config);\n }\n\n /**\n * Toogles the dark mode state.\n */\n public toggleDarkMode(): void {\n this._darkModeEnbled ? this.disableDarkMode() : this.enableDarkMode();\n }\n\n /**\n * Sets the dark mode state to active.\n */\n public enableDarkMode(): void {\n this.setDarkMode(ADD_ACTION);\n this.setStoredDarkMode();\n }\n\n /**\n * Sets the dark mode state to inactive.\n */\n public disableDarkMode(): void {\n this.setDarkMode(REMOVE_ACTION);\n this.setStoredDarkMode();\n }\n\n /**\n * Returns a boolean value that indicates the dark mode state is active (true), or not (false).\n * @returns true whether the dark mode state is active; false otherwise.\n */\n public darkModeEnabled(): boolean {\n return this._darkModeEnbled;\n }\n\n /**\n * Removes the dark mode information from local storage.\n */\n public invalidateStorage(): void {\n localStorage.removeItem(this._storageKey);\n }\n\n // --> Private methods\n private initDarkMode(config: DarkModeConfig): void {\n this._darkModeEnbled = config.darkModeEnbled || false;\n this._cssProperty = config.cssProperty || CSS_PROP;\n this._storageKey = config.storageKey || STORAGE_KEY;\n if (this._darkModeEnbled) {\n this.enableDarkMode();\n } else {\n this.initStoredDarkMode();\n }\n if (config.detectBrowserSettings) this.initBrowserMode();\n }\n \n private initStoredDarkMode(): void {\n const result: string | null = localStorage.getItem(this._storageKey);\n if (result === \"true\") this.enableDarkMode();\n }\n\n private setStoredDarkMode(): void {\n const data: string = String(this._darkModeEnbled);\n localStorage.setItem(this._storageKey, data);\n }\n\n private setDarkMode(action: string): void {\n const classList: DOMTokenList = this._document.body.classList;\n if (action === ADD_ACTION) {\n classList.add(this._cssProperty);\n this._darkModeEnbled = true;\n } else if (action === REMOVE_ACTION) {\n classList.remove(this._cssProperty);\n this._darkModeEnbled = false;\n }\n this.change.emit(this._darkModeEnbled);\n }\n\n private initBrowserMode(): void {\n if (window.matchMedia && window.matchMedia('(prefers-color-scheme: dark)').matches) {\n this.enableDarkMode();\n }\n }\n}\n\n","import { NgModule } from '@angular/core';\r\nimport { SafeHtmlPipe } from './pipe/safe/safe-html.pipe';\r\nimport { DARK_MODE_CONFIG } from './service/ui/dark-mode.service';\r\n\r\n@NgModule({\r\n declarations: [\r\n SafeHtmlPipe\r\n ],\r\n providers: [\r\n { provide: DARK_MODE_CONFIG, useValue: DARK_MODE_CONFIG }\r\n ],\r\n exports: [\r\n SafeHtmlPipe\r\n ]\r\n})\r\nexport class AngularToolboxModule { }","import { Injectable } from '@angular/core';\nimport { Subscription } from 'rxjs';\n\n@Injectable({\n providedIn: 'root'\n})\n/**\n * A lightweight service that helps to manage unregistration issues of Angular subscriptions.\n */\nexport class SubscriptionService {\n\n /**\n * The internal Subscription instances storage.\n */\n private _subMap: Map<String, Array<Subscription>> = new Map<String, Array<Subscription>>();\n\n /**\n * Stores a new Subscription instance associated with the specified reference.\n * \n * @param ref the reference for which to store a new Subscription instance.\n * @param subscription the Subscription instance to register.\n * @returns a reference to this SubscriptionService instance.\n */\n public register(ref: String, subscription: Subscription): SubscriptionService {\n if (!this._subMap.has(ref)) this._subMap.set(ref, []);\n this._subMap.get(ref)?.push(subscription);\n return this;\n }\n \n /**\n * Unsubscribes and removes all Subscription instances associated with the specified reference.\n * \n * @param ref the reference for which to remove all Subscription instances.\n * @returns true whether the specified reference exists; false otherwise.\n */\n public clearAll(ref: String): boolean {\n let result: boolean = false;\n if (this._subMap.has(ref)) {\n this._subMap.get(ref)?.forEach(subscription => subscription.unsubscribe());\n this._subMap.delete(ref);\n result = true;\n }\n return result;\n }\n\n /**\n * Returns all Subscription instances associated with the specified reference.\n * \n * @param ref the reference for which to remove get Subscription instances.\n * @returns all Subscription instances associated with the specified reference, or whether\n * the specified reference does not exists.\n */\n public get(ref: String): Array<Subscription> | null {\n return this._subMap.get(ref) || null;\n }\n}\n","/*\n * Public API Surface of angular-toolbox\n */\n\nexport * from './lib/angular-toolbox.module';\nexport * from './lib/pipe';\nexport * from './lib/service';\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './public-api';\n"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"angular-toolbox.mjs","sources":["../../../projects/angular-toolbox/src/lib/pipe/safe/safe-html.pipe.ts","../../../projects/angular-toolbox/src/lib/service/ui/dark-mode.service.ts","../../../projects/angular-toolbox/src/lib/angular-toolbox.module.ts","../../../projects/angular-toolbox/src/lib/service/subscription/subscription.service.ts","../../../projects/angular-toolbox/src/lib/service/ui/scroll.service.ts","../../../projects/angular-toolbox/src/public-api.ts","../../../projects/angular-toolbox/src/angular-toolbox.ts"],"sourcesContent":["import { DomSanitizer, SafeHtml } from '@angular/platform-browser'\r\nimport { PipeTransform, Pipe } from \"@angular/core\";\r\n\r\n@Pipe({ name: 'safeHtml'})\r\nexport class SafeHtmlPipe implements PipeTransform {\r\n\r\n constructor(private _sanitizer: DomSanitizer) {}\r\n\r\n public transform(value: string): SafeHtml {\r\n return this._sanitizer.bypassSecurityTrustHtml(value);\r\n }\r\n}","import { Inject, Injectable, EventEmitter } from '@angular/core';\nimport { DOCUMENT } from '@angular/common';\n\n// --> Internal constants\nconst STORAGE_KEY: string = \"dark-mode-key\";\nconst CSS_PROP: string = \"dark-mode\";\nconst ADD_ACTION: string = \"add\";\nconst REMOVE_ACTION: string = \"remove\";\n\n/**\n * Defines properties for the DarkModeService configuration.\n */\nexport interface DarkModeConfig {\n\n /**\n * Indicates whether the dark mode is activated by default (true), or not (false).\n */\n darkModeEnabled?: boolean;\n \n /**\n * Indicates whether the dark mode uses browser settings (true), or not (false).\n * When true, this property overrides the darkModeEnabled property.\n */\n detectBrowserSettings?: boolean;\n\n /**\n * CSS property name used to set the dark mode look and feel.\n */\n cssProperty?: string;\n\n /**\n * Reference to the key value used to persist the dark mode state to local storage.\n */\n storageKey?: string;\n}\n\n/**\n * The default provider for the DarkModeService configuration. You typically define\n * the custom properties in the main NgModule declaration to initialize the app dark mode:\n * \n * @NgModule({\n * ...\n * providers: [\n * { provide: DARK_MODE_CONFIG, useValue: { enableDarkMode: true} }\n * ],\n * ...\n * s);\n */\nexport const DARK_MODE_CONFIG: DarkModeConfig = {\n \n /**\n * Indicates whether the dark mode uses browser settings (true), or not (false).\n * Default value is false.\n */\n darkModeEnabled: false,\n \n /**\n * Indicates whether the dark mode uses browser settings (true), or not (false).\n * Default value is false.\n */\n detectBrowserSettings: false,\n \n /**\n * CSS property name used to set the dark mode look and feel.\n * Default value is 'dark-mode'.\n */\n cssProperty: CSS_PROP,\n \n /**\n * Reference to the key value used to persist the dark mode state to local storage.\n * Default value is 'dark-mode-key'.\n */\n storageKey: STORAGE_KEY\n};\n\n@Injectable({\n providedIn: 'root'\n})\n/**\n * A lightweight service that provides Dark Mode implementation for your Angular application.\n */\nexport class DarkModeService {\n\n // --> Private properties\n private _darkModeEnabled: boolean = false;\n private _cssProperty: string = CSS_PROP;\n private _storageKey: string = STORAGE_KEY;\n\n /**\n * The callback function that is triggered when the dark mode changes.\n * @typeParam EventEmitter<boolean> the value returned by the darkModeEnabled() property.\n */\n public readonly change: EventEmitter<boolean> = new EventEmitter<boolean>(true);\n\n /**\n * Creates a new DarkModeService instance.\n * @param _document the reference to the Document singleton.\n * @param config the reference to the DarkModeConfig provider.\n */\n constructor(@Inject(DOCUMENT) private _document: Document, @Inject(DARK_MODE_CONFIG) config: DarkModeConfig) {\n this.initDarkMode(config);\n }\n\n /**\n * Toogles the dark mode state.\n */\n public toggleDarkMode(): void {\n this._darkModeEnabled ? this.disableDarkMode() : this.enableDarkMode();\n }\n\n /**\n * Sets the dark mode state to active.\n */\n public enableDarkMode(): void {\n this.setDarkMode(ADD_ACTION);\n this.setStoredDarkMode();\n }\n\n /**\n * Sets the dark mode state to inactive.\n */\n public disableDarkMode(): void {\n this.setDarkMode(REMOVE_ACTION);\n this.setStoredDarkMode();\n }\n\n /**\n * Returns a boolean value that indicates the dark mode state is active (true), or not (false).\n * @returns true whether the dark mode state is active; false otherwise.\n */\n public darkModeEnabled(): boolean {\n return this._darkModeEnabled;\n }\n\n /**\n * Returns the value of the CSS property as defined by the config provider.\n * @returns the value of the CSS property.\n */\n public getCssProperty(): string {\n return this._cssProperty;\n }\n\n /**\n * Returns the value of the storage key as defined by the config provider.\n * @returns the value of the storage key.\n */\n public getStorageKey(): string {\n return this._storageKey;\n }\n \n /**\n * Removes the dark mode information from local storage.\n */\n public invalidateStorage(): void {\n localStorage.removeItem(this._storageKey);\n }\n\n // --> Private methods\n private initDarkMode(config: DarkModeConfig): void {\n this._darkModeEnabled = config.darkModeEnabled || false;\n this._cssProperty = config.cssProperty || CSS_PROP;\n this._storageKey = config.storageKey || STORAGE_KEY;\n if (this._darkModeEnabled) {\n this.enableDarkMode();\n } else {\n this.initStoredDarkMode();\n }\n if (config.detectBrowserSettings) this.initBrowserMode();\n }\n \n private initStoredDarkMode(): void {\n const result: string | null = localStorage.getItem(this._storageKey);\n if (result === \"true\") this.enableDarkMode();\n }\n\n private setStoredDarkMode(): void {\n const data: string = String(this._darkModeEnabled);\n localStorage.setItem(this._storageKey, data);\n }\n\n private setDarkMode(action: string): void {\n const classList: DOMTokenList = this._document.body.classList;\n if (action === ADD_ACTION) {\n classList.add(this._cssProperty);\n this._darkModeEnabled = true;\n } else if (action === REMOVE_ACTION) {\n classList.remove(this._cssProperty);\n this._darkModeEnabled = false;\n }\n this.change.emit(this._darkModeEnabled);\n }\n\n private initBrowserMode(): void {\n if (window.matchMedia && window.matchMedia('(prefers-color-scheme: dark)').matches) {\n this.enableDarkMode();\n }\n }\n}\n\n","import { NgModule } from '@angular/core';\r\nimport { SafeHtmlPipe } from './pipe/safe/safe-html.pipe';\r\nimport { DARK_MODE_CONFIG } from './service/ui/dark-mode.service';\r\n\r\n@NgModule({\r\n declarations: [\r\n SafeHtmlPipe\r\n ],\r\n providers: [\r\n { provide: DARK_MODE_CONFIG, useValue: DARK_MODE_CONFIG }\r\n ],\r\n exports: [\r\n SafeHtmlPipe\r\n ]\r\n})\r\nexport class AngularToolboxModule { }","import { Injectable } from '@angular/core';\nimport { Subscription } from 'rxjs';\n\n@Injectable({\n providedIn: 'root'\n})\n/**\n * A lightweight service that helps to manage unregistration issues of Angular subscriptions.\n */\nexport class SubscriptionService {\n\n /**\n * The internal Subscription instances storage.\n */\n private _subMap: Map<String, Array<Subscription>> = new Map<String, Array<Subscription>>();\n\n /**\n * Stores a new Subscription instance associated with the specified reference.\n * \n * @param ref the reference for which to store a new Subscription instance.\n * @param subscription the Subscription instance to register.\n * @returns a reference to this SubscriptionService instance.\n */\n public register(ref: String, subscription: Subscription): SubscriptionService {\n if (!this._subMap.has(ref)) this._subMap.set(ref, []);\n this._subMap.get(ref)?.push(subscription);\n return this;\n }\n \n /**\n * Unsubscribes and removes all Subscription instances associated with the specified reference.\n * \n * @param ref the reference for which to remove all Subscription instances.\n * @returns true whether the specified reference exists; false otherwise.\n */\n public clearAll(ref: String): boolean {\n let result: boolean = false;\n if (this._subMap.has(ref)) {\n this._subMap.get(ref)?.forEach(subscription => subscription.unsubscribe());\n this._subMap.delete(ref);\n result = true;\n }\n return result;\n }\n\n /**\n * Returns all Subscription instances associated with the specified reference.\n * \n * @param ref the reference for which to remove get Subscription instances.\n * @returns all Subscription instances associated with the specified reference, or whether\n * the specified reference does not exists.\n */\n public get(ref: String): Array<Subscription> | null {\n return this._subMap.get(ref) || null;\n }\n}\n","import { DOCUMENT } from '@angular/common';\nimport { EventEmitter, Inject, Injectable } from '@angular/core';\n\n/**\n * Workaround for the typescript ScrollBehavior declaration.\n */\ndeclare type ScrollBehavior = \"auto\" | \"instant\" | \"smooth\";\n\n@Injectable({\n providedIn: 'root'\n})\n/**\n * A lightweight service that provides scrolling capabilities to your Angular application.\n */\nexport class ScrollService {\n\n /**\n * The callback function that is triggered when a scroll operation is performed.\n * @typeParam EventEmitter<Event> the reference to the original scroll event.\n */\n public readonly onScroll: EventEmitter<Event> = new EventEmitter<Event>();\n\n /**\n * Creates a new ScrollService instance.\n * @param _document the reference to the Document singleton.\n */\n constructor(@Inject(DOCUMENT) private _document: Document) {\n window.addEventListener(\"scroll\", (e: Event) => {\n this.onScroll.next(e);\n });\n }\n\n /**\n * Scrolls the ancestor containers of the element with the specified selector such that \n * this element is visible to the user.\n * @param selector the selector of the target element.\n * @param arg a boolean value:\n * If true, the top of the element will be aligned to the top of the visible area of the\n * scrollable ancestor.\n * If false, the bottom of the element will be aligned to the bottom of the visible area\n * of the scrollable ancestor. \n * @param arg a dictionary containing the scroll parameters.\n */\n public scrollIntoView(selector: string, arg?: boolean | ScrollIntoViewOptions | undefined): void {\n const elm: Element | null = this._document.querySelector(selector);\n if (elm) elm.scrollIntoView(arg);\n }\n\n /**\n * Scrolls the app viewport to the top of the browser window.\n * @param behavior Specifies whether the scrolling should animate smoothly (smooth),\n * happen instantly in a single jump (instant), or let the browser\n * choose (auto, default).\n */\n public gotoTop(behavior: ScrollBehavior = 'smooth'): void {\n const options: ScrollToOptions = {\n top: 0,\n behavior: behavior as any\n };\n this.scroll(options);\n }\n\n /**\n * Scrolls the app viewport according to the specified options, into the browser window.\n * @param options A dictionary containing the scroll parameters.\n */\n public scroll(options?: ScrollToOptions): void {\n window.scroll(options);\n }\n \n /**\n * Scrolls the app viewport to the specified x/y coordinates, into the browser window.\n * @param x the horizontal pixel value that you want to scroll by.\n * @param y the vertical pixel value that you want to scroll by.\n */\n public scrollTo(x: number, y: number): void {\n window.scrollBy(x, y);\n }\n}\n","/*\n * Public API Surface of angular-toolbox\n */\n\nexport * from './lib/angular-toolbox.module';\nexport * from './lib/pipe';\nexport * from './lib/service';\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './public-api';\n"],"names":[],"mappings":"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"}
|
|
@@ -40,7 +40,7 @@ const DARK_MODE_CONFIG = {
|
|
|
40
40
|
* Indicates whether the dark mode uses browser settings (true), or not (false).
|
|
41
41
|
* Default value is false.
|
|
42
42
|
*/
|
|
43
|
-
|
|
43
|
+
darkModeEnabled: false,
|
|
44
44
|
/**
|
|
45
45
|
* Indicates whether the dark mode uses browser settings (true), or not (false).
|
|
46
46
|
* Default value is false.
|
|
@@ -69,7 +69,7 @@ class DarkModeService {
|
|
|
69
69
|
constructor(_document, config) {
|
|
70
70
|
this._document = _document;
|
|
71
71
|
// --> Private properties
|
|
72
|
-
this.
|
|
72
|
+
this._darkModeEnabled = false;
|
|
73
73
|
this._cssProperty = CSS_PROP;
|
|
74
74
|
this._storageKey = STORAGE_KEY;
|
|
75
75
|
/**
|
|
@@ -83,7 +83,7 @@ class DarkModeService {
|
|
|
83
83
|
* Toogles the dark mode state.
|
|
84
84
|
*/
|
|
85
85
|
toggleDarkMode() {
|
|
86
|
-
this.
|
|
86
|
+
this._darkModeEnabled ? this.disableDarkMode() : this.enableDarkMode();
|
|
87
87
|
}
|
|
88
88
|
/**
|
|
89
89
|
* Sets the dark mode state to active.
|
|
@@ -104,7 +104,21 @@ class DarkModeService {
|
|
|
104
104
|
* @returns true whether the dark mode state is active; false otherwise.
|
|
105
105
|
*/
|
|
106
106
|
darkModeEnabled() {
|
|
107
|
-
return this.
|
|
107
|
+
return this._darkModeEnabled;
|
|
108
|
+
}
|
|
109
|
+
/**
|
|
110
|
+
* Returns the value of the CSS property as defined by the config provider.
|
|
111
|
+
* @returns the value of the CSS property.
|
|
112
|
+
*/
|
|
113
|
+
getCssProperty() {
|
|
114
|
+
return this._cssProperty;
|
|
115
|
+
}
|
|
116
|
+
/**
|
|
117
|
+
* Returns the value of the storage key as defined by the config provider.
|
|
118
|
+
* @returns the value of the storage key.
|
|
119
|
+
*/
|
|
120
|
+
getStorageKey() {
|
|
121
|
+
return this._storageKey;
|
|
108
122
|
}
|
|
109
123
|
/**
|
|
110
124
|
* Removes the dark mode information from local storage.
|
|
@@ -114,10 +128,10 @@ class DarkModeService {
|
|
|
114
128
|
}
|
|
115
129
|
// --> Private methods
|
|
116
130
|
initDarkMode(config) {
|
|
117
|
-
this.
|
|
131
|
+
this._darkModeEnabled = config.darkModeEnabled || false;
|
|
118
132
|
this._cssProperty = config.cssProperty || CSS_PROP;
|
|
119
133
|
this._storageKey = config.storageKey || STORAGE_KEY;
|
|
120
|
-
if (this.
|
|
134
|
+
if (this._darkModeEnabled) {
|
|
121
135
|
this.enableDarkMode();
|
|
122
136
|
}
|
|
123
137
|
else {
|
|
@@ -132,20 +146,20 @@ class DarkModeService {
|
|
|
132
146
|
this.enableDarkMode();
|
|
133
147
|
}
|
|
134
148
|
setStoredDarkMode() {
|
|
135
|
-
const data = String(this.
|
|
149
|
+
const data = String(this._darkModeEnabled);
|
|
136
150
|
localStorage.setItem(this._storageKey, data);
|
|
137
151
|
}
|
|
138
152
|
setDarkMode(action) {
|
|
139
153
|
const classList = this._document.body.classList;
|
|
140
154
|
if (action === ADD_ACTION) {
|
|
141
155
|
classList.add(this._cssProperty);
|
|
142
|
-
this.
|
|
156
|
+
this._darkModeEnabled = true;
|
|
143
157
|
}
|
|
144
158
|
else if (action === REMOVE_ACTION) {
|
|
145
159
|
classList.remove(this._cssProperty);
|
|
146
|
-
this.
|
|
160
|
+
this._darkModeEnabled = false;
|
|
147
161
|
}
|
|
148
|
-
this.change.emit(this.
|
|
162
|
+
this.change.emit(this._darkModeEnabled);
|
|
149
163
|
}
|
|
150
164
|
initBrowserMode() {
|
|
151
165
|
if (window.matchMedia && window.matchMedia('(prefers-color-scheme: dark)').matches) {
|
|
@@ -248,6 +262,82 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImpor
|
|
|
248
262
|
}]
|
|
249
263
|
}] });
|
|
250
264
|
|
|
265
|
+
/**
|
|
266
|
+
* A lightweight service that provides scrolling capabilities to your Angular application.
|
|
267
|
+
*/
|
|
268
|
+
class ScrollService {
|
|
269
|
+
/**
|
|
270
|
+
* Creates a new ScrollService instance.
|
|
271
|
+
* @param _document the reference to the Document singleton.
|
|
272
|
+
*/
|
|
273
|
+
constructor(_document) {
|
|
274
|
+
this._document = _document;
|
|
275
|
+
/**
|
|
276
|
+
* The callback function that is triggered when a scroll operation is performed.
|
|
277
|
+
* @typeParam EventEmitter<Event> the reference to the original scroll event.
|
|
278
|
+
*/
|
|
279
|
+
this.onScroll = new EventEmitter();
|
|
280
|
+
window.addEventListener("scroll", (e) => {
|
|
281
|
+
this.onScroll.next(e);
|
|
282
|
+
});
|
|
283
|
+
}
|
|
284
|
+
/**
|
|
285
|
+
* Scrolls the ancestor containers of the element with the specified selector such that
|
|
286
|
+
* this element is visible to the user.
|
|
287
|
+
* @param selector the selector of the target element.
|
|
288
|
+
* @param arg a boolean value:
|
|
289
|
+
* If true, the top of the element will be aligned to the top of the visible area of the
|
|
290
|
+
* scrollable ancestor.
|
|
291
|
+
* If false, the bottom of the element will be aligned to the bottom of the visible area
|
|
292
|
+
* of the scrollable ancestor.
|
|
293
|
+
* @param arg a dictionary containing the scroll parameters.
|
|
294
|
+
*/
|
|
295
|
+
scrollIntoView(selector, arg) {
|
|
296
|
+
const elm = this._document.querySelector(selector);
|
|
297
|
+
if (elm)
|
|
298
|
+
elm.scrollIntoView(arg);
|
|
299
|
+
}
|
|
300
|
+
/**
|
|
301
|
+
* Scrolls the app viewport to the top of the browser window.
|
|
302
|
+
* @param behavior Specifies whether the scrolling should animate smoothly (smooth),
|
|
303
|
+
* happen instantly in a single jump (instant), or let the browser
|
|
304
|
+
* choose (auto, default).
|
|
305
|
+
*/
|
|
306
|
+
gotoTop(behavior = 'smooth') {
|
|
307
|
+
const options = {
|
|
308
|
+
top: 0,
|
|
309
|
+
behavior: behavior
|
|
310
|
+
};
|
|
311
|
+
this.scroll(options);
|
|
312
|
+
}
|
|
313
|
+
/**
|
|
314
|
+
* Scrolls the app viewport according to the specified options, into the browser window.
|
|
315
|
+
* @param options A dictionary containing the scroll parameters.
|
|
316
|
+
*/
|
|
317
|
+
scroll(options) {
|
|
318
|
+
window.scroll(options);
|
|
319
|
+
}
|
|
320
|
+
/**
|
|
321
|
+
* Scrolls the app viewport to the specified x/y coordinates, into the browser window.
|
|
322
|
+
* @param x the horizontal pixel value that you want to scroll by.
|
|
323
|
+
* @param y the vertical pixel value that you want to scroll by.
|
|
324
|
+
*/
|
|
325
|
+
scrollTo(x, y) {
|
|
326
|
+
window.scrollBy(x, y);
|
|
327
|
+
}
|
|
328
|
+
}
|
|
329
|
+
ScrollService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: ScrollService, deps: [{ token: DOCUMENT }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
330
|
+
ScrollService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: ScrollService, providedIn: 'root' });
|
|
331
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImport: i0, type: ScrollService, decorators: [{
|
|
332
|
+
type: Injectable,
|
|
333
|
+
args: [{
|
|
334
|
+
providedIn: 'root'
|
|
335
|
+
}]
|
|
336
|
+
}], ctorParameters: function () { return [{ type: Document, decorators: [{
|
|
337
|
+
type: Inject,
|
|
338
|
+
args: [DOCUMENT]
|
|
339
|
+
}] }]; } });
|
|
340
|
+
|
|
251
341
|
/*
|
|
252
342
|
* Public API Surface of angular-toolbox
|
|
253
343
|
*/
|
|
@@ -256,5 +346,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.9", ngImpor
|
|
|
256
346
|
* Generated bundle index. Do not edit.
|
|
257
347
|
*/
|
|
258
348
|
|
|
259
|
-
export { AngularToolboxModule, DARK_MODE_CONFIG, DarkModeService, SafeHtmlPipe, SubscriptionService };
|
|
349
|
+
export { AngularToolboxModule, DARK_MODE_CONFIG, DarkModeService, SafeHtmlPipe, ScrollService, SubscriptionService };
|
|
260
350
|
//# sourceMappingURL=angular-toolbox.mjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"angular-toolbox.mjs","sources":["../../../projects/angular-toolbox/src/lib/pipe/safe/safe-html.pipe.ts","../../../projects/angular-toolbox/src/lib/service/ui/dark-mode.service.ts","../../../projects/angular-toolbox/src/lib/angular-toolbox.module.ts","../../../projects/angular-toolbox/src/lib/service/subscription/subscription.service.ts","../../../projects/angular-toolbox/src/public-api.ts","../../../projects/angular-toolbox/src/angular-toolbox.ts"],"sourcesContent":["import { DomSanitizer, SafeHtml } from '@angular/platform-browser'\r\nimport { PipeTransform, Pipe } from \"@angular/core\";\r\n\r\n@Pipe({ name: 'safeHtml'})\r\nexport class SafeHtmlPipe implements PipeTransform {\r\n\r\n constructor(private _sanitizer: DomSanitizer) {}\r\n\r\n public transform(value: string): SafeHtml {\r\n return this._sanitizer.bypassSecurityTrustHtml(value);\r\n }\r\n}","import { Inject, Injectable, EventEmitter } from '@angular/core';\nimport { DOCUMENT } from '@angular/common';\n\n// --> Internal constants\nconst STORAGE_KEY: string = \"dark-mode-key\";\nconst CSS_PROP: string = \"dark-mode\";\nconst ADD_ACTION: string = \"add\";\nconst REMOVE_ACTION: string = \"remove\";\n\n/**\n * Defines properties for the DarkModeService configuration.\n */\nexport interface DarkModeConfig {\n\n /**\n * Indicates whether the dark mode is activated by default (true), or not (false).\n */\n darkModeEnbled?: boolean;\n \n /**\n * Indicates whether the dark mode uses browser settings (true), or not (false).\n * When true, this property overrides the darkModeEnbled property.\n */\n detectBrowserSettings?: boolean;\n\n /**\n * CSS property name used to set the dark mode look and feel.\n */\n cssProperty?: string;\n\n /**\n * Reference to the key value used to persist the dark mode state to local storage.\n */\n storageKey?: string;\n}\n\n/**\n * The default provider for the DarkModeService configuration. You typically define\n * the custom properties in the main NgModule declaration to initialize the app dark mode:\n * \n * @NgModule({\n * ...\n * providers: [\n * { provide: DARK_MODE_CONFIG, useValue: { enableDarkMode: true} }\n * ],\n * ...\n * s);\n */\nexport const DARK_MODE_CONFIG: DarkModeConfig = {\n \n /**\n * Indicates whether the dark mode uses browser settings (true), or not (false).\n * Default value is false.\n */\n darkModeEnbled: false,\n \n /**\n * Indicates whether the dark mode uses browser settings (true), or not (false).\n * Default value is false.\n */\n detectBrowserSettings: false,\n \n /**\n * CSS property name used to set the dark mode look and feel.\n * Default value is 'dark-mode'.\n */\n cssProperty: CSS_PROP,\n \n /**\n * Reference to the key value used to persist the dark mode state to local storage.\n * Default value is 'dark-mode-key'.\n */\n storageKey: STORAGE_KEY\n};\n\n@Injectable({\n providedIn: 'root'\n})\n/**\n * A lightweight service that provides Dark Mode implementation for your Angular application.\n */\nexport class DarkModeService {\n\n // --> Private properties\n private _darkModeEnbled: boolean = false;\n private _cssProperty: string = CSS_PROP;\n private _storageKey: string = STORAGE_KEY;\n\n /**\n * The callback function that is triggered when the dark mode changes.\n * @typeParam EventEmitter<boolean> the value returned by the darkModeEnabled() property.\n */\n public readonly change: EventEmitter<boolean> = new EventEmitter<boolean>(true);\n\n /**\n * Creates a new DarkModeService instance.\n * @param _document the reference to the Document singleton.\n * @param config the reference to the DarkModeConfig provider.\n */\n constructor(@Inject(DOCUMENT) private _document: Document, @Inject(DARK_MODE_CONFIG) config: DarkModeConfig) {\n this.initDarkMode(config);\n }\n\n /**\n * Toogles the dark mode state.\n */\n public toggleDarkMode(): void {\n this._darkModeEnbled ? this.disableDarkMode() : this.enableDarkMode();\n }\n\n /**\n * Sets the dark mode state to active.\n */\n public enableDarkMode(): void {\n this.setDarkMode(ADD_ACTION);\n this.setStoredDarkMode();\n }\n\n /**\n * Sets the dark mode state to inactive.\n */\n public disableDarkMode(): void {\n this.setDarkMode(REMOVE_ACTION);\n this.setStoredDarkMode();\n }\n\n /**\n * Returns a boolean value that indicates the dark mode state is active (true), or not (false).\n * @returns true whether the dark mode state is active; false otherwise.\n */\n public darkModeEnabled(): boolean {\n return this._darkModeEnbled;\n }\n\n /**\n * Removes the dark mode information from local storage.\n */\n public invalidateStorage(): void {\n localStorage.removeItem(this._storageKey);\n }\n\n // --> Private methods\n private initDarkMode(config: DarkModeConfig): void {\n this._darkModeEnbled = config.darkModeEnbled || false;\n this._cssProperty = config.cssProperty || CSS_PROP;\n this._storageKey = config.storageKey || STORAGE_KEY;\n if (this._darkModeEnbled) {\n this.enableDarkMode();\n } else {\n this.initStoredDarkMode();\n }\n if (config.detectBrowserSettings) this.initBrowserMode();\n }\n \n private initStoredDarkMode(): void {\n const result: string | null = localStorage.getItem(this._storageKey);\n if (result === \"true\") this.enableDarkMode();\n }\n\n private setStoredDarkMode(): void {\n const data: string = String(this._darkModeEnbled);\n localStorage.setItem(this._storageKey, data);\n }\n\n private setDarkMode(action: string): void {\n const classList: DOMTokenList = this._document.body.classList;\n if (action === ADD_ACTION) {\n classList.add(this._cssProperty);\n this._darkModeEnbled = true;\n } else if (action === REMOVE_ACTION) {\n classList.remove(this._cssProperty);\n this._darkModeEnbled = false;\n }\n this.change.emit(this._darkModeEnbled);\n }\n\n private initBrowserMode(): void {\n if (window.matchMedia && window.matchMedia('(prefers-color-scheme: dark)').matches) {\n this.enableDarkMode();\n }\n }\n}\n\n","import { NgModule } from '@angular/core';\r\nimport { SafeHtmlPipe } from './pipe/safe/safe-html.pipe';\r\nimport { DARK_MODE_CONFIG } from './service/ui/dark-mode.service';\r\n\r\n@NgModule({\r\n declarations: [\r\n SafeHtmlPipe\r\n ],\r\n providers: [\r\n { provide: DARK_MODE_CONFIG, useValue: DARK_MODE_CONFIG }\r\n ],\r\n exports: [\r\n SafeHtmlPipe\r\n ]\r\n})\r\nexport class AngularToolboxModule { }","import { Injectable } from '@angular/core';\nimport { Subscription } from 'rxjs';\n\n@Injectable({\n providedIn: 'root'\n})\n/**\n * A lightweight service that helps to manage unregistration issues of Angular subscriptions.\n */\nexport class SubscriptionService {\n\n /**\n * The internal Subscription instances storage.\n */\n private _subMap: Map<String, Array<Subscription>> = new Map<String, Array<Subscription>>();\n\n /**\n * Stores a new Subscription instance associated with the specified reference.\n * \n * @param ref the reference for which to store a new Subscription instance.\n * @param subscription the Subscription instance to register.\n * @returns a reference to this SubscriptionService instance.\n */\n public register(ref: String, subscription: Subscription): SubscriptionService {\n if (!this._subMap.has(ref)) this._subMap.set(ref, []);\n this._subMap.get(ref)?.push(subscription);\n return this;\n }\n \n /**\n * Unsubscribes and removes all Subscription instances associated with the specified reference.\n * \n * @param ref the reference for which to remove all Subscription instances.\n * @returns true whether the specified reference exists; false otherwise.\n */\n public clearAll(ref: String): boolean {\n let result: boolean = false;\n if (this._subMap.has(ref)) {\n this._subMap.get(ref)?.forEach(subscription => subscription.unsubscribe());\n this._subMap.delete(ref);\n result = true;\n }\n return result;\n }\n\n /**\n * Returns all Subscription instances associated with the specified reference.\n * \n * @param ref the reference for which to remove get Subscription instances.\n * @returns all Subscription instances associated with the specified reference, or whether\n * the specified reference does not exists.\n */\n public get(ref: String): Array<Subscription> | null {\n return this._subMap.get(ref) || null;\n }\n}\n","/*\n * Public API Surface of angular-toolbox\n */\n\nexport * from './lib/angular-toolbox.module';\nexport * from './lib/pipe';\nexport * from './lib/service';\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './public-api';\n"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"angular-toolbox.mjs","sources":["../../../projects/angular-toolbox/src/lib/pipe/safe/safe-html.pipe.ts","../../../projects/angular-toolbox/src/lib/service/ui/dark-mode.service.ts","../../../projects/angular-toolbox/src/lib/angular-toolbox.module.ts","../../../projects/angular-toolbox/src/lib/service/subscription/subscription.service.ts","../../../projects/angular-toolbox/src/lib/service/ui/scroll.service.ts","../../../projects/angular-toolbox/src/public-api.ts","../../../projects/angular-toolbox/src/angular-toolbox.ts"],"sourcesContent":["import { DomSanitizer, SafeHtml } from '@angular/platform-browser'\r\nimport { PipeTransform, Pipe } from \"@angular/core\";\r\n\r\n@Pipe({ name: 'safeHtml'})\r\nexport class SafeHtmlPipe implements PipeTransform {\r\n\r\n constructor(private _sanitizer: DomSanitizer) {}\r\n\r\n public transform(value: string): SafeHtml {\r\n return this._sanitizer.bypassSecurityTrustHtml(value);\r\n }\r\n}","import { Inject, Injectable, EventEmitter } from '@angular/core';\nimport { DOCUMENT } from '@angular/common';\n\n// --> Internal constants\nconst STORAGE_KEY: string = \"dark-mode-key\";\nconst CSS_PROP: string = \"dark-mode\";\nconst ADD_ACTION: string = \"add\";\nconst REMOVE_ACTION: string = \"remove\";\n\n/**\n * Defines properties for the DarkModeService configuration.\n */\nexport interface DarkModeConfig {\n\n /**\n * Indicates whether the dark mode is activated by default (true), or not (false).\n */\n darkModeEnabled?: boolean;\n \n /**\n * Indicates whether the dark mode uses browser settings (true), or not (false).\n * When true, this property overrides the darkModeEnabled property.\n */\n detectBrowserSettings?: boolean;\n\n /**\n * CSS property name used to set the dark mode look and feel.\n */\n cssProperty?: string;\n\n /**\n * Reference to the key value used to persist the dark mode state to local storage.\n */\n storageKey?: string;\n}\n\n/**\n * The default provider for the DarkModeService configuration. You typically define\n * the custom properties in the main NgModule declaration to initialize the app dark mode:\n * \n * @NgModule({\n * ...\n * providers: [\n * { provide: DARK_MODE_CONFIG, useValue: { enableDarkMode: true} }\n * ],\n * ...\n * s);\n */\nexport const DARK_MODE_CONFIG: DarkModeConfig = {\n \n /**\n * Indicates whether the dark mode uses browser settings (true), or not (false).\n * Default value is false.\n */\n darkModeEnabled: false,\n \n /**\n * Indicates whether the dark mode uses browser settings (true), or not (false).\n * Default value is false.\n */\n detectBrowserSettings: false,\n \n /**\n * CSS property name used to set the dark mode look and feel.\n * Default value is 'dark-mode'.\n */\n cssProperty: CSS_PROP,\n \n /**\n * Reference to the key value used to persist the dark mode state to local storage.\n * Default value is 'dark-mode-key'.\n */\n storageKey: STORAGE_KEY\n};\n\n@Injectable({\n providedIn: 'root'\n})\n/**\n * A lightweight service that provides Dark Mode implementation for your Angular application.\n */\nexport class DarkModeService {\n\n // --> Private properties\n private _darkModeEnabled: boolean = false;\n private _cssProperty: string = CSS_PROP;\n private _storageKey: string = STORAGE_KEY;\n\n /**\n * The callback function that is triggered when the dark mode changes.\n * @typeParam EventEmitter<boolean> the value returned by the darkModeEnabled() property.\n */\n public readonly change: EventEmitter<boolean> = new EventEmitter<boolean>(true);\n\n /**\n * Creates a new DarkModeService instance.\n * @param _document the reference to the Document singleton.\n * @param config the reference to the DarkModeConfig provider.\n */\n constructor(@Inject(DOCUMENT) private _document: Document, @Inject(DARK_MODE_CONFIG) config: DarkModeConfig) {\n this.initDarkMode(config);\n }\n\n /**\n * Toogles the dark mode state.\n */\n public toggleDarkMode(): void {\n this._darkModeEnabled ? this.disableDarkMode() : this.enableDarkMode();\n }\n\n /**\n * Sets the dark mode state to active.\n */\n public enableDarkMode(): void {\n this.setDarkMode(ADD_ACTION);\n this.setStoredDarkMode();\n }\n\n /**\n * Sets the dark mode state to inactive.\n */\n public disableDarkMode(): void {\n this.setDarkMode(REMOVE_ACTION);\n this.setStoredDarkMode();\n }\n\n /**\n * Returns a boolean value that indicates the dark mode state is active (true), or not (false).\n * @returns true whether the dark mode state is active; false otherwise.\n */\n public darkModeEnabled(): boolean {\n return this._darkModeEnabled;\n }\n\n /**\n * Returns the value of the CSS property as defined by the config provider.\n * @returns the value of the CSS property.\n */\n public getCssProperty(): string {\n return this._cssProperty;\n }\n\n /**\n * Returns the value of the storage key as defined by the config provider.\n * @returns the value of the storage key.\n */\n public getStorageKey(): string {\n return this._storageKey;\n }\n \n /**\n * Removes the dark mode information from local storage.\n */\n public invalidateStorage(): void {\n localStorage.removeItem(this._storageKey);\n }\n\n // --> Private methods\n private initDarkMode(config: DarkModeConfig): void {\n this._darkModeEnabled = config.darkModeEnabled || false;\n this._cssProperty = config.cssProperty || CSS_PROP;\n this._storageKey = config.storageKey || STORAGE_KEY;\n if (this._darkModeEnabled) {\n this.enableDarkMode();\n } else {\n this.initStoredDarkMode();\n }\n if (config.detectBrowserSettings) this.initBrowserMode();\n }\n \n private initStoredDarkMode(): void {\n const result: string | null = localStorage.getItem(this._storageKey);\n if (result === \"true\") this.enableDarkMode();\n }\n\n private setStoredDarkMode(): void {\n const data: string = String(this._darkModeEnabled);\n localStorage.setItem(this._storageKey, data);\n }\n\n private setDarkMode(action: string): void {\n const classList: DOMTokenList = this._document.body.classList;\n if (action === ADD_ACTION) {\n classList.add(this._cssProperty);\n this._darkModeEnabled = true;\n } else if (action === REMOVE_ACTION) {\n classList.remove(this._cssProperty);\n this._darkModeEnabled = false;\n }\n this.change.emit(this._darkModeEnabled);\n }\n\n private initBrowserMode(): void {\n if (window.matchMedia && window.matchMedia('(prefers-color-scheme: dark)').matches) {\n this.enableDarkMode();\n }\n }\n}\n\n","import { NgModule } from '@angular/core';\r\nimport { SafeHtmlPipe } from './pipe/safe/safe-html.pipe';\r\nimport { DARK_MODE_CONFIG } from './service/ui/dark-mode.service';\r\n\r\n@NgModule({\r\n declarations: [\r\n SafeHtmlPipe\r\n ],\r\n providers: [\r\n { provide: DARK_MODE_CONFIG, useValue: DARK_MODE_CONFIG }\r\n ],\r\n exports: [\r\n SafeHtmlPipe\r\n ]\r\n})\r\nexport class AngularToolboxModule { }","import { Injectable } from '@angular/core';\nimport { Subscription } from 'rxjs';\n\n@Injectable({\n providedIn: 'root'\n})\n/**\n * A lightweight service that helps to manage unregistration issues of Angular subscriptions.\n */\nexport class SubscriptionService {\n\n /**\n * The internal Subscription instances storage.\n */\n private _subMap: Map<String, Array<Subscription>> = new Map<String, Array<Subscription>>();\n\n /**\n * Stores a new Subscription instance associated with the specified reference.\n * \n * @param ref the reference for which to store a new Subscription instance.\n * @param subscription the Subscription instance to register.\n * @returns a reference to this SubscriptionService instance.\n */\n public register(ref: String, subscription: Subscription): SubscriptionService {\n if (!this._subMap.has(ref)) this._subMap.set(ref, []);\n this._subMap.get(ref)?.push(subscription);\n return this;\n }\n \n /**\n * Unsubscribes and removes all Subscription instances associated with the specified reference.\n * \n * @param ref the reference for which to remove all Subscription instances.\n * @returns true whether the specified reference exists; false otherwise.\n */\n public clearAll(ref: String): boolean {\n let result: boolean = false;\n if (this._subMap.has(ref)) {\n this._subMap.get(ref)?.forEach(subscription => subscription.unsubscribe());\n this._subMap.delete(ref);\n result = true;\n }\n return result;\n }\n\n /**\n * Returns all Subscription instances associated with the specified reference.\n * \n * @param ref the reference for which to remove get Subscription instances.\n * @returns all Subscription instances associated with the specified reference, or whether\n * the specified reference does not exists.\n */\n public get(ref: String): Array<Subscription> | null {\n return this._subMap.get(ref) || null;\n }\n}\n","import { DOCUMENT } from '@angular/common';\nimport { EventEmitter, Inject, Injectable } from '@angular/core';\n\n/**\n * Workaround for the typescript ScrollBehavior declaration.\n */\ndeclare type ScrollBehavior = \"auto\" | \"instant\" | \"smooth\";\n\n@Injectable({\n providedIn: 'root'\n})\n/**\n * A lightweight service that provides scrolling capabilities to your Angular application.\n */\nexport class ScrollService {\n\n /**\n * The callback function that is triggered when a scroll operation is performed.\n * @typeParam EventEmitter<Event> the reference to the original scroll event.\n */\n public readonly onScroll: EventEmitter<Event> = new EventEmitter<Event>();\n\n /**\n * Creates a new ScrollService instance.\n * @param _document the reference to the Document singleton.\n */\n constructor(@Inject(DOCUMENT) private _document: Document) {\n window.addEventListener(\"scroll\", (e: Event) => {\n this.onScroll.next(e);\n });\n }\n\n /**\n * Scrolls the ancestor containers of the element with the specified selector such that \n * this element is visible to the user.\n * @param selector the selector of the target element.\n * @param arg a boolean value:\n * If true, the top of the element will be aligned to the top of the visible area of the\n * scrollable ancestor.\n * If false, the bottom of the element will be aligned to the bottom of the visible area\n * of the scrollable ancestor. \n * @param arg a dictionary containing the scroll parameters.\n */\n public scrollIntoView(selector: string, arg?: boolean | ScrollIntoViewOptions | undefined): void {\n const elm: Element | null = this._document.querySelector(selector);\n if (elm) elm.scrollIntoView(arg);\n }\n\n /**\n * Scrolls the app viewport to the top of the browser window.\n * @param behavior Specifies whether the scrolling should animate smoothly (smooth),\n * happen instantly in a single jump (instant), or let the browser\n * choose (auto, default).\n */\n public gotoTop(behavior: ScrollBehavior = 'smooth'): void {\n const options: ScrollToOptions = {\n top: 0,\n behavior: behavior as any\n };\n this.scroll(options);\n }\n\n /**\n * Scrolls the app viewport according to the specified options, into the browser window.\n * @param options A dictionary containing the scroll parameters.\n */\n public scroll(options?: ScrollToOptions): void {\n window.scroll(options);\n }\n \n /**\n * Scrolls the app viewport to the specified x/y coordinates, into the browser window.\n * @param x the horizontal pixel value that you want to scroll by.\n * @param y the vertical pixel value that you want to scroll by.\n */\n public scrollTo(x: number, y: number): void {\n window.scrollBy(x, y);\n }\n}\n","/*\n * Public API Surface of angular-toolbox\n */\n\nexport * from './lib/angular-toolbox.module';\nexport * from './lib/pipe';\nexport * from './lib/service';\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './public-api';\n"],"names":[],"mappings":"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"}
|
package/lib/service/index.d.ts
CHANGED
|
@@ -7,10 +7,10 @@ export interface DarkModeConfig {
|
|
|
7
7
|
/**
|
|
8
8
|
* Indicates whether the dark mode is activated by default (true), or not (false).
|
|
9
9
|
*/
|
|
10
|
-
|
|
10
|
+
darkModeEnabled?: boolean;
|
|
11
11
|
/**
|
|
12
12
|
* Indicates whether the dark mode uses browser settings (true), or not (false).
|
|
13
|
-
* When true, this property overrides the
|
|
13
|
+
* When true, this property overrides the darkModeEnabled property.
|
|
14
14
|
*/
|
|
15
15
|
detectBrowserSettings?: boolean;
|
|
16
16
|
/**
|
|
@@ -37,7 +37,7 @@ export interface DarkModeConfig {
|
|
|
37
37
|
export declare const DARK_MODE_CONFIG: DarkModeConfig;
|
|
38
38
|
export declare class DarkModeService {
|
|
39
39
|
private _document;
|
|
40
|
-
private
|
|
40
|
+
private _darkModeEnabled;
|
|
41
41
|
private _cssProperty;
|
|
42
42
|
private _storageKey;
|
|
43
43
|
/**
|
|
@@ -68,6 +68,16 @@ export declare class DarkModeService {
|
|
|
68
68
|
* @returns true whether the dark mode state is active; false otherwise.
|
|
69
69
|
*/
|
|
70
70
|
darkModeEnabled(): boolean;
|
|
71
|
+
/**
|
|
72
|
+
* Returns the value of the CSS property as defined by the config provider.
|
|
73
|
+
* @returns the value of the CSS property.
|
|
74
|
+
*/
|
|
75
|
+
getCssProperty(): string;
|
|
76
|
+
/**
|
|
77
|
+
* Returns the value of the storage key as defined by the config provider.
|
|
78
|
+
* @returns the value of the storage key.
|
|
79
|
+
*/
|
|
80
|
+
getStorageKey(): string;
|
|
71
81
|
/**
|
|
72
82
|
* Removes the dark mode information from local storage.
|
|
73
83
|
*/
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
import { EventEmitter } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
/**
|
|
4
|
+
* Workaround for the typescript ScrollBehavior declaration.
|
|
5
|
+
*/
|
|
6
|
+
declare type ScrollBehavior = "auto" | "instant" | "smooth";
|
|
7
|
+
export declare class ScrollService {
|
|
8
|
+
private _document;
|
|
9
|
+
/**
|
|
10
|
+
* The callback function that is triggered when a scroll operation is performed.
|
|
11
|
+
* @typeParam EventEmitter<Event> the reference to the original scroll event.
|
|
12
|
+
*/
|
|
13
|
+
readonly onScroll: EventEmitter<Event>;
|
|
14
|
+
/**
|
|
15
|
+
* Creates a new ScrollService instance.
|
|
16
|
+
* @param _document the reference to the Document singleton.
|
|
17
|
+
*/
|
|
18
|
+
constructor(_document: Document);
|
|
19
|
+
/**
|
|
20
|
+
* Scrolls the ancestor containers of the element with the specified selector such that
|
|
21
|
+
* this element is visible to the user.
|
|
22
|
+
* @param selector the selector of the target element.
|
|
23
|
+
* @param arg a boolean value:
|
|
24
|
+
* If true, the top of the element will be aligned to the top of the visible area of the
|
|
25
|
+
* scrollable ancestor.
|
|
26
|
+
* If false, the bottom of the element will be aligned to the bottom of the visible area
|
|
27
|
+
* of the scrollable ancestor.
|
|
28
|
+
* @param arg a dictionary containing the scroll parameters.
|
|
29
|
+
*/
|
|
30
|
+
scrollIntoView(selector: string, arg?: boolean | ScrollIntoViewOptions | undefined): void;
|
|
31
|
+
/**
|
|
32
|
+
* Scrolls the app viewport to the top of the browser window.
|
|
33
|
+
* @param behavior Specifies whether the scrolling should animate smoothly (smooth),
|
|
34
|
+
* happen instantly in a single jump (instant), or let the browser
|
|
35
|
+
* choose (auto, default).
|
|
36
|
+
*/
|
|
37
|
+
gotoTop(behavior?: ScrollBehavior): void;
|
|
38
|
+
/**
|
|
39
|
+
* Scrolls the app viewport according to the specified options, into the browser window.
|
|
40
|
+
* @param options A dictionary containing the scroll parameters.
|
|
41
|
+
*/
|
|
42
|
+
scroll(options?: ScrollToOptions): void;
|
|
43
|
+
/**
|
|
44
|
+
* Scrolls the app viewport to the specified x/y coordinates, into the browser window.
|
|
45
|
+
* @param x the horizontal pixel value that you want to scroll by.
|
|
46
|
+
* @param y the vertical pixel value that you want to scroll by.
|
|
47
|
+
*/
|
|
48
|
+
scrollTo(x: number, y: number): void;
|
|
49
|
+
static ɵfac: i0.ɵɵFactoryDeclaration<ScrollService, never>;
|
|
50
|
+
static ɵprov: i0.ɵɵInjectableDeclaration<ScrollService>;
|
|
51
|
+
}
|
|
52
|
+
export {};
|