@o3r/styling 11.6.0-prerelease.0 → 11.6.0-prerelease.10
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/breakpoints.d.ts.map +1 -1
- package/builders/metadata-check/helpers/styling-metadata-comparison.helper.d.ts +1 -1
- package/builders/metadata-check/helpers/styling-metadata-comparison.helper.d.ts.map +1 -1
- package/builders/metadata-check/index.d.ts.map +1 -1
- package/builders/metadata-check/schema.d.ts.map +1 -1
- package/builders/style-extractor/helpers/css-variable.extractor.d.ts +1 -1
- package/builders/style-extractor/helpers/css-variable.extractor.d.ts.map +1 -1
- package/builders/style-extractor/helpers/css-variable.extractor.js +31 -31
- package/builders/style-extractor/index.d.ts.map +1 -1
- package/builders/style-extractor/index.js +23 -26
- package/builders/style-extractor/schema.d.ts.map +1 -1
- package/core/styles.interface.d.ts.map +1 -1
- package/devkit/styling-devkit.interface.d.ts.map +1 -1
- package/devkit/styling-devtools.message.service.d.ts +1 -2
- package/devkit/styling-devtools.message.service.d.ts.map +1 -1
- package/devkit/styling-devtools.module.d.ts.map +1 -1
- package/devkit/styling-devtools.service.d.ts.map +1 -1
- package/devkit/styling-devtools.token.d.ts.map +1 -1
- package/esm2022/breakpoints.mjs +2 -2
- package/esm2022/core/styles.interface.mjs +1 -1
- package/esm2022/devkit/index.mjs +1 -1
- package/esm2022/devkit/styling-devkit.interface.mjs +1 -1
- package/esm2022/devkit/styling-devtools.message.service.mjs +9 -9
- package/esm2022/devkit/styling-devtools.module.mjs +5 -5
- package/esm2022/devkit/styling-devtools.service.mjs +3 -3
- package/esm2022/devkit/styling-devtools.token.mjs +2 -2
- package/esm2022/public_api.mjs +2 -2
- package/esm2022/services/styling/style-lazy-loader.module.mjs +3 -3
- package/esm2022/services/styling/style-lazy-loader.service.mjs +9 -9
- package/fesm2022/o3r-styling.mjs +16 -16
- package/fesm2022/o3r-styling.mjs.map +1 -1
- package/package.json +6 -6
- package/public_api.d.ts +1 -1
- package/public_api.d.ts.map +1 -1
- package/schematics/cms-adapter/index.d.ts.map +1 -1
- package/schematics/cms-adapter/index.js +1 -1
- package/schematics/ng-add/index.d.ts.map +1 -1
- package/schematics/ng-add/index.js +6 -10
- package/schematics/ng-add/schema.d.ts.map +1 -1
- package/schematics/ng-add/theme-files/index.d.ts +1 -2
- package/schematics/ng-add/theme-files/index.d.ts.map +1 -1
- package/schematics/ng-add/theme-files/index.js +10 -12
- package/schematics/ng-update/index.d.ts.map +1 -1
- package/schematics/ng-update/index.js +1 -2
- package/schematics/ng-update/v10.0/update-scss-imports.d.ts.map +1 -1
- package/schematics/ng-update/v10.0/update-scss-imports.js +5 -5
- package/schematics/theming-to-component/index.d.ts.map +1 -1
- package/schematics/theming-to-component/index.js +1 -1
- package/schematics/theming-to-component/schema.d.ts.map +1 -1
- package/scss/theming/functions.spec.ts +8 -4
- package/scss/theming/mixins.spec.ts +9 -5
- package/scss/utils/functions.spec.ts +8 -3
- package/services/styling/style-lazy-loader.module.d.ts.map +1 -1
- package/services/styling/style-lazy-loader.service.d.ts.map +1 -1
package/breakpoints.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"breakpoints.d.ts","sourceRoot":"","sources":["../src/breakpoints.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"breakpoints.d.ts","sourceRoot":"","sources":["../src/breakpoints.ts"],"names":[],"mappings":"AAIA;;;GAGG;AACH,eAAO,MAAM,iBAAiB;;;CAG7B,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"styling-metadata-comparison.helper.d.ts","sourceRoot":"","sources":["../../../../builders/metadata-check/helpers/styling-metadata-comparison.helper.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,
|
|
1
|
+
{"version":3,"file":"styling-metadata-comparison.helper.d.ts","sourceRoot":"","sources":["../../../../builders/metadata-check/helpers/styling-metadata-comparison.helper.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,kBAAkB,EACnB,MAAM,iBAAiB,CAAC;AACzB,OAAO,KAAK,EACV,WAAW,EACX,WAAW,EACZ,MAAM,cAAc,CAAC;AAEtB;;GAEG;AACH,MAAM,WAAW,oBAAoB;IACnC,wBAAwB;IACxB,IAAI,EAAE,MAAM,CAAC;CACd;AAcD;;GAEG;AACH,eAAO,MAAM,yBAAyB,EAAE,kBAAkB,CAAC,WAAW,EAAE,oBAAoB,EAAE,WAAW,CAKxG,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../builders/metadata-check/index.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../builders/metadata-check/index.ts"],"names":[],"mappings":"AAWA,OAAO,KAAK,EACV,0CAA0C,EAC3C,MAAM,UAAU,CAAC;;AAElB,wBAEI"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"schema.d.ts","sourceRoot":"","sources":["../../../builders/metadata-check/schema.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,
|
|
1
|
+
{"version":3,"file":"schema.d.ts","sourceRoot":"","sources":["../../../builders/metadata-check/schema.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,oCAAoC,EACrC,MAAM,iBAAiB,CAAC;AAEzB,8CAA8C;AAC9C,MAAM,WAAW,0CAA2C,SAAQ,oCAAoC;CACvG"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"css-variable.extractor.d.ts","sourceRoot":"","sources":["../../../../builders/style-extractor/helpers/css-variable.extractor.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"css-variable.extractor.d.ts","sourceRoot":"","sources":["../../../../builders/style-extractor/helpers/css-variable.extractor.ts"],"names":[],"mappings":"AAWA,OAAO,EAQL,aAAa,EAEd,MAAM,MAAM,CAAC;AACd,OAAO,KAAK,EACV,2BAA2B,EAC5B,MAAM,WAAW,CAAC;AACnB,OAAO,KAAK,EACV,WAAW,EACX,WAAW,EAEZ,MAAM,cAAc,CAAC;AAUtB;;GAEG;AACH,qBAAa,oBAAoB;IAGZ,kBAAkB,CAAC,EAAE,aAAa,CAAC,MAAM,CAAC;IAAE,OAAO,CAAC,QAAQ,CAAC,cAAc,CAAC;IAF/F,OAAO,CAAC,QAAQ,CAAC,KAAK,CAA2B;gBAE9B,kBAAkB,CAAC,EAAE,aAAa,CAAC,MAAM,CAAC,YAAA,EAAmB,cAAc,CAAC,EAAE,IAAI,CAAC,2BAA2B,EAAE,oBAAoB,CAAC,YAAA;IAExJ;;;;OAIG;IACH,OAAO,CAAC,gBAAgB;IA6BxB;;;OAGG;IACH,OAAO,CAAC,MAAM,CAAC,iBAAiB;IAIhC;;;OAGG;IACH,OAAO,CAAC,MAAM,CAAC,cAAc;IAI7B;;;OAGG;IACH,OAAO,CAAC,MAAM,CAAC,cAAc;IAO7B,OAAO,CAAC,MAAM,CAAC,WAAW;IAqB1B;;;;;OAKG;IACI,kBAAkB,CAAC,YAAY,EAAE,MAAM,EAAE,eAAe,EAAE,MAAM,EAAE,qBAAqB,CAAC,EAAE,aAAa,CAAC,MAAM,CAAC;IAgLtH;;;OAGG;IACI,WAAW,CAAC,YAAY,EAAE,MAAM,GAAG,WAAW,EAAE;IAKvD;;;;OAIG;IACI,OAAO,CAAC,SAAS,EAAE,MAAM,EAAE,EAAE,OAAO,EAAE,WAAW,GAAG,WAAW;CAiBvE"}
|
|
@@ -1,11 +1,11 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.CssVariableExtractor = void 0;
|
|
4
|
-
const extractors_1 = require("@o3r/extractors");
|
|
5
|
-
const schematics_1 = require("@o3r/schematics");
|
|
6
4
|
const fs = require("node:fs");
|
|
7
|
-
const node_url_1 = require("node:url");
|
|
8
5
|
const path = require("node:path");
|
|
6
|
+
const node_url_1 = require("node:url");
|
|
7
|
+
const extractors_1 = require("@o3r/extractors");
|
|
8
|
+
const schematics_1 = require("@o3r/schematics");
|
|
9
9
|
const sass_1 = require("sass");
|
|
10
10
|
/**
|
|
11
11
|
* CSS Variable extractor
|
|
@@ -23,29 +23,29 @@ class CssVariableExtractor {
|
|
|
23
23
|
*/
|
|
24
24
|
parseCssVariable(name, value = '') {
|
|
25
25
|
const defaultValue = value.trim();
|
|
26
|
-
const res = defaultValue.match(/^var\(
|
|
26
|
+
const res = defaultValue.match(/^var\(\s*([^\s),]+)\s*(?:,\s*([^(),]+(?:\([^)]*\))?))*\s*\)$/);
|
|
27
27
|
const ret = { name, defaultValue };
|
|
28
|
-
if (
|
|
28
|
+
if (res) {
|
|
29
|
+
ret.references = [
|
|
30
|
+
this.parseCssVariable(res[1].replace(/^--/, ''), res[2])
|
|
31
|
+
];
|
|
32
|
+
}
|
|
33
|
+
else {
|
|
29
34
|
let findRef = defaultValue;
|
|
30
35
|
let ref;
|
|
31
36
|
const references = {};
|
|
32
37
|
do {
|
|
33
|
-
ref = /var\(
|
|
38
|
+
ref = /var\(\s*([^\s),]+)\s*(?:,\s*([^(),]+(\([^)]*\))?))*\s*\)/.exec(findRef);
|
|
34
39
|
if (ref) {
|
|
35
40
|
const refName = ref[1].replace(/^--/, '');
|
|
36
41
|
references[refName] = this.parseCssVariable(refName, ref[2]);
|
|
37
42
|
findRef = findRef.replace(ref[0], '');
|
|
38
43
|
}
|
|
39
44
|
} while (ref);
|
|
40
|
-
if (Object.keys(references).length) {
|
|
45
|
+
if (Object.keys(references).length > 0) {
|
|
41
46
|
ret.references = Object.values(references);
|
|
42
47
|
}
|
|
43
48
|
}
|
|
44
|
-
else {
|
|
45
|
-
ret.references = [
|
|
46
|
-
this.parseCssVariable(res[1].replace(/^--/, ''), res[2])
|
|
47
|
-
];
|
|
48
|
-
}
|
|
49
49
|
return ret;
|
|
50
50
|
}
|
|
51
51
|
/**
|
|
@@ -120,22 +120,18 @@ class CssVariableExtractor {
|
|
|
120
120
|
const packageJsonPath = require.resolve(`${moduleName}/package.json`);
|
|
121
121
|
const packagePath = path.dirname(packageJsonPath);
|
|
122
122
|
const packageJson = JSON.parse(fs.readFileSync(packageJsonPath, { encoding: 'utf8' }));
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
}
|
|
129
|
-
else {
|
|
130
|
-
computedPathUrl = path.join(packagePath, cleanedUrl.replace(moduleName, ''));
|
|
131
|
-
}
|
|
123
|
+
const computedPathUrl = subEntry !== '.' && packageJson.exports?.[subEntry]
|
|
124
|
+
? path.join(packagePath, packageJson.exports[subEntry].sass
|
|
125
|
+
|| packageJson.exports[subEntry].scss || packageJson.exports[subEntry].css
|
|
126
|
+
|| packageJson.exports[subEntry].default)
|
|
127
|
+
: path.join(packagePath, cleanedUrl.replace(moduleName, ''));
|
|
132
128
|
const fileUrl = (0, node_url_1.pathToFileURL)(computedPathUrl);
|
|
133
129
|
this.cache[url] = fileUrl;
|
|
134
130
|
return fileUrl;
|
|
135
131
|
}
|
|
136
132
|
}],
|
|
137
133
|
functions: {
|
|
138
|
-
// eslint-disable-next-line @typescript-eslint/naming-convention
|
|
134
|
+
// eslint-disable-next-line @typescript-eslint/naming-convention -- format imposed by sass loader
|
|
139
135
|
'metadata-report($name, $value, $details: null)': (args) => {
|
|
140
136
|
let contextTags;
|
|
141
137
|
const varName = args[0];
|
|
@@ -179,6 +175,7 @@ class CssVariableExtractor {
|
|
|
179
175
|
break;
|
|
180
176
|
}
|
|
181
177
|
default: {
|
|
178
|
+
// eslint-disable-next-line no-console -- no other logger available
|
|
182
179
|
console.warn(`Unsupported property: ${key.text}`);
|
|
183
180
|
break;
|
|
184
181
|
}
|
|
@@ -219,9 +216,10 @@ class CssVariableExtractor {
|
|
|
219
216
|
}
|
|
220
217
|
}
|
|
221
218
|
parsedValue = parsedValueItems.join(' ');
|
|
222
|
-
if (invalidIndexes.length) {
|
|
219
|
+
if (invalidIndexes.length > 0) {
|
|
223
220
|
const message = `Invalid value in the list (indexes: ${invalidIndexes.join(', ')}) for variable ${varName.text}.`;
|
|
224
221
|
if (this.builderOptions?.ignoreInvalidValue ?? true) {
|
|
222
|
+
// eslint-disable-next-line no-console -- no other logger available
|
|
225
223
|
console.warn(`${message} It will be ignored.`);
|
|
226
224
|
}
|
|
227
225
|
else {
|
|
@@ -232,15 +230,10 @@ class CssVariableExtractor {
|
|
|
232
230
|
else if (CssVariableExtractor.isSassCalculation(varValue)) {
|
|
233
231
|
parsedValue = `calc(${varValue.$arguments[0]})`;
|
|
234
232
|
}
|
|
235
|
-
else if (
|
|
236
|
-
if (!details) {
|
|
237
|
-
console.warn(`The value "null" of ${varName.text} is available only for details override`);
|
|
238
|
-
return new sass_1.SassString(`[METADATA:VARIABLE] ${varName.text} : invalid Null value`);
|
|
239
|
-
}
|
|
240
|
-
}
|
|
241
|
-
else {
|
|
233
|
+
else if (varValue.realNull) {
|
|
242
234
|
const message = `Invalid value for variable ${varName.text}.`;
|
|
243
235
|
if (this.builderOptions?.ignoreInvalidValue ?? true) {
|
|
236
|
+
// eslint-disable-next-line no-console -- no other logger available
|
|
244
237
|
console.warn(`${message} It will be ignored.`);
|
|
245
238
|
return new sass_1.SassString(`[METADATA:VARIABLE] ${varName.text} : invalid value`);
|
|
246
239
|
}
|
|
@@ -248,6 +241,13 @@ class CssVariableExtractor {
|
|
|
248
241
|
throw new schematics_1.O3rCliError(message);
|
|
249
242
|
}
|
|
250
243
|
}
|
|
244
|
+
else {
|
|
245
|
+
if (!details) {
|
|
246
|
+
// eslint-disable-next-line no-console -- no other logger available
|
|
247
|
+
console.warn(`The value "null" of ${varName.text} is available only for details override`);
|
|
248
|
+
return new sass_1.SassString(`[METADATA:VARIABLE] ${varName.text} : invalid Null value`);
|
|
249
|
+
}
|
|
250
|
+
}
|
|
251
251
|
const cssVariableObj = this.parseCssVariable(varName.text, parsedValue);
|
|
252
252
|
const cssVariableDetails = {
|
|
253
253
|
tags: contextTags,
|
|
@@ -258,7 +258,7 @@ class CssVariableExtractor {
|
|
|
258
258
|
};
|
|
259
259
|
if (parsedValue === undefined) {
|
|
260
260
|
const cssVariableIndex = cssVariables.findIndex(({ name }) => name === cssVariableObj.name);
|
|
261
|
-
if (cssVariableIndex
|
|
261
|
+
if (cssVariableIndex !== -1) {
|
|
262
262
|
cssVariables[cssVariableIndex] = {
|
|
263
263
|
...cssVariables[cssVariableIndex],
|
|
264
264
|
...cssVariableDetails
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../builders/style-extractor/index.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../builders/style-extractor/index.ts"],"names":[],"mappings":"AA6BA,OAAO,EACL,2BAA2B,EAC5B,MAAM,UAAU,CAAC;AAKlB,cAAc,UAAU,CAAC;;AAWzB,wBA0MI"}
|
|
@@ -1,14 +1,14 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
const tslib_1 = require("tslib");
|
|
4
|
+
const fs = require("node:fs");
|
|
5
|
+
const node_os_1 = require("node:os");
|
|
6
|
+
const path = require("node:path");
|
|
4
7
|
const architect_1 = require("@angular-devkit/architect");
|
|
5
8
|
const extractors_1 = require("@o3r/extractors");
|
|
6
9
|
const schematics_1 = require("@o3r/schematics");
|
|
7
10
|
const chokidar = require("chokidar");
|
|
8
|
-
const fs = require("node:fs");
|
|
9
11
|
const globby_1 = require("globby");
|
|
10
|
-
const path = require("node:path");
|
|
11
|
-
const node_os_1 = require("node:os");
|
|
12
12
|
const ts = require("typescript");
|
|
13
13
|
const index_1 = require("./helpers/index");
|
|
14
14
|
tslib_1.__exportStar(require("./schema"), exports);
|
|
@@ -38,15 +38,13 @@ exports.default = (0, architect_1.createBuilder)((0, extractors_1.createBuilderW
|
|
|
38
38
|
}
|
|
39
39
|
};
|
|
40
40
|
const cssVariableExtractor = new index_1.CssVariableExtractor({ logger: sassLogger }, options);
|
|
41
|
-
const execute = async (files, previousMetadata
|
|
42
|
-
variables: {}
|
|
43
|
-
}) => {
|
|
41
|
+
const execute = async (files, previousMetadata) => {
|
|
44
42
|
/** Maximum number of steps */
|
|
45
43
|
const STEP_NUMBER = files.length + 1;
|
|
46
44
|
/** List of SCSS files for which the extraction failed */
|
|
47
45
|
const hasFailedFiles = [];
|
|
48
46
|
/** Copy of previous metadata file generated */
|
|
49
|
-
const initialPreviousMetadata = { ...previousMetadata };
|
|
47
|
+
const initialPreviousMetadata = { variables: {}, ...previousMetadata };
|
|
50
48
|
/** CSS Metadata file to write */
|
|
51
49
|
let cssMetadata = (
|
|
52
50
|
// extract metadata for each file
|
|
@@ -82,19 +80,18 @@ exports.default = (0, architect_1.createBuilder)((0, extractors_1.createBuilderW
|
|
|
82
80
|
acc.variables[item.name] = item;
|
|
83
81
|
});
|
|
84
82
|
return acc;
|
|
85
|
-
},
|
|
83
|
+
}, initialPreviousMetadata);
|
|
86
84
|
// exit on failure
|
|
87
|
-
if (hasFailedFiles.length) {
|
|
85
|
+
if (hasFailedFiles.length > 0) {
|
|
88
86
|
return {
|
|
89
87
|
success: false,
|
|
90
|
-
|
|
91
|
-
error: hasFailedFiles.reduce((acc, errorCss) => acc + '\n' + errorCss.file + '\n' + errorCss.error, '')
|
|
88
|
+
error: hasFailedFiles.reduce((acc, errorCss) => acc + '\n' + errorCss.file + '\n' + (errorCss.error.stack || errorCss.error.message), '')
|
|
92
89
|
};
|
|
93
90
|
}
|
|
94
91
|
else {
|
|
95
92
|
context.reportProgress(STEP_NUMBER - 1, STEP_NUMBER, 'Read libraries Metadata');
|
|
96
93
|
// extract library metadata if a library has been specified
|
|
97
|
-
if (options.libraries.length) {
|
|
94
|
+
if (options.libraries.length > 0) {
|
|
98
95
|
cssMetadata = cssVariableExtractor.extract(options.libraries, cssMetadata);
|
|
99
96
|
}
|
|
100
97
|
context.reportProgress(STEP_NUMBER, STEP_NUMBER, 'Generating metadata');
|
|
@@ -143,10 +140,7 @@ exports.default = (0, architect_1.createBuilder)((0, extractors_1.createBuilderW
|
|
|
143
140
|
context.reportStatus('Waiting for changes...');
|
|
144
141
|
return result;
|
|
145
142
|
};
|
|
146
|
-
if (
|
|
147
|
-
return execute(getAllFiles());
|
|
148
|
-
}
|
|
149
|
-
else {
|
|
143
|
+
if (options.watch) {
|
|
150
144
|
/** Cache */
|
|
151
145
|
const cacheMetadata = {
|
|
152
146
|
variables: {}
|
|
@@ -155,10 +149,10 @@ exports.default = (0, architect_1.createBuilder)((0, extractors_1.createBuilderW
|
|
|
155
149
|
const metadataFiles = options.libraries.map((library) => (0, extractors_1.getLibraryCmsMetadata)(library, context.currentDirectory));
|
|
156
150
|
const libMetadataFiles = metadataFiles
|
|
157
151
|
.filter(({ styleFilePath }) => !!styleFilePath)
|
|
158
|
-
.map(({ styleFilePath }) => styleFilePath.replace(/[
|
|
152
|
+
.map(({ styleFilePath }) => styleFilePath.replace(/[/\\]/g, '/'));
|
|
159
153
|
/** List of scss file pattern */
|
|
160
154
|
const scssFiles = options.filePatterns
|
|
161
|
-
.map((pattern) => path.resolve(context.currentDirectory, pattern).replace(/[
|
|
155
|
+
.map((pattern) => path.resolve(context.currentDirectory, pattern).replace(/[/\\]/g, '/'));
|
|
162
156
|
/** SCSS file watcher */
|
|
163
157
|
const watcher = chokidar.watch(scssFiles);
|
|
164
158
|
/** Libraries Metadata files watcher */
|
|
@@ -167,27 +161,27 @@ exports.default = (0, architect_1.createBuilder)((0, extractors_1.createBuilderW
|
|
|
167
161
|
.then(() => currentProcess = undefined);
|
|
168
162
|
metadataWatcher
|
|
169
163
|
.on('all', async (eventName, filePath) => {
|
|
170
|
-
if (
|
|
164
|
+
if (currentProcess) {
|
|
165
|
+
context.logger.debug(`Ignored action ${eventName} on ${filePath}`);
|
|
166
|
+
}
|
|
167
|
+
else {
|
|
171
168
|
context.logger.debug(`Refreshed for action ${eventName} on ${filePath}`);
|
|
172
169
|
currentProcess = generateWithReport(null, cacheMetadata);
|
|
173
170
|
await currentProcess;
|
|
174
171
|
currentProcess = undefined;
|
|
175
172
|
}
|
|
176
|
-
else {
|
|
177
|
-
context.logger.debug(`Ignored action ${eventName} on ${filePath}`);
|
|
178
|
-
}
|
|
179
173
|
});
|
|
180
174
|
watcher
|
|
181
175
|
.on('all', async (eventName, filePath) => {
|
|
182
|
-
if (
|
|
176
|
+
if (currentProcess) {
|
|
177
|
+
context.logger.debug(`Ignored action ${eventName} on ${filePath}`);
|
|
178
|
+
}
|
|
179
|
+
else {
|
|
183
180
|
context.logger.debug(`Refreshed for action ${eventName} on ${filePath}`);
|
|
184
181
|
currentProcess = generateWithReport(filePath, cacheMetadata);
|
|
185
182
|
await currentProcess;
|
|
186
183
|
currentProcess = undefined;
|
|
187
184
|
}
|
|
188
|
-
else {
|
|
189
|
-
context.logger.debug(`Ignored action ${eventName} on ${filePath}`);
|
|
190
|
-
}
|
|
191
185
|
});
|
|
192
186
|
context.addTeardown(async () => {
|
|
193
187
|
await watcher.close();
|
|
@@ -197,5 +191,8 @@ exports.default = (0, architect_1.createBuilder)((0, extractors_1.createBuilderW
|
|
|
197
191
|
return new Promise((_resolve, reject) => watcher
|
|
198
192
|
.on('error', (err) => reject(err)));
|
|
199
193
|
}
|
|
194
|
+
else {
|
|
195
|
+
return execute(getAllFiles());
|
|
196
|
+
}
|
|
200
197
|
}));
|
|
201
198
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"schema.d.ts","sourceRoot":"","sources":["../../../builders/style-extractor/schema.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,
|
|
1
|
+
{"version":3,"file":"schema.d.ts","sourceRoot":"","sources":["../../../builders/style-extractor/schema.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,qBAAqB,EACtB,MAAM,iBAAiB,CAAC;AAEzB,MAAM,WAAW,2BAA4B,SAAQ,qBAAqB;IACxE,8BAA8B;IAC9B,UAAU,EAAE,MAAM,CAAC;IAEnB,wBAAwB;IACxB,KAAK,EAAE,OAAO,CAAC;IAEf,4BAA4B;IAC5B,MAAM,EAAE,OAAO,CAAC;IAEhB,+CAA+C;IAC/C,YAAY,EAAE,MAAM,EAAE,CAAC;IAEvB,iCAAiC;IACjC,SAAS,EAAE,MAAM,EAAE,CAAC;IAEpB,4DAA4D;IAC5D,IAAI,CAAC,EAAE,MAAM,GAAG,SAAS,CAAC;IAE1B,uDAAuD;IACvD,sBAAsB,EAAE,OAAO,CAAC;IAEhC;;;OAGG;IACH,kBAAkB,EAAE,OAAO,CAAC;CAC7B"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"styles.interface.d.ts","sourceRoot":"","sources":["../../src/core/styles.interface.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,
|
|
1
|
+
{"version":3,"file":"styles.interface.d.ts","sourceRoot":"","sources":["../../src/core/styles.interface.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,cAAc,EACf,MAAM,WAAW,CAAC;AAEnB,MAAM,MAAM,eAAe,GAAG,QAAQ,GAAG,OAAO,CAAC;AAEjD,kCAAkC;AAClC,MAAM,WAAW,WAAW;IAC1B,2BAA2B;IAC3B,IAAI,EAAE,MAAM,CAAC;IACb,oCAAoC;IACpC,YAAY,EAAE,MAAM,CAAC;IACrB,iCAAiC;IACjC,UAAU,CAAC,EAAE,WAAW,EAAE,CAAC;IAC3B,2BAA2B;IAC3B,IAAI,CAAC,EAAE,MAAM,EAAE,CAAC;IAChB,kCAAkC;IAClC,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,kCAAkC;IAClC,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,2BAA2B;IAC3B,IAAI,CAAC,EAAE,eAAe,CAAC;IACvB,mCAAmC;IACnC,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,2DAA2D;IAC3D,SAAS,CAAC,EAAE,cAAc,CAAC;CAC5B;AAED,yBAAyB;AACzB,MAAM,WAAW,WAAW;IAC1B,4BAA4B;IAC5B,SAAS,EAAE;QACT,CAAC,IAAI,EAAE,MAAM,GAAG,WAAW,CAAC;KAC7B,CAAC;CACH"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"styling-devkit.interface.d.ts","sourceRoot":"","sources":["../../src/devkit/styling-devkit.interface.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,qBAAqB,EACrB,qBAAqB,EACrB,gBAAgB,EAChB,mBAAmB,EACnB,6BAA6B,EAC9B,MAAM,WAAW,CAAC;AACnB,OAAO,
|
|
1
|
+
{"version":3,"file":"styling-devkit.interface.d.ts","sourceRoot":"","sources":["../../src/devkit/styling-devkit.interface.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,qBAAqB,EACrB,qBAAqB,EACrB,gBAAgB,EAChB,mBAAmB,EACnB,6BAA6B,EAC9B,MAAM,WAAW,CAAC;AACnB,OAAO,EACL,WAAW,EACZ,MAAM,eAAe,CAAC;AAEvB;;GAEG;AACH,MAAM,WAAW,6BAA8B,SAAQ,qBAAqB;IAC1E;;OAEG;IACH,mBAAmB,EAAE,MAAM,CAAC;CAC7B;AAED,+BAA+B;AAC/B,MAAM,WAAW,oCAAqC,SAAQ,mBAAmB,CAAC,wBAAwB,CAAC;IACzG;;;OAGG;IACH,SAAS,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;CACnC;AAED,uCAAuC;AACvC,MAAM,WAAW,mCAAoC,SAAQ,mBAAmB,CAAC,uBAAuB,CAAC;CAAG;AAE5G,uBAAuB;AACvB,MAAM,MAAM,eAAe,GAAG,WAAW,GAAG;IAAE,YAAY,CAAC,EAAE,MAAM,CAAA;CAAE,CAAC;AAEtE,4BAA4B;AAC5B,MAAM,WAAW,gCAAiC,SAAQ,mBAAmB,CAAC,oBAAoB,CAAC;IACjG,gCAAgC;IAChC,SAAS,EAAE,eAAe,EAAE,CAAC;CAC9B;AAED;;GAEG;AACH,KAAK,sBAAsB,GACvB,oCAAoC,GACpC,mCAAmC,GACnC,gCAAgC,CAAC;AAErC,sDAAsD;AACtD,MAAM,MAAM,uBAAuB,GAAG,gBAAgB,CAAC,sBAAsB,CAAC,CAAC;AAE/E,gDAAgD;AAChD,MAAM,MAAM,+BAA+B,GACvC,sBAAsB,GACtB,qBAAqB,GACrB,6BAA6B,CAAC,uBAAuB,CAAC,CAAC;AAE3D,qCAAqC;AACrC,eAAO,MAAM,cAAc,UAAU,CAAC;AAEtC,uCAAuC;AACvC,eAAO,MAAM,gBAAgB,YAAY,CAAC"}
|
|
@@ -21,8 +21,7 @@ export declare class StylingDevtoolsMessageService implements OnDestroy {
|
|
|
21
21
|
private handleReEmitRequest;
|
|
22
22
|
/**
|
|
23
23
|
* Function to handle the incoming messages from Otter Chrome DevTools extension
|
|
24
|
-
* @param
|
|
25
|
-
* @param message
|
|
24
|
+
* @param message Message coming from the Otter Chrome DevTools extension
|
|
26
25
|
*/
|
|
27
26
|
private handleEvents;
|
|
28
27
|
/**
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"styling-devtools.message.service.d.ts","sourceRoot":"","sources":["../../src/devkit/styling-devtools.message.service.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"styling-devtools.message.service.d.ts","sourceRoot":"","sources":["../../src/devkit/styling-devtools.message.service.ts"],"names":[],"mappings":"AACA,OAAO,EAGL,SAAS,EAEV,MAAM,eAAe,CAAC;AAKvB,OAAO,EACL,aAAa,EACd,MAAM,aAAa,CAAC;AAKrB,OAAO,EAEL,6BAA6B,EAE9B,MAAM,4BAA4B,CAAC;AACpC,OAAO,EACL,oBAAoB,EACrB,MAAM,4BAA4B,CAAC;;AAqDpC;;GAEG;AACH,qBACa,6BAA8B,YAAW,SAAS;IAM3D,OAAO,CAAC,QAAQ,CAAC,MAAM;IACvB,OAAO,CAAC,QAAQ,CAAC,eAAe;IACoB,OAAO,CAAC,QAAQ,CAAC,OAAO;IAP9E,OAAO,CAAC,QAAQ,CAAC,aAAa,CAAsB;IAEpD,OAAO,CAAC,QAAQ,CAAC,WAAW,CAAqD;gBAG9D,MAAM,EAAE,aAAa,EACrB,eAAe,EAAE,oBAAoB,EACe,OAAO,GAAE,6BAAsE;YAUxI,YAAY;IAU1B;;;OAGG;IACH,OAAO,CAAC,mBAAmB;IAM3B;;;OAGG;IACH,OAAO,CAAC,YAAY;IA0BpB;;OAEG;IACH,OAAO,CAAC,aAAa;IAIrB,kBAAkB;IACX,QAAQ;IAMf,kBAAkB;IACX,WAAW;yCAnFP,6BAA6B;6CAA7B,6BAA6B;CAsFzC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"styling-devtools.module.d.ts","sourceRoot":"","sources":["../../src/devkit/styling-devtools.module.ts"],"names":[],"mappings":"AAAA,OAAO,
|
|
1
|
+
{"version":3,"file":"styling-devtools.module.d.ts","sourceRoot":"","sources":["../../src/devkit/styling-devtools.module.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,mBAAmB,EAEpB,MAAM,eAAe,CAAC;AACvB,OAAO,KAAK,EACV,6BAA6B,EAC9B,MAAM,4BAA4B,CAAC;;AAYpC,qBAOa,qBAAqB;IAChC;;;OAGG;WACW,UAAU,CAAC,OAAO,EAAE,OAAO,CAAC,6BAA6B,CAAC,GAAG,mBAAmB,CAAC,qBAAqB,CAAC;yCAL1G,qBAAqB;0CAArB,qBAAqB;0CAArB,qBAAqB;CAejC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"styling-devtools.service.d.ts","sourceRoot":"","sources":["../../src/devkit/styling-devtools.service.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"styling-devtools.service.d.ts","sourceRoot":"","sources":["../../src/devkit/styling-devtools.service.ts"],"names":[],"mappings":"AAOA,OAAO,KAAK,EACV,WAAW,EACZ,MAAM,eAAe,CAAC;;AAEvB;;GAEG;AACH,qBACa,oBAAoB;IAC/B,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAoB;IAE7C;;;OAGG;IACU,kBAAkB,CAAC,mBAAmB,EAAE,MAAM,GAAG,OAAO,CAAC,WAAW,CAAC;IAIlF;;;OAGG;IACI,eAAe,CAAC,SAAS,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC;IAIxD;;OAEG;IACI,qBAAqB;yCAtBjB,oBAAoB;6CAApB,oBAAoB;CAgChC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"styling-devtools.token.d.ts","sourceRoot":"","sources":["../../src/devkit/styling-devtools.token.ts"],"names":[],"mappings":"AAAA,OAAO,
|
|
1
|
+
{"version":3,"file":"styling-devtools.token.d.ts","sourceRoot":"","sources":["../../src/devkit/styling-devtools.token.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,cAAc,EACf,MAAM,eAAe,CAAC;AACvB,OAAO,KAAK,EACV,6BAA6B,EAC9B,MAAM,4BAA4B,CAAC;AAEpC;;GAEG;AACH,eAAO,MAAM,sCAAsC,EAAE,6BAGpD,CAAC;AAEF;;GAEG;AACH,eAAO,MAAM,8BAA8B,EAAE,cAAc,CAAC,6BAA6B,CAAuF,CAAC"}
|
package/esm2022/breakpoints.mjs
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Breakpoints } from '@angular/cdk/layout';
|
|
1
|
+
import { Breakpoints, } from '@angular/cdk/layout';
|
|
2
2
|
/**
|
|
3
3
|
* Angular CDK Breakpoints to detect devices
|
|
4
4
|
* @deprecated use Breakpoints exported by @angular/cdk instead, will be removed in v12
|
|
@@ -7,4 +7,4 @@ export const deviceBreakpoints = {
|
|
|
7
7
|
mobile: [Breakpoints.HandsetLandscape, Breakpoints.HandsetPortrait],
|
|
8
8
|
tablet: [Breakpoints.TabletLandscape, Breakpoints.TabletPortrait]
|
|
9
9
|
};
|
|
10
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
10
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnJlYWtwb2ludHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvYnJlYWtwb2ludHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUNMLFdBQVcsR0FDWixNQUFNLHFCQUFxQixDQUFDO0FBRTdCOzs7R0FHRztBQUNILE1BQU0sQ0FBQyxNQUFNLGlCQUFpQixHQUFHO0lBQy9CLE1BQU0sRUFBRSxDQUFDLFdBQVcsQ0FBQyxnQkFBZ0IsRUFBRSxXQUFXLENBQUMsZUFBZSxDQUFDO0lBQ25FLE1BQU0sRUFBRSxDQUFDLFdBQVcsQ0FBQyxlQUFlLEVBQUUsV0FBVyxDQUFDLGNBQWMsQ0FBQztDQUNsRSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgQnJlYWtwb2ludHMsXG59IGZyb20gJ0Bhbmd1bGFyL2Nkay9sYXlvdXQnO1xuXG4vKipcbiAqIEFuZ3VsYXIgQ0RLIEJyZWFrcG9pbnRzIHRvIGRldGVjdCBkZXZpY2VzXG4gKiBAZGVwcmVjYXRlZCB1c2UgQnJlYWtwb2ludHMgZXhwb3J0ZWQgYnkgQGFuZ3VsYXIvY2RrIGluc3RlYWQsIHdpbGwgYmUgcmVtb3ZlZCBpbiB2MTJcbiAqL1xuZXhwb3J0IGNvbnN0IGRldmljZUJyZWFrcG9pbnRzID0ge1xuICBtb2JpbGU6IFtCcmVha3BvaW50cy5IYW5kc2V0TGFuZHNjYXBlLCBCcmVha3BvaW50cy5IYW5kc2V0UG9ydHJhaXRdLFxuICB0YWJsZXQ6IFtCcmVha3BvaW50cy5UYWJsZXRMYW5kc2NhcGUsIEJyZWFrcG9pbnRzLlRhYmxldFBvcnRyYWl0XVxufTtcbiJdfQ==
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3R5bGVzLmludGVyZmFjZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb3JlL3N0eWxlcy5pbnRlcmZhY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHtcbiAgSXRlbUlkZW50aWZpZXIsXG59IGZyb20gJ0BvM3IvY29yZSc7XG5cbmV4cG9ydCB0eXBlIENzc1ZhcmlhYmxlVHlwZSA9ICdzdHJpbmcnIHwgJ2NvbG9yJztcblxuLyoqIE1ldGFkYXRhIGZvciBhIENTUyBWYXJpYWJsZSAqL1xuZXhwb3J0IGludGVyZmFjZSBDc3NWYXJpYWJsZSB7XG4gIC8qKiBOYW1lIG9mIHRoZSB2YXJpYWJsZSAqL1xuICBuYW1lOiBzdHJpbmc7XG4gIC8qKiBEZWZhdWx0IHZhbHVlIG9mIHRoZSB2YXJpYWJsZSAqL1xuICBkZWZhdWx0VmFsdWU6IHN0cmluZztcbiAgLyoqIFJlZmVyZW5jZXMgb2YgdGhlIHZhcmlhYmxlICovXG4gIHJlZmVyZW5jZXM/OiBDc3NWYXJpYWJsZVtdO1xuICAvKiogVGFncyBvZiB0aGUgdmFyaWFibGUgKi9cbiAgdGFncz86IHN0cmluZ1tdO1xuICAvKiogRGVzY3JpcHRpb24gb2YgdGhlIHZhcmlhYmxlICovXG4gIGRlc2NyaXB0aW9uPzogc3RyaW5nO1xuICAvKiogRGVzY3JpcHRpb24gb2YgdGhlIHZhcmlhYmxlICovXG4gIGxhYmVsPzogc3RyaW5nO1xuICAvKiogVHlwZSBvZiB0aGUgdmFyaWFibGUgKi9cbiAgdHlwZT86IENzc1ZhcmlhYmxlVHlwZTtcbiAgLyoqIE5hbWUgb2YgYSBncm91cCBvZiB2YXJpYWJsZXMgKi9cbiAgY2F0ZWdvcnk/OiBzdHJpbmc7XG4gIC8qKiBjb21wb25lbnQgcmVmZXJlbmNlIGlmIHRoZSB2YXJpYWJsZSBpcyBsaW5rZWQgdG8gb25lICovXG4gIGNvbXBvbmVudD86IEl0ZW1JZGVudGlmaWVyO1xufVxuXG4vKiogU3R5bGUgTWV0YWRhdGEgbWFwICovXG5leHBvcnQgaW50ZXJmYWNlIENzc01ldGFkYXRhIHtcbiAgLyoqIFZhcmlhYmxlcycgZGljdGlvbmFyeSAqL1xuICB2YXJpYWJsZXM6IHtcbiAgICBbbmFtZTogc3RyaW5nXTogQ3NzVmFyaWFibGU7XG4gIH07XG59XG4iXX0=
|
package/esm2022/devkit/index.mjs
CHANGED
|
@@ -3,4 +3,4 @@ export * from './styling-devtools.message.service';
|
|
|
3
3
|
export * from './styling-devtools.module';
|
|
4
4
|
export * from './styling-devtools.service';
|
|
5
5
|
export * from './styling-devtools.token';
|
|
6
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
6
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvZGV2a2l0L2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsNEJBQTRCLENBQUM7QUFDM0MsY0FBYyxvQ0FBb0MsQ0FBQztBQUNuRCxjQUFjLDJCQUEyQixDQUFDO0FBQzFDLGNBQWMsNEJBQTRCLENBQUM7QUFDM0MsY0FBYywwQkFBMEIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vc3R5bGluZy1kZXZraXQuaW50ZXJmYWNlJztcbmV4cG9ydCAqIGZyb20gJy4vc3R5bGluZy1kZXZ0b29scy5tZXNzYWdlLnNlcnZpY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9zdHlsaW5nLWRldnRvb2xzLm1vZHVsZSc7XG5leHBvcnQgKiBmcm9tICcuL3N0eWxpbmctZGV2dG9vbHMuc2VydmljZSc7XG5leHBvcnQgKiBmcm9tICcuL3N0eWxpbmctZGV2dG9vbHMudG9rZW4nO1xuIl19
|
|
@@ -2,4 +2,4 @@
|
|
|
2
2
|
export const THEME_TAG_NAME = 'theme';
|
|
3
3
|
/** Tag to identify palette variable */
|
|
4
4
|
export const PALETTE_TAG_NAME = 'palette';
|
|
5
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3R5bGluZy1kZXZraXQuaW50ZXJmYWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2RldmtpdC9zdHlsaW5nLWRldmtpdC5pbnRlcmZhY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBMkRBLHFDQUFxQztBQUNyQyxNQUFNLENBQUMsTUFBTSxjQUFjLEdBQUcsT0FBTyxDQUFDO0FBRXRDLHVDQUF1QztBQUN2QyxNQUFNLENBQUMsTUFBTSxnQkFBZ0IsR0FBRyxTQUFTLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7XG4gIENvbm5lY3RDb250ZW50TWVzc2FnZSxcbiAgRGV2dG9vbHNDb21tb25PcHRpb25zLFxuICBNZXNzYWdlRGF0YVR5cGVzLFxuICBPdHRlck1lc3NhZ2VDb250ZW50LFxuICBSZXF1ZXN0TWVzc2FnZXNDb250ZW50TWVzc2FnZSxcbn0gZnJvbSAnQG8zci9jb3JlJztcbmltcG9ydCB7XG4gIENzc1ZhcmlhYmxlLFxufSBmcm9tICcuLi9jb3JlL2luZGV4JztcblxuLyoqXG4gKiBTdHlsaW5nIGRldnRvb2xzIHNlcnZpY2Ugb3B0aW9uc1xuICovXG5leHBvcnQgaW50ZXJmYWNlIFN0eWxpbmdEZXZ0b29sc1NlcnZpY2VPcHRpb25zIGV4dGVuZHMgRGV2dG9vbHNDb21tb25PcHRpb25zIHtcbiAgLyoqXG4gICAqIFBhdGggdG8gcmV0cmlldmUgdGhlIHN0eWxpbmcgbWV0YWRhdGEgZmlsZVxuICAgKi9cbiAgc3R5bGluZ01ldGFkYXRhUGF0aDogc3RyaW5nO1xufVxuXG4vKiogVXBkYXRlIHN0eWxpbmcgdmFyaWFibGVzICovXG5leHBvcnQgaW50ZXJmYWNlIFVwZGF0ZVN0eWxpbmdWYXJpYWJsZXNDb250ZW50TWVzc2FnZSBleHRlbmRzIE90dGVyTWVzc2FnZUNvbnRlbnQ8J3VwZGF0ZVN0eWxpbmdWYXJpYWJsZXMnPiB7XG4gIC8qKlxuICAgKiBEaWN0aW9uYXJ5IG9mIHZhcmlhYmxlIHZhbHVlIHRvIHVwZGF0ZVxuICAgKiBpbmRleGVkIGJ5IHRoZSB2YXJpYWJsZSBuYW1lXG4gICAqL1xuICB2YXJpYWJsZXM6IFJlY29yZDxzdHJpbmcsIHN0cmluZz47XG59XG5cbi8qKiBSZXNldCBzdHlsaW5nIHZhcmlhYmxlcyBvdmVycmlkZSAqL1xuZXhwb3J0IGludGVyZmFjZSBSZXNldFN0eWxpbmdWYXJpYWJsZXNDb250ZW50TWVzc2FnZSBleHRlbmRzIE90dGVyTWVzc2FnZUNvbnRlbnQ8J3Jlc2V0U3R5bGluZ1ZhcmlhYmxlcyc+IHt9XG5cbi8qKiBTdHlsaW5nIHZhcmlhYmxlICovXG5leHBvcnQgdHlwZSBTdHlsaW5nVmFyaWFibGUgPSBDc3NWYXJpYWJsZSAmIHsgcnVudGltZVZhbHVlPzogc3RyaW5nIH07XG5cbi8qKiBHZXQgc3R5bGluZyB2YXJpYWJsZXMgKi9cbmV4cG9ydCBpbnRlcmZhY2UgR2V0U3R5bGluZ1ZhcmlhYmxlQ29udGVudE1lc3NhZ2UgZXh0ZW5kcyBPdHRlck1lc3NhZ2VDb250ZW50PCdnZXRTdHlsaW5nVmFyaWFibGUnPiB7XG4gIC8qKiBMaXN0IG9mIHN0eWxpbmcgdmFyaWFibGVzICovXG4gIHZhcmlhYmxlczogU3R5bGluZ1ZhcmlhYmxlW107XG59XG5cbi8qKlxuICogTGlzdCBvZiBzdHlsaW5nIG1lc3NhZ2UgY29udGVudHNcbiAqL1xudHlwZSBTdHlsaW5nTWVzc2FnZUNvbnRlbnRzID1cbiAgfCBVcGRhdGVTdHlsaW5nVmFyaWFibGVzQ29udGVudE1lc3NhZ2VcbiAgfCBSZXNldFN0eWxpbmdWYXJpYWJsZXNDb250ZW50TWVzc2FnZVxuICB8IEdldFN0eWxpbmdWYXJpYWJsZUNvbnRlbnRNZXNzYWdlO1xuXG4vKiogTGlzdCBvZiBwb3NzaWJsZSBEYXRhVHlwZXMgZm9yIFN0eWxpbmcgbWVzc2FnZXMgKi9cbmV4cG9ydCB0eXBlIFN0eWxpbmdNZXNzYWdlRGF0YVR5cGVzID0gTWVzc2FnZURhdGFUeXBlczxTdHlsaW5nTWVzc2FnZUNvbnRlbnRzPjtcblxuLyoqIExpc3Qgb2YgYWxsIG1lc3NhZ2VzIGZvciBTdHlsaW5nIHB1cnBvc2VzICovXG5leHBvcnQgdHlwZSBBdmFpbGFibGVTdHlsaW5nTWVzc2FnZUNvbnRlbnRzID1cbiAgfCBTdHlsaW5nTWVzc2FnZUNvbnRlbnRzXG4gIHwgQ29ubmVjdENvbnRlbnRNZXNzYWdlXG4gIHwgUmVxdWVzdE1lc3NhZ2VzQ29udGVudE1lc3NhZ2U8U3R5bGluZ01lc3NhZ2VEYXRhVHlwZXM+O1xuXG4vKiogVGFnIHRvIGlkZW50aWZ5IHRoZW1lIHZhcmlhYmxlICovXG5leHBvcnQgY29uc3QgVEhFTUVfVEFHX05BTUUgPSAndGhlbWUnO1xuXG4vKiogVGFnIHRvIGlkZW50aWZ5IHBhbGV0dGUgdmFyaWFibGUgKi9cbmV4cG9ydCBjb25zdCBQQUxFVFRFX1RBR19OQU1FID0gJ3BhbGV0dGUnO1xuIl19
|
|
@@ -1,9 +1,10 @@
|
|
|
1
|
-
|
|
2
|
-
import {
|
|
3
|
-
import {
|
|
4
|
-
import {
|
|
5
|
-
import {
|
|
6
|
-
import {
|
|
1
|
+
/* eslint-disable no-console -- this is the purpose of this service */
|
|
2
|
+
import { Inject, Injectable, Optional, } from '@angular/core';
|
|
3
|
+
import { filterMessageContent, sendOtterMessage, } from '@o3r/core';
|
|
4
|
+
import { LoggerService, } from '@o3r/logger';
|
|
5
|
+
import { fromEvent, Subscription, } from 'rxjs';
|
|
6
|
+
import { OtterStylingDevtools, } from './styling-devtools.service';
|
|
7
|
+
import { OTTER_STYLING_DEVTOOLS_DEFAULT_OPTIONS, OTTER_STYLING_DEVTOOLS_OPTIONS, } from './styling-devtools.token';
|
|
7
8
|
import * as i0 from "@angular/core";
|
|
8
9
|
import * as i1 from "@o3r/logger";
|
|
9
10
|
import * as i2 from "./styling-devtools.service";
|
|
@@ -82,8 +83,7 @@ export class StylingDevtoolsMessageService {
|
|
|
82
83
|
}
|
|
83
84
|
/**
|
|
84
85
|
* Function to handle the incoming messages from Otter Chrome DevTools extension
|
|
85
|
-
* @param
|
|
86
|
-
* @param message
|
|
86
|
+
* @param message Message coming from the Otter Chrome DevTools extension
|
|
87
87
|
*/
|
|
88
88
|
handleEvents(message) {
|
|
89
89
|
this.logger.debug('Message handling by the styling service', message);
|
|
@@ -134,4 +134,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImpo
|
|
|
134
134
|
type: Inject,
|
|
135
135
|
args: [OTTER_STYLING_DEVTOOLS_OPTIONS]
|
|
136
136
|
}] }] });
|
|
137
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"styling-devtools.message.service.js","sourceRoot":"","sources":["../../../src/devkit/styling-devtools.message.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Inject, Injectable, OnDestroy, Optional } from '@angular/core';\nimport { filterMessageContent, sendOtterMessage } from '@o3r/core';\nimport { LoggerService } from '@o3r/logger';\nimport { fromEvent, Subscription } from 'rxjs';\nimport { AvailableStylingMessageContents, StylingDevtoolsServiceOptions, StylingMessageDataTypes } from './styling-devkit.interface';\nimport { OtterStylingDevtools } from './styling-devtools.service';\nimport { OTTER_STYLING_DEVTOOLS_DEFAULT_OPTIONS, OTTER_STYLING_DEVTOOLS_OPTIONS } from './styling-devtools.token';\n\nconst isStylingMessage = (message: any): message is AvailableStylingMessageContents => {\n  return message && (\n    message.dataType === 'updateStylingVariables'\n    || message.dataType === 'resetStylingVariables'\n    || message.dataType === 'getStylingVariable'\n    || message.dataType === 'requestMessages'\n    || message.dataType === 'connect'\n  );\n};\n\nconst getCSSRulesAppliedOnRoot = () => Array.from(document.styleSheets)\n  .reverse()\n  .reduce((acc: CSSStyleRule[], styleSheet) => {\n    let rules;\n    try {\n      rules = styleSheet.cssRules || styleSheet.rules;\n    } catch (err) {\n      console.debug(`Could not access to stylesheet ${styleSheet.href}. This might be due to network issues, please check:\n- network connectivity\n- CORS setup\n- granted access to the stylesheet`, err);\n    }\n\n    return acc.concat(\n      Array.from(rules || [])\n        .reverse()\n        .filter((rule): rule is CSSStyleRule => rule instanceof CSSStyleRule && /\\b:root\\b/.test(rule.selectorText))\n    );\n  }, []);\n\nconst getCSSVariableValueInCSSStyleDeclaration = (variableName: string, style: CSSStyleDeclaration) =>\n  style.getPropertyValue(variableName).trim();\n\nconst getCSSVariableValue = (variableName: string, cssRules: CSSStyleRule[]) => {\n  const inlineValue = getCSSVariableValueInCSSStyleDeclaration(variableName, document.querySelector('html')!.style);\n  if (inlineValue) {\n    return inlineValue;\n  }\n\n  for (const rule of cssRules) {\n    const ruleValue = getCSSVariableValueInCSSStyleDeclaration(variableName, rule.style);\n    if (ruleValue) {\n      return ruleValue;\n    }\n  }\n};\n\n/**\n * Service to handle communication between application and chrome extension for styling\n */\n@Injectable()\nexport class StylingDevtoolsMessageService implements OnDestroy {\n\n  private readonly subscriptions = new Subscription();\n\n  private readonly sendMessage = sendOtterMessage<AvailableStylingMessageContents>;\n\n  constructor(\n      private readonly logger: LoggerService,\n      private readonly stylingDevTools: OtterStylingDevtools,\n    @Optional() @Inject(OTTER_STYLING_DEVTOOLS_OPTIONS) private readonly options: StylingDevtoolsServiceOptions = OTTER_STYLING_DEVTOOLS_DEFAULT_OPTIONS) {\n    this.options = {\n      ...OTTER_STYLING_DEVTOOLS_DEFAULT_OPTIONS,\n      ...this.options\n    };\n    if (this.options.isActivatedOnBootstrap) {\n      this.activate();\n    }\n  }\n\n  private async sendMetadata() {\n    const metadata = await this.stylingDevTools.getStylingMetadata(this.options.stylingMetadataPath);\n    const cssRules = getCSSRulesAppliedOnRoot();\n    const variables = Object.values(metadata.variables).map((variable) => ({\n      ...variable,\n      runtimeValue: getCSSVariableValue(`--${variable.name}`, cssRules)\n    }));\n    this.sendMessage('getStylingVariable', { variables });\n  }\n\n  /**\n   * Function to trigger a re-send a requested messages to the Otter Chrome DevTools extension\n   * @param only restricted list of messages to re-send\n   */\n  private handleReEmitRequest(only?: StylingMessageDataTypes[]) {\n    if (!only || only.includes('getStylingVariable')) {\n      return this.sendMetadata();\n    }\n  }\n\n  /**\n   * Function to handle the incoming messages from Otter Chrome DevTools extension\n   * @param event Event coming from the Otter Chrome DevTools extension\n   * @param message\n   */\n  private handleEvents(message: AvailableStylingMessageContents) {\n    this.logger.debug('Message handling by the styling service', message);\n\n    switch (message.dataType) {\n      case 'connect': {\n        this.connectPlugin();\n        break;\n      }\n      case 'requestMessages': {\n        void this.handleReEmitRequest(message.only);\n        break;\n      }\n      case 'updateStylingVariables': {\n        this.stylingDevTools.updateVariables(message.variables);\n        break;\n      }\n      case 'resetStylingVariables': {\n        this.stylingDevTools.resetStylingVariables();\n        break;\n      }\n      default: {\n        this.logger.warn('Message ignored by the styling service', message);\n      }\n    }\n  }\n\n  /**\n   * Function to connect the plugin to the Otter Chrome DevTools extension\n   */\n  private connectPlugin() {\n    this.logger.debug('Otter DevTools is plugged to styling service of the application');\n  }\n\n  /** @inheritDoc */\n  public activate() {\n    this.subscriptions.add(\n      fromEvent(window, 'message').pipe(filterMessageContent(isStylingMessage)).subscribe((e) => this.handleEvents(e))\n    );\n  }\n\n  /** @inheritDoc */\n  public ngOnDestroy() {\n    this.subscriptions.unsubscribe();\n  }\n}\n"]}
|
|
137
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"styling-devtools.message.service.js","sourceRoot":"","sources":["../../../src/devkit/styling-devtools.message.service.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable no-console -- this is the purpose of this service */\nimport {\n  Inject,\n  Injectable,\n  OnDestroy,\n  Optional,\n} from '@angular/core';\nimport {\n  filterMessageContent,\n  sendOtterMessage,\n} from '@o3r/core';\nimport {\n  LoggerService,\n} from '@o3r/logger';\nimport {\n  fromEvent,\n  Subscription,\n} from 'rxjs';\nimport {\n  AvailableStylingMessageContents,\n  StylingDevtoolsServiceOptions,\n  StylingMessageDataTypes,\n} from './styling-devkit.interface';\nimport {\n  OtterStylingDevtools,\n} from './styling-devtools.service';\nimport {\n  OTTER_STYLING_DEVTOOLS_DEFAULT_OPTIONS,\n  OTTER_STYLING_DEVTOOLS_OPTIONS,\n} from './styling-devtools.token';\n\nconst isStylingMessage = (message: any): message is AvailableStylingMessageContents => {\n  return message && (\n    message.dataType === 'updateStylingVariables'\n    || message.dataType === 'resetStylingVariables'\n    || message.dataType === 'getStylingVariable'\n    || message.dataType === 'requestMessages'\n    || message.dataType === 'connect'\n  );\n};\n\nconst getCSSRulesAppliedOnRoot = () => Array.from(document.styleSheets)\n  .reverse()\n  .reduce((acc: CSSStyleRule[], styleSheet) => {\n    let rules;\n    try {\n      rules = styleSheet.cssRules || styleSheet.rules;\n    } catch (err) {\n      console.debug(`Could not access to stylesheet ${styleSheet.href}. This might be due to network issues, please check:\n- network connectivity\n- CORS setup\n- granted access to the stylesheet`, err);\n    }\n\n    return acc.concat(\n      Array.from(rules || [])\n        .reverse()\n        .filter((rule): rule is CSSStyleRule => rule instanceof CSSStyleRule && /\\b:root\\b/.test(rule.selectorText))\n    );\n  }, []);\n\nconst getCSSVariableValueInCSSStyleDeclaration = (variableName: string, style: CSSStyleDeclaration) =>\n  style.getPropertyValue(variableName).trim();\n\nconst getCSSVariableValue = (variableName: string, cssRules: CSSStyleRule[]) => {\n  const inlineValue = getCSSVariableValueInCSSStyleDeclaration(variableName, document.querySelector('html')!.style);\n  if (inlineValue) {\n    return inlineValue;\n  }\n\n  for (const rule of cssRules) {\n    const ruleValue = getCSSVariableValueInCSSStyleDeclaration(variableName, rule.style);\n    if (ruleValue) {\n      return ruleValue;\n    }\n  }\n};\n\n/**\n * Service to handle communication between application and chrome extension for styling\n */\n@Injectable()\nexport class StylingDevtoolsMessageService implements OnDestroy {\n  private readonly subscriptions = new Subscription();\n\n  private readonly sendMessage = sendOtterMessage<AvailableStylingMessageContents>;\n\n  constructor(\n    private readonly logger: LoggerService,\n    private readonly stylingDevTools: OtterStylingDevtools,\n    @Optional() @Inject(OTTER_STYLING_DEVTOOLS_OPTIONS) private readonly options: StylingDevtoolsServiceOptions = OTTER_STYLING_DEVTOOLS_DEFAULT_OPTIONS) {\n    this.options = {\n      ...OTTER_STYLING_DEVTOOLS_DEFAULT_OPTIONS,\n      ...this.options\n    };\n    if (this.options.isActivatedOnBootstrap) {\n      this.activate();\n    }\n  }\n\n  private async sendMetadata() {\n    const metadata = await this.stylingDevTools.getStylingMetadata(this.options.stylingMetadataPath);\n    const cssRules = getCSSRulesAppliedOnRoot();\n    const variables = Object.values(metadata.variables).map((variable) => ({\n      ...variable,\n      runtimeValue: getCSSVariableValue(`--${variable.name}`, cssRules)\n    }));\n    this.sendMessage('getStylingVariable', { variables });\n  }\n\n  /**\n   * Function to trigger a re-send a requested messages to the Otter Chrome DevTools extension\n   * @param only restricted list of messages to re-send\n   */\n  private handleReEmitRequest(only?: StylingMessageDataTypes[]) {\n    if (!only || only.includes('getStylingVariable')) {\n      return this.sendMetadata();\n    }\n  }\n\n  /**\n   * Function to handle the incoming messages from Otter Chrome DevTools extension\n   * @param message Message coming from the Otter Chrome DevTools extension\n   */\n  private handleEvents(message: AvailableStylingMessageContents) {\n    this.logger.debug('Message handling by the styling service', message);\n\n    switch (message.dataType) {\n      case 'connect': {\n        this.connectPlugin();\n        break;\n      }\n      case 'requestMessages': {\n        void this.handleReEmitRequest(message.only);\n        break;\n      }\n      case 'updateStylingVariables': {\n        this.stylingDevTools.updateVariables(message.variables);\n        break;\n      }\n      case 'resetStylingVariables': {\n        this.stylingDevTools.resetStylingVariables();\n        break;\n      }\n      default: {\n        this.logger.warn('Message ignored by the styling service', message);\n      }\n    }\n  }\n\n  /**\n   * Function to connect the plugin to the Otter Chrome DevTools extension\n   */\n  private connectPlugin() {\n    this.logger.debug('Otter DevTools is plugged to styling service of the application');\n  }\n\n  /** @inheritDoc */\n  public activate() {\n    this.subscriptions.add(\n      fromEvent(window, 'message').pipe(filterMessageContent(isStylingMessage)).subscribe((e) => this.handleEvents(e))\n    );\n  }\n\n  /** @inheritDoc */\n  public ngOnDestroy() {\n    this.subscriptions.unsubscribe();\n  }\n}\n"]}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
import { NgModule } from '@angular/core';
|
|
2
|
-
import { StylingDevtoolsMessageService } from './styling-devtools.message.service';
|
|
3
|
-
import { OtterStylingDevtools } from './styling-devtools.service';
|
|
4
|
-
import { OTTER_STYLING_DEVTOOLS_DEFAULT_OPTIONS, OTTER_STYLING_DEVTOOLS_OPTIONS } from './styling-devtools.token';
|
|
1
|
+
import { NgModule, } from '@angular/core';
|
|
2
|
+
import { StylingDevtoolsMessageService, } from './styling-devtools.message.service';
|
|
3
|
+
import { OtterStylingDevtools, } from './styling-devtools.service';
|
|
4
|
+
import { OTTER_STYLING_DEVTOOLS_DEFAULT_OPTIONS, OTTER_STYLING_DEVTOOLS_OPTIONS, } from './styling-devtools.token';
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
6
6
|
export class StylingDevtoolsModule {
|
|
7
7
|
/**
|
|
@@ -36,4 +36,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImpo
|
|
|
36
36
|
]
|
|
37
37
|
}]
|
|
38
38
|
}] });
|
|
39
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
39
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3R5bGluZy1kZXZ0b29scy5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvZGV2a2l0L3N0eWxpbmctZGV2dG9vbHMubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFFTCxRQUFRLEdBQ1QsTUFBTSxlQUFlLENBQUM7QUFJdkIsT0FBTyxFQUNMLDZCQUE2QixHQUM5QixNQUFNLG9DQUFvQyxDQUFDO0FBQzVDLE9BQU8sRUFDTCxvQkFBb0IsR0FDckIsTUFBTSw0QkFBNEIsQ0FBQztBQUNwQyxPQUFPLEVBQ0wsc0NBQXNDLEVBQ3RDLDhCQUE4QixHQUMvQixNQUFNLDBCQUEwQixDQUFDOztBQVNsQyxNQUFNLE9BQU8scUJBQXFCO0lBQ2hDOzs7T0FHRztJQUNJLE1BQU0sQ0FBQyxVQUFVLENBQUMsT0FBK0M7UUFDdEUsT0FBTztZQUNMLFFBQVEsRUFBRSxxQkFBcUI7WUFDL0IsU0FBUyxFQUFFO2dCQUNULEVBQUUsT0FBTyxFQUFFLDhCQUE4QixFQUFFLFFBQVEsRUFBRSxFQUFFLEdBQUcsc0NBQXNDLEVBQUUsR0FBRyxPQUFPLEVBQUUsRUFBRSxLQUFLLEVBQUUsS0FBSyxFQUFFO2dCQUM5SCw2QkFBNkI7Z0JBQzdCLG9CQUFvQjthQUNyQjtTQUNGLENBQUM7SUFDSixDQUFDO2tJQWRVLHFCQUFxQjttSUFBckIscUJBQXFCO21JQUFyQixxQkFBcUIsYUFOckI7WUFDVCxFQUFFLE9BQU8sRUFBRSw4QkFBOEIsRUFBRSxRQUFRLEVBQUUsc0NBQXNDLEVBQUU7WUFDN0YsNkJBQTZCO1lBQzdCLG9CQUFvQjtTQUNyQjs7NEZBRVUscUJBQXFCO2tCQVBqQyxRQUFRO21CQUFDO29CQUNSLFNBQVMsRUFBRTt3QkFDVCxFQUFFLE9BQU8sRUFBRSw4QkFBOEIsRUFBRSxRQUFRLEVBQUUsc0NBQXNDLEVBQUU7d0JBQzdGLDZCQUE2Qjt3QkFDN0Isb0JBQW9CO3FCQUNyQjtpQkFDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIE1vZHVsZVdpdGhQcm92aWRlcnMsXG4gIE5nTW9kdWxlLFxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB0eXBlIHtcbiAgU3R5bGluZ0RldnRvb2xzU2VydmljZU9wdGlvbnMsXG59IGZyb20gJy4vc3R5bGluZy1kZXZraXQuaW50ZXJmYWNlJztcbmltcG9ydCB7XG4gIFN0eWxpbmdEZXZ0b29sc01lc3NhZ2VTZXJ2aWNlLFxufSBmcm9tICcuL3N0eWxpbmctZGV2dG9vbHMubWVzc2FnZS5zZXJ2aWNlJztcbmltcG9ydCB7XG4gIE90dGVyU3R5bGluZ0RldnRvb2xzLFxufSBmcm9tICcuL3N0eWxpbmctZGV2dG9vbHMuc2VydmljZSc7XG5pbXBvcnQge1xuICBPVFRFUl9TVFlMSU5HX0RFVlRPT0xTX0RFRkFVTFRfT1BUSU9OUyxcbiAgT1RURVJfU1RZTElOR19ERVZUT09MU19PUFRJT05TLFxufSBmcm9tICcuL3N0eWxpbmctZGV2dG9vbHMudG9rZW4nO1xuXG5ATmdNb2R1bGUoe1xuICBwcm92aWRlcnM6IFtcbiAgICB7IHByb3ZpZGU6IE9UVEVSX1NUWUxJTkdfREVWVE9PTFNfT1BUSU9OUywgdXNlVmFsdWU6IE9UVEVSX1NUWUxJTkdfREVWVE9PTFNfREVGQVVMVF9PUFRJT05TIH0sXG4gICAgU3R5bGluZ0RldnRvb2xzTWVzc2FnZVNlcnZpY2UsXG4gICAgT3R0ZXJTdHlsaW5nRGV2dG9vbHNcbiAgXVxufSlcbmV4cG9ydCBjbGFzcyBTdHlsaW5nRGV2dG9vbHNNb2R1bGUge1xuICAvKipcbiAgICogSW5pdGlhbGl6ZSBPdHRlciBEZXZ0b29sc1xuICAgKiBAcGFyYW0gb3B0aW9uc1xuICAgKi9cbiAgcHVibGljIHN0YXRpYyBpbnN0cnVtZW50KG9wdGlvbnM6IFBhcnRpYWw8U3R5bGluZ0RldnRvb2xzU2VydmljZU9wdGlvbnM+KTogTW9kdWxlV2l0aFByb3ZpZGVyczxTdHlsaW5nRGV2dG9vbHNNb2R1bGU+IHtcbiAgICByZXR1cm4ge1xuICAgICAgbmdNb2R1bGU6IFN0eWxpbmdEZXZ0b29sc01vZHVsZSxcbiAgICAgIHByb3ZpZGVyczogW1xuICAgICAgICB7IHByb3ZpZGU6IE9UVEVSX1NUWUxJTkdfREVWVE9PTFNfT1BUSU9OUywgdXNlVmFsdWU6IHsgLi4uT1RURVJfU1RZTElOR19ERVZUT09MU19ERUZBVUxUX09QVElPTlMsIC4uLm9wdGlvbnMgfSwgbXVsdGk6IGZhbHNlIH0sXG4gICAgICAgIFN0eWxpbmdEZXZ0b29sc01lc3NhZ2VTZXJ2aWNlLFxuICAgICAgICBPdHRlclN0eWxpbmdEZXZ0b29sc1xuICAgICAgXVxuICAgIH07XG4gIH1cbn1cbiJdfQ==
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { DOCUMENT } from '@angular/common';
|
|
2
|
-
import { inject, Injectable } from '@angular/core';
|
|
1
|
+
import { DOCUMENT, } from '@angular/common';
|
|
2
|
+
import { inject, Injectable, } from '@angular/core';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
4
|
/**
|
|
5
5
|
* Styling devtools service
|
|
@@ -41,4 +41,4 @@ export class OtterStylingDevtools {
|
|
|
41
41
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: OtterStylingDevtools, decorators: [{
|
|
42
42
|
type: Injectable
|
|
43
43
|
}] });
|
|
44
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
44
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3R5bGluZy1kZXZ0b29scy5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2RldmtpdC9zdHlsaW5nLWRldnRvb2xzLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUNMLFFBQVEsR0FDVCxNQUFNLGlCQUFpQixDQUFDO0FBQ3pCLE9BQU8sRUFDTCxNQUFNLEVBQ04sVUFBVSxHQUNYLE1BQU0sZUFBZSxDQUFDOztBQUt2Qjs7R0FFRztBQUVILE1BQU0sT0FBTyxvQkFBb0I7SUFEakM7UUFFbUIsYUFBUSxHQUFHLE1BQU0sQ0FBQyxRQUFRLENBQUMsQ0FBQztLQStCOUM7SUE3QkM7OztPQUdHO0lBQ0ksS0FBSyxDQUFDLGtCQUFrQixDQUFDLG1CQUEyQjtRQUN6RCxPQUFPLENBQUMsTUFBTSxLQUFLLENBQUMsbUJBQW1CLENBQUMsQ0FBQyxDQUFDLElBQUksRUFBRSxDQUFDO0lBQ25ELENBQUM7SUFFRDs7O09BR0c7SUFDSSxlQUFlLENBQUMsU0FBaUM7UUFDdEQsTUFBTSxDQUFDLE9BQU8sQ0FBQyxTQUFTLENBQUMsQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLE9BQU8sRUFBRSxLQUFLLENBQUMsRUFBRSxFQUFFLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxhQUFhLENBQUMsTUFBTSxDQUFFLENBQUMsS0FBSyxDQUFDLFdBQVcsQ0FBQyxLQUFLLE9BQU8sRUFBRSxFQUFFLEtBQUssQ0FBQyxDQUFDLENBQUM7SUFDekksQ0FBQztJQUVEOztPQUVHO0lBQ0kscUJBQXFCO1FBQzFCLE1BQU0sS0FBSyxHQUFHLElBQUksQ0FBQyxRQUFRLENBQUMsYUFBYSxDQUFDLE1BQU0sQ0FBRSxDQUFDLEtBQUssQ0FBQztRQUN6RCxLQUFLLENBQUMsT0FBTzthQUNWLEtBQUssQ0FBQyxTQUFTLENBQUM7YUFDaEIsTUFBTSxDQUFDLENBQUMsR0FBYSxFQUFFLEdBQUcsRUFBRSxFQUFFO1lBQzdCLE1BQU0sS0FBSyxHQUFHLEdBQUcsRUFBRSxLQUFLLENBQUMsVUFBVSxDQUFDLENBQUM7WUFDckMsT0FBTyxLQUFLLENBQUMsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLEdBQUcsQ0FBQztRQUM1QyxDQUFDLEVBQUUsRUFBRSxDQUFDO2FBQ0wsT0FBTyxDQUFDLENBQUMsT0FBTyxFQUFFLEVBQUUsQ0FBQyxLQUFLLENBQUMsY0FBYyxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUM7SUFDekQsQ0FBQztrSUEvQlUsb0JBQW9CO3NJQUFwQixvQkFBb0I7OzRGQUFwQixvQkFBb0I7a0JBRGhDLFVBQVUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBET0NVTUVOVCxcbn0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7XG4gIGluamVjdCxcbiAgSW5qZWN0YWJsZSxcbn0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgdHlwZSB7XG4gIENzc01ldGFkYXRhLFxufSBmcm9tICcuLi9jb3JlL2luZGV4JztcblxuLyoqXG4gKiBTdHlsaW5nIGRldnRvb2xzIHNlcnZpY2VcbiAqL1xuQEluamVjdGFibGUoKVxuZXhwb3J0IGNsYXNzIE90dGVyU3R5bGluZ0RldnRvb2xzIHtcbiAgcHJpdmF0ZSByZWFkb25seSBkb2N1bWVudCA9IGluamVjdChET0NVTUVOVCk7XG5cbiAgLyoqXG4gICAqIFJldHJpZXZlIHN0eWxpbmcgbWV0YWRhdGFcbiAgICogQHBhcmFtIHN0eWxpbmdNZXRhZGF0YVBhdGhcbiAgICovXG4gIHB1YmxpYyBhc3luYyBnZXRTdHlsaW5nTWV0YWRhdGEoc3R5bGluZ01ldGFkYXRhUGF0aDogc3RyaW5nKTogUHJvbWlzZTxDc3NNZXRhZGF0YT4ge1xuICAgIHJldHVybiAoYXdhaXQgZmV0Y2goc3R5bGluZ01ldGFkYXRhUGF0aCkpLmpzb24oKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBVcGRhdGUgc3R5bGluZyB2YXJpYWJsZXNcbiAgICogQHBhcmFtIHZhcmlhYmxlc1xuICAgKi9cbiAgcHVibGljIHVwZGF0ZVZhcmlhYmxlcyh2YXJpYWJsZXM6IFJlY29yZDxzdHJpbmcsIHN0cmluZz4pIHtcbiAgICBPYmplY3QuZW50cmllcyh2YXJpYWJsZXMpLmZvckVhY2goKFt2YXJOYW1lLCB2YWx1ZV0pID0+IHRoaXMuZG9jdW1lbnQucXVlcnlTZWxlY3RvcignaHRtbCcpIS5zdHlsZS5zZXRQcm9wZXJ0eShgLS0ke3Zhck5hbWV9YCwgdmFsdWUpKTtcbiAgfVxuXG4gIC8qKlxuICAgKiBSZXNldCBzdHlsaW5nIHZhcmlhYmxlcyBvdmVycmlkZVxuICAgKi9cbiAgcHVibGljIHJlc2V0U3R5bGluZ1ZhcmlhYmxlcygpIHtcbiAgICBjb25zdCBzdHlsZSA9IHRoaXMuZG9jdW1lbnQucXVlcnlTZWxlY3RvcignaHRtbCcpIS5zdHlsZTtcbiAgICBzdHlsZS5jc3NUZXh0XG4gICAgICAuc3BsaXQoLzsoXFxzKyk/LylcbiAgICAgIC5yZWR1Y2UoKGFjYzogc3RyaW5nW10sIHN0cikgPT4ge1xuICAgICAgICBjb25zdCBtYXRjaCA9IHN0cj8ubWF0Y2goL14oLS0uKik6Lyk7XG4gICAgICAgIHJldHVybiBtYXRjaCA/IGFjYy5jb25jYXQobWF0Y2hbMV0pIDogYWNjO1xuICAgICAgfSwgW10pXG4gICAgICAuZm9yRWFjaCgodmFyTmFtZSkgPT4gc3R5bGUucmVtb3ZlUHJvcGVydHkodmFyTmFtZSkpO1xuICB9XG59XG4iXX0=
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { InjectionToken } from '@angular/core';
|
|
1
|
+
import { InjectionToken, } from '@angular/core';
|
|
2
2
|
/**
|
|
3
3
|
* Default value for styling devtools
|
|
4
4
|
*/
|
|
@@ -10,4 +10,4 @@ export const OTTER_STYLING_DEVTOOLS_DEFAULT_OPTIONS = {
|
|
|
10
10
|
* Token for styling devtools
|
|
11
11
|
*/
|
|
12
12
|
export const OTTER_STYLING_DEVTOOLS_OPTIONS = new InjectionToken('Otter Styling Devtools options');
|
|
13
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
13
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3R5bGluZy1kZXZ0b29scy50b2tlbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9kZXZraXQvc3R5bGluZy1kZXZ0b29scy50b2tlbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0wsY0FBYyxHQUNmLE1BQU0sZUFBZSxDQUFDO0FBS3ZCOztHQUVHO0FBQ0gsTUFBTSxDQUFDLE1BQU0sc0NBQXNDLEdBQWtDO0lBQ25GLHNCQUFzQixFQUFFLEtBQUs7SUFDN0IsbUJBQW1CLEVBQUUsa0NBQWtDO0NBQ3hELENBQUM7QUFFRjs7R0FFRztBQUNILE1BQU0sQ0FBQyxNQUFNLDhCQUE4QixHQUFrRCxJQUFJLGNBQWMsQ0FBZ0MsZ0NBQWdDLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIEluamVjdGlvblRva2VuLFxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB0eXBlIHtcbiAgU3R5bGluZ0RldnRvb2xzU2VydmljZU9wdGlvbnMsXG59IGZyb20gJy4vc3R5bGluZy1kZXZraXQuaW50ZXJmYWNlJztcblxuLyoqXG4gKiBEZWZhdWx0IHZhbHVlIGZvciBzdHlsaW5nIGRldnRvb2xzXG4gKi9cbmV4cG9ydCBjb25zdCBPVFRFUl9TVFlMSU5HX0RFVlRPT0xTX0RFRkFVTFRfT1BUSU9OUzogU3R5bGluZ0RldnRvb2xzU2VydmljZU9wdGlvbnMgPSB7XG4gIGlzQWN0aXZhdGVkT25Cb290c3RyYXA6IGZhbHNlLFxuICBzdHlsaW5nTWV0YWRhdGFQYXRoOiAnLi9tZXRhZGF0YS9zdHlsaW5nLm1ldGFkYXRhLmpzb24nXG59O1xuXG4vKipcbiAqIFRva2VuIGZvciBzdHlsaW5nIGRldnRvb2xzXG4gKi9cbmV4cG9ydCBjb25zdCBPVFRFUl9TVFlMSU5HX0RFVlRPT0xTX09QVElPTlM6IEluamVjdGlvblRva2VuPFN0eWxpbmdEZXZ0b29sc1NlcnZpY2VPcHRpb25zPiA9IG5ldyBJbmplY3Rpb25Ub2tlbjxTdHlsaW5nRGV2dG9vbHNTZXJ2aWNlT3B0aW9ucz4oJ090dGVyIFN0eWxpbmcgRGV2dG9vbHMgb3B0aW9ucycpO1xuIl19
|