1 | /**
|
2 | * @license
|
3 | * Copyright Google Inc. All Rights Reserved.
|
4 | *
|
5 | * Use of this source code is governed by an MIT-style license that can be
|
6 | * found in the LICENSE file at https://angular.io/license
|
7 | */
|
8 | import * as tslib_1 from "tslib";
|
9 | /**
|
10 | * This file is a port of shadowCSS from webcomponents.js to TypeScript.
|
11 | *
|
12 | * Please make sure to keep to edits in sync with the source file.
|
13 | *
|
14 | * Source:
|
15 | * https://github.com/webcomponents/webcomponentsjs/blob/4efecd7e0e/src/ShadowCSS/ShadowCSS.js
|
16 | *
|
17 | * The original file level comment is reproduced below
|
18 | */
|
19 | /*
|
20 | This is a limited shim for ShadowDOM css styling.
|
21 | https://dvcs.w3.org/hg/webcomponents/raw-file/tip/spec/shadow/index.html#styles
|
22 |
|
23 | The intention here is to support only the styling features which can be
|
24 | relatively simply implemented. The goal is to allow users to avoid the
|
25 | most obvious pitfalls and do so without compromising performance significantly.
|
26 | For ShadowDOM styling that's not covered here, a set of best practices
|
27 | can be provided that should allow users to accomplish more complex styling.
|
28 |
|
29 | The following is a list of specific ShadowDOM styling features and a brief
|
30 | discussion of the approach used to shim.
|
31 |
|
32 | Shimmed features:
|
33 |
|
34 | * :host, :host-context: ShadowDOM allows styling of the shadowRoot's host
|
35 | element using the :host rule. To shim this feature, the :host styles are
|
36 | reformatted and prefixed with a given scope name and promoted to a
|
37 | document level stylesheet.
|
38 | For example, given a scope name of .foo, a rule like this:
|
39 |
|
40 | :host {
|
41 | background: red;
|
42 | }
|
43 | }
|
44 |
|
45 | becomes:
|
46 |
|
47 | .foo {
|
48 | background: red;
|
49 | }
|
50 |
|
51 | * encapsulation: Styles defined within ShadowDOM, apply only to
|
52 | dom inside the ShadowDOM. Polymer uses one of two techniques to implement
|
53 | this feature.
|
54 |
|
55 | By default, rules are prefixed with the host element tag name
|
56 | as a descendant selector. This ensures styling does not leak out of the 'top'
|
57 | of the element's ShadowDOM. For example,
|
58 |
|
59 | div {
|
60 | font-weight: bold;
|
61 | }
|
62 |
|
63 | becomes:
|
64 |
|
65 | x-foo div {
|
66 | font-weight: bold;
|
67 | }
|
68 |
|
69 | becomes:
|
70 |
|
71 |
|
72 | Alternatively, if WebComponents.ShadowCSS.strictStyling is set to true then
|
73 | selectors are scoped by adding an attribute selector suffix to each
|
74 | simple selector that contains the host element tag name. Each element
|
75 | in the element's ShadowDOM template is also given the scope attribute.
|
76 | Thus, these rules match only elements that have the scope attribute.
|
77 | For example, given a scope name of x-foo, a rule like this:
|
78 |
|
79 | div {
|
80 | font-weight: bold;
|
81 | }
|
82 |
|
83 | becomes:
|
84 |
|
85 | div[x-foo] {
|
86 | font-weight: bold;
|
87 | }
|
88 |
|
89 | Note that elements that are dynamically added to a scope must have the scope
|
90 | selector added to them manually.
|
91 |
|
92 | * upper/lower bound encapsulation: Styles which are defined outside a
|
93 | shadowRoot should not cross the ShadowDOM boundary and should not apply
|
94 | inside a shadowRoot.
|
95 |
|
96 | This styling behavior is not emulated. Some possible ways to do this that
|
97 | were rejected due to complexity and/or performance concerns include: (1) reset
|
98 | every possible property for every possible selector for a given scope name;
|
99 | (2) re-implement css in javascript.
|
100 |
|
101 | As an alternative, users should make sure to use selectors
|
102 | specific to the scope in which they are working.
|
103 |
|
104 | * ::distributed: This behavior is not emulated. It's often not necessary
|
105 | to style the contents of a specific insertion point and instead, descendants
|
106 | of the host element can be styled selectively. Users can also create an
|
107 | extra node around an insertion point and style that node's contents
|
108 | via descendent selectors. For example, with a shadowRoot like this:
|
109 |
|
110 | <style>
|
111 | ::content(div) {
|
112 | background: red;
|
113 | }
|
114 | </style>
|
115 | <content></content>
|
116 |
|
117 | could become:
|
118 |
|
119 | <style>
|
120 | / *@polyfill .content-container div * /
|
121 | ::content(div) {
|
122 | background: red;
|
123 | }
|
124 | </style>
|
125 | <div class="content-container">
|
126 | <content></content>
|
127 | </div>
|
128 |
|
129 | Note the use of @polyfill in the comment above a ShadowDOM specific style
|
130 | declaration. This is a directive to the styling shim to use the selector
|
131 | in comments in lieu of the next selector when running under polyfill.
|
132 | */
|
133 | var ShadowCss = /** @class */ (function () {
|
134 | function ShadowCss() {
|
135 | this.strictStyling = true;
|
136 | }
|
137 | /*
|
138 | * Shim some cssText with the given selector. Returns cssText that can
|
139 | * be included in the document via WebComponents.ShadowCSS.addCssToDocument(css).
|
140 | *
|
141 | * When strictStyling is true:
|
142 | * - selector is the attribute added to all elements inside the host,
|
143 | * - hostSelector is the attribute added to the host itself.
|
144 | */
|
145 | ShadowCss.prototype.shimCssText = function (cssText, selector, hostSelector) {
|
146 | if (hostSelector === void 0) { hostSelector = ''; }
|
147 | var commentsWithHash = extractCommentsWithHash(cssText);
|
148 | cssText = stripComments(cssText);
|
149 | cssText = this._insertDirectives(cssText);
|
150 | var scopedCssText = this._scopeCssText(cssText, selector, hostSelector);
|
151 | return tslib_1.__spread([scopedCssText], commentsWithHash).join('\n');
|
152 | };
|
153 | ShadowCss.prototype._insertDirectives = function (cssText) {
|
154 | cssText = this._insertPolyfillDirectivesInCssText(cssText);
|
155 | return this._insertPolyfillRulesInCssText(cssText);
|
156 | };
|
157 | /*
|
158 | * Process styles to convert native ShadowDOM rules that will trip
|
159 | * up the css parser; we rely on decorating the stylesheet with inert rules.
|
160 | *
|
161 | * For example, we convert this rule:
|
162 | *
|
163 | * polyfill-next-selector { content: ':host menu-item'; }
|
164 | * ::content menu-item {
|
165 | *
|
166 | * to this:
|
167 | *
|
168 | * scopeName menu-item {
|
169 | *
|
170 | **/
|
171 | ShadowCss.prototype._insertPolyfillDirectivesInCssText = function (cssText) {
|
172 | // Difference with webcomponents.js: does not handle comments
|
173 | return cssText.replace(_cssContentNextSelectorRe, function () {
|
174 | var m = [];
|
175 | for (var _i = 0; _i < arguments.length; _i++) {
|
176 | m[_i] = arguments[_i];
|
177 | }
|
178 | return m[2] + '{';
|
179 | });
|
180 | };
|
181 | /*
|
182 | * Process styles to add rules which will only apply under the polyfill
|
183 | *
|
184 | * For example, we convert this rule:
|
185 | *
|
186 | * polyfill-rule {
|
187 | * content: ':host menu-item';
|
188 | * ...
|
189 | * }
|
190 | *
|
191 | * to this:
|
192 | *
|
193 | * scopeName menu-item {...}
|
194 | *
|
195 | **/
|
196 | ShadowCss.prototype._insertPolyfillRulesInCssText = function (cssText) {
|
197 | // Difference with webcomponents.js: does not handle comments
|
198 | return cssText.replace(_cssContentRuleRe, function () {
|
199 | var m = [];
|
200 | for (var _i = 0; _i < arguments.length; _i++) {
|
201 | m[_i] = arguments[_i];
|
202 | }
|
203 | var rule = m[0].replace(m[1], '').replace(m[2], '');
|
204 | return m[4] + rule;
|
205 | });
|
206 | };
|
207 | /* Ensure styles are scoped. Pseudo-scoping takes a rule like:
|
208 | *
|
209 | * .foo {... }
|
210 | *
|
211 | * and converts this to
|
212 | *
|
213 | * scopeName .foo { ... }
|
214 | */
|
215 | ShadowCss.prototype._scopeCssText = function (cssText, scopeSelector, hostSelector) {
|
216 | var unscopedRules = this._extractUnscopedRulesFromCssText(cssText);
|
217 | // replace :host and :host-context -shadowcsshost and -shadowcsshost respectively
|
218 | cssText = this._insertPolyfillHostInCssText(cssText);
|
219 | cssText = this._convertColonHost(cssText);
|
220 | cssText = this._convertColonHostContext(cssText);
|
221 | cssText = this._convertShadowDOMSelectors(cssText);
|
222 | if (scopeSelector) {
|
223 | cssText = this._scopeSelectors(cssText, scopeSelector, hostSelector);
|
224 | }
|
225 | cssText = cssText + '\n' + unscopedRules;
|
226 | return cssText.trim();
|
227 | };
|
228 | /*
|
229 | * Process styles to add rules which will only apply under the polyfill
|
230 | * and do not process via CSSOM. (CSSOM is destructive to rules on rare
|
231 | * occasions, e.g. -webkit-calc on Safari.)
|
232 | * For example, we convert this rule:
|
233 | *
|
234 | * @polyfill-unscoped-rule {
|
235 | * content: 'menu-item';
|
236 | * ... }
|
237 | *
|
238 | * to this:
|
239 | *
|
240 | * menu-item {...}
|
241 | *
|
242 | **/
|
243 | ShadowCss.prototype._extractUnscopedRulesFromCssText = function (cssText) {
|
244 | // Difference with webcomponents.js: does not handle comments
|
245 | var r = '';
|
246 | var m;
|
247 | _cssContentUnscopedRuleRe.lastIndex = 0;
|
248 | while ((m = _cssContentUnscopedRuleRe.exec(cssText)) !== null) {
|
249 | var rule = m[0].replace(m[2], '').replace(m[1], m[4]);
|
250 | r += rule + '\n\n';
|
251 | }
|
252 | return r;
|
253 | };
|
254 | /*
|
255 | * convert a rule like :host(.foo) > .bar { }
|
256 | *
|
257 | * to
|
258 | *
|
259 | * .foo<scopeName> > .bar
|
260 | */
|
261 | ShadowCss.prototype._convertColonHost = function (cssText) {
|
262 | return this._convertColonRule(cssText, _cssColonHostRe, this._colonHostPartReplacer);
|
263 | };
|
264 | /*
|
265 | * convert a rule like :host-context(.foo) > .bar { }
|
266 | *
|
267 | * to
|
268 | *
|
269 | * .foo<scopeName> > .bar, .foo scopeName > .bar { }
|
270 | *
|
271 | * and
|
272 | *
|
273 | * :host-context(.foo:host) .bar { ... }
|
274 | *
|
275 | * to
|
276 | *
|
277 | * .foo<scopeName> .bar { ... }
|
278 | */
|
279 | ShadowCss.prototype._convertColonHostContext = function (cssText) {
|
280 | return this._convertColonRule(cssText, _cssColonHostContextRe, this._colonHostContextPartReplacer);
|
281 | };
|
282 | ShadowCss.prototype._convertColonRule = function (cssText, regExp, partReplacer) {
|
283 | // m[1] = :host(-context), m[2] = contents of (), m[3] rest of rule
|
284 | return cssText.replace(regExp, function () {
|
285 | var m = [];
|
286 | for (var _i = 0; _i < arguments.length; _i++) {
|
287 | m[_i] = arguments[_i];
|
288 | }
|
289 | if (m[2]) {
|
290 | var parts = m[2].split(',');
|
291 | var r = [];
|
292 | for (var i = 0; i < parts.length; i++) {
|
293 | var p = parts[i].trim();
|
294 | if (!p)
|
295 | break;
|
296 | r.push(partReplacer(_polyfillHostNoCombinator, p, m[3]));
|
297 | }
|
298 | return r.join(',');
|
299 | }
|
300 | else {
|
301 | return _polyfillHostNoCombinator + m[3];
|
302 | }
|
303 | });
|
304 | };
|
305 | ShadowCss.prototype._colonHostContextPartReplacer = function (host, part, suffix) {
|
306 | if (part.indexOf(_polyfillHost) > -1) {
|
307 | return this._colonHostPartReplacer(host, part, suffix);
|
308 | }
|
309 | else {
|
310 | return host + part + suffix + ', ' + part + ' ' + host + suffix;
|
311 | }
|
312 | };
|
313 | ShadowCss.prototype._colonHostPartReplacer = function (host, part, suffix) {
|
314 | return host + part.replace(_polyfillHost, '') + suffix;
|
315 | };
|
316 | /*
|
317 | * Convert combinators like ::shadow and pseudo-elements like ::content
|
318 | * by replacing with space.
|
319 | */
|
320 | ShadowCss.prototype._convertShadowDOMSelectors = function (cssText) {
|
321 | return _shadowDOMSelectorsRe.reduce(function (result, pattern) { return result.replace(pattern, ' '); }, cssText);
|
322 | };
|
323 | // change a selector like 'div' to 'name div'
|
324 | ShadowCss.prototype._scopeSelectors = function (cssText, scopeSelector, hostSelector) {
|
325 | var _this = this;
|
326 | return processRules(cssText, function (rule) {
|
327 | var selector = rule.selector;
|
328 | var content = rule.content;
|
329 | if (rule.selector[0] != '@') {
|
330 | selector =
|
331 | _this._scopeSelector(rule.selector, scopeSelector, hostSelector, _this.strictStyling);
|
332 | }
|
333 | else if (rule.selector.startsWith('@media') || rule.selector.startsWith('@supports') ||
|
334 | rule.selector.startsWith('@page') || rule.selector.startsWith('@document')) {
|
335 | content = _this._scopeSelectors(rule.content, scopeSelector, hostSelector);
|
336 | }
|
337 | return new CssRule(selector, content);
|
338 | });
|
339 | };
|
340 | ShadowCss.prototype._scopeSelector = function (selector, scopeSelector, hostSelector, strict) {
|
341 | var _this = this;
|
342 | return selector.split(',')
|
343 | .map(function (part) { return part.trim().split(_shadowDeepSelectors); })
|
344 | .map(function (deepParts) {
|
345 | var _a = tslib_1.__read(deepParts), shallowPart = _a[0], otherParts = _a.slice(1);
|
346 | var applyScope = function (shallowPart) {
|
347 | if (_this._selectorNeedsScoping(shallowPart, scopeSelector)) {
|
348 | return strict ?
|
349 | _this._applyStrictSelectorScope(shallowPart, scopeSelector, hostSelector) :
|
350 | _this._applySelectorScope(shallowPart, scopeSelector, hostSelector);
|
351 | }
|
352 | else {
|
353 | return shallowPart;
|
354 | }
|
355 | };
|
356 | return tslib_1.__spread([applyScope(shallowPart)], otherParts).join(' ');
|
357 | })
|
358 | .join(', ');
|
359 | };
|
360 | ShadowCss.prototype._selectorNeedsScoping = function (selector, scopeSelector) {
|
361 | var re = this._makeScopeMatcher(scopeSelector);
|
362 | return !re.test(selector);
|
363 | };
|
364 | ShadowCss.prototype._makeScopeMatcher = function (scopeSelector) {
|
365 | var lre = /\[/g;
|
366 | var rre = /\]/g;
|
367 | scopeSelector = scopeSelector.replace(lre, '\\[').replace(rre, '\\]');
|
368 | return new RegExp('^(' + scopeSelector + ')' + _selectorReSuffix, 'm');
|
369 | };
|
370 | ShadowCss.prototype._applySelectorScope = function (selector, scopeSelector, hostSelector) {
|
371 | // Difference from webcomponents.js: scopeSelector could not be an array
|
372 | return this._applySimpleSelectorScope(selector, scopeSelector, hostSelector);
|
373 | };
|
374 | // scope via name and [is=name]
|
375 | ShadowCss.prototype._applySimpleSelectorScope = function (selector, scopeSelector, hostSelector) {
|
376 | // In Android browser, the lastIndex is not reset when the regex is used in String.replace()
|
377 | _polyfillHostRe.lastIndex = 0;
|
378 | if (_polyfillHostRe.test(selector)) {
|
379 | var replaceBy_1 = this.strictStyling ? "[" + hostSelector + "]" : scopeSelector;
|
380 | return selector
|
381 | .replace(_polyfillHostNoCombinatorRe, function (hnc, selector) {
|
382 | return selector.replace(/([^:]*)(:*)(.*)/, function (_, before, colon, after) {
|
383 | return before + replaceBy_1 + colon + after;
|
384 | });
|
385 | })
|
386 | .replace(_polyfillHostRe, replaceBy_1 + ' ');
|
387 | }
|
388 | return scopeSelector + ' ' + selector;
|
389 | };
|
390 | // return a selector with [name] suffix on each simple selector
|
391 | // e.g. .foo.bar > .zot becomes .foo[name].bar[name] > .zot[name] /** @internal */
|
392 | ShadowCss.prototype._applyStrictSelectorScope = function (selector, scopeSelector, hostSelector) {
|
393 | var _this = this;
|
394 | var isRe = /\[is=([^\]]*)\]/g;
|
395 | scopeSelector = scopeSelector.replace(isRe, function (_) {
|
396 | var parts = [];
|
397 | for (var _i = 1; _i < arguments.length; _i++) {
|
398 | parts[_i - 1] = arguments[_i];
|
399 | }
|
400 | return parts[0];
|
401 | });
|
402 | var attrName = '[' + scopeSelector + ']';
|
403 | var _scopeSelectorPart = function (p) {
|
404 | var scopedP = p.trim();
|
405 | if (!scopedP) {
|
406 | return '';
|
407 | }
|
408 | if (p.indexOf(_polyfillHostNoCombinator) > -1) {
|
409 | scopedP = _this._applySimpleSelectorScope(p, scopeSelector, hostSelector);
|
410 | }
|
411 | else {
|
412 | // remove :host since it should be unnecessary
|
413 | var t = p.replace(_polyfillHostRe, '');
|
414 | if (t.length > 0) {
|
415 | var matches = t.match(/([^:]*)(:*)(.*)/);
|
416 | if (matches) {
|
417 | scopedP = matches[1] + attrName + matches[2] + matches[3];
|
418 | }
|
419 | }
|
420 | }
|
421 | return scopedP;
|
422 | };
|
423 | var safeContent = new SafeSelector(selector);
|
424 | selector = safeContent.content();
|
425 | var scopedSelector = '';
|
426 | var startIndex = 0;
|
427 | var res;
|
428 | var sep = /( |>|\+|~(?!=))\s*/g;
|
429 | // If a selector appears before :host it should not be shimmed as it
|
430 | // matches on ancestor elements and not on elements in the host's shadow
|
431 | // `:host-context(div)` is transformed to
|
432 | // `-shadowcsshost-no-combinatordiv, div -shadowcsshost-no-combinator`
|
433 | // the `div` is not part of the component in the 2nd selectors and should not be scoped.
|
434 | // Historically `component-tag:host` was matching the component so we also want to preserve
|
435 | // this behavior to avoid breaking legacy apps (it should not match).
|
436 | // The behavior should be:
|
437 | // - `tag:host` -> `tag[h]` (this is to avoid breaking legacy apps, should not match anything)
|
438 | // - `tag :host` -> `tag [h]` (`tag` is not scoped because it's considered part of a
|
439 | // `:host-context(tag)`)
|
440 | var hasHost = selector.indexOf(_polyfillHostNoCombinator) > -1;
|
441 | // Only scope parts after the first `-shadowcsshost-no-combinator` when it is present
|
442 | var shouldScope = !hasHost;
|
443 | while ((res = sep.exec(selector)) !== null) {
|
444 | var separator = res[1];
|
445 | var part_1 = selector.slice(startIndex, res.index).trim();
|
446 | shouldScope = shouldScope || part_1.indexOf(_polyfillHostNoCombinator) > -1;
|
447 | var scopedPart = shouldScope ? _scopeSelectorPart(part_1) : part_1;
|
448 | scopedSelector += scopedPart + " " + separator + " ";
|
449 | startIndex = sep.lastIndex;
|
450 | }
|
451 | var part = selector.substring(startIndex);
|
452 | shouldScope = shouldScope || part.indexOf(_polyfillHostNoCombinator) > -1;
|
453 | scopedSelector += shouldScope ? _scopeSelectorPart(part) : part;
|
454 | // replace the placeholders with their original values
|
455 | return safeContent.restore(scopedSelector);
|
456 | };
|
457 | ShadowCss.prototype._insertPolyfillHostInCssText = function (selector) {
|
458 | return selector.replace(_colonHostContextRe, _polyfillHostContext)
|
459 | .replace(_colonHostRe, _polyfillHost);
|
460 | };
|
461 | return ShadowCss;
|
462 | }());
|
463 | export { ShadowCss };
|
464 | var SafeSelector = /** @class */ (function () {
|
465 | function SafeSelector(selector) {
|
466 | var _this = this;
|
467 | this.placeholders = [];
|
468 | this.index = 0;
|
469 | // Replaces attribute selectors with placeholders.
|
470 | // The WS in [attr="va lue"] would otherwise be interpreted as a selector separator.
|
471 | selector = selector.replace(/(\[[^\]]*\])/g, function (_, keep) {
|
472 | var replaceBy = "__ph-" + _this.index + "__";
|
473 | _this.placeholders.push(keep);
|
474 | _this.index++;
|
475 | return replaceBy;
|
476 | });
|
477 | // Replaces the expression in `:nth-child(2n + 1)` with a placeholder.
|
478 | // WS and "+" would otherwise be interpreted as selector separators.
|
479 | this._content = selector.replace(/(:nth-[-\w]+)(\([^)]+\))/g, function (_, pseudo, exp) {
|
480 | var replaceBy = "__ph-" + _this.index + "__";
|
481 | _this.placeholders.push(exp);
|
482 | _this.index++;
|
483 | return pseudo + replaceBy;
|
484 | });
|
485 | }
|
486 | SafeSelector.prototype.restore = function (content) {
|
487 | var _this = this;
|
488 | return content.replace(/__ph-(\d+)__/g, function (ph, index) { return _this.placeholders[+index]; });
|
489 | };
|
490 | SafeSelector.prototype.content = function () { return this._content; };
|
491 | return SafeSelector;
|
492 | }());
|
493 | var _cssContentNextSelectorRe = /polyfill-next-selector[^}]*content:[\s]*?(['"])(.*?)\1[;\s]*}([^{]*?){/gim;
|
494 | var _cssContentRuleRe = /(polyfill-rule)[^}]*(content:[\s]*(['"])(.*?)\3)[;\s]*[^}]*}/gim;
|
495 | var _cssContentUnscopedRuleRe = /(polyfill-unscoped-rule)[^}]*(content:[\s]*(['"])(.*?)\3)[;\s]*[^}]*}/gim;
|
496 | var _polyfillHost = '-shadowcsshost';
|
497 | // note: :host-context pre-processed to -shadowcsshostcontext.
|
498 | var _polyfillHostContext = '-shadowcsscontext';
|
499 | var _parenSuffix = ')(?:\\((' +
|
500 | '(?:\\([^)(]*\\)|[^)(]*)+?' +
|
501 | ')\\))?([^,{]*)';
|
502 | var _cssColonHostRe = new RegExp('(' + _polyfillHost + _parenSuffix, 'gim');
|
503 | var _cssColonHostContextRe = new RegExp('(' + _polyfillHostContext + _parenSuffix, 'gim');
|
504 | var _polyfillHostNoCombinator = _polyfillHost + '-no-combinator';
|
505 | var _polyfillHostNoCombinatorRe = /-shadowcsshost-no-combinator([^\s]*)/;
|
506 | var _shadowDOMSelectorsRe = [
|
507 | /::shadow/g,
|
508 | /::content/g,
|
509 | // Deprecated selectors
|
510 | /\/shadow-deep\//g,
|
511 | /\/shadow\//g,
|
512 | ];
|
513 | // The deep combinator is deprecated in the CSS spec
|
514 | // Support for `>>>`, `deep`, `::ng-deep` is then also deprecated and will be removed in the future.
|
515 | // see https://github.com/angular/angular/pull/17677
|
516 | var _shadowDeepSelectors = /(?:>>>)|(?:\/deep\/)|(?:::ng-deep)/g;
|
517 | var _selectorReSuffix = '([>\\s~+\[.,{:][\\s\\S]*)?$';
|
518 | var _polyfillHostRe = /-shadowcsshost/gim;
|
519 | var _colonHostRe = /:host/gim;
|
520 | var _colonHostContextRe = /:host-context/gim;
|
521 | var _commentRe = /\/\*\s*[\s\S]*?\*\//g;
|
522 | function stripComments(input) {
|
523 | return input.replace(_commentRe, '');
|
524 | }
|
525 | var _commentWithHashRe = /\/\*\s*#\s*source(Mapping)?URL=[\s\S]+?\*\//g;
|
526 | function extractCommentsWithHash(input) {
|
527 | return input.match(_commentWithHashRe) || [];
|
528 | }
|
529 | var _ruleRe = /(\s*)([^;\{\}]+?)(\s*)((?:{%BLOCK%}?\s*;?)|(?:\s*;))/g;
|
530 | var _curlyRe = /([{}])/g;
|
531 | var OPEN_CURLY = '{';
|
532 | var CLOSE_CURLY = '}';
|
533 | var BLOCK_PLACEHOLDER = '%BLOCK%';
|
534 | var CssRule = /** @class */ (function () {
|
535 | function CssRule(selector, content) {
|
536 | this.selector = selector;
|
537 | this.content = content;
|
538 | }
|
539 | return CssRule;
|
540 | }());
|
541 | export { CssRule };
|
542 | export function processRules(input, ruleCallback) {
|
543 | var inputWithEscapedBlocks = escapeBlocks(input);
|
544 | var nextBlockIndex = 0;
|
545 | return inputWithEscapedBlocks.escapedString.replace(_ruleRe, function () {
|
546 | var m = [];
|
547 | for (var _i = 0; _i < arguments.length; _i++) {
|
548 | m[_i] = arguments[_i];
|
549 | }
|
550 | var selector = m[2];
|
551 | var content = '';
|
552 | var suffix = m[4];
|
553 | var contentPrefix = '';
|
554 | if (suffix && suffix.startsWith('{' + BLOCK_PLACEHOLDER)) {
|
555 | content = inputWithEscapedBlocks.blocks[nextBlockIndex++];
|
556 | suffix = suffix.substring(BLOCK_PLACEHOLDER.length + 1);
|
557 | contentPrefix = '{';
|
558 | }
|
559 | var rule = ruleCallback(new CssRule(selector, content));
|
560 | return "" + m[1] + rule.selector + m[3] + contentPrefix + rule.content + suffix;
|
561 | });
|
562 | }
|
563 | var StringWithEscapedBlocks = /** @class */ (function () {
|
564 | function StringWithEscapedBlocks(escapedString, blocks) {
|
565 | this.escapedString = escapedString;
|
566 | this.blocks = blocks;
|
567 | }
|
568 | return StringWithEscapedBlocks;
|
569 | }());
|
570 | function escapeBlocks(input) {
|
571 | var inputParts = input.split(_curlyRe);
|
572 | var resultParts = [];
|
573 | var escapedBlocks = [];
|
574 | var bracketCount = 0;
|
575 | var currentBlockParts = [];
|
576 | for (var partIndex = 0; partIndex < inputParts.length; partIndex++) {
|
577 | var part = inputParts[partIndex];
|
578 | if (part == CLOSE_CURLY) {
|
579 | bracketCount--;
|
580 | }
|
581 | if (bracketCount > 0) {
|
582 | currentBlockParts.push(part);
|
583 | }
|
584 | else {
|
585 | if (currentBlockParts.length > 0) {
|
586 | escapedBlocks.push(currentBlockParts.join(''));
|
587 | resultParts.push(BLOCK_PLACEHOLDER);
|
588 | currentBlockParts = [];
|
589 | }
|
590 | resultParts.push(part);
|
591 | }
|
592 | if (part == OPEN_CURLY) {
|
593 | bracketCount++;
|
594 | }
|
595 | }
|
596 | if (currentBlockParts.length > 0) {
|
597 | escapedBlocks.push(currentBlockParts.join(''));
|
598 | resultParts.push(BLOCK_PLACEHOLDER);
|
599 | }
|
600 | return new StringWithEscapedBlocks(resultParts.join(''), escapedBlocks);
|
601 | }
|
602 | //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"shadow_css.js","sourceRoot":"","sources":["../../../../../../../../../packages/compiler/src/shadow_css.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Google Inc. All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://angular.io/license\n */\n\n/**\n * This file is a port of shadowCSS from webcomponents.js to TypeScript.\n *\n * Please make sure to keep to edits in sync with the source file.\n *\n * Source:\n * https://github.com/webcomponents/webcomponentsjs/blob/4efecd7e0e/src/ShadowCSS/ShadowCSS.js\n *\n * The original file level comment is reproduced below\n */\n\n/*\n  This is a limited shim for ShadowDOM css styling.\n  https://dvcs.w3.org/hg/webcomponents/raw-file/tip/spec/shadow/index.html#styles\n\n  The intention here is to support only the styling features which can be\n  relatively simply implemented. The goal is to allow users to avoid the\n  most obvious pitfalls and do so without compromising performance significantly.\n  For ShadowDOM styling that's not covered here, a set of best practices\n  can be provided that should allow users to accomplish more complex styling.\n\n  The following is a list of specific ShadowDOM styling features and a brief\n  discussion of the approach used to shim.\n\n  Shimmed features:\n\n  * :host, :host-context: ShadowDOM allows styling of the shadowRoot's host\n  element using the :host rule. To shim this feature, the :host styles are\n  reformatted and prefixed with a given scope name and promoted to a\n  document level stylesheet.\n  For example, given a scope name of .foo, a rule like this:\n\n    :host {\n        background: red;\n      }\n    }\n\n  becomes:\n\n    .foo {\n      background: red;\n    }\n\n  * encapsulation: Styles defined within ShadowDOM, apply only to\n  dom inside the ShadowDOM. Polymer uses one of two techniques to implement\n  this feature.\n\n  By default, rules are prefixed with the host element tag name\n  as a descendant selector. This ensures styling does not leak out of the 'top'\n  of the element's ShadowDOM. For example,\n\n  div {\n      font-weight: bold;\n    }\n\n  becomes:\n\n  x-foo div {\n      font-weight: bold;\n    }\n\n  becomes:\n\n\n  Alternatively, if WebComponents.ShadowCSS.strictStyling is set to true then\n  selectors are scoped by adding an attribute selector suffix to each\n  simple selector that contains the host element tag name. Each element\n  in the element's ShadowDOM template is also given the scope attribute.\n  Thus, these rules match only elements that have the scope attribute.\n  For example, given a scope name of x-foo, a rule like this:\n\n    div {\n      font-weight: bold;\n    }\n\n  becomes:\n\n    div[x-foo] {\n      font-weight: bold;\n    }\n\n  Note that elements that are dynamically added to a scope must have the scope\n  selector added to them manually.\n\n  * upper/lower bound encapsulation: Styles which are defined outside a\n  shadowRoot should not cross the ShadowDOM boundary and should not apply\n  inside a shadowRoot.\n\n  This styling behavior is not emulated. Some possible ways to do this that\n  were rejected due to complexity and/or performance concerns include: (1) reset\n  every possible property for every possible selector for a given scope name;\n  (2) re-implement css in javascript.\n\n  As an alternative, users should make sure to use selectors\n  specific to the scope in which they are working.\n\n  * ::distributed: This behavior is not emulated. It's often not necessary\n  to style the contents of a specific insertion point and instead, descendants\n  of the host element can be styled selectively. Users can also create an\n  extra node around an insertion point and style that node's contents\n  via descendent selectors. For example, with a shadowRoot like this:\n\n    <style>\n      ::content(div) {\n        background: red;\n      }\n    </style>\n    <content></content>\n\n  could become:\n\n    <style>\n      / *@polyfill .content-container div * /\n      ::content(div) {\n        background: red;\n      }\n    </style>\n    <div class=\"content-container\">\n      <content></content>\n    </div>\n\n  Note the use of @polyfill in the comment above a ShadowDOM specific style\n  declaration. This is a directive to the styling shim to use the selector\n  in comments in lieu of the next selector when running under polyfill.\n*/\n\nexport class ShadowCss {\n  strictStyling: boolean = true;\n\n  constructor() {}\n\n  /*\n  * Shim some cssText with the given selector. Returns cssText that can\n  * be included in the document via WebComponents.ShadowCSS.addCssToDocument(css).\n  *\n  * When strictStyling is true:\n  * - selector is the attribute added to all elements inside the host,\n  * - hostSelector is the attribute added to the host itself.\n  */\n  shimCssText(cssText: string, selector: string, hostSelector: string = ''): string {\n    const commentsWithHash = extractCommentsWithHash(cssText);\n    cssText = stripComments(cssText);\n    cssText = this._insertDirectives(cssText);\n\n    const scopedCssText = this._scopeCssText(cssText, selector, hostSelector);\n    return [scopedCssText, ...commentsWithHash].join('\\n');\n  }\n\n  private _insertDirectives(cssText: string): string {\n    cssText = this._insertPolyfillDirectivesInCssText(cssText);\n    return this._insertPolyfillRulesInCssText(cssText);\n  }\n\n  /*\n   * Process styles to convert native ShadowDOM rules that will trip\n   * up the css parser; we rely on decorating the stylesheet with inert rules.\n   *\n   * For example, we convert this rule:\n   *\n   * polyfill-next-selector { content: ':host menu-item'; }\n   * ::content menu-item {\n   *\n   * to this:\n   *\n   * scopeName menu-item {\n   *\n  **/\n  private _insertPolyfillDirectivesInCssText(cssText: string): string {\n    // Difference with webcomponents.js: does not handle comments\n    return cssText.replace(\n        _cssContentNextSelectorRe, function(...m: string[]) { return m[2] + '{'; });\n  }\n\n  /*\n   * Process styles to add rules which will only apply under the polyfill\n   *\n   * For example, we convert this rule:\n   *\n   * polyfill-rule {\n   *   content: ':host menu-item';\n   * ...\n   * }\n   *\n   * to this:\n   *\n   * scopeName menu-item {...}\n   *\n  **/\n  private _insertPolyfillRulesInCssText(cssText: string): string {\n    // Difference with webcomponents.js: does not handle comments\n    return cssText.replace(_cssContentRuleRe, (...m: string[]) => {\n      const rule = m[0].replace(m[1], '').replace(m[2], '');\n      return m[4] + rule;\n    });\n  }\n\n  /* Ensure styles are scoped. Pseudo-scoping takes a rule like:\n   *\n   *  .foo {... }\n   *\n   *  and converts this to\n   *\n   *  scopeName .foo { ... }\n  */\n  private _scopeCssText(cssText: string, scopeSelector: string, hostSelector: string): string {\n    const unscopedRules = this._extractUnscopedRulesFromCssText(cssText);\n    // replace :host and :host-context -shadowcsshost and -shadowcsshost respectively\n    cssText = this._insertPolyfillHostInCssText(cssText);\n    cssText = this._convertColonHost(cssText);\n    cssText = this._convertColonHostContext(cssText);\n    cssText = this._convertShadowDOMSelectors(cssText);\n    if (scopeSelector) {\n      cssText = this._scopeSelectors(cssText, scopeSelector, hostSelector);\n    }\n    cssText = cssText + '\\n' + unscopedRules;\n    return cssText.trim();\n  }\n\n  /*\n   * Process styles to add rules which will only apply under the polyfill\n   * and do not process via CSSOM. (CSSOM is destructive to rules on rare\n   * occasions, e.g. -webkit-calc on Safari.)\n   * For example, we convert this rule:\n   *\n   * @polyfill-unscoped-rule {\n   *   content: 'menu-item';\n   * ... }\n   *\n   * to this:\n   *\n   * menu-item {...}\n   *\n  **/\n  private _extractUnscopedRulesFromCssText(cssText: string): string {\n    // Difference with webcomponents.js: does not handle comments\n    let r = '';\n    let m: RegExpExecArray|null;\n    _cssContentUnscopedRuleRe.lastIndex = 0;\n    while ((m = _cssContentUnscopedRuleRe.exec(cssText)) !== null) {\n      const rule = m[0].replace(m[2], '').replace(m[1], m[4]);\n      r += rule + '\\n\\n';\n    }\n    return r;\n  }\n\n  /*\n   * convert a rule like :host(.foo) > .bar { }\n   *\n   * to\n   *\n   * .foo<scopeName> > .bar\n  */\n  private _convertColonHost(cssText: string): string {\n    return this._convertColonRule(cssText, _cssColonHostRe, this._colonHostPartReplacer);\n  }\n\n  /*\n   * convert a rule like :host-context(.foo) > .bar { }\n   *\n   * to\n   *\n   * .foo<scopeName> > .bar, .foo scopeName > .bar { }\n   *\n   * and\n   *\n   * :host-context(.foo:host) .bar { ... }\n   *\n   * to\n   *\n   * .foo<scopeName> .bar { ... }\n  */\n  private _convertColonHostContext(cssText: string): string {\n    return this._convertColonRule(\n        cssText, _cssColonHostContextRe, this._colonHostContextPartReplacer);\n  }\n\n  private _convertColonRule(cssText: string, regExp: RegExp, partReplacer: Function): string {\n    // m[1] = :host(-context), m[2] = contents of (), m[3] rest of rule\n    return cssText.replace(regExp, function(...m: string[]) {\n      if (m[2]) {\n        const parts = m[2].split(',');\n        const r: string[] = [];\n        for (let i = 0; i < parts.length; i++) {\n          const p = parts[i].trim();\n          if (!p) break;\n          r.push(partReplacer(_polyfillHostNoCombinator, p, m[3]));\n        }\n        return r.join(',');\n      } else {\n        return _polyfillHostNoCombinator + m[3];\n      }\n    });\n  }\n\n  private _colonHostContextPartReplacer(host: string, part: string, suffix: string): string {\n    if (part.indexOf(_polyfillHost) > -1) {\n      return this._colonHostPartReplacer(host, part, suffix);\n    } else {\n      return host + part + suffix + ', ' + part + ' ' + host + suffix;\n    }\n  }\n\n  private _colonHostPartReplacer(host: string, part: string, suffix: string): string {\n    return host + part.replace(_polyfillHost, '') + suffix;\n  }\n\n  /*\n   * Convert combinators like ::shadow and pseudo-elements like ::content\n   * by replacing with space.\n  */\n  private _convertShadowDOMSelectors(cssText: string): string {\n    return _shadowDOMSelectorsRe.reduce((result, pattern) => result.replace(pattern, ' '), cssText);\n  }\n\n  // change a selector like 'div' to 'name div'\n  private _scopeSelectors(cssText: string, scopeSelector: string, hostSelector: string): string {\n    return processRules(cssText, (rule: CssRule) => {\n      let selector = rule.selector;\n      let content = rule.content;\n      if (rule.selector[0] != '@') {\n        selector =\n            this._scopeSelector(rule.selector, scopeSelector, hostSelector, this.strictStyling);\n      } else if (\n          rule.selector.startsWith('@media') || rule.selector.startsWith('@supports') ||\n          rule.selector.startsWith('@page') || rule.selector.startsWith('@document')) {\n        content = this._scopeSelectors(rule.content, scopeSelector, hostSelector);\n      }\n      return new CssRule(selector, content);\n    });\n  }\n\n  private _scopeSelector(\n      selector: string, scopeSelector: string, hostSelector: string, strict: boolean): string {\n    return selector.split(',')\n        .map(part => part.trim().split(_shadowDeepSelectors))\n        .map((deepParts) => {\n          const [shallowPart, ...otherParts] = deepParts;\n          const applyScope = (shallowPart: string) => {\n            if (this._selectorNeedsScoping(shallowPart, scopeSelector)) {\n              return strict ?\n                  this._applyStrictSelectorScope(shallowPart, scopeSelector, hostSelector) :\n                  this._applySelectorScope(shallowPart, scopeSelector, hostSelector);\n            } else {\n              return shallowPart;\n            }\n          };\n          return [applyScope(shallowPart), ...otherParts].join(' ');\n        })\n        .join(', ');\n  }\n\n  private _selectorNeedsScoping(selector: string, scopeSelector: string): boolean {\n    const re = this._makeScopeMatcher(scopeSelector);\n    return !re.test(selector);\n  }\n\n  private _makeScopeMatcher(scopeSelector: string): RegExp {\n    const lre = /\\[/g;\n    const rre = /\\]/g;\n    scopeSelector = scopeSelector.replace(lre, '\\\\[').replace(rre, '\\\\]');\n    return new RegExp('^(' + scopeSelector + ')' + _selectorReSuffix, 'm');\n  }\n\n  private _applySelectorScope(selector: string, scopeSelector: string, hostSelector: string):\n      string {\n    // Difference from webcomponents.js: scopeSelector could not be an array\n    return this._applySimpleSelectorScope(selector, scopeSelector, hostSelector);\n  }\n\n  // scope via name and [is=name]\n  private _applySimpleSelectorScope(selector: string, scopeSelector: string, hostSelector: string):\n      string {\n    // In Android browser, the lastIndex is not reset when the regex is used in String.replace()\n    _polyfillHostRe.lastIndex = 0;\n    if (_polyfillHostRe.test(selector)) {\n      const replaceBy = this.strictStyling ? `[${hostSelector}]` : scopeSelector;\n      return selector\n          .replace(\n              _polyfillHostNoCombinatorRe,\n              (hnc, selector) => {\n                return selector.replace(\n                    /([^:]*)(:*)(.*)/,\n                    (_: string, before: string, colon: string, after: string) => {\n                      return before + replaceBy + colon + after;\n                    });\n              })\n          .replace(_polyfillHostRe, replaceBy + ' ');\n    }\n\n    return scopeSelector + ' ' + selector;\n  }\n\n  // return a selector with [name] suffix on each simple selector\n  // e.g. .foo.bar > .zot becomes .foo[name].bar[name] > .zot[name]  /** @internal */\n  private _applyStrictSelectorScope(selector: string, scopeSelector: string, hostSelector: string):\n      string {\n    const isRe = /\\[is=([^\\]]*)\\]/g;\n    scopeSelector = scopeSelector.replace(isRe, (_: string, ...parts: string[]) => parts[0]);\n\n    const attrName = '[' + scopeSelector + ']';\n\n    const _scopeSelectorPart = (p: string) => {\n      let scopedP = p.trim();\n\n      if (!scopedP) {\n        return '';\n      }\n\n      if (p.indexOf(_polyfillHostNoCombinator) > -1) {\n        scopedP = this._applySimpleSelectorScope(p, scopeSelector, hostSelector);\n      } else {\n        // remove :host since it should be unnecessary\n        const t = p.replace(_polyfillHostRe, '');\n        if (t.length > 0) {\n          const matches = t.match(/([^:]*)(:*)(.*)/);\n          if (matches) {\n            scopedP = matches[1] + attrName + matches[2] + matches[3];\n          }\n        }\n      }\n\n      return scopedP;\n    };\n\n    const safeContent = new SafeSelector(selector);\n    selector = safeContent.content();\n\n    let scopedSelector = '';\n    let startIndex = 0;\n    let res: RegExpExecArray|null;\n    const sep = /( |>|\\+|~(?!=))\\s*/g;\n\n    // If a selector appears before :host it should not be shimmed as it\n    // matches on ancestor elements and not on elements in the host's shadow\n    // `:host-context(div)` is transformed to\n    // `-shadowcsshost-no-combinatordiv, div -shadowcsshost-no-combinator`\n    // the `div` is not part of the component in the 2nd selectors and should not be scoped.\n    // Historically `component-tag:host` was matching the component so we also want to preserve\n    // this behavior to avoid breaking legacy apps (it should not match).\n    // The behavior should be:\n    // - `tag:host` -> `tag[h]` (this is to avoid breaking legacy apps, should not match anything)\n    // - `tag :host` -> `tag [h]` (`tag` is not scoped because it's considered part of a\n    //   `:host-context(tag)`)\n    const hasHost = selector.indexOf(_polyfillHostNoCombinator) > -1;\n    // Only scope parts after the first `-shadowcsshost-no-combinator` when it is present\n    let shouldScope = !hasHost;\n\n    while ((res = sep.exec(selector)) !== null) {\n      const separator = res[1];\n      const part = selector.slice(startIndex, res.index).trim();\n      shouldScope = shouldScope || part.indexOf(_polyfillHostNoCombinator) > -1;\n      const scopedPart = shouldScope ? _scopeSelectorPart(part) : part;\n      scopedSelector += `${scopedPart} ${separator} `;\n      startIndex = sep.lastIndex;\n    }\n\n    const part = selector.substring(startIndex);\n    shouldScope = shouldScope || part.indexOf(_polyfillHostNoCombinator) > -1;\n    scopedSelector += shouldScope ? _scopeSelectorPart(part) : part;\n\n    // replace the placeholders with their original values\n    return safeContent.restore(scopedSelector);\n  }\n\n  private _insertPolyfillHostInCssText(selector: string): string {\n    return selector.replace(_colonHostContextRe, _polyfillHostContext)\n        .replace(_colonHostRe, _polyfillHost);\n  }\n}\n\nclass SafeSelector {\n  private placeholders: string[] = [];\n  private index = 0;\n  private _content: string;\n\n  constructor(selector: string) {\n    // Replaces attribute selectors with placeholders.\n    // The WS in [attr=\"va lue\"] would otherwise be interpreted as a selector separator.\n    selector = selector.replace(/(\\[[^\\]]*\\])/g, (_, keep) => {\n      const replaceBy = `__ph-${this.index}__`;\n      this.placeholders.push(keep);\n      this.index++;\n      return replaceBy;\n    });\n\n    // Replaces the expression in `:nth-child(2n + 1)` with a placeholder.\n    // WS and \"+\" would otherwise be interpreted as selector separators.\n    this._content = selector.replace(/(:nth-[-\\w]+)(\\([^)]+\\))/g, (_, pseudo, exp) => {\n      const replaceBy = `__ph-${this.index}__`;\n      this.placeholders.push(exp);\n      this.index++;\n      return pseudo + replaceBy;\n    });\n  }\n\n  restore(content: string): string {\n    return content.replace(/__ph-(\\d+)__/g, (ph, index) => this.placeholders[+index]);\n  }\n\n  content(): string { return this._content; }\n}\n\nconst _cssContentNextSelectorRe =\n    /polyfill-next-selector[^}]*content:[\\s]*?(['\"])(.*?)\\1[;\\s]*}([^{]*?){/gim;\nconst _cssContentRuleRe = /(polyfill-rule)[^}]*(content:[\\s]*(['\"])(.*?)\\3)[;\\s]*[^}]*}/gim;\nconst _cssContentUnscopedRuleRe =\n    /(polyfill-unscoped-rule)[^}]*(content:[\\s]*(['\"])(.*?)\\3)[;\\s]*[^}]*}/gim;\nconst _polyfillHost = '-shadowcsshost';\n// note: :host-context pre-processed to -shadowcsshostcontext.\nconst _polyfillHostContext = '-shadowcsscontext';\nconst _parenSuffix = ')(?:\\\\((' +\n    '(?:\\\\([^)(]*\\\\)|[^)(]*)+?' +\n    ')\\\\))?([^,{]*)';\nconst _cssColonHostRe = new RegExp('(' + _polyfillHost + _parenSuffix, 'gim');\nconst _cssColonHostContextRe = new RegExp('(' + _polyfillHostContext + _parenSuffix, 'gim');\nconst _polyfillHostNoCombinator = _polyfillHost + '-no-combinator';\nconst _polyfillHostNoCombinatorRe = /-shadowcsshost-no-combinator([^\\s]*)/;\nconst _shadowDOMSelectorsRe = [\n  /::shadow/g,\n  /::content/g,\n  // Deprecated selectors\n  /\\/shadow-deep\\//g,\n  /\\/shadow\\//g,\n];\n\n// The deep combinator is deprecated in the CSS spec\n// Support for `>>>`, `deep`, `::ng-deep` is then also deprecated and will be removed in the future.\n// see https://github.com/angular/angular/pull/17677\nconst _shadowDeepSelectors = /(?:>>>)|(?:\\/deep\\/)|(?:::ng-deep)/g;\nconst _selectorReSuffix = '([>\\\\s~+\\[.,{:][\\\\s\\\\S]*)?$';\nconst _polyfillHostRe = /-shadowcsshost/gim;\nconst _colonHostRe = /:host/gim;\nconst _colonHostContextRe = /:host-context/gim;\n\nconst _commentRe = /\\/\\*\\s*[\\s\\S]*?\\*\\//g;\n\nfunction stripComments(input: string): string {\n  return input.replace(_commentRe, '');\n}\n\nconst _commentWithHashRe = /\\/\\*\\s*#\\s*source(Mapping)?URL=[\\s\\S]+?\\*\\//g;\n\nfunction extractCommentsWithHash(input: string): string[] {\n  return input.match(_commentWithHashRe) || [];\n}\n\nconst _ruleRe = /(\\s*)([^;\\{\\}]+?)(\\s*)((?:{%BLOCK%}?\\s*;?)|(?:\\s*;))/g;\nconst _curlyRe = /([{}])/g;\nconst OPEN_CURLY = '{';\nconst CLOSE_CURLY = '}';\nconst BLOCK_PLACEHOLDER = '%BLOCK%';\n\nexport class CssRule {\n  constructor(public selector: string, public content: string) {}\n}\n\nexport function processRules(input: string, ruleCallback: (rule: CssRule) => CssRule): string {\n  const inputWithEscapedBlocks = escapeBlocks(input);\n  let nextBlockIndex = 0;\n  return inputWithEscapedBlocks.escapedString.replace(_ruleRe, function(...m: string[]) {\n    const selector = m[2];\n    let content = '';\n    let suffix = m[4];\n    let contentPrefix = '';\n    if (suffix && suffix.startsWith('{' + BLOCK_PLACEHOLDER)) {\n      content = inputWithEscapedBlocks.blocks[nextBlockIndex++];\n      suffix = suffix.substring(BLOCK_PLACEHOLDER.length + 1);\n      contentPrefix = '{';\n    }\n    const rule = ruleCallback(new CssRule(selector, content));\n    return `${m[1]}${rule.selector}${m[3]}${contentPrefix}${rule.content}${suffix}`;\n  });\n}\n\nclass StringWithEscapedBlocks {\n  constructor(public escapedString: string, public blocks: string[]) {}\n}\n\nfunction escapeBlocks(input: string): StringWithEscapedBlocks {\n  const inputParts = input.split(_curlyRe);\n  const resultParts: string[] = [];\n  const escapedBlocks: string[] = [];\n  let bracketCount = 0;\n  let currentBlockParts: string[] = [];\n  for (let partIndex = 0; partIndex < inputParts.length; partIndex++) {\n    const part = inputParts[partIndex];\n    if (part == CLOSE_CURLY) {\n      bracketCount--;\n    }\n    if (bracketCount > 0) {\n      currentBlockParts.push(part);\n    } else {\n      if (currentBlockParts.length > 0) {\n        escapedBlocks.push(currentBlockParts.join(''));\n        resultParts.push(BLOCK_PLACEHOLDER);\n        currentBlockParts = [];\n      }\n      resultParts.push(part);\n    }\n    if (part == OPEN_CURLY) {\n      bracketCount++;\n    }\n  }\n  if (currentBlockParts.length > 0) {\n    escapedBlocks.push(currentBlockParts.join(''));\n    resultParts.push(BLOCK_PLACEHOLDER);\n  }\n  return new StringWithEscapedBlocks(resultParts.join(''), escapedBlocks);\n}\n"]} |
\ | No newline at end of file |