@scania-nl/tegel-angular-extensions 0.0.4 → 0.0.6
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +390 -33
- package/docker/docker-entrypoint.sh +13 -0
- package/docker/extract-env-vars.sh +114 -0
- package/docker/nginx.conf +69 -0
- package/esm2022/index.mjs +24 -5
- package/esm2022/lib/components/tae-footer/tae-footer.component.mjs +48 -0
- package/esm2022/lib/directives/hard-refresh.directive.mjs +83 -0
- package/esm2022/lib/env/angular/provide-runtime-config.mjs +161 -0
- package/esm2022/lib/env/angular/provide-static-config.mjs +44 -0
- package/esm2022/lib/env/core/create-env-kit.mjs +81 -0
- package/esm2022/lib/env/core/env-types.mjs +2 -0
- package/esm2022/lib/env/core/parse-env-file.mjs +140 -0
- package/esm2022/lib/toast/toast.component.mjs +5 -5
- package/esm2022/lib/toast/toast.service.mjs +3 -3
- package/index.d.ts +547 -4
- package/package.json +18 -6
- package/lib/toast/models/toast-state.enum.d.ts +0 -17
- package/lib/toast/models/toast-type.d.ts +0 -8
- package/lib/toast/models/toast.model.d.ts +0 -73
- package/lib/toast/provide-toast.d.ts +0 -3
- package/lib/toast/toast.component.d.ts +0 -24
- package/lib/toast/toast.config.d.ts +0 -35
- package/lib/toast/toast.service.d.ts +0 -98
- package/lib/utils/bootstrap-global-component.d.ts +0 -23
|
@@ -0,0 +1,140 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Parses the contents of a `.env`-style file into a nested JavaScript object.
|
|
3
|
+
*
|
|
4
|
+
* Each line in the input string is expected to follow the format `KEY=VALUE`.
|
|
5
|
+
* Nested keys can be created using a configurable delimiter (default: `"__"`).
|
|
6
|
+
* Lines starting with `#` or containing only whitespace are ignored.
|
|
7
|
+
*
|
|
8
|
+
* Examples:
|
|
9
|
+
* ```env
|
|
10
|
+
* API_URL=https://api.local
|
|
11
|
+
* LOG__LEVEL=debug
|
|
12
|
+
* DB__CONNECTION__TIMEOUT=30
|
|
13
|
+
* ```
|
|
14
|
+
* Produces:
|
|
15
|
+
* ```ts
|
|
16
|
+
* {
|
|
17
|
+
* API_URL: "https://api.local",
|
|
18
|
+
* LOG: { LEVEL: "debug" },
|
|
19
|
+
* DB: { CONNECTION: { TIMEOUT: "30" } }
|
|
20
|
+
* }
|
|
21
|
+
* ```
|
|
22
|
+
*
|
|
23
|
+
* @param raw - The raw `.env` file content as a string.
|
|
24
|
+
* @param delimiter - The delimiter used to represent nested keys (default: `"__"`).
|
|
25
|
+
* @returns A nested object representing all parsed key-value pairs.
|
|
26
|
+
*/
|
|
27
|
+
export function parseEnvFile(raw, delimiter = '__') {
|
|
28
|
+
const result = {};
|
|
29
|
+
// Normalize CRLF -> LF and split into lines
|
|
30
|
+
const lines = raw.replace(/\r/g, '').split('\n');
|
|
31
|
+
for (const rawLine of lines) {
|
|
32
|
+
const line = rawLine.trim();
|
|
33
|
+
// Skip blank lines and comments
|
|
34
|
+
if (!line || line.startsWith('#'))
|
|
35
|
+
continue;
|
|
36
|
+
// Split "KEY=VALUE" (first '=' only)
|
|
37
|
+
const { key, value } = splitEnvLine(line);
|
|
38
|
+
if (!key)
|
|
39
|
+
continue; // malformed line with no key
|
|
40
|
+
// Support nesting via delimiter: "A__B__C" -> ["A","B","C"]
|
|
41
|
+
const path = key.split(delimiter).filter(Boolean);
|
|
42
|
+
// Coerce value (handles simple arrays)
|
|
43
|
+
const parsedValue = parseEnvValue(value);
|
|
44
|
+
// Write into `result` at nested path, creating objects as needed
|
|
45
|
+
assignNested(result, path, parsedValue);
|
|
46
|
+
}
|
|
47
|
+
return result;
|
|
48
|
+
}
|
|
49
|
+
/**
|
|
50
|
+
* Parses an environment variable value into a typed representation.
|
|
51
|
+
*
|
|
52
|
+
* Supports array syntax in square brackets:
|
|
53
|
+
* ```
|
|
54
|
+
* [one, two, three] -> ['one', 'two', 'three']
|
|
55
|
+
* ["a", "b", "c"] -> ['"a"', '"b"', '"c"']
|
|
56
|
+
* ```
|
|
57
|
+
* All other values are returned as raw strings.
|
|
58
|
+
*
|
|
59
|
+
* @param value - The raw string value to parse from a `.env` line.
|
|
60
|
+
* @returns The parsed value (string or array of strings).
|
|
61
|
+
*/
|
|
62
|
+
function parseEnvValue(value) {
|
|
63
|
+
// Remove leading/trailing whitespace
|
|
64
|
+
const trimmed = value.trim();
|
|
65
|
+
// Detect array syntax: [item1, item2, item3]
|
|
66
|
+
if (trimmed.startsWith('[') && trimmed.endsWith(']')) {
|
|
67
|
+
// Remove surrounding brackets and trim inner content
|
|
68
|
+
const inner = trimmed.slice(1, -1).trim();
|
|
69
|
+
if (!inner)
|
|
70
|
+
return []; // Empty array → []
|
|
71
|
+
// Split by comma and trim each entry
|
|
72
|
+
return inner.split(',').map((item) => item.trim());
|
|
73
|
+
}
|
|
74
|
+
// For non-array values, return as-is
|
|
75
|
+
return value;
|
|
76
|
+
}
|
|
77
|
+
/**
|
|
78
|
+
* Writes a value into a nested object structure using a key path.
|
|
79
|
+
*
|
|
80
|
+
* Example:
|
|
81
|
+
* ```ts
|
|
82
|
+
* const obj = {};
|
|
83
|
+
* assignNested(obj, ['Database', 'Host'], 'localhost');
|
|
84
|
+
* // Result: { Database: { Host: 'localhost' } }
|
|
85
|
+
* ```
|
|
86
|
+
*
|
|
87
|
+
* Intermediate objects are created automatically if they do not exist.
|
|
88
|
+
*
|
|
89
|
+
* @typeParam T - The type of the value being assigned.
|
|
90
|
+
* @param target - The root object to modify.
|
|
91
|
+
* @param path - The array of path segments (e.g., ['A','B','C']).
|
|
92
|
+
* @param value - The value to assign at the final key.
|
|
93
|
+
*/
|
|
94
|
+
function assignNested(target, path, value) {
|
|
95
|
+
// Start from the root object reference
|
|
96
|
+
let ref = target;
|
|
97
|
+
// Walk through all path segments except the last one
|
|
98
|
+
for (let i = 0; i < path.length - 1; i++) {
|
|
99
|
+
const seg = path[i];
|
|
100
|
+
// Ensure that each segment points to a plain object;
|
|
101
|
+
// replace invalid types (null, arrays, primitives) with {}
|
|
102
|
+
if (typeof ref[seg] !== 'object' ||
|
|
103
|
+
ref[seg] === null ||
|
|
104
|
+
Array.isArray(ref[seg])) {
|
|
105
|
+
ref[seg] = {};
|
|
106
|
+
}
|
|
107
|
+
// Move deeper into the structure
|
|
108
|
+
ref = ref[seg];
|
|
109
|
+
}
|
|
110
|
+
// Set the final property to the given value
|
|
111
|
+
ref[path[path.length - 1]] = value;
|
|
112
|
+
}
|
|
113
|
+
/**
|
|
114
|
+
* Splits a `.env` line into its key and value components.
|
|
115
|
+
*
|
|
116
|
+
* Example:
|
|
117
|
+
* ```
|
|
118
|
+
* "API_URL=https://api.example.com"
|
|
119
|
+
* -> { key: "API_URL", value: "https://api.example.com" }
|
|
120
|
+
* ```
|
|
121
|
+
*
|
|
122
|
+
* The split occurs at the **first** '=' character only.
|
|
123
|
+
* If the line does not contain '=', an empty `{ key: '', value: '' }` is returned.
|
|
124
|
+
*
|
|
125
|
+
* @param line - A single `.env` line to split.
|
|
126
|
+
* @returns An object containing the key and value strings.
|
|
127
|
+
*/
|
|
128
|
+
function splitEnvLine(line) {
|
|
129
|
+
// Find first '='; keys in .env files never contain '='
|
|
130
|
+
const eq = line.indexOf('=');
|
|
131
|
+
// Skip malformed lines
|
|
132
|
+
if (eq === -1)
|
|
133
|
+
return { key: '', value: '' };
|
|
134
|
+
// Extract key before '=' and value after '='
|
|
135
|
+
const key = line.slice(0, eq).trim();
|
|
136
|
+
const value = line.slice(eq + 1).trim();
|
|
137
|
+
// Return key-value pair
|
|
138
|
+
return { key, value };
|
|
139
|
+
}
|
|
140
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"parse-env-file.js","sourceRoot":"","sources":["../../../../../../../libs/tegel-angular-extensions/src/lib/env/core/parse-env-file.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Parses the contents of a `.env`-style file into a nested JavaScript object.\n *\n * Each line in the input string is expected to follow the format `KEY=VALUE`.\n * Nested keys can be created using a configurable delimiter (default: `\"__\"`).\n * Lines starting with `#` or containing only whitespace are ignored.\n *\n * Examples:\n * ```env\n * API_URL=https://api.local\n * LOG__LEVEL=debug\n * DB__CONNECTION__TIMEOUT=30\n * ```\n * Produces:\n * ```ts\n * {\n *   API_URL: \"https://api.local\",\n *   LOG: { LEVEL: \"debug\" },\n *   DB: { CONNECTION: { TIMEOUT: \"30\" } }\n * }\n * ```\n *\n * @param raw - The raw `.env` file content as a string.\n * @param delimiter - The delimiter used to represent nested keys (default: `\"__\"`).\n * @returns A nested object representing all parsed key-value pairs.\n */\nexport function parseEnvFile(\n  raw: string,\n  delimiter = '__'\n): Record<string, unknown> {\n  const result: Record<string, unknown> = {};\n\n  // Normalize CRLF -> LF and split into lines\n  const lines = raw.replace(/\\r/g, '').split('\\n');\n\n  for (const rawLine of lines) {\n    const line = rawLine.trim();\n\n    // Skip blank lines and comments\n    if (!line || line.startsWith('#')) continue;\n\n    // Split \"KEY=VALUE\" (first '=' only)\n    const { key, value } = splitEnvLine(line);\n    if (!key) continue; // malformed line with no key\n\n    // Support nesting via delimiter: \"A__B__C\" -> [\"A\",\"B\",\"C\"]\n    const path = key.split(delimiter).filter(Boolean);\n\n    // Coerce value (handles simple arrays)\n    const parsedValue = parseEnvValue(value);\n\n    // Write into `result` at nested path, creating objects as needed\n    assignNested(result, path, parsedValue);\n  }\n\n  return result;\n}\n\n/**\n * Parses an environment variable value into a typed representation.\n *\n * Supports array syntax in square brackets:\n * ```\n * [one, two, three]  -> ['one', 'two', 'three']\n * [\"a\", \"b\", \"c\"]    -> ['\"a\"', '\"b\"', '\"c\"']\n * ```\n * All other values are returned as raw strings.\n *\n * @param value - The raw string value to parse from a `.env` line.\n * @returns The parsed value (string or array of strings).\n */\nfunction parseEnvValue(value: string): unknown {\n  // Remove leading/trailing whitespace\n  const trimmed = value.trim();\n\n  // Detect array syntax: [item1, item2, item3]\n  if (trimmed.startsWith('[') && trimmed.endsWith(']')) {\n    // Remove surrounding brackets and trim inner content\n    const inner = trimmed.slice(1, -1).trim();\n    if (!inner) return []; // Empty array → []\n\n    // Split by comma and trim each entry\n    return inner.split(',').map((item) => item.trim());\n  }\n\n  // For non-array values, return as-is\n  return value;\n}\n\n/**\n * Writes a value into a nested object structure using a key path.\n *\n * Example:\n * ```ts\n * const obj = {};\n * assignNested(obj, ['Database', 'Host'], 'localhost');\n * // Result: { Database: { Host: 'localhost' } }\n * ```\n *\n * Intermediate objects are created automatically if they do not exist.\n *\n * @typeParam T - The type of the value being assigned.\n * @param target - The root object to modify.\n * @param path - The array of path segments (e.g., ['A','B','C']).\n * @param value - The value to assign at the final key.\n */\nfunction assignNested<T>(\n  target: Record<string, T>,\n  path: string[],\n  value: T\n): void {\n  // Start from the root object reference\n  let ref: Record<string, unknown> = target;\n\n  // Walk through all path segments except the last one\n  for (let i = 0; i < path.length - 1; i++) {\n    const seg = path[i];\n\n    // Ensure that each segment points to a plain object;\n    // replace invalid types (null, arrays, primitives) with {}\n    if (\n      typeof ref[seg] !== 'object' ||\n      ref[seg] === null ||\n      Array.isArray(ref[seg])\n    ) {\n      ref[seg] = {};\n    }\n\n    // Move deeper into the structure\n    ref = ref[seg] as Record<string, unknown>;\n  }\n\n  // Set the final property to the given value\n  ref[path[path.length - 1]] = value;\n}\n\n/**\n * Splits a `.env` line into its key and value components.\n *\n * Example:\n * ```\n * \"API_URL=https://api.example.com\"\n *   -> { key: \"API_URL\", value: \"https://api.example.com\" }\n * ```\n *\n * The split occurs at the **first** '=' character only.\n * If the line does not contain '=', an empty `{ key: '', value: '' }` is returned.\n *\n * @param line - A single `.env` line to split.\n * @returns An object containing the key and value strings.\n */\nfunction splitEnvLine(line: string): { key: string; value: string } {\n  // Find first '='; keys in .env files never contain '='\n  const eq = line.indexOf('=');\n\n  // Skip malformed lines\n  if (eq === -1) return { key: '', value: '' };\n\n  // Extract key before '=' and value after '='\n  const key = line.slice(0, eq).trim();\n  const value = line.slice(eq + 1).trim();\n\n  // Return key-value pair\n  return { key, value };\n}\n"]}
|
|
@@ -24,11 +24,11 @@ export class ToastComponent {
|
|
|
24
24
|
* @returns void
|
|
25
25
|
*/
|
|
26
26
|
closeToast = (toast) => this.toastService.close(toast.id);
|
|
27
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.2.
|
|
28
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "19.2.
|
|
27
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.2.17", ngImport: i0, type: ToastComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
28
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "19.2.17", type: ToastComponent, isStandalone: true, selector: "tae-toast", ngImport: i0, template: "<ul class=\"toast-list\" aria-live=\"polite\" aria-atomic=\"true\">\n @for (toast of toastsSignal(); track toast.id) {\n <li\n class=\"toast-item\"\n [class]=\"'toast-' + toast.type\"\n [class.toast-closing]=\"toast.state === 'closing'\"\n [style.--duration.ms]=\"toast.duration\"\n [style.--close-duration.ms]=\"toast.closeDuration\"\n role=\"status\"\n >\n <tds-toast\n [variant]=\"toast.type\"\n [header]=\"toast.title\"\n [subheader]=\"toast.description\"\n [closable]=\"toast.closable\"\n tds-close-aria-label=\"Toast close button\"\n >\n @if (toast.link) {\n <tds-link slot=\"actions\">\n <a [routerLink]=\"toast.link\">\n {{ toast.linkText ?? 'Click here' }}\n </a>\n </tds-link>\n } @else if (toast.action) {\n <tds-link slot=\"actions\">\n <a href=\"#\" (click)=\"toast.action()\">\n {{ toast.linkText ?? 'Click here' }}\n </a>\n </tds-link>\n }\n </tds-toast>\n @if (toast.closable) {\n <button\n class=\"toast-close\"\n (click)=\"closeToast(toast)\"\n aria-label=\"Close toast\"\n ></button>\n }\n </li>\n }\n</ul>\n", styles: [":host{position:fixed;right:0;bottom:0;overflow:hidden;z-index:9999}.toast-list{display:grid;grid-template-columns:1fr;gap:6px;list-style:none;padding:6px;margin:0}.toast-item{position:relative;animation:fadeIn .3s ease-in forwards}.toast-item.toast-closing{animation-name:fadeOut;animation-duration:var(--close-duration, .3s);animation-fill-mode:forwards;pointer-events:none}.toast-item:before{content:\"\";position:absolute;height:3px;width:100%;bottom:0;left:4px;right:0;animation:progress var(--duration, 7s) linear forwards;border-top-right-radius:4px;border-bottom-right-radius:4px}.toast-item.toast-information:before{background:var(--tds-information)}.toast-item.toast-success:before{background:var(--tds-positive)}.toast-item.toast-warning:before{background:var(--tds-warning)}.toast-item.toast-error:before{background:var(--tds-negative)}.toast-item .toast-close{height:20px;width:20px;box-sizing:border-box;cursor:pointer;position:absolute;top:14px;right:14px;border:0;background:transparent}.toast-item .toast-close:active{border:2px solid var(--tds-blue-400);outline-offset:-2px}@keyframes fadeIn{0%{transform:translateY(40%);opacity:0;margin-bottom:-25%}to{transform:translateY(0);opacity:1;margin-bottom:0%}}@keyframes fadeOut{0%{transform:translateY(0);opacity:1;margin-top:0}to{opacity:0;transform:translateY(75%);margin-top:-25%}}@keyframes progress{to{width:0%}}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "ngmodule", type: TegelModule }, { kind: "component", type: i1.TdsLink, selector: "tds-link", inputs: ["disabled", "standalone", "underline"] }, { kind: "component", type: i1.TdsToast, selector: "tds-toast", inputs: ["closable", "header", "hidden", "subheader", "tdsAriaLive", "tdsCloseAriaLabel", "toastId", "toastRole", "variant"] }, { kind: "directive", type: RouterLink, selector: "[routerLink]", inputs: ["target", "queryParams", "fragment", "queryParamsHandling", "state", "info", "relativeTo", "preserveFragment", "skipLocationChange", "replaceUrl", "routerLink"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
29
29
|
}
|
|
30
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.
|
|
30
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.17", ngImport: i0, type: ToastComponent, decorators: [{
|
|
31
31
|
type: Component,
|
|
32
|
-
args: [{ selector: '
|
|
32
|
+
args: [{ selector: 'tae-toast', imports: [CommonModule, TegelModule, RouterLink], changeDetection: ChangeDetectionStrategy.OnPush, template: "<ul class=\"toast-list\" aria-live=\"polite\" aria-atomic=\"true\">\n @for (toast of toastsSignal(); track toast.id) {\n <li\n class=\"toast-item\"\n [class]=\"'toast-' + toast.type\"\n [class.toast-closing]=\"toast.state === 'closing'\"\n [style.--duration.ms]=\"toast.duration\"\n [style.--close-duration.ms]=\"toast.closeDuration\"\n role=\"status\"\n >\n <tds-toast\n [variant]=\"toast.type\"\n [header]=\"toast.title\"\n [subheader]=\"toast.description\"\n [closable]=\"toast.closable\"\n tds-close-aria-label=\"Toast close button\"\n >\n @if (toast.link) {\n <tds-link slot=\"actions\">\n <a [routerLink]=\"toast.link\">\n {{ toast.linkText ?? 'Click here' }}\n </a>\n </tds-link>\n } @else if (toast.action) {\n <tds-link slot=\"actions\">\n <a href=\"#\" (click)=\"toast.action()\">\n {{ toast.linkText ?? 'Click here' }}\n </a>\n </tds-link>\n }\n </tds-toast>\n @if (toast.closable) {\n <button\n class=\"toast-close\"\n (click)=\"closeToast(toast)\"\n aria-label=\"Close toast\"\n ></button>\n }\n </li>\n }\n</ul>\n", styles: [":host{position:fixed;right:0;bottom:0;overflow:hidden;z-index:9999}.toast-list{display:grid;grid-template-columns:1fr;gap:6px;list-style:none;padding:6px;margin:0}.toast-item{position:relative;animation:fadeIn .3s ease-in forwards}.toast-item.toast-closing{animation-name:fadeOut;animation-duration:var(--close-duration, .3s);animation-fill-mode:forwards;pointer-events:none}.toast-item:before{content:\"\";position:absolute;height:3px;width:100%;bottom:0;left:4px;right:0;animation:progress var(--duration, 7s) linear forwards;border-top-right-radius:4px;border-bottom-right-radius:4px}.toast-item.toast-information:before{background:var(--tds-information)}.toast-item.toast-success:before{background:var(--tds-positive)}.toast-item.toast-warning:before{background:var(--tds-warning)}.toast-item.toast-error:before{background:var(--tds-negative)}.toast-item .toast-close{height:20px;width:20px;box-sizing:border-box;cursor:pointer;position:absolute;top:14px;right:14px;border:0;background:transparent}.toast-item .toast-close:active{border:2px solid var(--tds-blue-400);outline-offset:-2px}@keyframes fadeIn{0%{transform:translateY(40%);opacity:0;margin-bottom:-25%}to{transform:translateY(0);opacity:1;margin-bottom:0%}}@keyframes fadeOut{0%{transform:translateY(0);opacity:1;margin-top:0}to{opacity:0;transform:translateY(75%);margin-top:-25%}}@keyframes progress{to{width:0%}}\n"] }]
|
|
33
33
|
}] });
|
|
34
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
34
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9hc3QuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy90ZWdlbC1hbmd1bGFyLWV4dGVuc2lvbnMvc3JjL2xpYi90b2FzdC90b2FzdC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL3RlZ2VsLWFuZ3VsYXItZXh0ZW5zaW9ucy9zcmMvbGliL3RvYXN0L3RvYXN0LmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMzRSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDN0MsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLDBCQUEwQixDQUFDO0FBR3ZELE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQzs7O0FBRS9DOzs7OztHQUtHO0FBUUgsTUFBTSxPQUFPLGNBQWM7SUFDUixZQUFZLEdBQUcsTUFBTSxDQUFDLFlBQVksQ0FBQyxDQUFDO0lBRXJEOztPQUVHO0lBQ00sWUFBWSxHQUFHLElBQUksQ0FBQyxZQUFZLENBQUMsWUFBWSxDQUFDO0lBRXZEOzs7OztPQUtHO0lBQ0gsVUFBVSxHQUFHLENBQUMsS0FBWSxFQUFFLEVBQUUsQ0FBQyxJQUFJLENBQUMsWUFBWSxDQUFDLEtBQUssQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDLENBQUM7d0dBZHRELGNBQWM7NEZBQWQsY0FBYyxxRUNyQjNCLDBxQ0F5Q0EsKzVDRHZCWSxZQUFZLDhCQUFFLFdBQVcsOFVBQUUsVUFBVTs7NEZBR3BDLGNBQWM7a0JBUDFCLFNBQVM7K0JBQ0UsV0FBVyxXQUdaLENBQUMsWUFBWSxFQUFFLFdBQVcsRUFBRSxVQUFVLENBQUMsbUJBQy9CLHVCQUF1QixDQUFDLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgaW5qZWN0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBSb3V0ZXJMaW5rIH0gZnJvbSAnQGFuZ3VsYXIvcm91dGVyJztcbmltcG9ydCB7IFRlZ2VsTW9kdWxlIH0gZnJvbSAnQHNjYW5pYS90ZWdlbC1hbmd1bGFyLTE3JztcblxuaW1wb3J0IHsgVG9hc3QgfSBmcm9tICcuL21vZGVscy90b2FzdC5tb2RlbCc7XG5pbXBvcnQgeyBUb2FzdFNlcnZpY2UgfSBmcm9tICcuL3RvYXN0LnNlcnZpY2UnO1xuXG4vKipcbiAqIERpc3BsYXlzIHRvYXN0IG5vdGlmaWNhdGlvbnMgcHJvdmlkZWQgYnkgdGhlIFRvYXN0U2VydmljZS5cbiAqXG4gKiBUb2FzdHMgYXJlIG5vbi1ibG9ja2luZyBtZXNzYWdlcyB0aGF0IGF1dG9tYXRpY2FsbHkgZGlzYXBwZWFyIGFmdGVyIGEgc2V0IGR1cmF0aW9uXG4gKiBvciBjYW4gYmUgZGlzbWlzc2VkIG1hbnVhbGx5IGJ5IHRoZSB1c2VyLlxuICovXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICd0YWUtdG9hc3QnLFxuICB0ZW1wbGF0ZVVybDogJy4vdG9hc3QuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi90b2FzdC5jb21wb25lbnQuc2NzcyddLFxuICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlLCBUZWdlbE1vZHVsZSwgUm91dGVyTGlua10sXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxufSlcbmV4cG9ydCBjbGFzcyBUb2FzdENvbXBvbmVudCB7XG4gIHByaXZhdGUgcmVhZG9ubHkgdG9hc3RTZXJ2aWNlID0gaW5qZWN0KFRvYXN0U2VydmljZSk7XG5cbiAgLyoqXG4gICAqIEEgcmVhY3RpdmUgc2lnbmFsIG9mIGFsbCBjdXJyZW50bHkgYWN0aXZlIHRvYXN0cyAob3BlbiBvciBjbG9zaW5nKS5cbiAgICovXG4gIHJlYWRvbmx5IHRvYXN0c1NpZ25hbCA9IHRoaXMudG9hc3RTZXJ2aWNlLmFjdGl2ZVRvYXN0cztcblxuICAvKipcbiAgICogSW5pdGlhdGVzIHRoZSBjbG9zaW5nIHByb2Nlc3MgZm9yIHRoZSBnaXZlbiB0b2FzdC5cbiAgICpcbiAgICogQHBhcmFtIHRvYXN0IFRoZSB0b2FzdCB0byBiZSBjbG9zZWQuXG4gICAqIEByZXR1cm5zIHZvaWRcbiAgICovXG4gIGNsb3NlVG9hc3QgPSAodG9hc3Q6IFRvYXN0KSA9PiB0aGlzLnRvYXN0U2VydmljZS5jbG9zZSh0b2FzdC5pZCk7XG59XG4iLCI8dWwgY2xhc3M9XCJ0b2FzdC1saXN0XCIgYXJpYS1saXZlPVwicG9saXRlXCIgYXJpYS1hdG9taWM9XCJ0cnVlXCI+XG4gIEBmb3IgKHRvYXN0IG9mIHRvYXN0c1NpZ25hbCgpOyB0cmFjayB0b2FzdC5pZCkge1xuICA8bGlcbiAgICBjbGFzcz1cInRvYXN0LWl0ZW1cIlxuICAgIFtjbGFzc109XCIndG9hc3QtJyArIHRvYXN0LnR5cGVcIlxuICAgIFtjbGFzcy50b2FzdC1jbG9zaW5nXT1cInRvYXN0LnN0YXRlID09PSAnY2xvc2luZydcIlxuICAgIFtzdHlsZS4tLWR1cmF0aW9uLm1zXT1cInRvYXN0LmR1cmF0aW9uXCJcbiAgICBbc3R5bGUuLS1jbG9zZS1kdXJhdGlvbi5tc109XCJ0b2FzdC5jbG9zZUR1cmF0aW9uXCJcbiAgICByb2xlPVwic3RhdHVzXCJcbiAgPlxuICAgIDx0ZHMtdG9hc3RcbiAgICAgIFt2YXJpYW50XT1cInRvYXN0LnR5cGVcIlxuICAgICAgW2hlYWRlcl09XCJ0b2FzdC50aXRsZVwiXG4gICAgICBbc3ViaGVhZGVyXT1cInRvYXN0LmRlc2NyaXB0aW9uXCJcbiAgICAgIFtjbG9zYWJsZV09XCJ0b2FzdC5jbG9zYWJsZVwiXG4gICAgICB0ZHMtY2xvc2UtYXJpYS1sYWJlbD1cIlRvYXN0IGNsb3NlIGJ1dHRvblwiXG4gICAgPlxuICAgICAgQGlmICh0b2FzdC5saW5rKSB7XG4gICAgICA8dGRzLWxpbmsgc2xvdD1cImFjdGlvbnNcIj5cbiAgICAgICAgPGEgW3JvdXRlckxpbmtdPVwidG9hc3QubGlua1wiPlxuICAgICAgICAgIHt7IHRvYXN0LmxpbmtUZXh0ID8/ICdDbGljayBoZXJlJyB9fVxuICAgICAgICA8L2E+XG4gICAgICA8L3Rkcy1saW5rPlxuICAgICAgfSBAZWxzZSBpZiAodG9hc3QuYWN0aW9uKSB7XG4gICAgICA8dGRzLWxpbmsgc2xvdD1cImFjdGlvbnNcIj5cbiAgICAgICAgPGEgaHJlZj1cIiNcIiAoY2xpY2spPVwidG9hc3QuYWN0aW9uKClcIj5cbiAgICAgICAgICB7eyB0b2FzdC5saW5rVGV4dCA/PyAnQ2xpY2sgaGVyZScgfX1cbiAgICAgICAgPC9hPlxuICAgICAgPC90ZHMtbGluaz5cbiAgICAgIH1cbiAgICA8L3Rkcy10b2FzdD5cbiAgICBAaWYgKHRvYXN0LmNsb3NhYmxlKSB7XG4gICAgPGJ1dHRvblxuICAgICAgY2xhc3M9XCJ0b2FzdC1jbG9zZVwiXG4gICAgICAoY2xpY2spPVwiY2xvc2VUb2FzdCh0b2FzdClcIlxuICAgICAgYXJpYS1sYWJlbD1cIkNsb3NlIHRvYXN0XCJcbiAgICA+PC9idXR0b24+XG4gICAgfVxuICA8L2xpPlxuICB9XG48L3VsPlxuIl19
|
|
@@ -194,10 +194,10 @@ export class ToastService {
|
|
|
194
194
|
const num = typeof value === 'number' ? value : fallback;
|
|
195
195
|
return !Number.isFinite(num) || num < 0 ? 0 : num;
|
|
196
196
|
}
|
|
197
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.2.
|
|
198
|
-
static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "19.2.
|
|
197
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.2.17", ngImport: i0, type: ToastService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
|
|
198
|
+
static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "19.2.17", ngImport: i0, type: ToastService, providedIn: 'root' });
|
|
199
199
|
}
|
|
200
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.
|
|
200
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.17", ngImport: i0, type: ToastService, decorators: [{
|
|
201
201
|
type: Injectable,
|
|
202
202
|
args: [{
|
|
203
203
|
providedIn: 'root',
|