@arsedizioni/ars-utils 18.2.283 → 18.2.284
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/clipper.common/common/definitions.d.ts +6 -0
- package/core/public_api.d.ts +1 -0
- package/core/services/broadcastChannelManager.d.ts +83 -0
- package/core/services/theme.service.d.ts +6 -0
- package/esm2022/clipper.common/common/definitions.mjs +42 -1
- package/esm2022/core/public_api.mjs +2 -1
- package/esm2022/core/services/broadcastChannelManager.mjs +80 -0
- package/esm2022/core/services/theme.service.mjs +18 -8
- package/fesm2022/arsedizioni-ars-utils-clipper.common.mjs +41 -0
- package/fesm2022/arsedizioni-ars-utils-clipper.common.mjs.map +1 -1
- package/fesm2022/arsedizioni-ars-utils-core.mjs +17 -7
- package/fesm2022/arsedizioni-ars-utils-core.mjs.map +1 -1
- package/package.json +7 -7
|
@@ -16,6 +16,7 @@ export * from './system';
|
|
|
16
16
|
export * from './definitions';
|
|
17
17
|
export * from './selectable';
|
|
18
18
|
export * from './services/broadcast.service';
|
|
19
|
+
export * from './services/broadcastChannelManager';
|
|
19
20
|
export * from './services/environment.service';
|
|
20
21
|
export * from './services/screen.service';
|
|
21
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
22
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljX2FwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL2Fycy11dGlscy9jb3JlL3B1YmxpY19hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFDSCxjQUFjLGVBQWUsQ0FBQztBQUM5QixjQUFjLDBDQUEwQyxDQUFDO0FBQ3pELGNBQWMscUNBQXFDLENBQUM7QUFDcEQsY0FBYyxpQ0FBaUMsQ0FBQztBQUNoRCxjQUFjLHlCQUF5QixDQUFDO0FBQ3hDLGNBQWMsNEJBQTRCLENBQUM7QUFDM0MsY0FBYyw4QkFBOEIsQ0FBQztBQUM3QyxjQUFjLHVCQUF1QixDQUFDO0FBQ3RDLGNBQWMsd0JBQXdCLENBQUM7QUFDdkMsY0FBYyxzQkFBc0IsQ0FBQztBQUNyQyxjQUFjLHFCQUFxQixDQUFDO0FBQ3BDLGNBQWMsVUFBVSxDQUFDO0FBQ3pCLGNBQWMsZUFBZSxDQUFDO0FBQzlCLGNBQWMsY0FBYyxDQUFDO0FBQzdCLGNBQWMsOEJBQThCLENBQUM7QUFDN0MsY0FBYyxvQ0FBb0MsQ0FBQztBQUNuRCxjQUFjLGdDQUFnQyxDQUFDO0FBQy9DLGNBQWMsMkJBQTJCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKlxyXG4gKiBQdWJsaWMgQVBJIFN1cmZhY2Ugb2YgYXJzLXV0aWxzXHJcbiAqL1xyXG5leHBvcnQgKiBmcm9tICcuL2NvcmUubW9kdWxlJztcclxuZXhwb3J0ICogZnJvbSAnLi9kaXJlY3RpdmVzL2NoYW5nZURhdGVJbnRlcnZhbERpcmVjdGl2ZSc7XHJcbmV4cG9ydCAqIGZyb20gJy4vZGlyZWN0aXZlcy9jb3B5Q2xpcGJvYXJkRGlyZWN0aXZlJztcclxuZXhwb3J0ICogZnJvbSAnLi9kaXJlY3RpdmVzL2F1dG9Gb2N1c0RpcmVjdGl2ZSc7XHJcbmV4cG9ydCAqIGZyb20gJy4vZGlyZWN0aXZlcy92YWxpZGF0b3JzJztcclxuZXhwb3J0ICogZnJvbSAnLi9waXBlcy9zZWFyY2gtZmlsdGVyLnBpcGUnO1xyXG5leHBvcnQgKiBmcm9tICcuL3BpcGVzL3NlYXJjaC1jYWxsYmFjay5waXBlJztcclxuZXhwb3J0ICogZnJvbSAnLi9waXBlcy9zYWZlLXVybC5waXBlJztcclxuZXhwb3J0ICogZnJvbSAnLi9waXBlcy9zYWZlLWh0bWwucGlwZSc7XHJcbmV4cG9ydCAqIGZyb20gJy4vcGlwZXMvcmVwbGFjZS5waXBlJztcclxuZXhwb3J0ICogZnJvbSAnLi9waXBlcy9mb3JtYXQucGlwZSc7XHJcbmV4cG9ydCAqIGZyb20gJy4vc3lzdGVtJztcclxuZXhwb3J0ICogZnJvbSAnLi9kZWZpbml0aW9ucyc7XHJcbmV4cG9ydCAqIGZyb20gJy4vc2VsZWN0YWJsZSc7XHJcbmV4cG9ydCAqIGZyb20gJy4vc2VydmljZXMvYnJvYWRjYXN0LnNlcnZpY2UnO1xyXG5leHBvcnQgKiBmcm9tICcuL3NlcnZpY2VzL2Jyb2FkY2FzdENoYW5uZWxNYW5hZ2VyJztcclxuZXhwb3J0ICogZnJvbSAnLi9zZXJ2aWNlcy9lbnZpcm9ubWVudC5zZXJ2aWNlJztcclxuZXhwb3J0ICogZnJvbSAnLi9zZXJ2aWNlcy9zY3JlZW4uc2VydmljZSc7XHJcblxyXG4iXX0=
|
|
@@ -0,0 +1,80 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Standard Broadcast Messages Manager
|
|
3
|
+
* https://developer.mozilla.org/en-US/docs/Web/API/BroadcastChannel
|
|
4
|
+
*/
|
|
5
|
+
/**
|
|
6
|
+
* Web Standard Broadcast Messages Manager
|
|
7
|
+
* https://developer.mozilla.org/en-US/docs/Web/API/BroadcastChannel
|
|
8
|
+
*/
|
|
9
|
+
export class BroadcastChannelManager {
|
|
10
|
+
/**
|
|
11
|
+
* Get the current channel registration
|
|
12
|
+
*/
|
|
13
|
+
get currentBus() {
|
|
14
|
+
return this.channel?.name;
|
|
15
|
+
}
|
|
16
|
+
constructor(bus) {
|
|
17
|
+
this.channel = undefined;
|
|
18
|
+
this.subscriptions = [];
|
|
19
|
+
this.channel = new BroadcastChannel(bus);
|
|
20
|
+
this.channel.onmessageerror = (e) => {
|
|
21
|
+
console.error('[BroadcastChannelManager] Errore di ricezione del messaggio', e);
|
|
22
|
+
};
|
|
23
|
+
this.channel.onmessage = (e) => {
|
|
24
|
+
const bag = e.data;
|
|
25
|
+
if (bag) {
|
|
26
|
+
const bagInfo = this.subscriptions.find(m => m.messageId === bag.messageId);
|
|
27
|
+
bagInfo?.action(bag);
|
|
28
|
+
}
|
|
29
|
+
};
|
|
30
|
+
}
|
|
31
|
+
dispose() {
|
|
32
|
+
this.subscriptions = [];
|
|
33
|
+
this.channel?.close();
|
|
34
|
+
this.channel = null;
|
|
35
|
+
}
|
|
36
|
+
/**
|
|
37
|
+
* overloads
|
|
38
|
+
*/
|
|
39
|
+
sendMessage(messageIdorBag, dataOrDelay = null, delay = 0) {
|
|
40
|
+
// console.warn({ messageIdorBag, dataOrDelay, delay });
|
|
41
|
+
setTimeout(() => {
|
|
42
|
+
if (typeof messageIdorBag === 'string') {
|
|
43
|
+
this.channel?.postMessage({ messageId: messageIdorBag, data: dataOrDelay });
|
|
44
|
+
}
|
|
45
|
+
else {
|
|
46
|
+
this.channel?.postMessage(messageIdorBag);
|
|
47
|
+
}
|
|
48
|
+
}, (typeof dataOrDelay === 'number' ? dataOrDelay : delay) ?? 0);
|
|
49
|
+
}
|
|
50
|
+
/**
|
|
51
|
+
* Subscribe to a message
|
|
52
|
+
* @param args The subscription info, see also {@link BroadcastChannelSubscriberInfo}
|
|
53
|
+
*/
|
|
54
|
+
subscribe(args) {
|
|
55
|
+
const i = this.subscriptions.findIndex(m => m.messageId === args.messageId);
|
|
56
|
+
if (i === -1) {
|
|
57
|
+
this.subscriptions.push(args);
|
|
58
|
+
}
|
|
59
|
+
else {
|
|
60
|
+
this.subscriptions[i].action = args.action;
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
/**
|
|
64
|
+
* Remove a message subscription
|
|
65
|
+
* @param messageId The message id
|
|
66
|
+
*/
|
|
67
|
+
unsubscribe(messageId) {
|
|
68
|
+
const i = this.subscriptions.findIndex(m => m.messageId === messageId);
|
|
69
|
+
if (i !== -1) {
|
|
70
|
+
this.subscriptions.splice(i, 1);
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
/**
|
|
74
|
+
* Remove all the current subscriptions
|
|
75
|
+
*/
|
|
76
|
+
unsubscribeAll() {
|
|
77
|
+
this.subscriptions = [];
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"broadcastChannelManager.js","sourceRoot":"","sources":["../../../../../projects/ars-utils/core/services/broadcastChannelManager.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAqBH;;;GAGG;AACH,MAAM,OAAO,uBAAuB;IAIlC;;OAEG;IACH,IAAW,UAAU;QACnB,OAAO,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC;IAC5B,CAAC;IAED,YAAY,GAAW;QAVf,YAAO,GAA6B,SAAS,CAAC;QAC9C,kBAAa,GAA0C,EAAE,CAAC;QAUhE,IAAI,CAAC,OAAO,GAAG,IAAI,gBAAgB,CAAC,GAAG,CAAC,CAAC;QAEzC,IAAI,CAAC,OAAO,CAAC,cAAc,GAAG,CAAC,CAAM,EAAE,EAAE;YACvC,OAAO,CAAC,KAAK,CAAC,6DAA6D,EAAE,CAAC,CAAC,CAAC;QAClF,CAAC,CAAC;QAEF,IAAI,CAAC,OAAO,CAAC,SAAS,GAAG,CAAC,CAAe,EAAE,EAAE;YAC3C,MAAM,GAAG,GAAuD,CAAC,CAAC,IAAuC,CAAC;YAC1G,IAAI,GAAG,EAAE,CAAC;gBACR,MAAM,OAAO,GAAoD,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,SAAS,KAAK,GAAG,CAAC,SAAS,CAAC,CAAC;gBAC7H,OAAO,EAAE,MAAM,CAAC,GAAG,CAAC,CAAC;YACvB,CAAC;QACH,CAAC,CAAA;IACH,CAAC;IAED,OAAO;QACL,IAAI,CAAC,aAAa,GAAG,EAAE,CAAC;QACxB,IAAI,CAAC,OAAO,EAAE,KAAK,EAAE,CAAC;QACtB,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;IACtB,CAAC;IAuCD;;OAEG;IACH,WAAW,CAAI,cAAsD,EAAE,cAA0B,IAAI,EAAE,QAAuB,CAAC;QAC7H,wDAAwD;QACxD,UAAU,CAAC,GAAG,EAAE;YACd,IAAI,OAAO,cAAc,KAAK,QAAQ,EAAE,CAAC;gBACvC,IAAI,CAAC,OAAO,EAAE,WAAW,CAAC,EAAE,SAAS,EAAE,cAAc,EAAE,IAAI,EAAE,WAAW,EAAmC,CAAC,CAAC;YAC/G,CAAC;iBAAM,CAAC;gBACN,IAAI,CAAC,OAAO,EAAE,WAAW,CAAC,cAA+C,CAAC,CAAC;YAC7E,CAAC;QACH,CAAC,EAAE,CAAC,OAAO,WAAW,KAAK,QAAQ,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC;IACnE,CAAC;IAGD;;;OAGG;IACH,SAAS,CAAI,IAAuC;QAClD,MAAM,CAAC,GAAW,IAAI,CAAC,aAAa,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,SAAS,KAAK,IAAI,CAAC,SAAS,CAAC,CAAC;QACpF,IAAI,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC;YACb,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;QAC/B,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,CAAC;QAC7C,CAAC;IACH,CAAC;IAED;;;OAGG;IACH,WAAW,CAAC,SAAiB;QAC3B,MAAM,CAAC,GAAW,IAAI,CAAC,aAAa,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,SAAS,KAAK,SAAS,CAAC,CAAC;QAC/E,IAAI,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC;YACb,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;QAClC,CAAC;IACH,CAAC;IAED;;OAEG;IACH,cAAc;QACZ,IAAI,CAAC,aAAa,GAAG,EAAE,CAAC;IAC1B,CAAC;CACF","sourcesContent":["/**\r\n * Standard Broadcast Messages Manager\r\n * https://developer.mozilla.org/en-US/docs/Web/API/BroadcastChannel\r\n */\r\n\r\n\r\n/**\r\n * The message bag sent as a message\r\n */\r\nexport interface BroadcastChannelMessageBag<T> {\r\n  messageId: string;\r\n  sender: string,\r\n  data?: T;\r\n}\r\n\r\n/**\r\n * Message subscription params\r\n */\r\nexport interface BroadcastChannelSubscriberInfo<T> {\r\n  messageId: string,\r\n  action: (bag: BroadcastChannelMessageBag<T>) => void;\r\n}\r\n\r\n\r\n/**\r\n * Web Standard Broadcast Messages Manager\r\n * https://developer.mozilla.org/en-US/docs/Web/API/BroadcastChannel\r\n */\r\nexport class BroadcastChannelManager {\r\n  private channel?: BroadcastChannel | null = undefined;\r\n  private subscriptions: BroadcastChannelSubscriberInfo<any>[] = [];\r\n\r\n  /**\r\n   * Get the current channel registration\r\n   */\r\n  public get currentBus(): string | null | undefined {\r\n    return this.channel?.name;\r\n  }\r\n\r\n  constructor(bus: string) {\r\n    this.channel = new BroadcastChannel(bus);\r\n\r\n    this.channel.onmessageerror = (e: any) => {\r\n      console.error('[BroadcastChannelManager] Errore di ricezione del messaggio', e);\r\n    };\r\n\r\n    this.channel.onmessage = (e: MessageEvent) => {\r\n      const bag: BroadcastChannelMessageBag<any> | null | undefined = e.data as BroadcastChannelMessageBag<any>;\r\n      if (bag) {\r\n        const bagInfo: BroadcastChannelSubscriberInfo<any> | undefined = this.subscriptions.find(m => m.messageId === bag.messageId);\r\n        bagInfo?.action(bag);\r\n      }\r\n    }\r\n  }\r\n\r\n  dispose(): void {\r\n    this.subscriptions = [];\r\n    this.channel?.close();\r\n    this.channel = null;\r\n  }\r\n\r\n  /**\r\n   * Send a message\r\n   * @param bag The message, see also {@link BroadcastChannelMessageBag}\r\n   * \r\n   * @example     \r\n   * channel.sendMessage({ messageId: 'my-broadcast-message', sender: 'the-sender', data: value });\r\n   */\r\n  sendMessage<T>(bag: BroadcastChannelMessageBag<T>): void;\r\n  /**\r\n   * Send a message\r\n   * @param bag   The message, see also {@link BroadcastChannelMessageBag}\r\n   * @param delay The number of milliseconds to wait before sending the message, see also {@link setTimeout}\r\n   * \r\n   * @example     \r\n   * channel.sendMessage({ messageId: 'my-broadcast-message', sender: 'the-sender', data: value }, 250);\r\n   */\r\n  sendMessage<T>(bag: BroadcastChannelMessageBag<T>, delay: number | null): void;\r\n  /**\r\n   * Send a message\r\n   * @param messageId The message id\r\n   * @param data      The data to send\r\n   * \r\n   * @example     \r\n   * channel.sendMessage('my-broadcast-message', value);\r\n   */\r\n  sendMessage<T>(messageId: string, data: T | null): void;\r\n  /**\r\n   * Send a message\r\n   * @param messageId The message id\r\n   * @param data      The data to send\r\n   * @param delay     The number of milliseconds to wait before sending the message\r\n   * \r\n   * @example     \r\n   * channel.sendMessage('my-broadcast-message', value, 250);\r\n   */\r\n  sendMessage<T>(messageId: string, data: T | null, delay: number | null): void;\r\n\r\n  /**\r\n   * overloads\r\n   */\r\n  sendMessage<T>(messageIdorBag: string | BroadcastChannelMessageBag<T>, dataOrDelay: T | number = null, delay: number | null = 0) {\r\n    // console.warn({ messageIdorBag, dataOrDelay, delay });\r\n    setTimeout(() => {\r\n      if (typeof messageIdorBag === 'string') {\r\n        this.channel?.postMessage({ messageId: messageIdorBag, data: dataOrDelay } as BroadcastChannelMessageBag<T>);\r\n      } else {\r\n        this.channel?.postMessage(messageIdorBag as BroadcastChannelMessageBag<T>);\r\n      }\r\n    }, (typeof dataOrDelay === 'number' ? dataOrDelay : delay) ?? 0);\r\n  }\r\n\r\n\r\n  /**\r\n   * Subscribe to a message\r\n   * @param args The subscription info, see also {@link BroadcastChannelSubscriberInfo}\r\n   */\r\n  subscribe<T>(args: BroadcastChannelSubscriberInfo<T>) {\r\n    const i: number = this.subscriptions.findIndex(m => m.messageId === args.messageId);\r\n    if (i === -1) {\r\n      this.subscriptions.push(args)\r\n    } else {\r\n      this.subscriptions[i].action = args.action;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Remove a message subscription\r\n   * @param messageId The message id\r\n   */\r\n  unsubscribe(messageId: string) {\r\n    const i: number = this.subscriptions.findIndex(m => m.messageId === messageId);\r\n    if (i !== -1) {\r\n      this.subscriptions.splice(i, 1);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Remove all the current subscriptions\r\n   */\r\n  unsubscribeAll() {\r\n    this.subscriptions = [];\r\n  }\r\n}\r\n"]}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { computed, inject, Injectable, RendererFactory2, signal } from "@angular/core";
|
|
2
|
-
import { BroadcastChannelManager } from './
|
|
2
|
+
import { BroadcastChannelManager } from './broadcastChannelManager';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
4
|
export class ThemeService {
|
|
5
5
|
constructor() {
|
|
@@ -38,9 +38,9 @@ export class ThemeService {
|
|
|
38
38
|
* Tooltip text on toggle
|
|
39
39
|
*/
|
|
40
40
|
this.toggleTooltip = computed(() => this.themeInfo[this.theme()].tooltip);
|
|
41
|
-
//
|
|
41
|
+
// React to current theme
|
|
42
42
|
this.prefersColorSchemeMediaQueryList.onchange = (_) => this.auto() ? this.setTheme() : null;
|
|
43
|
-
//
|
|
43
|
+
// Support boradcast channel messaging
|
|
44
44
|
this.broadcastChannel.subscribe({
|
|
45
45
|
messageId: this.broadcastMessage,
|
|
46
46
|
action: (bag) => {
|
|
@@ -49,13 +49,24 @@ export class ThemeService {
|
|
|
49
49
|
}
|
|
50
50
|
}
|
|
51
51
|
});
|
|
52
|
-
//
|
|
53
|
-
|
|
52
|
+
// Initialize
|
|
53
|
+
let theme = localStorage.getItem("preferred-theme");
|
|
54
|
+
if (!this.isTheme(theme)) {
|
|
55
|
+
theme = 'auto';
|
|
56
|
+
}
|
|
57
|
+
this.setTheme(theme);
|
|
54
58
|
}
|
|
55
59
|
ngOnDestroy() {
|
|
56
|
-
// chiude il canale di comunicazione broadcast
|
|
57
60
|
this.broadcastChannel.dispose();
|
|
58
61
|
}
|
|
62
|
+
/**
|
|
63
|
+
* Check if a value string is a theme type
|
|
64
|
+
* @param value : th string value
|
|
65
|
+
* @returns true if the the value is a valid theme type
|
|
66
|
+
*/
|
|
67
|
+
isTheme(value) {
|
|
68
|
+
return ['auto', 'light', 'dark'].includes(value);
|
|
69
|
+
}
|
|
59
70
|
/**
|
|
60
71
|
* Set the new theme
|
|
61
72
|
* @param theme the new theme
|
|
@@ -66,7 +77,6 @@ export class ThemeService {
|
|
|
66
77
|
this.theme.set(theme);
|
|
67
78
|
localStorage.setItem("preferred-theme", this.theme());
|
|
68
79
|
this.renderer.addClass(document.body, this.auto() ? (window.matchMedia && window.matchMedia("(prefers-color-scheme: dark)").matches ? "dark" : "light") : theme);
|
|
69
|
-
// lancia il messaggio broadcast
|
|
70
80
|
this.broadcastChannel.sendMessage(this.broadcastMessage, this.theme());
|
|
71
81
|
}
|
|
72
82
|
/**
|
|
@@ -93,4 +103,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.1", ngImpor
|
|
|
93
103
|
providedIn: "root",
|
|
94
104
|
}]
|
|
95
105
|
}], ctorParameters: () => [] });
|
|
96
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"theme.service.js","sourceRoot":"","sources":["../../../../../projects/ars-utils/core/services/theme.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { computed, inject, Injectable, OnDestroy, RendererFactory2, Signal, signal } from \"@angular/core\";\r\nimport { BroadcastChannelManager, BroadcastChannelMessageBag } from './broadcastChannelHandler';\r\n\r\n\r\n/**\r\n * Kind of themes: system default, light or dark\r\n */\r\nexport type ThemeType = 'auto' | 'light' | 'dark';\r\n\r\n/**\r\n * Available themes' schema\r\n */\r\ninterface ThemeInfoRecord {\r\n  icon: string;\r\n  name: string;\r\n  next: ThemeType;\r\n  tooltip: string;\r\n}\r\n\r\n@Injectable({\r\n  providedIn: \"root\",\r\n})\r\nexport class ThemeService implements OnDestroy {\r\n\r\n  // messaggi broadcast\r\n  private readonly broadcastChannel = new BroadcastChannelManager('THEME-SERVICE');\r\n  private readonly broadcastMessage: string = '$theme-changed';\r\n\r\n  // per intercettare il cambio di tema a livello di sistema\r\n  private readonly prefersColorSchemeMediaQueryList = window.matchMedia('(prefers-color-scheme: dark)');\r\n\r\n  private renderFactory2 = inject(RendererFactory2);\r\n  private renderer = this.renderFactory2.createRenderer(null, null);\r\n\r\n  /**\r\n   * Current theme\r\n   */\r\n  private readonly theme = signal<ThemeType>(\"light\");\r\n  /**\r\n   * The current theme is \"System default\"\r\n   */\r\n  private readonly auto: Signal<boolean> = computed(() => this.theme() === 'auto');\r\n\r\n  /**\r\n   * Configuration schema about the icon, the text and the toggle() sequence\r\n   */\r\n  private readonly themeInfo: Record<ThemeType, ThemeInfoRecord> = {\r\n    ['auto']: { icon: 'contrast', name: 'Impostazione predefinita di sistema', next: 'light', tooltip: 'Passa a tema chiaro', },\r\n    ['light']: { icon: 'light_mode', name: 'Tema chiaro', next: 'dark', tooltip: 'Passa a tema scuro', },\r\n    ['dark']: { icon: 'dark_mode', name: 'Tema scuro', next: 'auto', tooltip: 'Passa a tema predefinito di sistema', },\r\n  };\r\n\r\n  /**\r\n   * Icon of the current theme (mat-icon code)\r\n   */\r\n  public readonly themeIcon: Signal<string> = computed(() => this.themeInfo[this.theme()].icon);\r\n  /**\r\n   * Current theme name\r\n   */\r\n  public readonly themeName: Signal<string> = computed(() => this.themeInfo[this.theme()].name);\r\n  /**\r\n   * Tooltip text on toggle \r\n   */\r\n  public readonly toggleTooltip: Signal<string> = computed(() => this.themeInfo[this.theme()].tooltip);\r\n\r\n\r\n  constructor() {\r\n    // reagisce al cambio di tema nel sistema\r\n    this.prefersColorSchemeMediaQueryList.onchange = (_: MediaQueryListEvent) => this.auto() ? this.setTheme() : null;\r\n\r\n    // reagisce al messaggio broadcast (sincronizza i temi tra i popup dell'applicazione)\r\n    this.broadcastChannel.subscribe<ThemeType>({\r\n      messageId: this.broadcastMessage,\r\n      action: (bag: BroadcastChannelMessageBag<ThemeType>) => {\r\n        if (this.theme() !== bag.data) {\r\n          this.setTheme(bag.data);\r\n        }\r\n      }\r\n    });\r\n\r\n    // inizializza il tema\r\n    this.setTheme(localStorage.getItem(\"preferred-theme\") as ThemeType ?? null);\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    // chiude il canale di comunicazione broadcast\r\n    this.broadcastChannel.dispose();\r\n  }\r\n\r\n\r\n  /**\r\n   * Set the new theme\r\n   * @param theme the new theme\r\n   */\r\n  private setTheme(theme: ThemeType = 'auto') {\r\n    this.renderer.removeClass(document.body, 'light');\r\n    this.renderer.removeClass(document.body, 'dark');\r\n\r\n    this.theme.set(theme);\r\n    localStorage.setItem(\"preferred-theme\", this.theme());\r\n    this.renderer.addClass(document.body, this.auto() ? (window.matchMedia && window.matchMedia(\"(prefers-color-scheme: dark)\").matches ? \"dark\" : \"light\") : theme);\r\n\r\n    // lancia il messaggio broadcast\r\n    this.broadcastChannel.sendMessage(this.broadcastMessage, this.theme());\r\n  }\r\n\r\n  /**\r\n   * Toggle theme\r\n   */\r\n  public toggleTheme(): void {\r\n    this.setTheme(this.themeInfo[this.theme()].next);\r\n  }\r\n\r\n  /**\r\n   * Get current active theme\r\n   * @returns the current theme\r\n   */\r\n  public getTheme(): ThemeType {\r\n    return (\r\n      this.auto() \r\n        ? (window.matchMedia && window.matchMedia(\"(prefers-color-scheme: dark)\").matches ? \"dark\" : \"light\") \r\n        : this.theme());\r\n\r\n  }\r\n}"]}
|
|
106
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"theme.service.js","sourceRoot":"","sources":["../../../../../projects/ars-utils/core/services/theme.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { computed, inject, Injectable, OnDestroy, RendererFactory2, Signal, signal } from \"@angular/core\";\r\nimport { BroadcastChannelManager, BroadcastChannelMessageBag } from './broadcastChannelManager';\r\n\r\n\r\n/**\r\n * Kind of themes: system default, light or dark\r\n */\r\nexport type ThemeType = 'auto' | 'light' | 'dark';\r\n\r\n/**\r\n * Available themes' schema\r\n */\r\ninterface ThemeInfoRecord {\r\n  icon: string;\r\n  name: string;\r\n  next: ThemeType;\r\n  tooltip: string;\r\n}\r\n\r\n@Injectable({\r\n  providedIn: \"root\",\r\n})\r\nexport class ThemeService implements OnDestroy {\r\n\r\n  // messaggi broadcast\r\n  private readonly broadcastChannel = new BroadcastChannelManager('THEME-SERVICE');\r\n  private readonly broadcastMessage: string = '$theme-changed';\r\n\r\n  // per intercettare il cambio di tema a livello di sistema\r\n  private readonly prefersColorSchemeMediaQueryList = window.matchMedia('(prefers-color-scheme: dark)');\r\n\r\n  private renderFactory2 = inject(RendererFactory2);\r\n  private renderer = this.renderFactory2.createRenderer(null, null);\r\n\r\n  /**\r\n   * Current theme\r\n   */\r\n  private readonly theme = signal<ThemeType>(\"light\");\r\n  /**\r\n   * The current theme is \"System default\"\r\n   */\r\n  private readonly auto: Signal<boolean> = computed(() => this.theme() === 'auto');\r\n\r\n  /**\r\n   * Configuration schema about the icon, the text and the toggle() sequence\r\n   */\r\n  private readonly themeInfo: Record<ThemeType, ThemeInfoRecord> = {\r\n    ['auto']: { icon: 'contrast', name: 'Impostazione predefinita di sistema', next: 'light', tooltip: 'Passa a tema chiaro', },\r\n    ['light']: { icon: 'light_mode', name: 'Tema chiaro', next: 'dark', tooltip: 'Passa a tema scuro', },\r\n    ['dark']: { icon: 'dark_mode', name: 'Tema scuro', next: 'auto', tooltip: 'Passa a tema predefinito di sistema', },\r\n  };\r\n\r\n  /**\r\n   * Icon of the current theme (mat-icon code)\r\n   */\r\n  public readonly themeIcon: Signal<string> = computed(() => this.themeInfo[this.theme()].icon);\r\n  /**\r\n   * Current theme name\r\n   */\r\n  public readonly themeName: Signal<string> = computed(() => this.themeInfo[this.theme()].name);\r\n  /**\r\n   * Tooltip text on toggle \r\n   */\r\n  public readonly toggleTooltip: Signal<string> = computed(() => this.themeInfo[this.theme()].tooltip);\r\n\r\n\r\n  constructor() {\r\n    // React to current theme\r\n    this.prefersColorSchemeMediaQueryList.onchange = (_: MediaQueryListEvent) => this.auto() ? this.setTheme() : null;\r\n\r\n    // Support boradcast channel messaging\r\n    this.broadcastChannel.subscribe<ThemeType>({\r\n      messageId: this.broadcastMessage,\r\n      action: (bag: BroadcastChannelMessageBag<ThemeType>) => {\r\n        if (this.theme() !== bag.data) {\r\n          this.setTheme(bag.data);\r\n        }\r\n      }\r\n    });\r\n\r\n    // Initialize\r\n    let theme: ThemeType = localStorage.getItem(\"preferred-theme\") as ThemeType;\r\n    if (!this.isTheme(theme)) {\r\n      theme = 'auto';\r\n    }\r\n    this.setTheme(theme);\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.broadcastChannel.dispose();\r\n  }\r\n\r\n  /**\r\n   * Check if a value string is a theme type\r\n   * @param value : th string value\r\n   * @returns true if the the value is a valid theme type\r\n   */\r\n  private isTheme(value: string): value is ThemeType {\r\n    return ['auto', 'light', 'dark'].includes(value);\r\n  }\r\n\r\n\r\n  /**\r\n   * Set the new theme\r\n   * @param theme the new theme\r\n   */\r\n  private setTheme(theme: ThemeType = 'auto') {\r\n    this.renderer.removeClass(document.body, 'light');\r\n    this.renderer.removeClass(document.body, 'dark');\r\n    this.theme.set(theme);\r\n    localStorage.setItem(\"preferred-theme\", this.theme());\r\n    this.renderer.addClass(document.body, this.auto() ? (window.matchMedia && window.matchMedia(\"(prefers-color-scheme: dark)\").matches ? \"dark\" : \"light\") : theme);\r\n    this.broadcastChannel.sendMessage(this.broadcastMessage, this.theme());\r\n  }\r\n\r\n  /**\r\n   * Toggle theme\r\n   */\r\n  public toggleTheme(): void {\r\n    this.setTheme(this.themeInfo[this.theme()].next);\r\n  }\r\n\r\n  /**\r\n   * Get current active theme\r\n   * @returns the current theme\r\n   */\r\n  public getTheme(): ThemeType {\r\n    return (\r\n      this.auto() \r\n        ? (window.matchMedia && window.matchMedia(\"(prefers-color-scheme: dark)\").matches ? \"dark\" : \"light\") \r\n        : this.theme());\r\n\r\n  }\r\n}"]}
|
|
@@ -1720,6 +1720,47 @@ class ClipperUtils {
|
|
|
1720
1720
|
}
|
|
1721
1721
|
}
|
|
1722
1722
|
class ClipperSearchUtils {
|
|
1723
|
+
/**
|
|
1724
|
+
* Check if search params have at least on params set
|
|
1725
|
+
* @param params : the search params to check
|
|
1726
|
+
* @returns true if validation succeded
|
|
1727
|
+
*/
|
|
1728
|
+
static canSearch(params) {
|
|
1729
|
+
return (params.sector !== null
|
|
1730
|
+
|| params.sectors?.length > 0
|
|
1731
|
+
|| params.author !== null
|
|
1732
|
+
|| params.authors?.length > 0
|
|
1733
|
+
|| params.topic !== null
|
|
1734
|
+
|| params.taxonomy !== null
|
|
1735
|
+
|| params.taxonomyPath !== null
|
|
1736
|
+
|| params.taxonomyNode !== null
|
|
1737
|
+
|| params.number !== null
|
|
1738
|
+
|| params.fromDate !== null
|
|
1739
|
+
|| params.toDate !== null
|
|
1740
|
+
|| params.year !== null
|
|
1741
|
+
|| params.sourceNumber !== null
|
|
1742
|
+
|| params.source !== null
|
|
1743
|
+
|| params.sourceFromDate !== null
|
|
1744
|
+
|| params.sourceToDate !== null
|
|
1745
|
+
|| params.sourceYear !== null
|
|
1746
|
+
|| params.tags?.length > 0
|
|
1747
|
+
|| params.text !== null
|
|
1748
|
+
|| params.titleOnly !== null
|
|
1749
|
+
|| params.type !== null
|
|
1750
|
+
|| params.showUnreadDocumentsOnly !== null
|
|
1751
|
+
|| params.showCommentedDocumentsOnly !== null
|
|
1752
|
+
|| params.changeReason !== null
|
|
1753
|
+
|| params.changedNumber !== null
|
|
1754
|
+
|| params.changedYear !== null
|
|
1755
|
+
|| params.changedTitle !== null
|
|
1756
|
+
|| params.modifierNumber !== null
|
|
1757
|
+
|| params.modifierYear !== null
|
|
1758
|
+
|| params.modifierTitle !== null
|
|
1759
|
+
|| params.model !== null
|
|
1760
|
+
|| params.models?.length > 0
|
|
1761
|
+
|| params.module !== null
|
|
1762
|
+
|| params.modules?.length > 0);
|
|
1763
|
+
}
|
|
1723
1764
|
/**
|
|
1724
1765
|
* Clear the search params object
|
|
1725
1766
|
* @param params : the search params to clear
|