From b311956e1520c6eda1775323e6f387166ba214e5 Mon Sep 17 00:00:00 2001 From: David Newell Date: Tue, 22 Oct 2024 17:33:03 +0100 Subject: [PATCH 01/21] chore: upgrade rrweb --- package.json | 10 ++-- patches/rrweb@2.0.0-alpha.17.patch | 81 ++++++++++++++++++++++++++++++ pnpm-lock.yaml | 47 ++++++++--------- 3 files changed, 110 insertions(+), 28 deletions(-) create mode 100644 patches/rrweb@2.0.0-alpha.17.patch diff --git a/package.json b/package.json index 17e2980c1..6351d2c61 100644 --- a/package.json +++ b/package.json @@ -58,7 +58,8 @@ "@rollup/plugin-node-resolve": "^15.3.0", "@rollup/plugin-terser": "^0.4.4", "@rollup/plugin-typescript": "^12.1.1", - "@rrweb/types": "2.0.0-alpha.16", + "@rrweb/rrweb-plugin-console-record": "2.0.0-alpha.15", + "@rrweb/types": "2.0.0-alpha.17", "@sentry/types": "8.7.0", "@testing-library/dom": "^9.3.0", "@testing-library/jest-dom": "^6.5.0", @@ -103,9 +104,8 @@ "rollup": "^4.24.0", "rollup-plugin-dts": "^6.1.1", "rollup-plugin-visualizer": "^5.12.0", - "rrweb": "2.0.0-alpha.16", - "@rrweb/rrweb-plugin-console-record": "2.0.0-alpha.15", - "rrweb-snapshot": "2.0.0-alpha.16", + "rrweb": "2.0.0-alpha.17", + "rrweb-snapshot": "2.0.0-alpha.17", "sinon": "9.0.2", "testcafe": "1.19.0", "testcafe-browser-provider-browserstack": "1.14.0", @@ -127,7 +127,7 @@ ], "pnpm": { "patchedDependencies": { - "rrweb@2.0.0-alpha.16": "patches/rrweb@2.0.0-alpha.16.patch" + "rrweb@2.0.0-alpha.17": "patches/rrweb@2.0.0-alpha.17.patch" } } } diff --git a/patches/rrweb@2.0.0-alpha.17.patch b/patches/rrweb@2.0.0-alpha.17.patch new file mode 100644 index 000000000..7caa5db40 --- /dev/null +++ b/patches/rrweb@2.0.0-alpha.17.patch @@ -0,0 +1,81 @@ +diff --git a/dist/rrweb.js b/dist/rrweb.js +index 12f4ad3c7f897fe8a9ee2f4595dcf37f302d17c5..43f6bd95676c456e187b7bd68ba7af56e7b09f29 100644 +--- a/dist/rrweb.js ++++ b/dist/rrweb.js +@@ -246,6 +246,9 @@ function isCSSImportRule(rule2) { + function isCSSStyleRule(rule2) { + return "selectorText" in rule2; + } ++function findStylesheet(doc, href) { ++ return Array.from(doc.styleSheets).find((s) => s.href === href); ++} + class Mirror { + constructor() { + __publicField$1(this, "idNodeMap", /* @__PURE__ */ new Map()); +@@ -821,9 +824,14 @@ function serializeElementNode(n2, options) { + } + } + if (tagName === "link" && inlineStylesheet) { +- const stylesheet = Array.from(doc.styleSheets).find((s2) => { +- return s2.href === n2.href; +- }); ++ const href = n2.href; ++ let stylesheet = findStylesheet(doc, href); ++ if (!stylesheet && href.includes('.css')) { ++ const rootDomain = window.location.origin; ++ const stylesheetPath = href.replace(window.location.href, ''); ++ const potentialStylesheetHref = rootDomain + '/' + stylesheetPath; ++ stylesheet = findStylesheet(doc, potentialStylesheetHref); ++ } + let cssText = null; + if (stylesheet) { + cssText = stringifyStylesheet(stylesheet); +@@ -13276,11 +13284,19 @@ class CanvasManager { + let rafId; + const getCanvas = () => { + const matchedCanvas = []; +- win.document.querySelectorAll("canvas").forEach((canvas) => { +- if (!isBlocked(canvas, blockClass, blockSelector, true)) { +- matchedCanvas.push(canvas); +- } +- }); ++ const searchCanvas = (root) => { ++ root.querySelectorAll("canvas").forEach((canvas) => { ++ if (!isBlocked(canvas, blockClass, blockSelector, true)) { ++ matchedCanvas.push(canvas); ++ } ++ }); ++ root.querySelectorAll("*").forEach((elem) => { ++ if (elem.shadowRoot) { ++ searchCanvas(elem.shadowRoot); ++ } ++ }); ++ }; ++ searchCanvas(win.document); + return matchedCanvas; + }; + const takeCanvasSnapshots = (timestamp) => { +@@ -13301,13 +13317,20 @@ class CanvasManager { + context.clear(context.COLOR_BUFFER_BIT); + } + } +- const bitmap = await createImageBitmap(canvas); ++ // createImageBitmap throws if resizing to 0 ++ // Fallback to intrinsic size if canvas has not yet rendered ++ const width = canvas.clientWidth || canvas.width; ++ const height = canvas.clientHeight || canvas.height; ++ const bitmap = await createImageBitmap(canvas, { ++ resizeWidth: width, ++ resizeHeight: height ++ }); + worker.postMessage( + { + id, + bitmap, +- width: canvas.width, +- height: canvas.height, ++ width: width, ++ height: height, + dataURLOptions: options.dataURLOptions + }, + [bitmap] diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml index bdee9346f..79ae50e62 100644 --- a/pnpm-lock.yaml +++ b/pnpm-lock.yaml @@ -5,9 +5,9 @@ settings: excludeLinksFromLockfile: false patchedDependencies: - rrweb@2.0.0-alpha.16: - hash: x52pllmg6k5suqkcoa7bdybazq - path: patches/rrweb@2.0.0-alpha.16.patch + rrweb@2.0.0-alpha.17: + hash: xlkuvshzdprjlpxe7nzsj3spyi + path: patches/rrweb@2.0.0-alpha.17.patch dependencies: core-js: @@ -68,10 +68,10 @@ devDependencies: version: 12.1.1(rollup@4.24.0)(tslib@2.5.0)(typescript@5.5.4) '@rrweb/rrweb-plugin-console-record': specifier: 2.0.0-alpha.15 - version: 2.0.0-alpha.15(rrweb@2.0.0-alpha.16) + version: 2.0.0-alpha.15(rrweb@2.0.0-alpha.17) '@rrweb/types': - specifier: 2.0.0-alpha.16 - version: 2.0.0-alpha.16 + specifier: 2.0.0-alpha.17 + version: 2.0.0-alpha.17 '@sentry/types': specifier: 8.7.0 version: 8.7.0 @@ -205,11 +205,11 @@ devDependencies: specifier: ^5.12.0 version: 5.12.0(rollup@4.24.0) rrweb: - specifier: 2.0.0-alpha.16 - version: 2.0.0-alpha.16(patch_hash=x52pllmg6k5suqkcoa7bdybazq) + specifier: 2.0.0-alpha.17 + version: 2.0.0-alpha.17(patch_hash=xlkuvshzdprjlpxe7nzsj3spyi) rrweb-snapshot: - specifier: 2.0.0-alpha.16 - version: 2.0.0-alpha.16 + specifier: 2.0.0-alpha.17 + version: 2.0.0-alpha.17 sinon: specifier: 9.0.2 version: 9.0.2 @@ -2802,18 +2802,22 @@ packages: dev: true optional: true - /@rrweb/rrweb-plugin-console-record@2.0.0-alpha.15(rrweb@2.0.0-alpha.16): + /@rrweb/rrweb-plugin-console-record@2.0.0-alpha.15(rrweb@2.0.0-alpha.17): resolution: {integrity: sha512-66iOkD99AS8WqQNAnDtkJsQnSD8E+tZx3tWMJltpRDovXs4GoBE9eYxQeTWSigz6iaqbrxYPIqQIRck+zqnheg==} peerDependencies: rrweb: ^2.0.0-alpha.15 dependencies: - rrweb: 2.0.0-alpha.16(patch_hash=x52pllmg6k5suqkcoa7bdybazq) + rrweb: 2.0.0-alpha.17(patch_hash=xlkuvshzdprjlpxe7nzsj3spyi) dev: true - /@rrweb/types@2.0.0-alpha.16: - resolution: {integrity: sha512-E6cACNVsm+NUhn7dzocQoKyXI7BHrHRRm5Ab23yrAzEQ2caWocCEYJhqDlc4KRVJBkQfXZfyWm8+2d0uggFuZg==} + /@rrweb/types@2.0.0-alpha.17: + resolution: {integrity: sha512-AfDTVUuCyCaIG0lTSqYtrZqJX39ZEYzs4fYKnexhQ+id+kbZIpIJtaut5cto6dWZbB3SEe4fW0o90Po3LvTmfg==} dependencies: - rrweb-snapshot: 2.0.0-alpha.16 + rrweb-snapshot: 2.0.0-alpha.17 + dev: true + + /@rrweb/utils@2.0.0-alpha.17: + resolution: {integrity: sha512-HCsasPERBwOS9/LQeOytO2ETKTCqRj1wORBuxiy3t41hKhmi225DdrUPiWnyDdTQm1GdVbOymMRknJVPnZaSXw==} dev: true /@sentry/types@8.7.0: @@ -9402,26 +9406,23 @@ packages: rrweb-snapshot: 2.0.0-alpha.17 dev: true - /rrweb-snapshot@2.0.0-alpha.16: - resolution: {integrity: sha512-p81OrzUiCmUMZzJu4fGHeLB00PIbVIqsV/zhqzr2pitHTUXpMYcyOvDWt0vHdla0vnowEPaHq3Wsu6cUc732/w==} - dev: true - /rrweb-snapshot@2.0.0-alpha.17: resolution: {integrity: sha512-GBg5pV8LHOTbeVmH2VHLEFR0mc2QpQMzAvcoxEGfPNWgWHc8UvKCyq7pqN1vA+fDZ+yXXbixeO0kB2pzVvFCBw==} dependencies: postcss: 8.4.47 dev: true - /rrweb@2.0.0-alpha.16(patch_hash=x52pllmg6k5suqkcoa7bdybazq): - resolution: {integrity: sha512-Uxl7quZc8gm9RqrUR+10prZBoAfKWvM5lqlWDe7zd2wAkMiBQawDHUrmt8dByx96aiLonvm4oLsbBK14A0A0Tg==} + /rrweb@2.0.0-alpha.17(patch_hash=xlkuvshzdprjlpxe7nzsj3spyi): + resolution: {integrity: sha512-GQxBkCC4r9XL2bwSdv7iIS49M3cEA8OtObVq0rrQ4GUT4+h7omucGQ4x7m5YN5Vq1oalStBaBlYqF7yRnfG3JA==} dependencies: - '@rrweb/types': 2.0.0-alpha.16 + '@rrweb/types': 2.0.0-alpha.17 + '@rrweb/utils': 2.0.0-alpha.17 '@types/css-font-loading-module': 0.0.7 '@xstate/fsm': 1.5.2 base64-arraybuffer: 1.0.2 mitt: 3.0.0 rrdom: 2.0.0-alpha.17 - rrweb-snapshot: 2.0.0-alpha.16 + rrweb-snapshot: 2.0.0-alpha.17 dev: true patched: true From c1ae66bb4afa8bcd665c5dc483b046263dfaa779 Mon Sep 17 00:00:00 2001 From: David Newell Date: Tue, 22 Oct 2024 17:33:21 +0100 Subject: [PATCH 02/21] remove old patch --- patches/rrweb@2.0.0-alpha.16.patch | 98 ------------------------------ 1 file changed, 98 deletions(-) delete mode 100644 patches/rrweb@2.0.0-alpha.16.patch diff --git a/patches/rrweb@2.0.0-alpha.16.patch b/patches/rrweb@2.0.0-alpha.16.patch deleted file mode 100644 index 5a76bf4d6..000000000 --- a/patches/rrweb@2.0.0-alpha.16.patch +++ /dev/null @@ -1,98 +0,0 @@ -diff --git a/dist/rrweb.js b/dist/rrweb.js -index 1db2d08b2fe9a73521001c3aa88b1a64d1b3e71a..5a3ea8410b0f1dfa7248b9cb9752c04eea7b3ad3 100644 ---- a/dist/rrweb.js -+++ b/dist/rrweb.js -@@ -85,6 +85,9 @@ function isCSSImportRule(rule) { - function isCSSStyleRule(rule) { - return "selectorText" in rule; - } -+function findStylesheet(doc, href) { -+ return Array.from(doc.styleSheets).find((s) => s.href === href); -+} - class Mirror { - constructor() { - __publicField$1(this, "idNodeMap", /* @__PURE__ */ new Map()); -@@ -661,9 +664,14 @@ function serializeElementNode(n2, options) { - } - } - if (tagName === "link" && inlineStylesheet) { -- const stylesheet = Array.from(doc.styleSheets).find((s2) => { -- return s2.href === n2.href; -- }); -+ const href = n2.href; -+ let stylesheet = findStylesheet(doc, href); -+ if (!stylesheet && href.includes('.css')) { -+ const rootDomain = window.location.origin -+ const stylesheetPath = href.replace(window.location.href, '') -+ const potentialStylesheetHref = rootDomain + '/' + stylesheetPath -+ stylesheet = findStylesheet(doc, potentialStylesheetHref); -+ } - let cssText = null; - if (stylesheet) { - cssText = stringifyStylesheet(stylesheet); -@@ -5016,11 +5024,19 @@ class CanvasManager { - let rafId; - const getCanvas = () => { - const matchedCanvas = []; -- win.document.querySelectorAll("canvas").forEach((canvas) => { -- if (!isBlocked(canvas, blockClass, blockSelector, true)) { -- matchedCanvas.push(canvas); -- } -- }); -+ const searchCanvas = (root) => { -+ root.querySelectorAll("canvas").forEach((canvas) => { -+ if (!isBlocked(canvas, blockClass, blockSelector, true)) { -+ matchedCanvas.push(canvas); -+ } -+ }); -+ root.querySelectorAll("*").forEach((elem) => { -+ if (elem.shadowRoot) { -+ searchCanvas(elem.shadowRoot); -+ } -+ }); -+ }; -+ searchCanvas(win.document); - return matchedCanvas; - }; - const takeCanvasSnapshots = (timestamp) => { -@@ -5041,13 +5057,20 @@ class CanvasManager { - context.clear(context.COLOR_BUFFER_BIT); - } - } -- const bitmap = await createImageBitmap(canvas); -+ // createImageBitmap throws if resizing to 0 -+ // Fallback to intrinsic size if canvas has not yet rendered -+ const width = canvas.clientWidth || canvas.width; -+ const height = canvas.clientHeight || canvas.height; -+ const bitmap = await createImageBitmap(canvas, { -+ resizeWidth: width, -+ resizeHeight: height -+ }); - worker.postMessage( - { - id, - bitmap, -- width: canvas.width, -- height: canvas.height, -+ width: width, -+ height: height, - dataURLOptions: options.dataURLOptions - }, - [bitmap] -@@ -9805,6 +9828,7 @@ class Replayer { - } - const { addCustomEvent } = record; - const { freezePage } = record; -+const version = "2.0.0-alpha.16" - export { - EventType, - IncrementalSource, -@@ -9816,6 +9840,7 @@ export { - freezePage, - _mirror as mirror, - record, -- utils -+ utils, -+ version, - }; - //# sourceMappingURL=rrweb.js.map From df01b84cee502ea5577e5861f4b5e87951523321 Mon Sep 17 00:00:00 2001 From: David Newell Date: Tue, 22 Oct 2024 18:30:10 +0100 Subject: [PATCH 03/21] fix wrong import --- package.json | 2 +- pnpm-lock.yaml | 10 +++++----- 2 files changed, 6 insertions(+), 6 deletions(-) diff --git a/package.json b/package.json index 6351d2c61..589235fae 100644 --- a/package.json +++ b/package.json @@ -58,7 +58,7 @@ "@rollup/plugin-node-resolve": "^15.3.0", "@rollup/plugin-terser": "^0.4.4", "@rollup/plugin-typescript": "^12.1.1", - "@rrweb/rrweb-plugin-console-record": "2.0.0-alpha.15", + "@rrweb/rrweb-plugin-console-record": "2.0.0-alpha.17", "@rrweb/types": "2.0.0-alpha.17", "@sentry/types": "8.7.0", "@testing-library/dom": "^9.3.0", diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml index 79ae50e62..bc8d2dcea 100644 --- a/pnpm-lock.yaml +++ b/pnpm-lock.yaml @@ -67,8 +67,8 @@ devDependencies: specifier: ^12.1.1 version: 12.1.1(rollup@4.24.0)(tslib@2.5.0)(typescript@5.5.4) '@rrweb/rrweb-plugin-console-record': - specifier: 2.0.0-alpha.15 - version: 2.0.0-alpha.15(rrweb@2.0.0-alpha.17) + specifier: 2.0.0-alpha.17 + version: 2.0.0-alpha.17(rrweb@2.0.0-alpha.17) '@rrweb/types': specifier: 2.0.0-alpha.17 version: 2.0.0-alpha.17 @@ -2802,10 +2802,10 @@ packages: dev: true optional: true - /@rrweb/rrweb-plugin-console-record@2.0.0-alpha.15(rrweb@2.0.0-alpha.17): - resolution: {integrity: sha512-66iOkD99AS8WqQNAnDtkJsQnSD8E+tZx3tWMJltpRDovXs4GoBE9eYxQeTWSigz6iaqbrxYPIqQIRck+zqnheg==} + /@rrweb/rrweb-plugin-console-record@2.0.0-alpha.17(rrweb@2.0.0-alpha.17): + resolution: {integrity: sha512-tjNJ3wWUDMMf275xr4Rb5tVYF2UR+wXvSxnyS9tRKnRa574PQQvx7sGbqM/O9AytYjnbiTrAMqNR7OFysGCMwQ==} peerDependencies: - rrweb: ^2.0.0-alpha.15 + rrweb: ^2.0.0-alpha.17 dependencies: rrweb: 2.0.0-alpha.17(patch_hash=xlkuvshzdprjlpxe7nzsj3spyi) dev: true From e0b8b402cb3126f0def399b4bf50d09e956d1a73 Mon Sep 17 00:00:00 2001 From: David Newell Date: Tue, 22 Oct 2024 18:34:03 +0100 Subject: [PATCH 04/21] add version back --- patches/rrweb@2.0.0-alpha.17.patch | 19 ++++++++++++++++++- pnpm-lock.yaml | 8 ++++---- 2 files changed, 22 insertions(+), 5 deletions(-) diff --git a/patches/rrweb@2.0.0-alpha.17.patch b/patches/rrweb@2.0.0-alpha.17.patch index 7caa5db40..1101b681e 100644 --- a/patches/rrweb@2.0.0-alpha.17.patch +++ b/patches/rrweb@2.0.0-alpha.17.patch @@ -1,5 +1,5 @@ diff --git a/dist/rrweb.js b/dist/rrweb.js -index 12f4ad3c7f897fe8a9ee2f4595dcf37f302d17c5..43f6bd95676c456e187b7bd68ba7af56e7b09f29 100644 +index 12f4ad3c7f897fe8a9ee2f4595dcf37f302d17c5..2fb78e052ab4daf9f8d2435d74035564b8f1ef13 100644 --- a/dist/rrweb.js +++ b/dist/rrweb.js @@ -246,6 +246,9 @@ function isCSSImportRule(rule2) { @@ -79,3 +79,20 @@ index 12f4ad3c7f897fe8a9ee2f4595dcf37f302d17c5..43f6bd95676c456e187b7bd68ba7af56 dataURLOptions: options.dataURLOptions }, [bitmap] +@@ -16841,6 +16864,7 @@ class Replayer { + const { addCustomEvent } = record; + const { freezePage } = record; + const { takeFullSnapshot } = record; ++const version = "2.0.0-alpha.17"; + export { + EventType, + IncrementalSource, +@@ -16853,6 +16877,7 @@ export { + _mirror as mirror, + record, + takeFullSnapshot, +- utils ++ utils, ++ version + }; + //# sourceMappingURL=rrweb.js.map diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml index bc8d2dcea..3520100a8 100644 --- a/pnpm-lock.yaml +++ b/pnpm-lock.yaml @@ -6,7 +6,7 @@ settings: patchedDependencies: rrweb@2.0.0-alpha.17: - hash: xlkuvshzdprjlpxe7nzsj3spyi + hash: ovqfbi26faqgvd4dbhm6fm7hwm path: patches/rrweb@2.0.0-alpha.17.patch dependencies: @@ -206,7 +206,7 @@ devDependencies: version: 5.12.0(rollup@4.24.0) rrweb: specifier: 2.0.0-alpha.17 - version: 2.0.0-alpha.17(patch_hash=xlkuvshzdprjlpxe7nzsj3spyi) + version: 2.0.0-alpha.17(patch_hash=ovqfbi26faqgvd4dbhm6fm7hwm) rrweb-snapshot: specifier: 2.0.0-alpha.17 version: 2.0.0-alpha.17 @@ -2807,7 +2807,7 @@ packages: peerDependencies: rrweb: ^2.0.0-alpha.17 dependencies: - rrweb: 2.0.0-alpha.17(patch_hash=xlkuvshzdprjlpxe7nzsj3spyi) + rrweb: 2.0.0-alpha.17(patch_hash=ovqfbi26faqgvd4dbhm6fm7hwm) dev: true /@rrweb/types@2.0.0-alpha.17: @@ -9412,7 +9412,7 @@ packages: postcss: 8.4.47 dev: true - /rrweb@2.0.0-alpha.17(patch_hash=xlkuvshzdprjlpxe7nzsj3spyi): + /rrweb@2.0.0-alpha.17(patch_hash=ovqfbi26faqgvd4dbhm6fm7hwm): resolution: {integrity: sha512-GQxBkCC4r9XL2bwSdv7iIS49M3cEA8OtObVq0rrQ4GUT4+h7omucGQ4x7m5YN5Vq1oalStBaBlYqF7yRnfG3JA==} dependencies: '@rrweb/types': 2.0.0-alpha.17 From a1539b0af9aa81d50ae7a8c5ab8ee7ef0b4fc457 Mon Sep 17 00:00:00 2001 From: David Newell Date: Wed, 23 Oct 2024 10:01:39 +0100 Subject: [PATCH 05/21] chore: use @rrweb/record --- package.json | 3 +-- playground/segment/server.js | 2 +- pnpm-lock.yaml | 16 ++++++++++------ src/entrypoints/recorder.ts | 2 +- src/extensions/replay/sessionrecording-utils.ts | 13 ++++++------- src/extensions/replay/sessionrecording.ts | 4 ---- src/types.ts | 5 ++--- 7 files changed, 21 insertions(+), 24 deletions(-) diff --git a/package.json b/package.json index 589235fae..8aeb40f48 100644 --- a/package.json +++ b/package.json @@ -104,8 +104,7 @@ "rollup": "^4.24.0", "rollup-plugin-dts": "^6.1.1", "rollup-plugin-visualizer": "^5.12.0", - "rrweb": "2.0.0-alpha.17", - "rrweb-snapshot": "2.0.0-alpha.17", + "@rrweb/record": "2.0.0-alpha.17", "sinon": "9.0.2", "testcafe": "1.19.0", "testcafe-browser-provider-browserstack": "1.14.0", diff --git a/playground/segment/server.js b/playground/segment/server.js index 8c67259a1..565b09bbf 100644 --- a/playground/segment/server.js +++ b/playground/segment/server.js @@ -10,7 +10,7 @@ app.get('/segment.html', function (req, res) { }) app.get('/static/recorder.js', function (req, res) { - let filePath = path.join(__dirname, '/../../node_modules/rrweb/dist/rrweb.js') + let filePath = path.join(__dirname, '/../../node_modules/@rrweb/record/dist/record.js') res.sendFile(filePath) }) diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml index 3520100a8..3ebb1381a 100644 --- a/pnpm-lock.yaml +++ b/pnpm-lock.yaml @@ -66,6 +66,9 @@ devDependencies: '@rollup/plugin-typescript': specifier: ^12.1.1 version: 12.1.1(rollup@4.24.0)(tslib@2.5.0)(typescript@5.5.4) + '@rrweb/record': + specifier: 2.0.0-alpha.17 + version: 2.0.0-alpha.17 '@rrweb/rrweb-plugin-console-record': specifier: 2.0.0-alpha.17 version: 2.0.0-alpha.17(rrweb@2.0.0-alpha.17) @@ -204,12 +207,6 @@ devDependencies: rollup-plugin-visualizer: specifier: ^5.12.0 version: 5.12.0(rollup@4.24.0) - rrweb: - specifier: 2.0.0-alpha.17 - version: 2.0.0-alpha.17(patch_hash=ovqfbi26faqgvd4dbhm6fm7hwm) - rrweb-snapshot: - specifier: 2.0.0-alpha.17 - version: 2.0.0-alpha.17 sinon: specifier: 9.0.2 version: 9.0.2 @@ -2802,6 +2799,13 @@ packages: dev: true optional: true + /@rrweb/record@2.0.0-alpha.17: + resolution: {integrity: sha512-Je+lzjeWMF8/I0IDoXFzkGPKT8j7AkaBup5YcwUHlkp18VhLVze416MvI6915teE27uUA2ScXMXzG0Yiu5VTIw==} + dependencies: + '@rrweb/types': 2.0.0-alpha.17 + rrweb: 2.0.0-alpha.17(patch_hash=ovqfbi26faqgvd4dbhm6fm7hwm) + dev: true + /@rrweb/rrweb-plugin-console-record@2.0.0-alpha.17(rrweb@2.0.0-alpha.17): resolution: {integrity: sha512-tjNJ3wWUDMMf275xr4Rb5tVYF2UR+wXvSxnyS9tRKnRa574PQQvx7sGbqM/O9AytYjnbiTrAMqNR7OFysGCMwQ==} peerDependencies: diff --git a/src/entrypoints/recorder.ts b/src/entrypoints/recorder.ts index 514cfb45f..705b6aad2 100644 --- a/src/entrypoints/recorder.ts +++ b/src/entrypoints/recorder.ts @@ -1,5 +1,5 @@ // @ts-expect-error - Patched to include the version -import { record as rrwebRecord, version } from 'rrweb' +import { record as rrwebRecord, version } from '@rrweb/record' import { getRecordConsolePlugin } from '@rrweb/rrweb-plugin-console-record' // rrweb/network@1 code starts diff --git a/src/extensions/replay/sessionrecording-utils.ts b/src/extensions/replay/sessionrecording-utils.ts index aba786e87..42cb7729c 100644 --- a/src/extensions/replay/sessionrecording-utils.ts +++ b/src/extensions/replay/sessionrecording-utils.ts @@ -9,7 +9,6 @@ import type { RecordPlugin, SamplingStrategy, } from '@rrweb/types' -import type { DataURLOptions, MaskInputFn, MaskInputOptions, MaskTextFn, Mirror, SlimDOMOptions } from 'rrweb-snapshot' import { isObject } from '../../utils/type-utils' import { SnapshotBuffer } from './sessionrecording' @@ -54,7 +53,7 @@ export type rrwebRecord = { (options: recordOptions): listenerHandler addCustomEvent: (tag: string, payload: any) => void takeFullSnapshot: () => void - mirror: Mirror + mirror: any } export declare type recordOptions = { @@ -67,16 +66,16 @@ export declare type recordOptions = { maskTextClass?: maskTextClass maskTextSelector?: string maskAllInputs?: boolean - maskInputOptions?: MaskInputOptions - maskInputFn?: MaskInputFn - maskTextFn?: MaskTextFn - slimDOMOptions?: SlimDOMOptions | 'all' | true + maskInputOptions?: any + maskInputFn?: any + maskTextFn?: any + slimDOMOptions?: any | 'all' | true ignoreCSSAttributes?: Set inlineStylesheet?: boolean hooks?: hooksParam // packFn?: PackFn sampling?: SamplingStrategy - dataURLOptions?: DataURLOptions + dataURLOptions?: any recordCanvas?: boolean recordCrossOriginIframes?: boolean recordAfter?: 'DOMContentLoaded' | 'load' diff --git a/src/extensions/replay/sessionrecording.ts b/src/extensions/replay/sessionrecording.ts index 95420aa5f..5c781edd0 100644 --- a/src/extensions/replay/sessionrecording.ts +++ b/src/extensions/replay/sessionrecording.ts @@ -63,10 +63,6 @@ export const RECORDING_MAX_EVENT_SIZE = ONE_KB * ONE_KB * 0.9 // ~1mb (with some export const RECORDING_BUFFER_TIMEOUT = 2000 // 2 seconds export const SESSION_RECORDING_BATCH_KEY = 'recordings' -// NOTE: Importing this type is problematic as we can't safely bundle it to a TS definition so, instead we redefine. -// import type { record } from 'rrweb2/typings' -// import type { recordOptions } from 'rrweb/typings/types' - const ACTIVE_SOURCES = [ IncrementalSource.MouseMove, IncrementalSource.MouseInteraction, diff --git a/src/types.ts b/src/types.ts index a652d729f..d3bf1f353 100644 --- a/src/types.ts +++ b/src/types.ts @@ -1,4 +1,3 @@ -import type { MaskInputOptions, SlimDOMOptions } from 'rrweb-snapshot' import { PostHog } from './posthog-core' import type { SegmentAnalytics } from './extensions/segment-integration' @@ -268,9 +267,9 @@ export interface SessionRecordingOptions { maskTextSelector?: string | null maskTextFn?: ((text: string, element: HTMLElement | null) => string) | null maskAllInputs?: boolean - maskInputOptions?: MaskInputOptions + maskInputOptions?: any maskInputFn?: ((text: string, element?: HTMLElement) => string) | null - slimDOMOptions?: SlimDOMOptions | 'all' | true + slimDOMOptions?: any | 'all' | true collectFonts?: boolean inlineStylesheet?: boolean recordCrossOriginIframes?: boolean From 3dfc69d262e325689c87e2f442dd88b6389b7663 Mon Sep 17 00:00:00 2001 From: David Newell Date: Wed, 23 Oct 2024 10:05:50 +0100 Subject: [PATCH 06/21] remove unused rrwebVersion --- src/__tests__/extensions/replay/sessionrecording.test.ts | 1 - src/entrypoints/recorder.ts | 7 +++---- src/utils/globals.ts | 2 +- 3 files changed, 4 insertions(+), 6 deletions(-) diff --git a/src/__tests__/extensions/replay/sessionrecording.test.ts b/src/__tests__/extensions/replay/sessionrecording.test.ts index bbb709194..eebda931d 100644 --- a/src/__tests__/extensions/replay/sessionrecording.test.ts +++ b/src/__tests__/extensions/replay/sessionrecording.test.ts @@ -190,7 +190,6 @@ describe('SessionRecording', () => { return () => {} }), version: 'fake', - rrwebVersion: 'fake', } assignableWindow.__PosthogExtensions__.rrweb.record.takeFullSnapshot = jest.fn(() => { // we pretend to be rrweb and call emit diff --git a/src/entrypoints/recorder.ts b/src/entrypoints/recorder.ts index 705b6aad2..134b252ff 100644 --- a/src/entrypoints/recorder.ts +++ b/src/entrypoints/recorder.ts @@ -1,5 +1,4 @@ -// @ts-expect-error - Patched to include the version -import { record as rrwebRecord, version } from '@rrweb/record' +import { record as rrwebRecord } from '@rrweb/record' import { getRecordConsolePlugin } from '@rrweb/rrweb-plugin-console-record' // rrweb/network@1 code starts @@ -670,14 +669,14 @@ export const getRecordNetworkPlugin: (options?: NetworkRecordOptions) => RecordP assignableWindow.__PosthogExtensions__ = assignableWindow.__PosthogExtensions__ || {} assignableWindow.__PosthogExtensions__.rrwebPlugins = { getRecordConsolePlugin, getRecordNetworkPlugin } -assignableWindow.__PosthogExtensions__.rrweb = { record: rrwebRecord, version: 'v2', rrwebVersion: version } +assignableWindow.__PosthogExtensions__.rrweb = { record: rrwebRecord, version: 'v2' } // we used to put all of these items directly on window, and now we put it on __PosthogExtensions__ // but that means that old clients which lazily load this extension are looking in the wrong place // yuck, // so we also put them directly on the window // when 1.161.1 is the oldest version seen in production we can remove this -assignableWindow.rrweb = { record: rrwebRecord, version: 'v2', rrwebVersion: version } +assignableWindow.rrweb = { record: rrwebRecord, version: 'v2' } assignableWindow.rrwebConsoleRecord = { getRecordConsolePlugin } assignableWindow.getRecordNetworkPlugin = getRecordNetworkPlugin diff --git a/src/utils/globals.ts b/src/utils/globals.ts index d1fb123f5..2f7e78eb9 100644 --- a/src/utils/globals.ts +++ b/src/utils/globals.ts @@ -46,7 +46,7 @@ interface PostHogExtensions { wrapOnError: (captureFn: (props: Properties) => void) => () => void wrapUnhandledRejection: (captureFn: (props: Properties) => void) => () => void } - rrweb?: { record: any; version: string; rrwebVersion: string } + rrweb?: { record: any; version: string } rrwebPlugins?: { getRecordConsolePlugin: any; getRecordNetworkPlugin?: any } canActivateRepeatedly?: (survey: any) => boolean generateSurveys?: (posthog: PostHog) => any | undefined From 9192f59429c6b31c19c854d30371c2b64df04015 Mon Sep 17 00:00:00 2001 From: David Newell Date: Wed, 23 Oct 2024 10:13:27 +0100 Subject: [PATCH 07/21] remove patch --- package.json | 7 +-- patches/rrweb@2.0.0-alpha.17.patch | 98 ------------------------------ 2 files changed, 1 insertion(+), 104 deletions(-) delete mode 100644 patches/rrweb@2.0.0-alpha.17.patch diff --git a/package.json b/package.json index 8aeb40f48..27596455e 100644 --- a/package.json +++ b/package.json @@ -123,10 +123,5 @@ }, "browserslist": [ "> 0.5%, last 2 versions, Firefox ESR, not dead, IE 11" - ], - "pnpm": { - "patchedDependencies": { - "rrweb@2.0.0-alpha.17": "patches/rrweb@2.0.0-alpha.17.patch" - } - } + ] } diff --git a/patches/rrweb@2.0.0-alpha.17.patch b/patches/rrweb@2.0.0-alpha.17.patch deleted file mode 100644 index 1101b681e..000000000 --- a/patches/rrweb@2.0.0-alpha.17.patch +++ /dev/null @@ -1,98 +0,0 @@ -diff --git a/dist/rrweb.js b/dist/rrweb.js -index 12f4ad3c7f897fe8a9ee2f4595dcf37f302d17c5..2fb78e052ab4daf9f8d2435d74035564b8f1ef13 100644 ---- a/dist/rrweb.js -+++ b/dist/rrweb.js -@@ -246,6 +246,9 @@ function isCSSImportRule(rule2) { - function isCSSStyleRule(rule2) { - return "selectorText" in rule2; - } -+function findStylesheet(doc, href) { -+ return Array.from(doc.styleSheets).find((s) => s.href === href); -+} - class Mirror { - constructor() { - __publicField$1(this, "idNodeMap", /* @__PURE__ */ new Map()); -@@ -821,9 +824,14 @@ function serializeElementNode(n2, options) { - } - } - if (tagName === "link" && inlineStylesheet) { -- const stylesheet = Array.from(doc.styleSheets).find((s2) => { -- return s2.href === n2.href; -- }); -+ const href = n2.href; -+ let stylesheet = findStylesheet(doc, href); -+ if (!stylesheet && href.includes('.css')) { -+ const rootDomain = window.location.origin; -+ const stylesheetPath = href.replace(window.location.href, ''); -+ const potentialStylesheetHref = rootDomain + '/' + stylesheetPath; -+ stylesheet = findStylesheet(doc, potentialStylesheetHref); -+ } - let cssText = null; - if (stylesheet) { - cssText = stringifyStylesheet(stylesheet); -@@ -13276,11 +13284,19 @@ class CanvasManager { - let rafId; - const getCanvas = () => { - const matchedCanvas = []; -- win.document.querySelectorAll("canvas").forEach((canvas) => { -- if (!isBlocked(canvas, blockClass, blockSelector, true)) { -- matchedCanvas.push(canvas); -- } -- }); -+ const searchCanvas = (root) => { -+ root.querySelectorAll("canvas").forEach((canvas) => { -+ if (!isBlocked(canvas, blockClass, blockSelector, true)) { -+ matchedCanvas.push(canvas); -+ } -+ }); -+ root.querySelectorAll("*").forEach((elem) => { -+ if (elem.shadowRoot) { -+ searchCanvas(elem.shadowRoot); -+ } -+ }); -+ }; -+ searchCanvas(win.document); - return matchedCanvas; - }; - const takeCanvasSnapshots = (timestamp) => { -@@ -13301,13 +13317,20 @@ class CanvasManager { - context.clear(context.COLOR_BUFFER_BIT); - } - } -- const bitmap = await createImageBitmap(canvas); -+ // createImageBitmap throws if resizing to 0 -+ // Fallback to intrinsic size if canvas has not yet rendered -+ const width = canvas.clientWidth || canvas.width; -+ const height = canvas.clientHeight || canvas.height; -+ const bitmap = await createImageBitmap(canvas, { -+ resizeWidth: width, -+ resizeHeight: height -+ }); - worker.postMessage( - { - id, - bitmap, -- width: canvas.width, -- height: canvas.height, -+ width: width, -+ height: height, - dataURLOptions: options.dataURLOptions - }, - [bitmap] -@@ -16841,6 +16864,7 @@ class Replayer { - const { addCustomEvent } = record; - const { freezePage } = record; - const { takeFullSnapshot } = record; -+const version = "2.0.0-alpha.17"; - export { - EventType, - IncrementalSource, -@@ -16853,6 +16877,7 @@ export { - _mirror as mirror, - record, - takeFullSnapshot, -- utils -+ utils, -+ version - }; - //# sourceMappingURL=rrweb.js.map From 96c148f5cea5f3af563727a18b0da3b0d4de4ab8 Mon Sep 17 00:00:00 2001 From: David Newell Date: Wed, 23 Oct 2024 10:13:45 +0100 Subject: [PATCH 08/21] update lockfile --- pnpm-lock.yaml | 12 +++--------- 1 file changed, 3 insertions(+), 9 deletions(-) diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml index 3ebb1381a..167ca724e 100644 --- a/pnpm-lock.yaml +++ b/pnpm-lock.yaml @@ -4,11 +4,6 @@ settings: autoInstallPeers: true excludeLinksFromLockfile: false -patchedDependencies: - rrweb@2.0.0-alpha.17: - hash: ovqfbi26faqgvd4dbhm6fm7hwm - path: patches/rrweb@2.0.0-alpha.17.patch - dependencies: core-js: specifier: ^3.38.1 @@ -2803,7 +2798,7 @@ packages: resolution: {integrity: sha512-Je+lzjeWMF8/I0IDoXFzkGPKT8j7AkaBup5YcwUHlkp18VhLVze416MvI6915teE27uUA2ScXMXzG0Yiu5VTIw==} dependencies: '@rrweb/types': 2.0.0-alpha.17 - rrweb: 2.0.0-alpha.17(patch_hash=ovqfbi26faqgvd4dbhm6fm7hwm) + rrweb: 2.0.0-alpha.17 dev: true /@rrweb/rrweb-plugin-console-record@2.0.0-alpha.17(rrweb@2.0.0-alpha.17): @@ -2811,7 +2806,7 @@ packages: peerDependencies: rrweb: ^2.0.0-alpha.17 dependencies: - rrweb: 2.0.0-alpha.17(patch_hash=ovqfbi26faqgvd4dbhm6fm7hwm) + rrweb: 2.0.0-alpha.17 dev: true /@rrweb/types@2.0.0-alpha.17: @@ -9416,7 +9411,7 @@ packages: postcss: 8.4.47 dev: true - /rrweb@2.0.0-alpha.17(patch_hash=ovqfbi26faqgvd4dbhm6fm7hwm): + /rrweb@2.0.0-alpha.17: resolution: {integrity: sha512-GQxBkCC4r9XL2bwSdv7iIS49M3cEA8OtObVq0rrQ4GUT4+h7omucGQ4x7m5YN5Vq1oalStBaBlYqF7yRnfG3JA==} dependencies: '@rrweb/types': 2.0.0-alpha.17 @@ -9428,7 +9423,6 @@ packages: rrdom: 2.0.0-alpha.17 rrweb-snapshot: 2.0.0-alpha.17 dev: true - patched: true /rsvp@4.8.5: resolution: {integrity: sha512-nfMOlASu9OnRJo1mbEk2cz0D56a1MBNrJ7orjRZQG10XDyuvwksKbuXNp6qa+kbn839HwjwhBzhFmdsaEAfauA==} From 2d0d6bfc054e80d9e6e0892db055a1c520e4c10f Mon Sep 17 00:00:00 2001 From: David Newell Date: Wed, 23 Oct 2024 10:22:47 +0100 Subject: [PATCH 09/21] remove all of postcss --- package.json | 9 +- patches/@rrweb__record@2.0.0-alpha.17.patch | 7085 +++++++++++++++++++ pnpm-lock.yaml | 10 +- 3 files changed, 7100 insertions(+), 4 deletions(-) create mode 100644 patches/@rrweb__record@2.0.0-alpha.17.patch diff --git a/package.json b/package.json index 27596455e..719f1ed9c 100644 --- a/package.json +++ b/package.json @@ -58,6 +58,7 @@ "@rollup/plugin-node-resolve": "^15.3.0", "@rollup/plugin-terser": "^0.4.4", "@rollup/plugin-typescript": "^12.1.1", + "@rrweb/record": "2.0.0-alpha.17", "@rrweb/rrweb-plugin-console-record": "2.0.0-alpha.17", "@rrweb/types": "2.0.0-alpha.17", "@sentry/types": "8.7.0", @@ -104,7 +105,6 @@ "rollup": "^4.24.0", "rollup-plugin-dts": "^6.1.1", "rollup-plugin-visualizer": "^5.12.0", - "@rrweb/record": "2.0.0-alpha.17", "sinon": "9.0.2", "testcafe": "1.19.0", "testcafe-browser-provider-browserstack": "1.14.0", @@ -123,5 +123,10 @@ }, "browserslist": [ "> 0.5%, last 2 versions, Firefox ESR, not dead, IE 11" - ] + ], + "pnpm": { + "patchedDependencies": { + "@rrweb/record@2.0.0-alpha.17": "patches/@rrweb__record@2.0.0-alpha.17.patch" + } + } } diff --git a/patches/@rrweb__record@2.0.0-alpha.17.patch b/patches/@rrweb__record@2.0.0-alpha.17.patch new file mode 100644 index 000000000..bc9a5b25b --- /dev/null +++ b/patches/@rrweb__record@2.0.0-alpha.17.patch @@ -0,0 +1,7085 @@ +diff --git a/dist/record.js b/dist/record.js +index 46ec389fefb698243008b39db65470dbdf0a3857..ab4f489bda64cb992c184b727a9175de7a646f2d 100644 +--- a/dist/record.js ++++ b/dist/record.js +@@ -1336,7080 +1336,6 @@ function getAugmentedNamespace$1(n2) { + }); + return a2; + } +-var picocolors_browser$1 = { exports: {} }; +-var x$1 = String; +-var create$1 = function() { +- return { isColorSupported: false, reset: x$1, bold: x$1, dim: x$1, italic: x$1, underline: x$1, inverse: x$1, hidden: x$1, strikethrough: x$1, black: x$1, red: x$1, green: x$1, yellow: x$1, blue: x$1, magenta: x$1, cyan: x$1, white: x$1, gray: x$1, bgBlack: x$1, bgRed: x$1, bgGreen: x$1, bgYellow: x$1, bgBlue: x$1, bgMagenta: x$1, bgCyan: x$1, bgWhite: x$1 }; +-}; +-picocolors_browser$1.exports = create$1(); +-picocolors_browser$1.exports.createColors = create$1; +-var picocolors_browserExports$1 = picocolors_browser$1.exports; +-const __viteBrowserExternal$2 = {}; +-const __viteBrowserExternal$1$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({ +- __proto__: null, +- default: __viteBrowserExternal$2 +-}, Symbol.toStringTag, { value: "Module" })); +-const require$$2$1 = /* @__PURE__ */ getAugmentedNamespace$1(__viteBrowserExternal$1$1); +-let pico$1 = picocolors_browserExports$1; +-let terminalHighlight$1$1 = require$$2$1; +-let CssSyntaxError$3$1 = class CssSyntaxError extends Error { +- constructor(message, line, column, source, file, plugin22) { +- super(message); +- this.name = "CssSyntaxError"; +- this.reason = message; +- if (file) { +- this.file = file; +- } +- if (source) { +- this.source = source; +- } +- if (plugin22) { +- this.plugin = plugin22; +- } +- if (typeof line !== "undefined" && typeof column !== "undefined") { +- if (typeof line === "number") { +- this.line = line; +- this.column = column; +- } else { +- this.line = line.line; +- this.column = line.column; +- this.endLine = column.line; +- this.endColumn = column.column; +- } +- } +- this.setMessage(); +- if (Error.captureStackTrace) { +- Error.captureStackTrace(this, CssSyntaxError); +- } +- } +- setMessage() { +- this.message = this.plugin ? this.plugin + ": " : ""; +- this.message += this.file ? this.file : ""; +- if (typeof this.line !== "undefined") { +- this.message += ":" + this.line + ":" + this.column; +- } +- this.message += ": " + this.reason; +- } +- showSourceCode(color) { +- if (!this.source) return ""; +- let css = this.source; +- if (color == null) color = pico$1.isColorSupported; +- if (terminalHighlight$1$1) { +- if (color) css = terminalHighlight$1$1(css); +- } +- let lines = css.split(/\r?\n/); +- let start = Math.max(this.line - 3, 0); +- let end = Math.min(this.line + 2, lines.length); +- let maxWidth = String(end).length; +- let mark, aside; +- if (color) { +- let { bold, gray, red } = pico$1.createColors(true); +- mark = (text) => bold(red(text)); +- aside = (text) => gray(text); +- } else { +- mark = aside = (str) => str; +- } +- return lines.slice(start, end).map((line, index2) => { +- let number = start + 1 + index2; +- let gutter = " " + (" " + number).slice(-maxWidth) + " | "; +- if (number === this.line) { +- let spacing = aside(gutter.replace(/\d/g, " ")) + line.slice(0, this.column - 1).replace(/[^\t]/g, " "); +- return mark(">") + aside(gutter) + line + "\n " + spacing + mark("^"); +- } +- return " " + aside(gutter) + line; +- }).join("\n"); +- } +- toString() { +- let code = this.showSourceCode(); +- if (code) { +- code = "\n\n" + code + "\n"; +- } +- return this.name + ": " + this.message + code; +- } +-}; +-var cssSyntaxError$1 = CssSyntaxError$3$1; +-CssSyntaxError$3$1.default = CssSyntaxError$3$1; +-var symbols$1 = {}; +-symbols$1.isClean = Symbol("isClean"); +-symbols$1.my = Symbol("my"); +-const DEFAULT_RAW$1 = { +- after: "\n", +- beforeClose: "\n", +- beforeComment: "\n", +- beforeDecl: "\n", +- beforeOpen: " ", +- beforeRule: "\n", +- colon: ": ", +- commentLeft: " ", +- commentRight: " ", +- emptyBody: "", +- indent: " ", +- semicolon: false +-}; +-function capitalize$1(str) { +- return str[0].toUpperCase() + str.slice(1); +-} +-let Stringifier$2$1 = class Stringifier { +- constructor(builder) { +- this.builder = builder; +- } +- atrule(node2, semicolon) { +- let name = "@" + node2.name; +- let params = node2.params ? this.rawValue(node2, "params") : ""; +- if (typeof node2.raws.afterName !== "undefined") { +- name += node2.raws.afterName; +- } else if (params) { +- name += " "; +- } +- if (node2.nodes) { +- this.block(node2, name + params); +- } else { +- let end = (node2.raws.between || "") + (semicolon ? ";" : ""); +- this.builder(name + params + end, node2); +- } +- } +- beforeAfter(node2, detect) { +- let value; +- if (node2.type === "decl") { +- value = this.raw(node2, null, "beforeDecl"); +- } else if (node2.type === "comment") { +- value = this.raw(node2, null, "beforeComment"); +- } else if (detect === "before") { +- value = this.raw(node2, null, "beforeRule"); +- } else { +- value = this.raw(node2, null, "beforeClose"); +- } +- let buf = node2.parent; +- let depth = 0; +- while (buf && buf.type !== "root") { +- depth += 1; +- buf = buf.parent; +- } +- if (value.includes("\n")) { +- let indent = this.raw(node2, null, "indent"); +- if (indent.length) { +- for (let step = 0; step < depth; step++) value += indent; +- } +- } +- return value; +- } +- block(node2, start) { +- let between = this.raw(node2, "between", "beforeOpen"); +- this.builder(start + between + "{", node2, "start"); +- let after; +- if (node2.nodes && node2.nodes.length) { +- this.body(node2); +- after = this.raw(node2, "after"); +- } else { +- after = this.raw(node2, "after", "emptyBody"); +- } +- if (after) this.builder(after); +- this.builder("}", node2, "end"); +- } +- body(node2) { +- let last = node2.nodes.length - 1; +- while (last > 0) { +- if (node2.nodes[last].type !== "comment") break; +- last -= 1; +- } +- let semicolon = this.raw(node2, "semicolon"); +- for (let i2 = 0; i2 < node2.nodes.length; i2++) { +- let child = node2.nodes[i2]; +- let before = this.raw(child, "before"); +- if (before) this.builder(before); +- this.stringify(child, last !== i2 || semicolon); +- } +- } +- comment(node2) { +- let left = this.raw(node2, "left", "commentLeft"); +- let right = this.raw(node2, "right", "commentRight"); +- this.builder("/*" + left + node2.text + right + "*/", node2); +- } +- decl(node2, semicolon) { +- let between = this.raw(node2, "between", "colon"); +- let string = node2.prop + between + this.rawValue(node2, "value"); +- if (node2.important) { +- string += node2.raws.important || " !important"; +- } +- if (semicolon) string += ";"; +- this.builder(string, node2); +- } +- document(node2) { +- this.body(node2); +- } +- raw(node2, own, detect) { +- let value; +- if (!detect) detect = own; +- if (own) { +- value = node2.raws[own]; +- if (typeof value !== "undefined") return value; +- } +- let parent = node2.parent; +- if (detect === "before") { +- if (!parent || parent.type === "root" && parent.first === node2) { +- return ""; +- } +- if (parent && parent.type === "document") { +- return ""; +- } +- } +- if (!parent) return DEFAULT_RAW$1[detect]; +- let root2 = node2.root(); +- if (!root2.rawCache) root2.rawCache = {}; +- if (typeof root2.rawCache[detect] !== "undefined") { +- return root2.rawCache[detect]; +- } +- if (detect === "before" || detect === "after") { +- return this.beforeAfter(node2, detect); +- } else { +- let method = "raw" + capitalize$1(detect); +- if (this[method]) { +- value = this[method](root2, node2); +- } else { +- root2.walk((i2) => { +- value = i2.raws[own]; +- if (typeof value !== "undefined") return false; +- }); +- } +- } +- if (typeof value === "undefined") value = DEFAULT_RAW$1[detect]; +- root2.rawCache[detect] = value; +- return value; +- } +- rawBeforeClose(root2) { +- let value; +- root2.walk((i2) => { +- if (i2.nodes && i2.nodes.length > 0) { +- if (typeof i2.raws.after !== "undefined") { +- value = i2.raws.after; +- if (value.includes("\n")) { +- value = value.replace(/[^\n]+$/, ""); +- } +- return false; +- } +- } +- }); +- if (value) value = value.replace(/\S/g, ""); +- return value; +- } +- rawBeforeComment(root2, node2) { +- let value; +- root2.walkComments((i2) => { +- if (typeof i2.raws.before !== "undefined") { +- value = i2.raws.before; +- if (value.includes("\n")) { +- value = value.replace(/[^\n]+$/, ""); +- } +- return false; +- } +- }); +- if (typeof value === "undefined") { +- value = this.raw(node2, null, "beforeDecl"); +- } else if (value) { +- value = value.replace(/\S/g, ""); +- } +- return value; +- } +- rawBeforeDecl(root2, node2) { +- let value; +- root2.walkDecls((i2) => { +- if (typeof i2.raws.before !== "undefined") { +- value = i2.raws.before; +- if (value.includes("\n")) { +- value = value.replace(/[^\n]+$/, ""); +- } +- return false; +- } +- }); +- if (typeof value === "undefined") { +- value = this.raw(node2, null, "beforeRule"); +- } else if (value) { +- value = value.replace(/\S/g, ""); +- } +- return value; +- } +- rawBeforeOpen(root2) { +- let value; +- root2.walk((i2) => { +- if (i2.type !== "decl") { +- value = i2.raws.between; +- if (typeof value !== "undefined") return false; +- } +- }); +- return value; +- } +- rawBeforeRule(root2) { +- let value; +- root2.walk((i2) => { +- if (i2.nodes && (i2.parent !== root2 || root2.first !== i2)) { +- if (typeof i2.raws.before !== "undefined") { +- value = i2.raws.before; +- if (value.includes("\n")) { +- value = value.replace(/[^\n]+$/, ""); +- } +- return false; +- } +- } +- }); +- if (value) value = value.replace(/\S/g, ""); +- return value; +- } +- rawColon(root2) { +- let value; +- root2.walkDecls((i2) => { +- if (typeof i2.raws.between !== "undefined") { +- value = i2.raws.between.replace(/[^\s:]/g, ""); +- return false; +- } +- }); +- return value; +- } +- rawEmptyBody(root2) { +- let value; +- root2.walk((i2) => { +- if (i2.nodes && i2.nodes.length === 0) { +- value = i2.raws.after; +- if (typeof value !== "undefined") return false; +- } +- }); +- return value; +- } +- rawIndent(root2) { +- if (root2.raws.indent) return root2.raws.indent; +- let value; +- root2.walk((i2) => { +- let p = i2.parent; +- if (p && p !== root2 && p.parent && p.parent === root2) { +- if (typeof i2.raws.before !== "undefined") { +- let parts = i2.raws.before.split("\n"); +- value = parts[parts.length - 1]; +- value = value.replace(/\S/g, ""); +- return false; +- } +- } +- }); +- return value; +- } +- rawSemicolon(root2) { +- let value; +- root2.walk((i2) => { +- if (i2.nodes && i2.nodes.length && i2.last.type === "decl") { +- value = i2.raws.semicolon; +- if (typeof value !== "undefined") return false; +- } +- }); +- return value; +- } +- rawValue(node2, prop) { +- let value = node2[prop]; +- let raw = node2.raws[prop]; +- if (raw && raw.value === value) { +- return raw.raw; +- } +- return value; +- } +- root(node2) { +- this.body(node2); +- if (node2.raws.after) this.builder(node2.raws.after); +- } +- rule(node2) { +- this.block(node2, this.rawValue(node2, "selector")); +- if (node2.raws.ownSemicolon) { +- this.builder(node2.raws.ownSemicolon, node2, "end"); +- } +- } +- stringify(node2, semicolon) { +- if (!this[node2.type]) { +- throw new Error( +- "Unknown AST node type " + node2.type + ". Maybe you need to change PostCSS stringifier." +- ); +- } +- this[node2.type](node2, semicolon); +- } +-}; +-var stringifier$1 = Stringifier$2$1; +-Stringifier$2$1.default = Stringifier$2$1; +-let Stringifier$1$1 = stringifier$1; +-function stringify$4$1(node2, builder) { +- let str = new Stringifier$1$1(builder); +- str.stringify(node2); +-} +-var stringify_1$1 = stringify$4$1; +-stringify$4$1.default = stringify$4$1; +-let { isClean: isClean$2$1, my: my$2$1 } = symbols$1; +-let CssSyntaxError$2$1 = cssSyntaxError$1; +-let Stringifier2$1 = stringifier$1; +-let stringify$3$1 = stringify_1$1; +-function cloneNode$1(obj, parent) { +- let cloned = new obj.constructor(); +- for (let i2 in obj) { +- if (!Object.prototype.hasOwnProperty.call(obj, i2)) { +- continue; +- } +- if (i2 === "proxyCache") continue; +- let value = obj[i2]; +- let type = typeof value; +- if (i2 === "parent" && type === "object") { +- if (parent) cloned[i2] = parent; +- } else if (i2 === "source") { +- cloned[i2] = value; +- } else if (Array.isArray(value)) { +- cloned[i2] = value.map((j) => cloneNode$1(j, cloned)); +- } else { +- if (type === "object" && value !== null) value = cloneNode$1(value); +- cloned[i2] = value; +- } +- } +- return cloned; +-} +-let Node$4$1 = class Node2 { +- constructor(defaults = {}) { +- this.raws = {}; +- this[isClean$2$1] = false; +- this[my$2$1] = true; +- for (let name in defaults) { +- if (name === "nodes") { +- this.nodes = []; +- for (let node2 of defaults[name]) { +- if (typeof node2.clone === "function") { +- this.append(node2.clone()); +- } else { +- this.append(node2); +- } +- } +- } else { +- this[name] = defaults[name]; +- } +- } +- } +- addToError(error) { +- error.postcssNode = this; +- if (error.stack && this.source && /\n\s{4}at /.test(error.stack)) { +- let s2 = this.source; +- error.stack = error.stack.replace( +- /\n\s{4}at /, +- `$&${s2.input.from}:${s2.start.line}:${s2.start.column}$&` +- ); +- } +- return error; +- } +- after(add) { +- this.parent.insertAfter(this, add); +- return this; +- } +- assign(overrides = {}) { +- for (let name in overrides) { +- this[name] = overrides[name]; +- } +- return this; +- } +- before(add) { +- this.parent.insertBefore(this, add); +- return this; +- } +- cleanRaws(keepBetween) { +- delete this.raws.before; +- delete this.raws.after; +- if (!keepBetween) delete this.raws.between; +- } +- clone(overrides = {}) { +- let cloned = cloneNode$1(this); +- for (let name in overrides) { +- cloned[name] = overrides[name]; +- } +- return cloned; +- } +- cloneAfter(overrides = {}) { +- let cloned = this.clone(overrides); +- this.parent.insertAfter(this, cloned); +- return cloned; +- } +- cloneBefore(overrides = {}) { +- let cloned = this.clone(overrides); +- this.parent.insertBefore(this, cloned); +- return cloned; +- } +- error(message, opts = {}) { +- if (this.source) { +- let { end, start } = this.rangeBy(opts); +- return this.source.input.error( +- message, +- { column: start.column, line: start.line }, +- { column: end.column, line: end.line }, +- opts +- ); +- } +- return new CssSyntaxError$2$1(message); +- } +- getProxyProcessor() { +- return { +- get(node2, prop) { +- if (prop === "proxyOf") { +- return node2; +- } else if (prop === "root") { +- return () => node2.root().toProxy(); +- } else { +- return node2[prop]; +- } +- }, +- set(node2, prop, value) { +- if (node2[prop] === value) return true; +- node2[prop] = value; +- if (prop === "prop" || prop === "value" || prop === "name" || prop === "params" || prop === "important" || /* c8 ignore next */ +- prop === "text") { +- node2.markDirty(); +- } +- return true; +- } +- }; +- } +- markDirty() { +- if (this[isClean$2$1]) { +- this[isClean$2$1] = false; +- let next = this; +- while (next = next.parent) { +- next[isClean$2$1] = false; +- } +- } +- } +- next() { +- if (!this.parent) return void 0; +- let index2 = this.parent.index(this); +- return this.parent.nodes[index2 + 1]; +- } +- positionBy(opts, stringRepresentation) { +- let pos = this.source.start; +- if (opts.index) { +- pos = this.positionInside(opts.index, stringRepresentation); +- } else if (opts.word) { +- stringRepresentation = this.toString(); +- let index2 = stringRepresentation.indexOf(opts.word); +- if (index2 !== -1) pos = this.positionInside(index2, stringRepresentation); +- } +- return pos; +- } +- positionInside(index2, stringRepresentation) { +- let string = stringRepresentation || this.toString(); +- let column = this.source.start.column; +- let line = this.source.start.line; +- for (let i2 = 0; i2 < index2; i2++) { +- if (string[i2] === "\n") { +- column = 1; +- line += 1; +- } else { +- column += 1; +- } +- } +- return { column, line }; +- } +- prev() { +- if (!this.parent) return void 0; +- let index2 = this.parent.index(this); +- return this.parent.nodes[index2 - 1]; +- } +- rangeBy(opts) { +- let start = { +- column: this.source.start.column, +- line: this.source.start.line +- }; +- let end = this.source.end ? { +- column: this.source.end.column + 1, +- line: this.source.end.line +- } : { +- column: start.column + 1, +- line: start.line +- }; +- if (opts.word) { +- let stringRepresentation = this.toString(); +- let index2 = stringRepresentation.indexOf(opts.word); +- if (index2 !== -1) { +- start = this.positionInside(index2, stringRepresentation); +- end = this.positionInside(index2 + opts.word.length, stringRepresentation); +- } +- } else { +- if (opts.start) { +- start = { +- column: opts.start.column, +- line: opts.start.line +- }; +- } else if (opts.index) { +- start = this.positionInside(opts.index); +- } +- if (opts.end) { +- end = { +- column: opts.end.column, +- line: opts.end.line +- }; +- } else if (typeof opts.endIndex === "number") { +- end = this.positionInside(opts.endIndex); +- } else if (opts.index) { +- end = this.positionInside(opts.index + 1); +- } +- } +- if (end.line < start.line || end.line === start.line && end.column <= start.column) { +- end = { column: start.column + 1, line: start.line }; +- } +- return { end, start }; +- } +- raw(prop, defaultType) { +- let str = new Stringifier2$1(); +- return str.raw(this, prop, defaultType); +- } +- remove() { +- if (this.parent) { +- this.parent.removeChild(this); +- } +- this.parent = void 0; +- return this; +- } +- replaceWith(...nodes) { +- if (this.parent) { +- let bookmark = this; +- let foundSelf = false; +- for (let node2 of nodes) { +- if (node2 === this) { +- foundSelf = true; +- } else if (foundSelf) { +- this.parent.insertAfter(bookmark, node2); +- bookmark = node2; +- } else { +- this.parent.insertBefore(bookmark, node2); +- } +- } +- if (!foundSelf) { +- this.remove(); +- } +- } +- return this; +- } +- root() { +- let result2 = this; +- while (result2.parent && result2.parent.type !== "document") { +- result2 = result2.parent; +- } +- return result2; +- } +- toJSON(_, inputs) { +- let fixed = {}; +- let emitInputs = inputs == null; +- inputs = inputs || /* @__PURE__ */ new Map(); +- let inputsNextIndex = 0; +- for (let name in this) { +- if (!Object.prototype.hasOwnProperty.call(this, name)) { +- continue; +- } +- if (name === "parent" || name === "proxyCache") continue; +- let value = this[name]; +- if (Array.isArray(value)) { +- fixed[name] = value.map((i2) => { +- if (typeof i2 === "object" && i2.toJSON) { +- return i2.toJSON(null, inputs); +- } else { +- return i2; +- } +- }); +- } else if (typeof value === "object" && value.toJSON) { +- fixed[name] = value.toJSON(null, inputs); +- } else if (name === "source") { +- let inputId = inputs.get(value.input); +- if (inputId == null) { +- inputId = inputsNextIndex; +- inputs.set(value.input, inputsNextIndex); +- inputsNextIndex++; +- } +- fixed[name] = { +- end: value.end, +- inputId, +- start: value.start +- }; +- } else { +- fixed[name] = value; +- } +- } +- if (emitInputs) { +- fixed.inputs = [...inputs.keys()].map((input2) => input2.toJSON()); +- } +- return fixed; +- } +- toProxy() { +- if (!this.proxyCache) { +- this.proxyCache = new Proxy(this, this.getProxyProcessor()); +- } +- return this.proxyCache; +- } +- toString(stringifier2 = stringify$3$1) { +- if (stringifier2.stringify) stringifier2 = stringifier2.stringify; +- let result2 = ""; +- stringifier2(this, (i2) => { +- result2 += i2; +- }); +- return result2; +- } +- warn(result2, text, opts) { +- let data = { node: this }; +- for (let i2 in opts) data[i2] = opts[i2]; +- return result2.warn(text, data); +- } +- get proxyOf() { +- return this; +- } +-}; +-var node$1 = Node$4$1; +-Node$4$1.default = Node$4$1; +-let Node$3$1 = node$1; +-let Declaration$4$1 = class Declaration extends Node$3$1 { +- constructor(defaults) { +- if (defaults && typeof defaults.value !== "undefined" && typeof defaults.value !== "string") { +- defaults = { ...defaults, value: String(defaults.value) }; +- } +- super(defaults); +- this.type = "decl"; +- } +- get variable() { +- return this.prop.startsWith("--") || this.prop[0] === "$"; +- } +-}; +-var declaration$1 = Declaration$4$1; +-Declaration$4$1.default = Declaration$4$1; +-let urlAlphabet$1 = "useandom-26T198340PX75pxJACKVERYMINDBUSHWOLF_GQZbfghjklqvwyzrict"; +-let customAlphabet$1 = (alphabet, defaultSize = 21) => { +- return (size = defaultSize) => { +- let id = ""; +- let i2 = size; +- while (i2--) { +- id += alphabet[Math.random() * alphabet.length | 0]; +- } +- return id; +- }; +-}; +-let nanoid$1$1 = (size = 21) => { +- let id = ""; +- let i2 = size; +- while (i2--) { +- id += urlAlphabet$1[Math.random() * 64 | 0]; +- } +- return id; +-}; +-var nonSecure$1 = { nanoid: nanoid$1$1, customAlphabet: customAlphabet$1 }; +-let { SourceMapConsumer: SourceMapConsumer$2$1, SourceMapGenerator: SourceMapGenerator$2$1 } = require$$2$1; +-let { existsSync: existsSync$1, readFileSync: readFileSync$1 } = require$$2$1; +-let { dirname: dirname$1$1, join: join$1 } = require$$2$1; +-function fromBase64$1(str) { +- if (Buffer) { +- return Buffer.from(str, "base64").toString(); +- } else { +- return window.atob(str); +- } +-} +-let PreviousMap$2$1 = class PreviousMap { +- constructor(css, opts) { +- if (opts.map === false) return; +- this.loadAnnotation(css); +- this.inline = this.startWith(this.annotation, "data:"); +- let prev = opts.map ? opts.map.prev : void 0; +- let text = this.loadMap(opts.from, prev); +- if (!this.mapFile && opts.from) { +- this.mapFile = opts.from; +- } +- if (this.mapFile) this.root = dirname$1$1(this.mapFile); +- if (text) this.text = text; +- } +- consumer() { +- if (!this.consumerCache) { +- this.consumerCache = new SourceMapConsumer$2$1(this.text); +- } +- return this.consumerCache; +- } +- decodeInline(text) { +- let baseCharsetUri = /^data:application\/json;charset=utf-?8;base64,/; +- let baseUri = /^data:application\/json;base64,/; +- let charsetUri = /^data:application\/json;charset=utf-?8,/; +- let uri = /^data:application\/json,/; +- if (charsetUri.test(text) || uri.test(text)) { +- return decodeURIComponent(text.substr(RegExp.lastMatch.length)); +- } +- if (baseCharsetUri.test(text) || baseUri.test(text)) { +- return fromBase64$1(text.substr(RegExp.lastMatch.length)); +- } +- let encoding = text.match(/data:application\/json;([^,]+),/)[1]; +- throw new Error("Unsupported source map encoding " + encoding); +- } +- getAnnotationURL(sourceMapString) { +- return sourceMapString.replace(/^\/\*\s*# sourceMappingURL=/, "").trim(); +- } +- isMap(map) { +- if (typeof map !== "object") return false; +- return typeof map.mappings === "string" || typeof map._mappings === "string" || Array.isArray(map.sections); +- } +- loadAnnotation(css) { +- let comments = css.match(/\/\*\s*# sourceMappingURL=/gm); +- if (!comments) return; +- let start = css.lastIndexOf(comments.pop()); +- let end = css.indexOf("*/", start); +- if (start > -1 && end > -1) { +- this.annotation = this.getAnnotationURL(css.substring(start, end)); +- } +- } +- loadFile(path) { +- this.root = dirname$1$1(path); +- if (existsSync$1(path)) { +- this.mapFile = path; +- return readFileSync$1(path, "utf-8").toString().trim(); +- } +- } +- loadMap(file, prev) { +- if (prev === false) return false; +- if (prev) { +- if (typeof prev === "string") { +- return prev; +- } else if (typeof prev === "function") { +- let prevPath = prev(file); +- if (prevPath) { +- let map = this.loadFile(prevPath); +- if (!map) { +- throw new Error( +- "Unable to load previous source map: " + prevPath.toString() +- ); +- } +- return map; +- } +- } else if (prev instanceof SourceMapConsumer$2$1) { +- return SourceMapGenerator$2$1.fromSourceMap(prev).toString(); +- } else if (prev instanceof SourceMapGenerator$2$1) { +- return prev.toString(); +- } else if (this.isMap(prev)) { +- return JSON.stringify(prev); +- } else { +- throw new Error( +- "Unsupported previous source map format: " + prev.toString() +- ); +- } +- } else if (this.inline) { +- return this.decodeInline(this.annotation); +- } else if (this.annotation) { +- let map = this.annotation; +- if (file) map = join$1(dirname$1$1(file), map); +- return this.loadFile(map); +- } +- } +- startWith(string, start) { +- if (!string) return false; +- return string.substr(0, start.length) === start; +- } +- withContent() { +- return !!(this.consumer().sourcesContent && this.consumer().sourcesContent.length > 0); +- } +-}; +-var previousMap$1 = PreviousMap$2$1; +-PreviousMap$2$1.default = PreviousMap$2$1; +-let { SourceMapConsumer: SourceMapConsumer$1$1, SourceMapGenerator: SourceMapGenerator$1$1 } = require$$2$1; +-let { fileURLToPath: fileURLToPath$1, pathToFileURL: pathToFileURL$1$1 } = require$$2$1; +-let { isAbsolute: isAbsolute$1, resolve: resolve$1$1 } = require$$2$1; +-let { nanoid: nanoid$2 } = nonSecure$1; +-let terminalHighlight$2 = require$$2$1; +-let CssSyntaxError$1$1 = cssSyntaxError$1; +-let PreviousMap$1$1 = previousMap$1; +-let fromOffsetCache$1 = Symbol("fromOffsetCache"); +-let sourceMapAvailable$1$1 = Boolean(SourceMapConsumer$1$1 && SourceMapGenerator$1$1); +-let pathAvailable$1$1 = Boolean(resolve$1$1 && isAbsolute$1); +-let Input$4$1 = class Input { +- constructor(css, opts = {}) { +- if (css === null || typeof css === "undefined" || typeof css === "object" && !css.toString) { +- throw new Error(`PostCSS received ${css} instead of CSS string`); +- } +- this.css = css.toString(); +- if (this.css[0] === "\uFEFF" || this.css[0] === "￾") { +- this.hasBOM = true; +- this.css = this.css.slice(1); +- } else { +- this.hasBOM = false; +- } +- if (opts.from) { +- if (!pathAvailable$1$1 || /^\w+:\/\//.test(opts.from) || isAbsolute$1(opts.from)) { +- this.file = opts.from; +- } else { +- this.file = resolve$1$1(opts.from); +- } +- } +- if (pathAvailable$1$1 && sourceMapAvailable$1$1) { +- let map = new PreviousMap$1$1(this.css, opts); +- if (map.text) { +- this.map = map; +- let file = map.consumer().file; +- if (!this.file && file) this.file = this.mapResolve(file); +- } +- } +- if (!this.file) { +- this.id = ""; +- } +- if (this.map) this.map.file = this.from; +- } +- error(message, line, column, opts = {}) { +- let result2, endLine, endColumn; +- if (line && typeof line === "object") { +- let start = line; +- let end = column; +- if (typeof start.offset === "number") { +- let pos = this.fromOffset(start.offset); +- line = pos.line; +- column = pos.col; +- } else { +- line = start.line; +- column = start.column; +- } +- if (typeof end.offset === "number") { +- let pos = this.fromOffset(end.offset); +- endLine = pos.line; +- endColumn = pos.col; +- } else { +- endLine = end.line; +- endColumn = end.column; +- } +- } else if (!column) { +- let pos = this.fromOffset(line); +- line = pos.line; +- column = pos.col; +- } +- let origin = this.origin(line, column, endLine, endColumn); +- if (origin) { +- result2 = new CssSyntaxError$1$1( +- message, +- origin.endLine === void 0 ? origin.line : { column: origin.column, line: origin.line }, +- origin.endLine === void 0 ? origin.column : { column: origin.endColumn, line: origin.endLine }, +- origin.source, +- origin.file, +- opts.plugin +- ); +- } else { +- result2 = new CssSyntaxError$1$1( +- message, +- endLine === void 0 ? line : { column, line }, +- endLine === void 0 ? column : { column: endColumn, line: endLine }, +- this.css, +- this.file, +- opts.plugin +- ); +- } +- result2.input = { column, endColumn, endLine, line, source: this.css }; +- if (this.file) { +- if (pathToFileURL$1$1) { +- result2.input.url = pathToFileURL$1$1(this.file).toString(); +- } +- result2.input.file = this.file; +- } +- return result2; +- } +- fromOffset(offset) { +- let lastLine, lineToIndex; +- if (!this[fromOffsetCache$1]) { +- let lines = this.css.split("\n"); +- lineToIndex = new Array(lines.length); +- let prevIndex = 0; +- for (let i2 = 0, l2 = lines.length; i2 < l2; i2++) { +- lineToIndex[i2] = prevIndex; +- prevIndex += lines[i2].length + 1; +- } +- this[fromOffsetCache$1] = lineToIndex; +- } else { +- lineToIndex = this[fromOffsetCache$1]; +- } +- lastLine = lineToIndex[lineToIndex.length - 1]; +- let min = 0; +- if (offset >= lastLine) { +- min = lineToIndex.length - 1; +- } else { +- let max = lineToIndex.length - 2; +- let mid; +- while (min < max) { +- mid = min + (max - min >> 1); +- if (offset < lineToIndex[mid]) { +- max = mid - 1; +- } else if (offset >= lineToIndex[mid + 1]) { +- min = mid + 1; +- } else { +- min = mid; +- break; +- } +- } +- } +- return { +- col: offset - lineToIndex[min] + 1, +- line: min + 1 +- }; +- } +- mapResolve(file) { +- if (/^\w+:\/\//.test(file)) { +- return file; +- } +- return resolve$1$1(this.map.consumer().sourceRoot || this.map.root || ".", file); +- } +- origin(line, column, endLine, endColumn) { +- if (!this.map) return false; +- let consumer = this.map.consumer(); +- let from = consumer.originalPositionFor({ column, line }); +- if (!from.source) return false; +- let to; +- if (typeof endLine === "number") { +- to = consumer.originalPositionFor({ column: endColumn, line: endLine }); +- } +- let fromUrl; +- if (isAbsolute$1(from.source)) { +- fromUrl = pathToFileURL$1$1(from.source); +- } else { +- fromUrl = new URL( +- from.source, +- this.map.consumer().sourceRoot || pathToFileURL$1$1(this.map.mapFile) +- ); +- } +- let result2 = { +- column: from.column, +- endColumn: to && to.column, +- endLine: to && to.line, +- line: from.line, +- url: fromUrl.toString() +- }; +- if (fromUrl.protocol === "file:") { +- if (fileURLToPath$1) { +- result2.file = fileURLToPath$1(fromUrl); +- } else { +- throw new Error(`file: protocol is not available in this PostCSS build`); +- } +- } +- let source = consumer.sourceContentFor(from.source); +- if (source) result2.source = source; +- return result2; +- } +- toJSON() { +- let json = {}; +- for (let name of ["hasBOM", "css", "file", "id"]) { +- if (this[name] != null) { +- json[name] = this[name]; +- } +- } +- if (this.map) { +- json.map = { ...this.map }; +- if (json.map.consumerCache) { +- json.map.consumerCache = void 0; +- } +- } +- return json; +- } +- get from() { +- return this.file || this.id; +- } +-}; +-var input$1 = Input$4$1; +-Input$4$1.default = Input$4$1; +-if (terminalHighlight$2 && terminalHighlight$2.registerInput) { +- terminalHighlight$2.registerInput(Input$4$1); +-} +-let { SourceMapConsumer: SourceMapConsumer$3, SourceMapGenerator: SourceMapGenerator$3 } = require$$2$1; +-let { dirname: dirname$2, relative: relative$1, resolve: resolve$2, sep: sep$1 } = require$$2$1; +-let { pathToFileURL: pathToFileURL$2 } = require$$2$1; +-let Input$3$1 = input$1; +-let sourceMapAvailable$2 = Boolean(SourceMapConsumer$3 && SourceMapGenerator$3); +-let pathAvailable$2 = Boolean(dirname$2 && resolve$2 && relative$1 && sep$1); +-let MapGenerator$2$1 = class MapGenerator { +- constructor(stringify2, root2, opts, cssString) { +- this.stringify = stringify2; +- this.mapOpts = opts.map || {}; +- this.root = root2; +- this.opts = opts; +- this.css = cssString; +- this.originalCSS = cssString; +- this.usesFileUrls = !this.mapOpts.from && this.mapOpts.absolute; +- this.memoizedFileURLs = /* @__PURE__ */ new Map(); +- this.memoizedPaths = /* @__PURE__ */ new Map(); +- this.memoizedURLs = /* @__PURE__ */ new Map(); +- } +- addAnnotation() { +- let content; +- if (this.isInline()) { +- content = "data:application/json;base64," + this.toBase64(this.map.toString()); +- } else if (typeof this.mapOpts.annotation === "string") { +- content = this.mapOpts.annotation; +- } else if (typeof this.mapOpts.annotation === "function") { +- content = this.mapOpts.annotation(this.opts.to, this.root); +- } else { +- content = this.outputFile() + ".map"; +- } +- let eol = "\n"; +- if (this.css.includes("\r\n")) eol = "\r\n"; +- this.css += eol + "/*# sourceMappingURL=" + content + " */"; +- } +- applyPrevMaps() { +- for (let prev of this.previous()) { +- let from = this.toUrl(this.path(prev.file)); +- let root2 = prev.root || dirname$2(prev.file); +- let map; +- if (this.mapOpts.sourcesContent === false) { +- map = new SourceMapConsumer$3(prev.text); +- if (map.sourcesContent) { +- map.sourcesContent = null; +- } +- } else { +- map = prev.consumer(); +- } +- this.map.applySourceMap(map, from, this.toUrl(this.path(root2))); +- } +- } +- clearAnnotation() { +- if (this.mapOpts.annotation === false) return; +- if (this.root) { +- let node2; +- for (let i2 = this.root.nodes.length - 1; i2 >= 0; i2--) { +- node2 = this.root.nodes[i2]; +- if (node2.type !== "comment") continue; +- if (node2.text.indexOf("# sourceMappingURL=") === 0) { +- this.root.removeChild(i2); +- } +- } +- } else if (this.css) { +- this.css = this.css.replace(/\n*?\/\*#[\S\s]*?\*\/$/gm, ""); +- } +- } +- generate() { +- this.clearAnnotation(); +- if (pathAvailable$2 && sourceMapAvailable$2 && this.isMap()) { +- return this.generateMap(); +- } else { +- let result2 = ""; +- this.stringify(this.root, (i2) => { +- result2 += i2; +- }); +- return [result2]; +- } +- } +- generateMap() { +- if (this.root) { +- this.generateString(); +- } else if (this.previous().length === 1) { +- let prev = this.previous()[0].consumer(); +- prev.file = this.outputFile(); +- this.map = SourceMapGenerator$3.fromSourceMap(prev, { +- ignoreInvalidMapping: true +- }); +- } else { +- this.map = new SourceMapGenerator$3({ +- file: this.outputFile(), +- ignoreInvalidMapping: true +- }); +- this.map.addMapping({ +- generated: { column: 0, line: 1 }, +- original: { column: 0, line: 1 }, +- source: this.opts.from ? this.toUrl(this.path(this.opts.from)) : "" +- }); +- } +- if (this.isSourcesContent()) this.setSourcesContent(); +- if (this.root && this.previous().length > 0) this.applyPrevMaps(); +- if (this.isAnnotation()) this.addAnnotation(); +- if (this.isInline()) { +- return [this.css]; +- } else { +- return [this.css, this.map]; +- } +- } +- generateString() { +- this.css = ""; +- this.map = new SourceMapGenerator$3({ +- file: this.outputFile(), +- ignoreInvalidMapping: true +- }); +- let line = 1; +- let column = 1; +- let noSource = ""; +- let mapping = { +- generated: { column: 0, line: 0 }, +- original: { column: 0, line: 0 }, +- source: "" +- }; +- let lines, last; +- this.stringify(this.root, (str, node2, type) => { +- this.css += str; +- if (node2 && type !== "end") { +- mapping.generated.line = line; +- mapping.generated.column = column - 1; +- if (node2.source && node2.source.start) { +- mapping.source = this.sourcePath(node2); +- mapping.original.line = node2.source.start.line; +- mapping.original.column = node2.source.start.column - 1; +- this.map.addMapping(mapping); +- } else { +- mapping.source = noSource; +- mapping.original.line = 1; +- mapping.original.column = 0; +- this.map.addMapping(mapping); +- } +- } +- lines = str.match(/\n/g); +- if (lines) { +- line += lines.length; +- last = str.lastIndexOf("\n"); +- column = str.length - last; +- } else { +- column += str.length; +- } +- if (node2 && type !== "start") { +- let p = node2.parent || { raws: {} }; +- let childless = node2.type === "decl" || node2.type === "atrule" && !node2.nodes; +- if (!childless || node2 !== p.last || p.raws.semicolon) { +- if (node2.source && node2.source.end) { +- mapping.source = this.sourcePath(node2); +- mapping.original.line = node2.source.end.line; +- mapping.original.column = node2.source.end.column - 1; +- mapping.generated.line = line; +- mapping.generated.column = column - 2; +- this.map.addMapping(mapping); +- } else { +- mapping.source = noSource; +- mapping.original.line = 1; +- mapping.original.column = 0; +- mapping.generated.line = line; +- mapping.generated.column = column - 1; +- this.map.addMapping(mapping); +- } +- } +- } +- }); +- } +- isAnnotation() { +- if (this.isInline()) { +- return true; +- } +- if (typeof this.mapOpts.annotation !== "undefined") { +- return this.mapOpts.annotation; +- } +- if (this.previous().length) { +- return this.previous().some((i2) => i2.annotation); +- } +- return true; +- } +- isInline() { +- if (typeof this.mapOpts.inline !== "undefined") { +- return this.mapOpts.inline; +- } +- let annotation = this.mapOpts.annotation; +- if (typeof annotation !== "undefined" && annotation !== true) { +- return false; +- } +- if (this.previous().length) { +- return this.previous().some((i2) => i2.inline); +- } +- return true; +- } +- isMap() { +- if (typeof this.opts.map !== "undefined") { +- return !!this.opts.map; +- } +- return this.previous().length > 0; +- } +- isSourcesContent() { +- if (typeof this.mapOpts.sourcesContent !== "undefined") { +- return this.mapOpts.sourcesContent; +- } +- if (this.previous().length) { +- return this.previous().some((i2) => i2.withContent()); +- } +- return true; +- } +- outputFile() { +- if (this.opts.to) { +- return this.path(this.opts.to); +- } else if (this.opts.from) { +- return this.path(this.opts.from); +- } else { +- return "to.css"; +- } +- } +- path(file) { +- if (this.mapOpts.absolute) return file; +- if (file.charCodeAt(0) === 60) return file; +- if (/^\w+:\/\//.test(file)) return file; +- let cached = this.memoizedPaths.get(file); +- if (cached) return cached; +- let from = this.opts.to ? dirname$2(this.opts.to) : "."; +- if (typeof this.mapOpts.annotation === "string") { +- from = dirname$2(resolve$2(from, this.mapOpts.annotation)); +- } +- let path = relative$1(from, file); +- this.memoizedPaths.set(file, path); +- return path; +- } +- previous() { +- if (!this.previousMaps) { +- this.previousMaps = []; +- if (this.root) { +- this.root.walk((node2) => { +- if (node2.source && node2.source.input.map) { +- let map = node2.source.input.map; +- if (!this.previousMaps.includes(map)) { +- this.previousMaps.push(map); +- } +- } +- }); +- } else { +- let input2 = new Input$3$1(this.originalCSS, this.opts); +- if (input2.map) this.previousMaps.push(input2.map); +- } +- } +- return this.previousMaps; +- } +- setSourcesContent() { +- let already = {}; +- if (this.root) { +- this.root.walk((node2) => { +- if (node2.source) { +- let from = node2.source.input.from; +- if (from && !already[from]) { +- already[from] = true; +- let fromUrl = this.usesFileUrls ? this.toFileUrl(from) : this.toUrl(this.path(from)); +- this.map.setSourceContent(fromUrl, node2.source.input.css); +- } +- } +- }); +- } else if (this.css) { +- let from = this.opts.from ? this.toUrl(this.path(this.opts.from)) : ""; +- this.map.setSourceContent(from, this.css); +- } +- } +- sourcePath(node2) { +- if (this.mapOpts.from) { +- return this.toUrl(this.mapOpts.from); +- } else if (this.usesFileUrls) { +- return this.toFileUrl(node2.source.input.from); +- } else { +- return this.toUrl(this.path(node2.source.input.from)); +- } +- } +- toBase64(str) { +- if (Buffer) { +- return Buffer.from(str).toString("base64"); +- } else { +- return window.btoa(unescape(encodeURIComponent(str))); +- } +- } +- toFileUrl(path) { +- let cached = this.memoizedFileURLs.get(path); +- if (cached) return cached; +- if (pathToFileURL$2) { +- let fileURL = pathToFileURL$2(path).toString(); +- this.memoizedFileURLs.set(path, fileURL); +- return fileURL; +- } else { +- throw new Error( +- "`map.absolute` option is not available in this PostCSS build" +- ); +- } +- } +- toUrl(path) { +- let cached = this.memoizedURLs.get(path); +- if (cached) return cached; +- if (sep$1 === "\\") { +- path = path.replace(/\\/g, "/"); +- } +- let url = encodeURI(path).replace(/[#?]/g, encodeURIComponent); +- this.memoizedURLs.set(path, url); +- return url; +- } +-}; +-var mapGenerator$1 = MapGenerator$2$1; +-let Node$2$1 = node$1; +-let Comment$4$1 = class Comment extends Node$2$1 { +- constructor(defaults) { +- super(defaults); +- this.type = "comment"; +- } +-}; +-var comment$1 = Comment$4$1; +-Comment$4$1.default = Comment$4$1; +-let { isClean: isClean$1$1, my: my$1$1 } = symbols$1; +-let Declaration$3$1 = declaration$1; +-let Comment$3$1 = comment$1; +-let Node$1$1 = node$1; +-let parse$4$1, Rule$4$1, AtRule$4$1, Root$6$1; +-function cleanSource$1(nodes) { +- return nodes.map((i2) => { +- if (i2.nodes) i2.nodes = cleanSource$1(i2.nodes); +- delete i2.source; +- return i2; +- }); +-} +-function markDirtyUp$1(node2) { +- node2[isClean$1$1] = false; +- if (node2.proxyOf.nodes) { +- for (let i2 of node2.proxyOf.nodes) { +- markDirtyUp$1(i2); +- } +- } +-} +-let Container$7$1 = class Container extends Node$1$1 { +- append(...children) { +- for (let child of children) { +- let nodes = this.normalize(child, this.last); +- for (let node2 of nodes) this.proxyOf.nodes.push(node2); +- } +- this.markDirty(); +- return this; +- } +- cleanRaws(keepBetween) { +- super.cleanRaws(keepBetween); +- if (this.nodes) { +- for (let node2 of this.nodes) node2.cleanRaws(keepBetween); +- } +- } +- each(callback) { +- if (!this.proxyOf.nodes) return void 0; +- let iterator = this.getIterator(); +- let index2, result2; +- while (this.indexes[iterator] < this.proxyOf.nodes.length) { +- index2 = this.indexes[iterator]; +- result2 = callback(this.proxyOf.nodes[index2], index2); +- if (result2 === false) break; +- this.indexes[iterator] += 1; +- } +- delete this.indexes[iterator]; +- return result2; +- } +- every(condition) { +- return this.nodes.every(condition); +- } +- getIterator() { +- if (!this.lastEach) this.lastEach = 0; +- if (!this.indexes) this.indexes = {}; +- this.lastEach += 1; +- let iterator = this.lastEach; +- this.indexes[iterator] = 0; +- return iterator; +- } +- getProxyProcessor() { +- return { +- get(node2, prop) { +- if (prop === "proxyOf") { +- return node2; +- } else if (!node2[prop]) { +- return node2[prop]; +- } else if (prop === "each" || typeof prop === "string" && prop.startsWith("walk")) { +- return (...args) => { +- return node2[prop]( +- ...args.map((i2) => { +- if (typeof i2 === "function") { +- return (child, index2) => i2(child.toProxy(), index2); +- } else { +- return i2; +- } +- }) +- ); +- }; +- } else if (prop === "every" || prop === "some") { +- return (cb) => { +- return node2[prop]( +- (child, ...other) => cb(child.toProxy(), ...other) +- ); +- }; +- } else if (prop === "root") { +- return () => node2.root().toProxy(); +- } else if (prop === "nodes") { +- return node2.nodes.map((i2) => i2.toProxy()); +- } else if (prop === "first" || prop === "last") { +- return node2[prop].toProxy(); +- } else { +- return node2[prop]; +- } +- }, +- set(node2, prop, value) { +- if (node2[prop] === value) return true; +- node2[prop] = value; +- if (prop === "name" || prop === "params" || prop === "selector") { +- node2.markDirty(); +- } +- return true; +- } +- }; +- } +- index(child) { +- if (typeof child === "number") return child; +- if (child.proxyOf) child = child.proxyOf; +- return this.proxyOf.nodes.indexOf(child); +- } +- insertAfter(exist, add) { +- let existIndex = this.index(exist); +- let nodes = this.normalize(add, this.proxyOf.nodes[existIndex]).reverse(); +- existIndex = this.index(exist); +- for (let node2 of nodes) this.proxyOf.nodes.splice(existIndex + 1, 0, node2); +- let index2; +- for (let id in this.indexes) { +- index2 = this.indexes[id]; +- if (existIndex < index2) { +- this.indexes[id] = index2 + nodes.length; +- } +- } +- this.markDirty(); +- return this; +- } +- insertBefore(exist, add) { +- let existIndex = this.index(exist); +- let type = existIndex === 0 ? "prepend" : false; +- let nodes = this.normalize(add, this.proxyOf.nodes[existIndex], type).reverse(); +- existIndex = this.index(exist); +- for (let node2 of nodes) this.proxyOf.nodes.splice(existIndex, 0, node2); +- let index2; +- for (let id in this.indexes) { +- index2 = this.indexes[id]; +- if (existIndex <= index2) { +- this.indexes[id] = index2 + nodes.length; +- } +- } +- this.markDirty(); +- return this; +- } +- normalize(nodes, sample) { +- if (typeof nodes === "string") { +- nodes = cleanSource$1(parse$4$1(nodes).nodes); +- } else if (typeof nodes === "undefined") { +- nodes = []; +- } else if (Array.isArray(nodes)) { +- nodes = nodes.slice(0); +- for (let i2 of nodes) { +- if (i2.parent) i2.parent.removeChild(i2, "ignore"); +- } +- } else if (nodes.type === "root" && this.type !== "document") { +- nodes = nodes.nodes.slice(0); +- for (let i2 of nodes) { +- if (i2.parent) i2.parent.removeChild(i2, "ignore"); +- } +- } else if (nodes.type) { +- nodes = [nodes]; +- } else if (nodes.prop) { +- if (typeof nodes.value === "undefined") { +- throw new Error("Value field is missed in node creation"); +- } else if (typeof nodes.value !== "string") { +- nodes.value = String(nodes.value); +- } +- nodes = [new Declaration$3$1(nodes)]; +- } else if (nodes.selector) { +- nodes = [new Rule$4$1(nodes)]; +- } else if (nodes.name) { +- nodes = [new AtRule$4$1(nodes)]; +- } else if (nodes.text) { +- nodes = [new Comment$3$1(nodes)]; +- } else { +- throw new Error("Unknown node type in node creation"); +- } +- let processed = nodes.map((i2) => { +- if (!i2[my$1$1]) Container.rebuild(i2); +- i2 = i2.proxyOf; +- if (i2.parent) i2.parent.removeChild(i2); +- if (i2[isClean$1$1]) markDirtyUp$1(i2); +- if (typeof i2.raws.before === "undefined") { +- if (sample && typeof sample.raws.before !== "undefined") { +- i2.raws.before = sample.raws.before.replace(/\S/g, ""); +- } +- } +- i2.parent = this.proxyOf; +- return i2; +- }); +- return processed; +- } +- prepend(...children) { +- children = children.reverse(); +- for (let child of children) { +- let nodes = this.normalize(child, this.first, "prepend").reverse(); +- for (let node2 of nodes) this.proxyOf.nodes.unshift(node2); +- for (let id in this.indexes) { +- this.indexes[id] = this.indexes[id] + nodes.length; +- } +- } +- this.markDirty(); +- return this; +- } +- push(child) { +- child.parent = this; +- this.proxyOf.nodes.push(child); +- return this; +- } +- removeAll() { +- for (let node2 of this.proxyOf.nodes) node2.parent = void 0; +- this.proxyOf.nodes = []; +- this.markDirty(); +- return this; +- } +- removeChild(child) { +- child = this.index(child); +- this.proxyOf.nodes[child].parent = void 0; +- this.proxyOf.nodes.splice(child, 1); +- let index2; +- for (let id in this.indexes) { +- index2 = this.indexes[id]; +- if (index2 >= child) { +- this.indexes[id] = index2 - 1; +- } +- } +- this.markDirty(); +- return this; +- } +- replaceValues(pattern, opts, callback) { +- if (!callback) { +- callback = opts; +- opts = {}; +- } +- this.walkDecls((decl) => { +- if (opts.props && !opts.props.includes(decl.prop)) return; +- if (opts.fast && !decl.value.includes(opts.fast)) return; +- decl.value = decl.value.replace(pattern, callback); +- }); +- this.markDirty(); +- return this; +- } +- some(condition) { +- return this.nodes.some(condition); +- } +- walk(callback) { +- return this.each((child, i2) => { +- let result2; +- try { +- result2 = callback(child, i2); +- } catch (e2) { +- throw child.addToError(e2); +- } +- if (result2 !== false && child.walk) { +- result2 = child.walk(callback); +- } +- return result2; +- }); +- } +- walkAtRules(name, callback) { +- if (!callback) { +- callback = name; +- return this.walk((child, i2) => { +- if (child.type === "atrule") { +- return callback(child, i2); +- } +- }); +- } +- if (name instanceof RegExp) { +- return this.walk((child, i2) => { +- if (child.type === "atrule" && name.test(child.name)) { +- return callback(child, i2); +- } +- }); +- } +- return this.walk((child, i2) => { +- if (child.type === "atrule" && child.name === name) { +- return callback(child, i2); +- } +- }); +- } +- walkComments(callback) { +- return this.walk((child, i2) => { +- if (child.type === "comment") { +- return callback(child, i2); +- } +- }); +- } +- walkDecls(prop, callback) { +- if (!callback) { +- callback = prop; +- return this.walk((child, i2) => { +- if (child.type === "decl") { +- return callback(child, i2); +- } +- }); +- } +- if (prop instanceof RegExp) { +- return this.walk((child, i2) => { +- if (child.type === "decl" && prop.test(child.prop)) { +- return callback(child, i2); +- } +- }); +- } +- return this.walk((child, i2) => { +- if (child.type === "decl" && child.prop === prop) { +- return callback(child, i2); +- } +- }); +- } +- walkRules(selector, callback) { +- if (!callback) { +- callback = selector; +- return this.walk((child, i2) => { +- if (child.type === "rule") { +- return callback(child, i2); +- } +- }); +- } +- if (selector instanceof RegExp) { +- return this.walk((child, i2) => { +- if (child.type === "rule" && selector.test(child.selector)) { +- return callback(child, i2); +- } +- }); +- } +- return this.walk((child, i2) => { +- if (child.type === "rule" && child.selector === selector) { +- return callback(child, i2); +- } +- }); +- } +- get first() { +- if (!this.proxyOf.nodes) return void 0; +- return this.proxyOf.nodes[0]; +- } +- get last() { +- if (!this.proxyOf.nodes) return void 0; +- return this.proxyOf.nodes[this.proxyOf.nodes.length - 1]; +- } +-}; +-Container$7$1.registerParse = (dependant) => { +- parse$4$1 = dependant; +-}; +-Container$7$1.registerRule = (dependant) => { +- Rule$4$1 = dependant; +-}; +-Container$7$1.registerAtRule = (dependant) => { +- AtRule$4$1 = dependant; +-}; +-Container$7$1.registerRoot = (dependant) => { +- Root$6$1 = dependant; +-}; +-var container$1 = Container$7$1; +-Container$7$1.default = Container$7$1; +-Container$7$1.rebuild = (node2) => { +- if (node2.type === "atrule") { +- Object.setPrototypeOf(node2, AtRule$4$1.prototype); +- } else if (node2.type === "rule") { +- Object.setPrototypeOf(node2, Rule$4$1.prototype); +- } else if (node2.type === "decl") { +- Object.setPrototypeOf(node2, Declaration$3$1.prototype); +- } else if (node2.type === "comment") { +- Object.setPrototypeOf(node2, Comment$3$1.prototype); +- } else if (node2.type === "root") { +- Object.setPrototypeOf(node2, Root$6$1.prototype); +- } +- node2[my$1$1] = true; +- if (node2.nodes) { +- node2.nodes.forEach((child) => { +- Container$7$1.rebuild(child); +- }); +- } +-}; +-let Container$6$1 = container$1; +-let LazyResult$4$1, Processor$3$1; +-let Document$3$1 = class Document2 extends Container$6$1 { +- constructor(defaults) { +- super({ type: "document", ...defaults }); +- if (!this.nodes) { +- this.nodes = []; +- } +- } +- toResult(opts = {}) { +- let lazy = new LazyResult$4$1(new Processor$3$1(), this, opts); +- return lazy.stringify(); +- } +-}; +-Document$3$1.registerLazyResult = (dependant) => { +- LazyResult$4$1 = dependant; +-}; +-Document$3$1.registerProcessor = (dependant) => { +- Processor$3$1 = dependant; +-}; +-var document$1$1 = Document$3$1; +-Document$3$1.default = Document$3$1; +-let printed$1 = {}; +-var warnOnce$2$1 = function warnOnce(message) { +- if (printed$1[message]) return; +- printed$1[message] = true; +- if (typeof console !== "undefined" && console.warn) { +- console.warn(message); +- } +-}; +-let Warning$2$1 = class Warning { +- constructor(text, opts = {}) { +- this.type = "warning"; +- this.text = text; +- if (opts.node && opts.node.source) { +- let range = opts.node.rangeBy(opts); +- this.line = range.start.line; +- this.column = range.start.column; +- this.endLine = range.end.line; +- this.endColumn = range.end.column; +- } +- for (let opt in opts) this[opt] = opts[opt]; +- } +- toString() { +- if (this.node) { +- return this.node.error(this.text, { +- index: this.index, +- plugin: this.plugin, +- word: this.word +- }).message; +- } +- if (this.plugin) { +- return this.plugin + ": " + this.text; +- } +- return this.text; +- } +-}; +-var warning$1 = Warning$2$1; +-Warning$2$1.default = Warning$2$1; +-let Warning$1$1 = warning$1; +-let Result$3$1 = class Result { +- constructor(processor2, root2, opts) { +- this.processor = processor2; +- this.messages = []; +- this.root = root2; +- this.opts = opts; +- this.css = void 0; +- this.map = void 0; +- } +- toString() { +- return this.css; +- } +- warn(text, opts = {}) { +- if (!opts.plugin) { +- if (this.lastPlugin && this.lastPlugin.postcssPlugin) { +- opts.plugin = this.lastPlugin.postcssPlugin; +- } +- } +- let warning2 = new Warning$1$1(text, opts); +- this.messages.push(warning2); +- return warning2; +- } +- warnings() { +- return this.messages.filter((i2) => i2.type === "warning"); +- } +- get content() { +- return this.css; +- } +-}; +-var result$1 = Result$3$1; +-Result$3$1.default = Result$3$1; +-const SINGLE_QUOTE$1 = "'".charCodeAt(0); +-const DOUBLE_QUOTE$1 = '"'.charCodeAt(0); +-const BACKSLASH$1 = "\\".charCodeAt(0); +-const SLASH$1 = "/".charCodeAt(0); +-const NEWLINE$1 = "\n".charCodeAt(0); +-const SPACE$1 = " ".charCodeAt(0); +-const FEED$1 = "\f".charCodeAt(0); +-const TAB$1 = " ".charCodeAt(0); +-const CR$1 = "\r".charCodeAt(0); +-const OPEN_SQUARE$1 = "[".charCodeAt(0); +-const CLOSE_SQUARE$1 = "]".charCodeAt(0); +-const OPEN_PARENTHESES$1 = "(".charCodeAt(0); +-const CLOSE_PARENTHESES$1 = ")".charCodeAt(0); +-const OPEN_CURLY$1 = "{".charCodeAt(0); +-const CLOSE_CURLY$1 = "}".charCodeAt(0); +-const SEMICOLON$1 = ";".charCodeAt(0); +-const ASTERISK$1 = "*".charCodeAt(0); +-const COLON$1 = ":".charCodeAt(0); +-const AT$1 = "@".charCodeAt(0); +-const RE_AT_END$1 = /[\t\n\f\r "#'()/;[\\\]{}]/g; +-const RE_WORD_END$1 = /[\t\n\f\r !"#'():;@[\\\]{}]|\/(?=\*)/g; +-const RE_BAD_BRACKET$1 = /.[\r\n"'(/\\]/; +-const RE_HEX_ESCAPE$1 = /[\da-f]/i; +-var tokenize$1 = function tokenizer(input2, options = {}) { +- let css = input2.css.valueOf(); +- let ignore = options.ignoreErrors; +- let code, next, quote, content, escape; +- let escaped, escapePos, prev, n2, currentToken; +- let length = css.length; +- let pos = 0; +- let buffer = []; +- let returned = []; +- function position() { +- return pos; +- } +- function unclosed(what) { +- throw input2.error("Unclosed " + what, pos); +- } +- function endOfFile() { +- return returned.length === 0 && pos >= length; +- } +- function nextToken(opts) { +- if (returned.length) return returned.pop(); +- if (pos >= length) return; +- let ignoreUnclosed = opts ? opts.ignoreUnclosed : false; +- code = css.charCodeAt(pos); +- switch (code) { +- case NEWLINE$1: +- case SPACE$1: +- case TAB$1: +- case CR$1: +- case FEED$1: { +- next = pos; +- do { +- next += 1; +- code = css.charCodeAt(next); +- } while (code === SPACE$1 || code === NEWLINE$1 || code === TAB$1 || code === CR$1 || code === FEED$1); +- currentToken = ["space", css.slice(pos, next)]; +- pos = next - 1; +- break; +- } +- case OPEN_SQUARE$1: +- case CLOSE_SQUARE$1: +- case OPEN_CURLY$1: +- case CLOSE_CURLY$1: +- case COLON$1: +- case SEMICOLON$1: +- case CLOSE_PARENTHESES$1: { +- let controlChar = String.fromCharCode(code); +- currentToken = [controlChar, controlChar, pos]; +- break; +- } +- case OPEN_PARENTHESES$1: { +- prev = buffer.length ? buffer.pop()[1] : ""; +- n2 = css.charCodeAt(pos + 1); +- if (prev === "url" && n2 !== SINGLE_QUOTE$1 && n2 !== DOUBLE_QUOTE$1 && n2 !== SPACE$1 && n2 !== NEWLINE$1 && n2 !== TAB$1 && n2 !== FEED$1 && n2 !== CR$1) { +- next = pos; +- do { +- escaped = false; +- next = css.indexOf(")", next + 1); +- if (next === -1) { +- if (ignore || ignoreUnclosed) { +- next = pos; +- break; +- } else { +- unclosed("bracket"); +- } +- } +- escapePos = next; +- while (css.charCodeAt(escapePos - 1) === BACKSLASH$1) { +- escapePos -= 1; +- escaped = !escaped; +- } +- } while (escaped); +- currentToken = ["brackets", css.slice(pos, next + 1), pos, next]; +- pos = next; +- } else { +- next = css.indexOf(")", pos + 1); +- content = css.slice(pos, next + 1); +- if (next === -1 || RE_BAD_BRACKET$1.test(content)) { +- currentToken = ["(", "(", pos]; +- } else { +- currentToken = ["brackets", content, pos, next]; +- pos = next; +- } +- } +- break; +- } +- case SINGLE_QUOTE$1: +- case DOUBLE_QUOTE$1: { +- quote = code === SINGLE_QUOTE$1 ? "'" : '"'; +- next = pos; +- do { +- escaped = false; +- next = css.indexOf(quote, next + 1); +- if (next === -1) { +- if (ignore || ignoreUnclosed) { +- next = pos + 1; +- break; +- } else { +- unclosed("string"); +- } +- } +- escapePos = next; +- while (css.charCodeAt(escapePos - 1) === BACKSLASH$1) { +- escapePos -= 1; +- escaped = !escaped; +- } +- } while (escaped); +- currentToken = ["string", css.slice(pos, next + 1), pos, next]; +- pos = next; +- break; +- } +- case AT$1: { +- RE_AT_END$1.lastIndex = pos + 1; +- RE_AT_END$1.test(css); +- if (RE_AT_END$1.lastIndex === 0) { +- next = css.length - 1; +- } else { +- next = RE_AT_END$1.lastIndex - 2; +- } +- currentToken = ["at-word", css.slice(pos, next + 1), pos, next]; +- pos = next; +- break; +- } +- case BACKSLASH$1: { +- next = pos; +- escape = true; +- while (css.charCodeAt(next + 1) === BACKSLASH$1) { +- next += 1; +- escape = !escape; +- } +- code = css.charCodeAt(next + 1); +- if (escape && code !== SLASH$1 && code !== SPACE$1 && code !== NEWLINE$1 && code !== TAB$1 && code !== CR$1 && code !== FEED$1) { +- next += 1; +- if (RE_HEX_ESCAPE$1.test(css.charAt(next))) { +- while (RE_HEX_ESCAPE$1.test(css.charAt(next + 1))) { +- next += 1; +- } +- if (css.charCodeAt(next + 1) === SPACE$1) { +- next += 1; +- } +- } +- } +- currentToken = ["word", css.slice(pos, next + 1), pos, next]; +- pos = next; +- break; +- } +- default: { +- if (code === SLASH$1 && css.charCodeAt(pos + 1) === ASTERISK$1) { +- next = css.indexOf("*/", pos + 2) + 1; +- if (next === 0) { +- if (ignore || ignoreUnclosed) { +- next = css.length; +- } else { +- unclosed("comment"); +- } +- } +- currentToken = ["comment", css.slice(pos, next + 1), pos, next]; +- pos = next; +- } else { +- RE_WORD_END$1.lastIndex = pos + 1; +- RE_WORD_END$1.test(css); +- if (RE_WORD_END$1.lastIndex === 0) { +- next = css.length - 1; +- } else { +- next = RE_WORD_END$1.lastIndex - 2; +- } +- currentToken = ["word", css.slice(pos, next + 1), pos, next]; +- buffer.push(currentToken); +- pos = next; +- } +- break; +- } +- } +- pos++; +- return currentToken; +- } +- function back(token) { +- returned.push(token); +- } +- return { +- back, +- endOfFile, +- nextToken, +- position +- }; +-}; +-let Container$5$1 = container$1; +-let AtRule$3$1 = class AtRule extends Container$5$1 { +- constructor(defaults) { +- super(defaults); +- this.type = "atrule"; +- } +- append(...children) { +- if (!this.proxyOf.nodes) this.nodes = []; +- return super.append(...children); +- } +- prepend(...children) { +- if (!this.proxyOf.nodes) this.nodes = []; +- return super.prepend(...children); +- } +-}; +-var atRule$1 = AtRule$3$1; +-AtRule$3$1.default = AtRule$3$1; +-Container$5$1.registerAtRule(AtRule$3$1); +-let Container$4$1 = container$1; +-let LazyResult$3$1, Processor$2$1; +-let Root$5$1 = class Root extends Container$4$1 { +- constructor(defaults) { +- super(defaults); +- this.type = "root"; +- if (!this.nodes) this.nodes = []; +- } +- normalize(child, sample, type) { +- let nodes = super.normalize(child); +- if (sample) { +- if (type === "prepend") { +- if (this.nodes.length > 1) { +- sample.raws.before = this.nodes[1].raws.before; +- } else { +- delete sample.raws.before; +- } +- } else if (this.first !== sample) { +- for (let node2 of nodes) { +- node2.raws.before = sample.raws.before; +- } +- } +- } +- return nodes; +- } +- removeChild(child, ignore) { +- let index2 = this.index(child); +- if (!ignore && index2 === 0 && this.nodes.length > 1) { +- this.nodes[1].raws.before = this.nodes[index2].raws.before; +- } +- return super.removeChild(child); +- } +- toResult(opts = {}) { +- let lazy = new LazyResult$3$1(new Processor$2$1(), this, opts); +- return lazy.stringify(); +- } +-}; +-Root$5$1.registerLazyResult = (dependant) => { +- LazyResult$3$1 = dependant; +-}; +-Root$5$1.registerProcessor = (dependant) => { +- Processor$2$1 = dependant; +-}; +-var root$1 = Root$5$1; +-Root$5$1.default = Root$5$1; +-Container$4$1.registerRoot(Root$5$1); +-let list$2$1 = { +- comma(string) { +- return list$2$1.split(string, [","], true); +- }, +- space(string) { +- let spaces = [" ", "\n", " "]; +- return list$2$1.split(string, spaces); +- }, +- split(string, separators, last) { +- let array = []; +- let current = ""; +- let split = false; +- let func = 0; +- let inQuote = false; +- let prevQuote = ""; +- let escape = false; +- for (let letter of string) { +- if (escape) { +- escape = false; +- } else if (letter === "\\") { +- escape = true; +- } else if (inQuote) { +- if (letter === prevQuote) { +- inQuote = false; +- } +- } else if (letter === '"' || letter === "'") { +- inQuote = true; +- prevQuote = letter; +- } else if (letter === "(") { +- func += 1; +- } else if (letter === ")") { +- if (func > 0) func -= 1; +- } else if (func === 0) { +- if (separators.includes(letter)) split = true; +- } +- if (split) { +- if (current !== "") array.push(current.trim()); +- current = ""; +- split = false; +- } else { +- current += letter; +- } +- } +- if (last || current !== "") array.push(current.trim()); +- return array; +- } +-}; +-var list_1$1 = list$2$1; +-list$2$1.default = list$2$1; +-let Container$3$1 = container$1; +-let list$1$1 = list_1$1; +-let Rule$3$1 = class Rule extends Container$3$1 { +- constructor(defaults) { +- super(defaults); +- this.type = "rule"; +- if (!this.nodes) this.nodes = []; +- } +- get selectors() { +- return list$1$1.comma(this.selector); +- } +- set selectors(values) { +- let match = this.selector ? this.selector.match(/,\s*/) : null; +- let sep2 = match ? match[0] : "," + this.raw("between", "beforeOpen"); +- this.selector = values.join(sep2); +- } +-}; +-var rule$1 = Rule$3$1; +-Rule$3$1.default = Rule$3$1; +-Container$3$1.registerRule(Rule$3$1); +-let Declaration$2$1 = declaration$1; +-let tokenizer2$1 = tokenize$1; +-let Comment$2$1 = comment$1; +-let AtRule$2$1 = atRule$1; +-let Root$4$1 = root$1; +-let Rule$2$1 = rule$1; +-const SAFE_COMMENT_NEIGHBOR$1 = { +- empty: true, +- space: true +-}; +-function findLastWithPosition$1(tokens) { +- for (let i2 = tokens.length - 1; i2 >= 0; i2--) { +- let token = tokens[i2]; +- let pos = token[3] || token[2]; +- if (pos) return pos; +- } +-} +-let Parser$1$1 = class Parser { +- constructor(input2) { +- this.input = input2; +- this.root = new Root$4$1(); +- this.current = this.root; +- this.spaces = ""; +- this.semicolon = false; +- this.createTokenizer(); +- this.root.source = { input: input2, start: { column: 1, line: 1, offset: 0 } }; +- } +- atrule(token) { +- let node2 = new AtRule$2$1(); +- node2.name = token[1].slice(1); +- if (node2.name === "") { +- this.unnamedAtrule(node2, token); +- } +- this.init(node2, token[2]); +- let type; +- let prev; +- let shift; +- let last = false; +- let open = false; +- let params = []; +- let brackets = []; +- while (!this.tokenizer.endOfFile()) { +- token = this.tokenizer.nextToken(); +- type = token[0]; +- if (type === "(" || type === "[") { +- brackets.push(type === "(" ? ")" : "]"); +- } else if (type === "{" && brackets.length > 0) { +- brackets.push("}"); +- } else if (type === brackets[brackets.length - 1]) { +- brackets.pop(); +- } +- if (brackets.length === 0) { +- if (type === ";") { +- node2.source.end = this.getPosition(token[2]); +- node2.source.end.offset++; +- this.semicolon = true; +- break; +- } else if (type === "{") { +- open = true; +- break; +- } else if (type === "}") { +- if (params.length > 0) { +- shift = params.length - 1; +- prev = params[shift]; +- while (prev && prev[0] === "space") { +- prev = params[--shift]; +- } +- if (prev) { +- node2.source.end = this.getPosition(prev[3] || prev[2]); +- node2.source.end.offset++; +- } +- } +- this.end(token); +- break; +- } else { +- params.push(token); +- } +- } else { +- params.push(token); +- } +- if (this.tokenizer.endOfFile()) { +- last = true; +- break; +- } +- } +- node2.raws.between = this.spacesAndCommentsFromEnd(params); +- if (params.length) { +- node2.raws.afterName = this.spacesAndCommentsFromStart(params); +- this.raw(node2, "params", params); +- if (last) { +- token = params[params.length - 1]; +- node2.source.end = this.getPosition(token[3] || token[2]); +- node2.source.end.offset++; +- this.spaces = node2.raws.between; +- node2.raws.between = ""; +- } +- } else { +- node2.raws.afterName = ""; +- node2.params = ""; +- } +- if (open) { +- node2.nodes = []; +- this.current = node2; +- } +- } +- checkMissedSemicolon(tokens) { +- let colon = this.colon(tokens); +- if (colon === false) return; +- let founded = 0; +- let token; +- for (let j = colon - 1; j >= 0; j--) { +- token = tokens[j]; +- if (token[0] !== "space") { +- founded += 1; +- if (founded === 2) break; +- } +- } +- throw this.input.error( +- "Missed semicolon", +- token[0] === "word" ? token[3] + 1 : token[2] +- ); +- } +- colon(tokens) { +- let brackets = 0; +- let token, type, prev; +- for (let [i2, element] of tokens.entries()) { +- token = element; +- type = token[0]; +- if (type === "(") { +- brackets += 1; +- } +- if (type === ")") { +- brackets -= 1; +- } +- if (brackets === 0 && type === ":") { +- if (!prev) { +- this.doubleColon(token); +- } else if (prev[0] === "word" && prev[1] === "progid") { +- continue; +- } else { +- return i2; +- } +- } +- prev = token; +- } +- return false; +- } +- comment(token) { +- let node2 = new Comment$2$1(); +- this.init(node2, token[2]); +- node2.source.end = this.getPosition(token[3] || token[2]); +- node2.source.end.offset++; +- let text = token[1].slice(2, -2); +- if (/^\s*$/.test(text)) { +- node2.text = ""; +- node2.raws.left = text; +- node2.raws.right = ""; +- } else { +- let match = text.match(/^(\s*)([^]*\S)(\s*)$/); +- node2.text = match[2]; +- node2.raws.left = match[1]; +- node2.raws.right = match[3]; +- } +- } +- createTokenizer() { +- this.tokenizer = tokenizer2$1(this.input); +- } +- decl(tokens, customProperty) { +- let node2 = new Declaration$2$1(); +- this.init(node2, tokens[0][2]); +- let last = tokens[tokens.length - 1]; +- if (last[0] === ";") { +- this.semicolon = true; +- tokens.pop(); +- } +- node2.source.end = this.getPosition( +- last[3] || last[2] || findLastWithPosition$1(tokens) +- ); +- node2.source.end.offset++; +- while (tokens[0][0] !== "word") { +- if (tokens.length === 1) this.unknownWord(tokens); +- node2.raws.before += tokens.shift()[1]; +- } +- node2.source.start = this.getPosition(tokens[0][2]); +- node2.prop = ""; +- while (tokens.length) { +- let type = tokens[0][0]; +- if (type === ":" || type === "space" || type === "comment") { +- break; +- } +- node2.prop += tokens.shift()[1]; +- } +- node2.raws.between = ""; +- let token; +- while (tokens.length) { +- token = tokens.shift(); +- if (token[0] === ":") { +- node2.raws.between += token[1]; +- break; +- } else { +- if (token[0] === "word" && /\w/.test(token[1])) { +- this.unknownWord([token]); +- } +- node2.raws.between += token[1]; +- } +- } +- if (node2.prop[0] === "_" || node2.prop[0] === "*") { +- node2.raws.before += node2.prop[0]; +- node2.prop = node2.prop.slice(1); +- } +- let firstSpaces = []; +- let next; +- while (tokens.length) { +- next = tokens[0][0]; +- if (next !== "space" && next !== "comment") break; +- firstSpaces.push(tokens.shift()); +- } +- this.precheckMissedSemicolon(tokens); +- for (let i2 = tokens.length - 1; i2 >= 0; i2--) { +- token = tokens[i2]; +- if (token[1].toLowerCase() === "!important") { +- node2.important = true; +- let string = this.stringFrom(tokens, i2); +- string = this.spacesFromEnd(tokens) + string; +- if (string !== " !important") node2.raws.important = string; +- break; +- } else if (token[1].toLowerCase() === "important") { +- let cache = tokens.slice(0); +- let str = ""; +- for (let j = i2; j > 0; j--) { +- let type = cache[j][0]; +- if (str.trim().indexOf("!") === 0 && type !== "space") { +- break; +- } +- str = cache.pop()[1] + str; +- } +- if (str.trim().indexOf("!") === 0) { +- node2.important = true; +- node2.raws.important = str; +- tokens = cache; +- } +- } +- if (token[0] !== "space" && token[0] !== "comment") { +- break; +- } +- } +- let hasWord = tokens.some((i2) => i2[0] !== "space" && i2[0] !== "comment"); +- if (hasWord) { +- node2.raws.between += firstSpaces.map((i2) => i2[1]).join(""); +- firstSpaces = []; +- } +- this.raw(node2, "value", firstSpaces.concat(tokens), customProperty); +- if (node2.value.includes(":") && !customProperty) { +- this.checkMissedSemicolon(tokens); +- } +- } +- doubleColon(token) { +- throw this.input.error( +- "Double colon", +- { offset: token[2] }, +- { offset: token[2] + token[1].length } +- ); +- } +- emptyRule(token) { +- let node2 = new Rule$2$1(); +- this.init(node2, token[2]); +- node2.selector = ""; +- node2.raws.between = ""; +- this.current = node2; +- } +- end(token) { +- if (this.current.nodes && this.current.nodes.length) { +- this.current.raws.semicolon = this.semicolon; +- } +- this.semicolon = false; +- this.current.raws.after = (this.current.raws.after || "") + this.spaces; +- this.spaces = ""; +- if (this.current.parent) { +- this.current.source.end = this.getPosition(token[2]); +- this.current.source.end.offset++; +- this.current = this.current.parent; +- } else { +- this.unexpectedClose(token); +- } +- } +- endFile() { +- if (this.current.parent) this.unclosedBlock(); +- if (this.current.nodes && this.current.nodes.length) { +- this.current.raws.semicolon = this.semicolon; +- } +- this.current.raws.after = (this.current.raws.after || "") + this.spaces; +- this.root.source.end = this.getPosition(this.tokenizer.position()); +- } +- freeSemicolon(token) { +- this.spaces += token[1]; +- if (this.current.nodes) { +- let prev = this.current.nodes[this.current.nodes.length - 1]; +- if (prev && prev.type === "rule" && !prev.raws.ownSemicolon) { +- prev.raws.ownSemicolon = this.spaces; +- this.spaces = ""; +- } +- } +- } +- // Helpers +- getPosition(offset) { +- let pos = this.input.fromOffset(offset); +- return { +- column: pos.col, +- line: pos.line, +- offset +- }; +- } +- init(node2, offset) { +- this.current.push(node2); +- node2.source = { +- input: this.input, +- start: this.getPosition(offset) +- }; +- node2.raws.before = this.spaces; +- this.spaces = ""; +- if (node2.type !== "comment") this.semicolon = false; +- } +- other(start) { +- let end = false; +- let type = null; +- let colon = false; +- let bracket = null; +- let brackets = []; +- let customProperty = start[1].startsWith("--"); +- let tokens = []; +- let token = start; +- while (token) { +- type = token[0]; +- tokens.push(token); +- if (type === "(" || type === "[") { +- if (!bracket) bracket = token; +- brackets.push(type === "(" ? ")" : "]"); +- } else if (customProperty && colon && type === "{") { +- if (!bracket) bracket = token; +- brackets.push("}"); +- } else if (brackets.length === 0) { +- if (type === ";") { +- if (colon) { +- this.decl(tokens, customProperty); +- return; +- } else { +- break; +- } +- } else if (type === "{") { +- this.rule(tokens); +- return; +- } else if (type === "}") { +- this.tokenizer.back(tokens.pop()); +- end = true; +- break; +- } else if (type === ":") { +- colon = true; +- } +- } else if (type === brackets[brackets.length - 1]) { +- brackets.pop(); +- if (brackets.length === 0) bracket = null; +- } +- token = this.tokenizer.nextToken(); +- } +- if (this.tokenizer.endOfFile()) end = true; +- if (brackets.length > 0) this.unclosedBracket(bracket); +- if (end && colon) { +- if (!customProperty) { +- while (tokens.length) { +- token = tokens[tokens.length - 1][0]; +- if (token !== "space" && token !== "comment") break; +- this.tokenizer.back(tokens.pop()); +- } +- } +- this.decl(tokens, customProperty); +- } else { +- this.unknownWord(tokens); +- } +- } +- parse() { +- let token; +- while (!this.tokenizer.endOfFile()) { +- token = this.tokenizer.nextToken(); +- switch (token[0]) { +- case "space": +- this.spaces += token[1]; +- break; +- case ";": +- this.freeSemicolon(token); +- break; +- case "}": +- this.end(token); +- break; +- case "comment": +- this.comment(token); +- break; +- case "at-word": +- this.atrule(token); +- break; +- case "{": +- this.emptyRule(token); +- break; +- default: +- this.other(token); +- break; +- } +- } +- this.endFile(); +- } +- precheckMissedSemicolon() { +- } +- raw(node2, prop, tokens, customProperty) { +- let token, type; +- let length = tokens.length; +- let value = ""; +- let clean = true; +- let next, prev; +- for (let i2 = 0; i2 < length; i2 += 1) { +- token = tokens[i2]; +- type = token[0]; +- if (type === "space" && i2 === length - 1 && !customProperty) { +- clean = false; +- } else if (type === "comment") { +- prev = tokens[i2 - 1] ? tokens[i2 - 1][0] : "empty"; +- next = tokens[i2 + 1] ? tokens[i2 + 1][0] : "empty"; +- if (!SAFE_COMMENT_NEIGHBOR$1[prev] && !SAFE_COMMENT_NEIGHBOR$1[next]) { +- if (value.slice(-1) === ",") { +- clean = false; +- } else { +- value += token[1]; +- } +- } else { +- clean = false; +- } +- } else { +- value += token[1]; +- } +- } +- if (!clean) { +- let raw = tokens.reduce((all, i2) => all + i2[1], ""); +- node2.raws[prop] = { raw, value }; +- } +- node2[prop] = value; +- } +- rule(tokens) { +- tokens.pop(); +- let node2 = new Rule$2$1(); +- this.init(node2, tokens[0][2]); +- node2.raws.between = this.spacesAndCommentsFromEnd(tokens); +- this.raw(node2, "selector", tokens); +- this.current = node2; +- } +- spacesAndCommentsFromEnd(tokens) { +- let lastTokenType; +- let spaces = ""; +- while (tokens.length) { +- lastTokenType = tokens[tokens.length - 1][0]; +- if (lastTokenType !== "space" && lastTokenType !== "comment") break; +- spaces = tokens.pop()[1] + spaces; +- } +- return spaces; +- } +- // Errors +- spacesAndCommentsFromStart(tokens) { +- let next; +- let spaces = ""; +- while (tokens.length) { +- next = tokens[0][0]; +- if (next !== "space" && next !== "comment") break; +- spaces += tokens.shift()[1]; +- } +- return spaces; +- } +- spacesFromEnd(tokens) { +- let lastTokenType; +- let spaces = ""; +- while (tokens.length) { +- lastTokenType = tokens[tokens.length - 1][0]; +- if (lastTokenType !== "space") break; +- spaces = tokens.pop()[1] + spaces; +- } +- return spaces; +- } +- stringFrom(tokens, from) { +- let result2 = ""; +- for (let i2 = from; i2 < tokens.length; i2++) { +- result2 += tokens[i2][1]; +- } +- tokens.splice(from, tokens.length - from); +- return result2; +- } +- unclosedBlock() { +- let pos = this.current.source.start; +- throw this.input.error("Unclosed block", pos.line, pos.column); +- } +- unclosedBracket(bracket) { +- throw this.input.error( +- "Unclosed bracket", +- { offset: bracket[2] }, +- { offset: bracket[2] + 1 } +- ); +- } +- unexpectedClose(token) { +- throw this.input.error( +- "Unexpected }", +- { offset: token[2] }, +- { offset: token[2] + 1 } +- ); +- } +- unknownWord(tokens) { +- throw this.input.error( +- "Unknown word", +- { offset: tokens[0][2] }, +- { offset: tokens[0][2] + tokens[0][1].length } +- ); +- } +- unnamedAtrule(node2, token) { +- throw this.input.error( +- "At-rule without name", +- { offset: token[2] }, +- { offset: token[2] + token[1].length } +- ); +- } +-}; +-var parser$1 = Parser$1$1; +-let Container$2$1 = container$1; +-let Parser2$1 = parser$1; +-let Input$2$1 = input$1; +-function parse$3$1(css, opts) { +- let input2 = new Input$2$1(css, opts); +- let parser2 = new Parser2$1(input2); +- try { +- parser2.parse(); +- } catch (e2) { +- if (process.env.NODE_ENV !== "production") { +- if (e2.name === "CssSyntaxError" && opts && opts.from) { +- if (/\.scss$/i.test(opts.from)) { +- e2.message += "\nYou tried to parse SCSS with the standard CSS parser; try again with the postcss-scss parser"; +- } else if (/\.sass/i.test(opts.from)) { +- e2.message += "\nYou tried to parse Sass with the standard CSS parser; try again with the postcss-sass parser"; +- } else if (/\.less$/i.test(opts.from)) { +- e2.message += "\nYou tried to parse Less with the standard CSS parser; try again with the postcss-less parser"; +- } +- } +- } +- throw e2; +- } +- return parser2.root; +-} +-var parse_1$1 = parse$3$1; +-parse$3$1.default = parse$3$1; +-Container$2$1.registerParse(parse$3$1); +-let { isClean: isClean$3, my: my$3 } = symbols$1; +-let MapGenerator$1$1 = mapGenerator$1; +-let stringify$2$1 = stringify_1$1; +-let Container$1$1 = container$1; +-let Document$2$1 = document$1$1; +-let warnOnce$1$1 = warnOnce$2$1; +-let Result$2$1 = result$1; +-let parse$2$1 = parse_1$1; +-let Root$3$1 = root$1; +-const TYPE_TO_CLASS_NAME$1 = { +- atrule: "AtRule", +- comment: "Comment", +- decl: "Declaration", +- document: "Document", +- root: "Root", +- rule: "Rule" +-}; +-const PLUGIN_PROPS$1 = { +- AtRule: true, +- AtRuleExit: true, +- Comment: true, +- CommentExit: true, +- Declaration: true, +- DeclarationExit: true, +- Document: true, +- DocumentExit: true, +- Once: true, +- OnceExit: true, +- postcssPlugin: true, +- prepare: true, +- Root: true, +- RootExit: true, +- Rule: true, +- RuleExit: true +-}; +-const NOT_VISITORS$1 = { +- Once: true, +- postcssPlugin: true, +- prepare: true +-}; +-const CHILDREN$1 = 0; +-function isPromise$1(obj) { +- return typeof obj === "object" && typeof obj.then === "function"; +-} +-function getEvents$1(node2) { +- let key = false; +- let type = TYPE_TO_CLASS_NAME$1[node2.type]; +- if (node2.type === "decl") { +- key = node2.prop.toLowerCase(); +- } else if (node2.type === "atrule") { +- key = node2.name.toLowerCase(); +- } +- if (key && node2.append) { +- return [ +- type, +- type + "-" + key, +- CHILDREN$1, +- type + "Exit", +- type + "Exit-" + key +- ]; +- } else if (key) { +- return [type, type + "-" + key, type + "Exit", type + "Exit-" + key]; +- } else if (node2.append) { +- return [type, CHILDREN$1, type + "Exit"]; +- } else { +- return [type, type + "Exit"]; +- } +-} +-function toStack$1(node2) { +- let events; +- if (node2.type === "document") { +- events = ["Document", CHILDREN$1, "DocumentExit"]; +- } else if (node2.type === "root") { +- events = ["Root", CHILDREN$1, "RootExit"]; +- } else { +- events = getEvents$1(node2); +- } +- return { +- eventIndex: 0, +- events, +- iterator: 0, +- node: node2, +- visitorIndex: 0, +- visitors: [] +- }; +-} +-function cleanMarks$1(node2) { +- node2[isClean$3] = false; +- if (node2.nodes) node2.nodes.forEach((i2) => cleanMarks$1(i2)); +- return node2; +-} +-let postcss$2$1 = {}; +-let LazyResult$2$1 = class LazyResult { +- constructor(processor2, css, opts) { +- this.stringified = false; +- this.processed = false; +- let root2; +- if (typeof css === "object" && css !== null && (css.type === "root" || css.type === "document")) { +- root2 = cleanMarks$1(css); +- } else if (css instanceof LazyResult || css instanceof Result$2$1) { +- root2 = cleanMarks$1(css.root); +- if (css.map) { +- if (typeof opts.map === "undefined") opts.map = {}; +- if (!opts.map.inline) opts.map.inline = false; +- opts.map.prev = css.map; +- } +- } else { +- let parser2 = parse$2$1; +- if (opts.syntax) parser2 = opts.syntax.parse; +- if (opts.parser) parser2 = opts.parser; +- if (parser2.parse) parser2 = parser2.parse; +- try { +- root2 = parser2(css, opts); +- } catch (error) { +- this.processed = true; +- this.error = error; +- } +- if (root2 && !root2[my$3]) { +- Container$1$1.rebuild(root2); +- } +- } +- this.result = new Result$2$1(processor2, root2, opts); +- this.helpers = { ...postcss$2$1, postcss: postcss$2$1, result: this.result }; +- this.plugins = this.processor.plugins.map((plugin22) => { +- if (typeof plugin22 === "object" && plugin22.prepare) { +- return { ...plugin22, ...plugin22.prepare(this.result) }; +- } else { +- return plugin22; +- } +- }); +- } +- async() { +- if (this.error) return Promise.reject(this.error); +- if (this.processed) return Promise.resolve(this.result); +- if (!this.processing) { +- this.processing = this.runAsync(); +- } +- return this.processing; +- } +- catch(onRejected) { +- return this.async().catch(onRejected); +- } +- finally(onFinally) { +- return this.async().then(onFinally, onFinally); +- } +- getAsyncError() { +- throw new Error("Use process(css).then(cb) to work with async plugins"); +- } +- handleError(error, node2) { +- let plugin22 = this.result.lastPlugin; +- try { +- if (node2) node2.addToError(error); +- this.error = error; +- if (error.name === "CssSyntaxError" && !error.plugin) { +- error.plugin = plugin22.postcssPlugin; +- error.setMessage(); +- } else if (plugin22.postcssVersion) { +- if (process.env.NODE_ENV !== "production") { +- let pluginName = plugin22.postcssPlugin; +- let pluginVer = plugin22.postcssVersion; +- let runtimeVer = this.result.processor.version; +- let a2 = pluginVer.split("."); +- let b = runtimeVer.split("."); +- if (a2[0] !== b[0] || parseInt(a2[1]) > parseInt(b[1])) { +- console.error( +- "Unknown error from PostCSS plugin. Your current PostCSS version is " + runtimeVer + ", but " + pluginName + " uses " + pluginVer + ". Perhaps this is the source of the error below." +- ); +- } +- } +- } +- } catch (err) { +- if (console && console.error) console.error(err); +- } +- return error; +- } +- prepareVisitors() { +- this.listeners = {}; +- let add = (plugin22, type, cb) => { +- if (!this.listeners[type]) this.listeners[type] = []; +- this.listeners[type].push([plugin22, cb]); +- }; +- for (let plugin22 of this.plugins) { +- if (typeof plugin22 === "object") { +- for (let event in plugin22) { +- if (!PLUGIN_PROPS$1[event] && /^[A-Z]/.test(event)) { +- throw new Error( +- `Unknown event ${event} in ${plugin22.postcssPlugin}. Try to update PostCSS (${this.processor.version} now).` +- ); +- } +- if (!NOT_VISITORS$1[event]) { +- if (typeof plugin22[event] === "object") { +- for (let filter in plugin22[event]) { +- if (filter === "*") { +- add(plugin22, event, plugin22[event][filter]); +- } else { +- add( +- plugin22, +- event + "-" + filter.toLowerCase(), +- plugin22[event][filter] +- ); +- } +- } +- } else if (typeof plugin22[event] === "function") { +- add(plugin22, event, plugin22[event]); +- } +- } +- } +- } +- } +- this.hasListener = Object.keys(this.listeners).length > 0; +- } +- async runAsync() { +- this.plugin = 0; +- for (let i2 = 0; i2 < this.plugins.length; i2++) { +- let plugin22 = this.plugins[i2]; +- let promise = this.runOnRoot(plugin22); +- if (isPromise$1(promise)) { +- try { +- await promise; +- } catch (error) { +- throw this.handleError(error); +- } +- } +- } +- this.prepareVisitors(); +- if (this.hasListener) { +- let root2 = this.result.root; +- while (!root2[isClean$3]) { +- root2[isClean$3] = true; +- let stack = [toStack$1(root2)]; +- while (stack.length > 0) { +- let promise = this.visitTick(stack); +- if (isPromise$1(promise)) { +- try { +- await promise; +- } catch (e2) { +- let node2 = stack[stack.length - 1].node; +- throw this.handleError(e2, node2); +- } +- } +- } +- } +- if (this.listeners.OnceExit) { +- for (let [plugin22, visitor] of this.listeners.OnceExit) { +- this.result.lastPlugin = plugin22; +- try { +- if (root2.type === "document") { +- let roots = root2.nodes.map( +- (subRoot) => visitor(subRoot, this.helpers) +- ); +- await Promise.all(roots); +- } else { +- await visitor(root2, this.helpers); +- } +- } catch (e2) { +- throw this.handleError(e2); +- } +- } +- } +- } +- this.processed = true; +- return this.stringify(); +- } +- runOnRoot(plugin22) { +- this.result.lastPlugin = plugin22; +- try { +- if (typeof plugin22 === "object" && plugin22.Once) { +- if (this.result.root.type === "document") { +- let roots = this.result.root.nodes.map( +- (root2) => plugin22.Once(root2, this.helpers) +- ); +- if (isPromise$1(roots[0])) { +- return Promise.all(roots); +- } +- return roots; +- } +- return plugin22.Once(this.result.root, this.helpers); +- } else if (typeof plugin22 === "function") { +- return plugin22(this.result.root, this.result); +- } +- } catch (error) { +- throw this.handleError(error); +- } +- } +- stringify() { +- if (this.error) throw this.error; +- if (this.stringified) return this.result; +- this.stringified = true; +- this.sync(); +- let opts = this.result.opts; +- let str = stringify$2$1; +- if (opts.syntax) str = opts.syntax.stringify; +- if (opts.stringifier) str = opts.stringifier; +- if (str.stringify) str = str.stringify; +- let map = new MapGenerator$1$1(str, this.result.root, this.result.opts); +- let data = map.generate(); +- this.result.css = data[0]; +- this.result.map = data[1]; +- return this.result; +- } +- sync() { +- if (this.error) throw this.error; +- if (this.processed) return this.result; +- this.processed = true; +- if (this.processing) { +- throw this.getAsyncError(); +- } +- for (let plugin22 of this.plugins) { +- let promise = this.runOnRoot(plugin22); +- if (isPromise$1(promise)) { +- throw this.getAsyncError(); +- } +- } +- this.prepareVisitors(); +- if (this.hasListener) { +- let root2 = this.result.root; +- while (!root2[isClean$3]) { +- root2[isClean$3] = true; +- this.walkSync(root2); +- } +- if (this.listeners.OnceExit) { +- if (root2.type === "document") { +- for (let subRoot of root2.nodes) { +- this.visitSync(this.listeners.OnceExit, subRoot); +- } +- } else { +- this.visitSync(this.listeners.OnceExit, root2); +- } +- } +- } +- return this.result; +- } +- then(onFulfilled, onRejected) { +- if (process.env.NODE_ENV !== "production") { +- if (!("from" in this.opts)) { +- warnOnce$1$1( +- "Without `from` option PostCSS could generate wrong source map and will not find Browserslist config. Set it to CSS file path or to `undefined` to prevent this warning." +- ); +- } +- } +- return this.async().then(onFulfilled, onRejected); +- } +- toString() { +- return this.css; +- } +- visitSync(visitors, node2) { +- for (let [plugin22, visitor] of visitors) { +- this.result.lastPlugin = plugin22; +- let promise; +- try { +- promise = visitor(node2, this.helpers); +- } catch (e2) { +- throw this.handleError(e2, node2.proxyOf); +- } +- if (node2.type !== "root" && node2.type !== "document" && !node2.parent) { +- return true; +- } +- if (isPromise$1(promise)) { +- throw this.getAsyncError(); +- } +- } +- } +- visitTick(stack) { +- let visit2 = stack[stack.length - 1]; +- let { node: node2, visitors } = visit2; +- if (node2.type !== "root" && node2.type !== "document" && !node2.parent) { +- stack.pop(); +- return; +- } +- if (visitors.length > 0 && visit2.visitorIndex < visitors.length) { +- let [plugin22, visitor] = visitors[visit2.visitorIndex]; +- visit2.visitorIndex += 1; +- if (visit2.visitorIndex === visitors.length) { +- visit2.visitors = []; +- visit2.visitorIndex = 0; +- } +- this.result.lastPlugin = plugin22; +- try { +- return visitor(node2.toProxy(), this.helpers); +- } catch (e2) { +- throw this.handleError(e2, node2); +- } +- } +- if (visit2.iterator !== 0) { +- let iterator = visit2.iterator; +- let child; +- while (child = node2.nodes[node2.indexes[iterator]]) { +- node2.indexes[iterator] += 1; +- if (!child[isClean$3]) { +- child[isClean$3] = true; +- stack.push(toStack$1(child)); +- return; +- } +- } +- visit2.iterator = 0; +- delete node2.indexes[iterator]; +- } +- let events = visit2.events; +- while (visit2.eventIndex < events.length) { +- let event = events[visit2.eventIndex]; +- visit2.eventIndex += 1; +- if (event === CHILDREN$1) { +- if (node2.nodes && node2.nodes.length) { +- node2[isClean$3] = true; +- visit2.iterator = node2.getIterator(); +- } +- return; +- } else if (this.listeners[event]) { +- visit2.visitors = this.listeners[event]; +- return; +- } +- } +- stack.pop(); +- } +- walkSync(node2) { +- node2[isClean$3] = true; +- let events = getEvents$1(node2); +- for (let event of events) { +- if (event === CHILDREN$1) { +- if (node2.nodes) { +- node2.each((child) => { +- if (!child[isClean$3]) this.walkSync(child); +- }); +- } +- } else { +- let visitors = this.listeners[event]; +- if (visitors) { +- if (this.visitSync(visitors, node2.toProxy())) return; +- } +- } +- } +- } +- warnings() { +- return this.sync().warnings(); +- } +- get content() { +- return this.stringify().content; +- } +- get css() { +- return this.stringify().css; +- } +- get map() { +- return this.stringify().map; +- } +- get messages() { +- return this.sync().messages; +- } +- get opts() { +- return this.result.opts; +- } +- get processor() { +- return this.result.processor; +- } +- get root() { +- return this.sync().root; +- } +- get [Symbol.toStringTag]() { +- return "LazyResult"; +- } +-}; +-LazyResult$2$1.registerPostcss = (dependant) => { +- postcss$2$1 = dependant; +-}; +-var lazyResult$1 = LazyResult$2$1; +-LazyResult$2$1.default = LazyResult$2$1; +-Root$3$1.registerLazyResult(LazyResult$2$1); +-Document$2$1.registerLazyResult(LazyResult$2$1); +-let MapGenerator2$1 = mapGenerator$1; +-let stringify$1$1 = stringify_1$1; +-let warnOnce2$1 = warnOnce$2$1; +-let parse$1$1 = parse_1$1; +-const Result$1$1 = result$1; +-let NoWorkResult$1$1 = class NoWorkResult { +- constructor(processor2, css, opts) { +- css = css.toString(); +- this.stringified = false; +- this._processor = processor2; +- this._css = css; +- this._opts = opts; +- this._map = void 0; +- let root2; +- let str = stringify$1$1; +- this.result = new Result$1$1(this._processor, root2, this._opts); +- this.result.css = css; +- let self = this; +- Object.defineProperty(this.result, "root", { +- get() { +- return self.root; +- } +- }); +- let map = new MapGenerator2$1(str, root2, this._opts, css); +- if (map.isMap()) { +- let [generatedCSS, generatedMap] = map.generate(); +- if (generatedCSS) { +- this.result.css = generatedCSS; +- } +- if (generatedMap) { +- this.result.map = generatedMap; +- } +- } else { +- map.clearAnnotation(); +- this.result.css = map.css; +- } +- } +- async() { +- if (this.error) return Promise.reject(this.error); +- return Promise.resolve(this.result); +- } +- catch(onRejected) { +- return this.async().catch(onRejected); +- } +- finally(onFinally) { +- return this.async().then(onFinally, onFinally); +- } +- sync() { +- if (this.error) throw this.error; +- return this.result; +- } +- then(onFulfilled, onRejected) { +- if (process.env.NODE_ENV !== "production") { +- if (!("from" in this._opts)) { +- warnOnce2$1( +- "Without `from` option PostCSS could generate wrong source map and will not find Browserslist config. Set it to CSS file path or to `undefined` to prevent this warning." +- ); +- } +- } +- return this.async().then(onFulfilled, onRejected); +- } +- toString() { +- return this._css; +- } +- warnings() { +- return []; +- } +- get content() { +- return this.result.css; +- } +- get css() { +- return this.result.css; +- } +- get map() { +- return this.result.map; +- } +- get messages() { +- return []; +- } +- get opts() { +- return this.result.opts; +- } +- get processor() { +- return this.result.processor; +- } +- get root() { +- if (this._root) { +- return this._root; +- } +- let root2; +- let parser2 = parse$1$1; +- try { +- root2 = parser2(this._css, this._opts); +- } catch (error) { +- this.error = error; +- } +- if (this.error) { +- throw this.error; +- } else { +- this._root = root2; +- return root2; +- } +- } +- get [Symbol.toStringTag]() { +- return "NoWorkResult"; +- } +-}; +-var noWorkResult$1 = NoWorkResult$1$1; +-NoWorkResult$1$1.default = NoWorkResult$1$1; +-let NoWorkResult2$1 = noWorkResult$1; +-let LazyResult$1$1 = lazyResult$1; +-let Document$1$1 = document$1$1; +-let Root$2$1 = root$1; +-let Processor$1$1 = class Processor { +- constructor(plugins = []) { +- this.version = "8.4.38"; +- this.plugins = this.normalize(plugins); +- } +- normalize(plugins) { +- let normalized = []; +- for (let i2 of plugins) { +- if (i2.postcss === true) { +- i2 = i2(); +- } else if (i2.postcss) { +- i2 = i2.postcss; +- } +- if (typeof i2 === "object" && Array.isArray(i2.plugins)) { +- normalized = normalized.concat(i2.plugins); +- } else if (typeof i2 === "object" && i2.postcssPlugin) { +- normalized.push(i2); +- } else if (typeof i2 === "function") { +- normalized.push(i2); +- } else if (typeof i2 === "object" && (i2.parse || i2.stringify)) { +- if (process.env.NODE_ENV !== "production") { +- throw new Error( +- "PostCSS syntaxes cannot be used as plugins. Instead, please use one of the syntax/parser/stringifier options as outlined in your PostCSS runner documentation." +- ); +- } +- } else { +- throw new Error(i2 + " is not a PostCSS plugin"); +- } +- } +- return normalized; +- } +- process(css, opts = {}) { +- if (!this.plugins.length && !opts.parser && !opts.stringifier && !opts.syntax) { +- return new NoWorkResult2$1(this, css, opts); +- } else { +- return new LazyResult$1$1(this, css, opts); +- } +- } +- use(plugin22) { +- this.plugins = this.plugins.concat(this.normalize([plugin22])); +- return this; +- } +-}; +-var processor$1 = Processor$1$1; +-Processor$1$1.default = Processor$1$1; +-Root$2$1.registerProcessor(Processor$1$1); +-Document$1$1.registerProcessor(Processor$1$1); +-let Declaration$1$1 = declaration$1; +-let PreviousMap2$1 = previousMap$1; +-let Comment$1$1 = comment$1; +-let AtRule$1$1 = atRule$1; +-let Input$1$1 = input$1; +-let Root$1$1 = root$1; +-let Rule$1$1 = rule$1; +-function fromJSON$1$1(json, inputs) { +- if (Array.isArray(json)) return json.map((n2) => fromJSON$1$1(n2)); +- let { inputs: ownInputs, ...defaults } = json; +- if (ownInputs) { +- inputs = []; +- for (let input2 of ownInputs) { +- let inputHydrated = { ...input2, __proto__: Input$1$1.prototype }; +- if (inputHydrated.map) { +- inputHydrated.map = { +- ...inputHydrated.map, +- __proto__: PreviousMap2$1.prototype +- }; +- } +- inputs.push(inputHydrated); +- } +- } +- if (defaults.nodes) { +- defaults.nodes = json.nodes.map((n2) => fromJSON$1$1(n2, inputs)); +- } +- if (defaults.source) { +- let { inputId, ...source } = defaults.source; +- defaults.source = source; +- if (inputId != null) { +- defaults.source.input = inputs[inputId]; +- } +- } +- if (defaults.type === "root") { +- return new Root$1$1(defaults); +- } else if (defaults.type === "decl") { +- return new Declaration$1$1(defaults); +- } else if (defaults.type === "rule") { +- return new Rule$1$1(defaults); +- } else if (defaults.type === "comment") { +- return new Comment$1$1(defaults); +- } else if (defaults.type === "atrule") { +- return new AtRule$1$1(defaults); +- } else { +- throw new Error("Unknown node type: " + json.type); +- } +-} +-var fromJSON_1$1 = fromJSON$1$1; +-fromJSON$1$1.default = fromJSON$1$1; +-let CssSyntaxError2$1 = cssSyntaxError$1; +-let Declaration2$1 = declaration$1; +-let LazyResult2$1 = lazyResult$1; +-let Container2$1 = container$1; +-let Processor2$1 = processor$1; +-let stringify$5 = stringify_1$1; +-let fromJSON$2 = fromJSON_1$1; +-let Document22 = document$1$1; +-let Warning2$1 = warning$1; +-let Comment2$1 = comment$1; +-let AtRule2$1 = atRule$1; +-let Result2$1 = result$1; +-let Input2$1 = input$1; +-let parse$5 = parse_1$1; +-let list$3 = list_1$1; +-let Rule2$1 = rule$1; +-let Root2$1 = root$1; +-let Node2$1 = node$1; +-function postcss$3(...plugins) { +- if (plugins.length === 1 && Array.isArray(plugins[0])) { +- plugins = plugins[0]; +- } +- return new Processor2$1(plugins); +-} +-postcss$3.plugin = function plugin(name, initializer) { +- let warningPrinted = false; +- function creator(...args) { +- if (console && console.warn && !warningPrinted) { +- warningPrinted = true; +- console.warn( +- name + ": postcss.plugin was deprecated. Migration guide:\nhttps://evilmartians.com/chronicles/postcss-8-plugin-migration" +- ); +- if (process.env.LANG && process.env.LANG.startsWith("cn")) { +- console.warn( +- name + ": 里面 postcss.plugin 被弃用. 迁移指南:\nhttps://www.w3ctech.com/topic/2226" +- ); +- } +- } +- let transformer = initializer(...args); +- transformer.postcssPlugin = name; +- transformer.postcssVersion = new Processor2$1().version; +- return transformer; +- } +- let cache; +- Object.defineProperty(creator, "postcss", { +- get() { +- if (!cache) cache = creator(); +- return cache; +- } +- }); +- creator.process = function(css, processOpts, pluginOpts) { +- return postcss$3([creator(pluginOpts)]).process(css, processOpts); +- }; +- return creator; +-}; +-postcss$3.stringify = stringify$5; +-postcss$3.parse = parse$5; +-postcss$3.fromJSON = fromJSON$2; +-postcss$3.list = list$3; +-postcss$3.comment = (defaults) => new Comment2$1(defaults); +-postcss$3.atRule = (defaults) => new AtRule2$1(defaults); +-postcss$3.decl = (defaults) => new Declaration2$1(defaults); +-postcss$3.rule = (defaults) => new Rule2$1(defaults); +-postcss$3.root = (defaults) => new Root2$1(defaults); +-postcss$3.document = (defaults) => new Document22(defaults); +-postcss$3.CssSyntaxError = CssSyntaxError2$1; +-postcss$3.Declaration = Declaration2$1; +-postcss$3.Container = Container2$1; +-postcss$3.Processor = Processor2$1; +-postcss$3.Document = Document22; +-postcss$3.Comment = Comment2$1; +-postcss$3.Warning = Warning2$1; +-postcss$3.AtRule = AtRule2$1; +-postcss$3.Result = Result2$1; +-postcss$3.Input = Input2$1; +-postcss$3.Rule = Rule2$1; +-postcss$3.Root = Root2$1; +-postcss$3.Node = Node2$1; +-LazyResult2$1.registerPostcss(postcss$3); +-var postcss_1$1 = postcss$3; +-postcss$3.default = postcss$3; +-const postcss$1$1 = /* @__PURE__ */ getDefaultExportFromCjs$1(postcss_1$1); +-postcss$1$1.stringify; +-postcss$1$1.fromJSON; +-postcss$1$1.plugin; +-postcss$1$1.parse; +-postcss$1$1.list; +-postcss$1$1.document; +-postcss$1$1.comment; +-postcss$1$1.atRule; +-postcss$1$1.rule; +-postcss$1$1.decl; +-postcss$1$1.root; +-postcss$1$1.CssSyntaxError; +-postcss$1$1.Declaration; +-postcss$1$1.Container; +-postcss$1$1.Processor; +-postcss$1$1.Document; +-postcss$1$1.Comment; +-postcss$1$1.Warning; +-postcss$1$1.AtRule; +-postcss$1$1.Result; +-postcss$1$1.Input; +-postcss$1$1.Rule; +-postcss$1$1.Root; +-postcss$1$1.Node; +-var __defProp2 = Object.defineProperty; +-var __defNormalProp2 = (obj, key, value) => key in obj ? __defProp2(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value; +-var __publicField2 = (obj, key, value) => __defNormalProp2(obj, typeof key !== "symbol" ? key + "" : key, value); +-function getDefaultExportFromCjs(x2) { +- return x2 && x2.__esModule && Object.prototype.hasOwnProperty.call(x2, "default") ? x2["default"] : x2; +-} +-function getAugmentedNamespace(n2) { +- if (n2.__esModule) return n2; +- var f2 = n2.default; +- if (typeof f2 == "function") { +- var a2 = function a22() { +- if (this instanceof a22) { +- return Reflect.construct(f2, arguments, this.constructor); +- } +- return f2.apply(this, arguments); +- }; +- a2.prototype = f2.prototype; +- } else a2 = {}; +- Object.defineProperty(a2, "__esModule", { value: true }); +- Object.keys(n2).forEach(function(k) { +- var d = Object.getOwnPropertyDescriptor(n2, k); +- Object.defineProperty(a2, k, d.get ? d : { +- enumerable: true, +- get: function() { +- return n2[k]; +- } +- }); +- }); +- return a2; +-} +-var picocolors_browser = { exports: {} }; +-var x = String; +-var create = function() { +- return { isColorSupported: false, reset: x, bold: x, dim: x, italic: x, underline: x, inverse: x, hidden: x, strikethrough: x, black: x, red: x, green: x, yellow: x, blue: x, magenta: x, cyan: x, white: x, gray: x, bgBlack: x, bgRed: x, bgGreen: x, bgYellow: x, bgBlue: x, bgMagenta: x, bgCyan: x, bgWhite: x }; +-}; +-picocolors_browser.exports = create(); +-picocolors_browser.exports.createColors = create; +-var picocolors_browserExports = picocolors_browser.exports; +-const __viteBrowserExternal = {}; +-const __viteBrowserExternal$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({ +- __proto__: null, +- default: __viteBrowserExternal +-}, Symbol.toStringTag, { value: "Module" })); +-const require$$2 = /* @__PURE__ */ getAugmentedNamespace(__viteBrowserExternal$1); +-let pico = picocolors_browserExports; +-let terminalHighlight$1 = require$$2; +-let CssSyntaxError$3 = class CssSyntaxError2 extends Error { +- constructor(message, line, column, source, file, plugin22) { +- super(message); +- this.name = "CssSyntaxError"; +- this.reason = message; +- if (file) { +- this.file = file; +- } +- if (source) { +- this.source = source; +- } +- if (plugin22) { +- this.plugin = plugin22; +- } +- if (typeof line !== "undefined" && typeof column !== "undefined") { +- if (typeof line === "number") { +- this.line = line; +- this.column = column; +- } else { +- this.line = line.line; +- this.column = line.column; +- this.endLine = column.line; +- this.endColumn = column.column; +- } +- } +- this.setMessage(); +- if (Error.captureStackTrace) { +- Error.captureStackTrace(this, CssSyntaxError2); +- } +- } +- setMessage() { +- this.message = this.plugin ? this.plugin + ": " : ""; +- this.message += this.file ? this.file : ""; +- if (typeof this.line !== "undefined") { +- this.message += ":" + this.line + ":" + this.column; +- } +- this.message += ": " + this.reason; +- } +- showSourceCode(color) { +- if (!this.source) return ""; +- let css = this.source; +- if (color == null) color = pico.isColorSupported; +- if (terminalHighlight$1) { +- if (color) css = terminalHighlight$1(css); +- } +- let lines = css.split(/\r?\n/); +- let start = Math.max(this.line - 3, 0); +- let end = Math.min(this.line + 2, lines.length); +- let maxWidth = String(end).length; +- let mark, aside; +- if (color) { +- let { bold, gray, red } = pico.createColors(true); +- mark = (text) => bold(red(text)); +- aside = (text) => gray(text); +- } else { +- mark = aside = (str) => str; +- } +- return lines.slice(start, end).map((line, index2) => { +- let number = start + 1 + index2; +- let gutter = " " + (" " + number).slice(-maxWidth) + " | "; +- if (number === this.line) { +- let spacing = aside(gutter.replace(/\d/g, " ")) + line.slice(0, this.column - 1).replace(/[^\t]/g, " "); +- return mark(">") + aside(gutter) + line + "\n " + spacing + mark("^"); +- } +- return " " + aside(gutter) + line; +- }).join("\n"); +- } +- toString() { +- let code = this.showSourceCode(); +- if (code) { +- code = "\n\n" + code + "\n"; +- } +- return this.name + ": " + this.message + code; +- } +-}; +-var cssSyntaxError = CssSyntaxError$3; +-CssSyntaxError$3.default = CssSyntaxError$3; +-var symbols = {}; +-symbols.isClean = Symbol("isClean"); +-symbols.my = Symbol("my"); +-const DEFAULT_RAW = { +- after: "\n", +- beforeClose: "\n", +- beforeComment: "\n", +- beforeDecl: "\n", +- beforeOpen: " ", +- beforeRule: "\n", +- colon: ": ", +- commentLeft: " ", +- commentRight: " ", +- emptyBody: "", +- indent: " ", +- semicolon: false +-}; +-function capitalize(str) { +- return str[0].toUpperCase() + str.slice(1); +-} +-let Stringifier$2 = class Stringifier2 { +- constructor(builder) { +- this.builder = builder; +- } +- atrule(node2, semicolon) { +- let name = "@" + node2.name; +- let params = node2.params ? this.rawValue(node2, "params") : ""; +- if (typeof node2.raws.afterName !== "undefined") { +- name += node2.raws.afterName; +- } else if (params) { +- name += " "; +- } +- if (node2.nodes) { +- this.block(node2, name + params); +- } else { +- let end = (node2.raws.between || "") + (semicolon ? ";" : ""); +- this.builder(name + params + end, node2); +- } +- } +- beforeAfter(node2, detect) { +- let value; +- if (node2.type === "decl") { +- value = this.raw(node2, null, "beforeDecl"); +- } else if (node2.type === "comment") { +- value = this.raw(node2, null, "beforeComment"); +- } else if (detect === "before") { +- value = this.raw(node2, null, "beforeRule"); +- } else { +- value = this.raw(node2, null, "beforeClose"); +- } +- let buf = node2.parent; +- let depth = 0; +- while (buf && buf.type !== "root") { +- depth += 1; +- buf = buf.parent; +- } +- if (value.includes("\n")) { +- let indent = this.raw(node2, null, "indent"); +- if (indent.length) { +- for (let step = 0; step < depth; step++) value += indent; +- } +- } +- return value; +- } +- block(node2, start) { +- let between = this.raw(node2, "between", "beforeOpen"); +- this.builder(start + between + "{", node2, "start"); +- let after; +- if (node2.nodes && node2.nodes.length) { +- this.body(node2); +- after = this.raw(node2, "after"); +- } else { +- after = this.raw(node2, "after", "emptyBody"); +- } +- if (after) this.builder(after); +- this.builder("}", node2, "end"); +- } +- body(node2) { +- let last = node2.nodes.length - 1; +- while (last > 0) { +- if (node2.nodes[last].type !== "comment") break; +- last -= 1; +- } +- let semicolon = this.raw(node2, "semicolon"); +- for (let i2 = 0; i2 < node2.nodes.length; i2++) { +- let child = node2.nodes[i2]; +- let before = this.raw(child, "before"); +- if (before) this.builder(before); +- this.stringify(child, last !== i2 || semicolon); +- } +- } +- comment(node2) { +- let left = this.raw(node2, "left", "commentLeft"); +- let right = this.raw(node2, "right", "commentRight"); +- this.builder("/*" + left + node2.text + right + "*/", node2); +- } +- decl(node2, semicolon) { +- let between = this.raw(node2, "between", "colon"); +- let string = node2.prop + between + this.rawValue(node2, "value"); +- if (node2.important) { +- string += node2.raws.important || " !important"; +- } +- if (semicolon) string += ";"; +- this.builder(string, node2); +- } +- document(node2) { +- this.body(node2); +- } +- raw(node2, own, detect) { +- let value; +- if (!detect) detect = own; +- if (own) { +- value = node2.raws[own]; +- if (typeof value !== "undefined") return value; +- } +- let parent = node2.parent; +- if (detect === "before") { +- if (!parent || parent.type === "root" && parent.first === node2) { +- return ""; +- } +- if (parent && parent.type === "document") { +- return ""; +- } +- } +- if (!parent) return DEFAULT_RAW[detect]; +- let root2 = node2.root(); +- if (!root2.rawCache) root2.rawCache = {}; +- if (typeof root2.rawCache[detect] !== "undefined") { +- return root2.rawCache[detect]; +- } +- if (detect === "before" || detect === "after") { +- return this.beforeAfter(node2, detect); +- } else { +- let method = "raw" + capitalize(detect); +- if (this[method]) { +- value = this[method](root2, node2); +- } else { +- root2.walk((i2) => { +- value = i2.raws[own]; +- if (typeof value !== "undefined") return false; +- }); +- } +- } +- if (typeof value === "undefined") value = DEFAULT_RAW[detect]; +- root2.rawCache[detect] = value; +- return value; +- } +- rawBeforeClose(root2) { +- let value; +- root2.walk((i2) => { +- if (i2.nodes && i2.nodes.length > 0) { +- if (typeof i2.raws.after !== "undefined") { +- value = i2.raws.after; +- if (value.includes("\n")) { +- value = value.replace(/[^\n]+$/, ""); +- } +- return false; +- } +- } +- }); +- if (value) value = value.replace(/\S/g, ""); +- return value; +- } +- rawBeforeComment(root2, node2) { +- let value; +- root2.walkComments((i2) => { +- if (typeof i2.raws.before !== "undefined") { +- value = i2.raws.before; +- if (value.includes("\n")) { +- value = value.replace(/[^\n]+$/, ""); +- } +- return false; +- } +- }); +- if (typeof value === "undefined") { +- value = this.raw(node2, null, "beforeDecl"); +- } else if (value) { +- value = value.replace(/\S/g, ""); +- } +- return value; +- } +- rawBeforeDecl(root2, node2) { +- let value; +- root2.walkDecls((i2) => { +- if (typeof i2.raws.before !== "undefined") { +- value = i2.raws.before; +- if (value.includes("\n")) { +- value = value.replace(/[^\n]+$/, ""); +- } +- return false; +- } +- }); +- if (typeof value === "undefined") { +- value = this.raw(node2, null, "beforeRule"); +- } else if (value) { +- value = value.replace(/\S/g, ""); +- } +- return value; +- } +- rawBeforeOpen(root2) { +- let value; +- root2.walk((i2) => { +- if (i2.type !== "decl") { +- value = i2.raws.between; +- if (typeof value !== "undefined") return false; +- } +- }); +- return value; +- } +- rawBeforeRule(root2) { +- let value; +- root2.walk((i2) => { +- if (i2.nodes && (i2.parent !== root2 || root2.first !== i2)) { +- if (typeof i2.raws.before !== "undefined") { +- value = i2.raws.before; +- if (value.includes("\n")) { +- value = value.replace(/[^\n]+$/, ""); +- } +- return false; +- } +- } +- }); +- if (value) value = value.replace(/\S/g, ""); +- return value; +- } +- rawColon(root2) { +- let value; +- root2.walkDecls((i2) => { +- if (typeof i2.raws.between !== "undefined") { +- value = i2.raws.between.replace(/[^\s:]/g, ""); +- return false; +- } +- }); +- return value; +- } +- rawEmptyBody(root2) { +- let value; +- root2.walk((i2) => { +- if (i2.nodes && i2.nodes.length === 0) { +- value = i2.raws.after; +- if (typeof value !== "undefined") return false; +- } +- }); +- return value; +- } +- rawIndent(root2) { +- if (root2.raws.indent) return root2.raws.indent; +- let value; +- root2.walk((i2) => { +- let p = i2.parent; +- if (p && p !== root2 && p.parent && p.parent === root2) { +- if (typeof i2.raws.before !== "undefined") { +- let parts = i2.raws.before.split("\n"); +- value = parts[parts.length - 1]; +- value = value.replace(/\S/g, ""); +- return false; +- } +- } +- }); +- return value; +- } +- rawSemicolon(root2) { +- let value; +- root2.walk((i2) => { +- if (i2.nodes && i2.nodes.length && i2.last.type === "decl") { +- value = i2.raws.semicolon; +- if (typeof value !== "undefined") return false; +- } +- }); +- return value; +- } +- rawValue(node2, prop) { +- let value = node2[prop]; +- let raw = node2.raws[prop]; +- if (raw && raw.value === value) { +- return raw.raw; +- } +- return value; +- } +- root(node2) { +- this.body(node2); +- if (node2.raws.after) this.builder(node2.raws.after); +- } +- rule(node2) { +- this.block(node2, this.rawValue(node2, "selector")); +- if (node2.raws.ownSemicolon) { +- this.builder(node2.raws.ownSemicolon, node2, "end"); +- } +- } +- stringify(node2, semicolon) { +- if (!this[node2.type]) { +- throw new Error( +- "Unknown AST node type " + node2.type + ". Maybe you need to change PostCSS stringifier." +- ); +- } +- this[node2.type](node2, semicolon); +- } +-}; +-var stringifier = Stringifier$2; +-Stringifier$2.default = Stringifier$2; +-let Stringifier$1 = stringifier; +-function stringify$4(node2, builder) { +- let str = new Stringifier$1(builder); +- str.stringify(node2); +-} +-var stringify_1 = stringify$4; +-stringify$4.default = stringify$4; +-let { isClean: isClean$2, my: my$2 } = symbols; +-let CssSyntaxError$2 = cssSyntaxError; +-let Stringifier22 = stringifier; +-let stringify$3 = stringify_1; +-function cloneNode(obj, parent) { +- let cloned = new obj.constructor(); +- for (let i2 in obj) { +- if (!Object.prototype.hasOwnProperty.call(obj, i2)) { +- continue; +- } +- if (i2 === "proxyCache") continue; +- let value = obj[i2]; +- let type = typeof value; +- if (i2 === "parent" && type === "object") { +- if (parent) cloned[i2] = parent; +- } else if (i2 === "source") { +- cloned[i2] = value; +- } else if (Array.isArray(value)) { +- cloned[i2] = value.map((j) => cloneNode(j, cloned)); +- } else { +- if (type === "object" && value !== null) value = cloneNode(value); +- cloned[i2] = value; +- } +- } +- return cloned; +-} +-let Node$4 = class Node3 { +- constructor(defaults = {}) { +- this.raws = {}; +- this[isClean$2] = false; +- this[my$2] = true; +- for (let name in defaults) { +- if (name === "nodes") { +- this.nodes = []; +- for (let node2 of defaults[name]) { +- if (typeof node2.clone === "function") { +- this.append(node2.clone()); +- } else { +- this.append(node2); +- } +- } +- } else { +- this[name] = defaults[name]; +- } +- } +- } +- addToError(error) { +- error.postcssNode = this; +- if (error.stack && this.source && /\n\s{4}at /.test(error.stack)) { +- let s2 = this.source; +- error.stack = error.stack.replace( +- /\n\s{4}at /, +- `$&${s2.input.from}:${s2.start.line}:${s2.start.column}$&` +- ); +- } +- return error; +- } +- after(add) { +- this.parent.insertAfter(this, add); +- return this; +- } +- assign(overrides = {}) { +- for (let name in overrides) { +- this[name] = overrides[name]; +- } +- return this; +- } +- before(add) { +- this.parent.insertBefore(this, add); +- return this; +- } +- cleanRaws(keepBetween) { +- delete this.raws.before; +- delete this.raws.after; +- if (!keepBetween) delete this.raws.between; +- } +- clone(overrides = {}) { +- let cloned = cloneNode(this); +- for (let name in overrides) { +- cloned[name] = overrides[name]; +- } +- return cloned; +- } +- cloneAfter(overrides = {}) { +- let cloned = this.clone(overrides); +- this.parent.insertAfter(this, cloned); +- return cloned; +- } +- cloneBefore(overrides = {}) { +- let cloned = this.clone(overrides); +- this.parent.insertBefore(this, cloned); +- return cloned; +- } +- error(message, opts = {}) { +- if (this.source) { +- let { end, start } = this.rangeBy(opts); +- return this.source.input.error( +- message, +- { column: start.column, line: start.line }, +- { column: end.column, line: end.line }, +- opts +- ); +- } +- return new CssSyntaxError$2(message); +- } +- getProxyProcessor() { +- return { +- get(node2, prop) { +- if (prop === "proxyOf") { +- return node2; +- } else if (prop === "root") { +- return () => node2.root().toProxy(); +- } else { +- return node2[prop]; +- } +- }, +- set(node2, prop, value) { +- if (node2[prop] === value) return true; +- node2[prop] = value; +- if (prop === "prop" || prop === "value" || prop === "name" || prop === "params" || prop === "important" || /* c8 ignore next */ +- prop === "text") { +- node2.markDirty(); +- } +- return true; +- } +- }; +- } +- markDirty() { +- if (this[isClean$2]) { +- this[isClean$2] = false; +- let next = this; +- while (next = next.parent) { +- next[isClean$2] = false; +- } +- } +- } +- next() { +- if (!this.parent) return void 0; +- let index2 = this.parent.index(this); +- return this.parent.nodes[index2 + 1]; +- } +- positionBy(opts, stringRepresentation) { +- let pos = this.source.start; +- if (opts.index) { +- pos = this.positionInside(opts.index, stringRepresentation); +- } else if (opts.word) { +- stringRepresentation = this.toString(); +- let index2 = stringRepresentation.indexOf(opts.word); +- if (index2 !== -1) pos = this.positionInside(index2, stringRepresentation); +- } +- return pos; +- } +- positionInside(index2, stringRepresentation) { +- let string = stringRepresentation || this.toString(); +- let column = this.source.start.column; +- let line = this.source.start.line; +- for (let i2 = 0; i2 < index2; i2++) { +- if (string[i2] === "\n") { +- column = 1; +- line += 1; +- } else { +- column += 1; +- } +- } +- return { column, line }; +- } +- prev() { +- if (!this.parent) return void 0; +- let index2 = this.parent.index(this); +- return this.parent.nodes[index2 - 1]; +- } +- rangeBy(opts) { +- let start = { +- column: this.source.start.column, +- line: this.source.start.line +- }; +- let end = this.source.end ? { +- column: this.source.end.column + 1, +- line: this.source.end.line +- } : { +- column: start.column + 1, +- line: start.line +- }; +- if (opts.word) { +- let stringRepresentation = this.toString(); +- let index2 = stringRepresentation.indexOf(opts.word); +- if (index2 !== -1) { +- start = this.positionInside(index2, stringRepresentation); +- end = this.positionInside(index2 + opts.word.length, stringRepresentation); +- } +- } else { +- if (opts.start) { +- start = { +- column: opts.start.column, +- line: opts.start.line +- }; +- } else if (opts.index) { +- start = this.positionInside(opts.index); +- } +- if (opts.end) { +- end = { +- column: opts.end.column, +- line: opts.end.line +- }; +- } else if (typeof opts.endIndex === "number") { +- end = this.positionInside(opts.endIndex); +- } else if (opts.index) { +- end = this.positionInside(opts.index + 1); +- } +- } +- if (end.line < start.line || end.line === start.line && end.column <= start.column) { +- end = { column: start.column + 1, line: start.line }; +- } +- return { end, start }; +- } +- raw(prop, defaultType) { +- let str = new Stringifier22(); +- return str.raw(this, prop, defaultType); +- } +- remove() { +- if (this.parent) { +- this.parent.removeChild(this); +- } +- this.parent = void 0; +- return this; +- } +- replaceWith(...nodes) { +- if (this.parent) { +- let bookmark = this; +- let foundSelf = false; +- for (let node2 of nodes) { +- if (node2 === this) { +- foundSelf = true; +- } else if (foundSelf) { +- this.parent.insertAfter(bookmark, node2); +- bookmark = node2; +- } else { +- this.parent.insertBefore(bookmark, node2); +- } +- } +- if (!foundSelf) { +- this.remove(); +- } +- } +- return this; +- } +- root() { +- let result2 = this; +- while (result2.parent && result2.parent.type !== "document") { +- result2 = result2.parent; +- } +- return result2; +- } +- toJSON(_, inputs) { +- let fixed = {}; +- let emitInputs = inputs == null; +- inputs = inputs || /* @__PURE__ */ new Map(); +- let inputsNextIndex = 0; +- for (let name in this) { +- if (!Object.prototype.hasOwnProperty.call(this, name)) { +- continue; +- } +- if (name === "parent" || name === "proxyCache") continue; +- let value = this[name]; +- if (Array.isArray(value)) { +- fixed[name] = value.map((i2) => { +- if (typeof i2 === "object" && i2.toJSON) { +- return i2.toJSON(null, inputs); +- } else { +- return i2; +- } +- }); +- } else if (typeof value === "object" && value.toJSON) { +- fixed[name] = value.toJSON(null, inputs); +- } else if (name === "source") { +- let inputId = inputs.get(value.input); +- if (inputId == null) { +- inputId = inputsNextIndex; +- inputs.set(value.input, inputsNextIndex); +- inputsNextIndex++; +- } +- fixed[name] = { +- end: value.end, +- inputId, +- start: value.start +- }; +- } else { +- fixed[name] = value; +- } +- } +- if (emitInputs) { +- fixed.inputs = [...inputs.keys()].map((input2) => input2.toJSON()); +- } +- return fixed; +- } +- toProxy() { +- if (!this.proxyCache) { +- this.proxyCache = new Proxy(this, this.getProxyProcessor()); +- } +- return this.proxyCache; +- } +- toString(stringifier2 = stringify$3) { +- if (stringifier2.stringify) stringifier2 = stringifier2.stringify; +- let result2 = ""; +- stringifier2(this, (i2) => { +- result2 += i2; +- }); +- return result2; +- } +- warn(result2, text, opts) { +- let data = { node: this }; +- for (let i2 in opts) data[i2] = opts[i2]; +- return result2.warn(text, data); +- } +- get proxyOf() { +- return this; +- } +-}; +-var node = Node$4; +-Node$4.default = Node$4; +-let Node$3 = node; +-let Declaration$4 = class Declaration2 extends Node$3 { +- constructor(defaults) { +- if (defaults && typeof defaults.value !== "undefined" && typeof defaults.value !== "string") { +- defaults = { ...defaults, value: String(defaults.value) }; +- } +- super(defaults); +- this.type = "decl"; +- } +- get variable() { +- return this.prop.startsWith("--") || this.prop[0] === "$"; +- } +-}; +-var declaration = Declaration$4; +-Declaration$4.default = Declaration$4; +-let urlAlphabet = "useandom-26T198340PX75pxJACKVERYMINDBUSHWOLF_GQZbfghjklqvwyzrict"; +-let customAlphabet = (alphabet, defaultSize = 21) => { +- return (size = defaultSize) => { +- let id = ""; +- let i2 = size; +- while (i2--) { +- id += alphabet[Math.random() * alphabet.length | 0]; +- } +- return id; +- }; +-}; +-let nanoid$1 = (size = 21) => { +- let id = ""; +- let i2 = size; +- while (i2--) { +- id += urlAlphabet[Math.random() * 64 | 0]; +- } +- return id; +-}; +-var nonSecure = { nanoid: nanoid$1, customAlphabet }; +-let { SourceMapConsumer: SourceMapConsumer$2, SourceMapGenerator: SourceMapGenerator$2 } = require$$2; +-let { existsSync, readFileSync } = require$$2; +-let { dirname: dirname$1, join } = require$$2; +-function fromBase64(str) { +- if (Buffer) { +- return Buffer.from(str, "base64").toString(); +- } else { +- return window.atob(str); +- } +-} +-let PreviousMap$2 = class PreviousMap2 { +- constructor(css, opts) { +- if (opts.map === false) return; +- this.loadAnnotation(css); +- this.inline = this.startWith(this.annotation, "data:"); +- let prev = opts.map ? opts.map.prev : void 0; +- let text = this.loadMap(opts.from, prev); +- if (!this.mapFile && opts.from) { +- this.mapFile = opts.from; +- } +- if (this.mapFile) this.root = dirname$1(this.mapFile); +- if (text) this.text = text; +- } +- consumer() { +- if (!this.consumerCache) { +- this.consumerCache = new SourceMapConsumer$2(this.text); +- } +- return this.consumerCache; +- } +- decodeInline(text) { +- let baseCharsetUri = /^data:application\/json;charset=utf-?8;base64,/; +- let baseUri = /^data:application\/json;base64,/; +- let charsetUri = /^data:application\/json;charset=utf-?8,/; +- let uri = /^data:application\/json,/; +- if (charsetUri.test(text) || uri.test(text)) { +- return decodeURIComponent(text.substr(RegExp.lastMatch.length)); +- } +- if (baseCharsetUri.test(text) || baseUri.test(text)) { +- return fromBase64(text.substr(RegExp.lastMatch.length)); +- } +- let encoding = text.match(/data:application\/json;([^,]+),/)[1]; +- throw new Error("Unsupported source map encoding " + encoding); +- } +- getAnnotationURL(sourceMapString) { +- return sourceMapString.replace(/^\/\*\s*# sourceMappingURL=/, "").trim(); +- } +- isMap(map) { +- if (typeof map !== "object") return false; +- return typeof map.mappings === "string" || typeof map._mappings === "string" || Array.isArray(map.sections); +- } +- loadAnnotation(css) { +- let comments = css.match(/\/\*\s*# sourceMappingURL=/gm); +- if (!comments) return; +- let start = css.lastIndexOf(comments.pop()); +- let end = css.indexOf("*/", start); +- if (start > -1 && end > -1) { +- this.annotation = this.getAnnotationURL(css.substring(start, end)); +- } +- } +- loadFile(path) { +- this.root = dirname$1(path); +- if (existsSync(path)) { +- this.mapFile = path; +- return readFileSync(path, "utf-8").toString().trim(); +- } +- } +- loadMap(file, prev) { +- if (prev === false) return false; +- if (prev) { +- if (typeof prev === "string") { +- return prev; +- } else if (typeof prev === "function") { +- let prevPath = prev(file); +- if (prevPath) { +- let map = this.loadFile(prevPath); +- if (!map) { +- throw new Error( +- "Unable to load previous source map: " + prevPath.toString() +- ); +- } +- return map; +- } +- } else if (prev instanceof SourceMapConsumer$2) { +- return SourceMapGenerator$2.fromSourceMap(prev).toString(); +- } else if (prev instanceof SourceMapGenerator$2) { +- return prev.toString(); +- } else if (this.isMap(prev)) { +- return JSON.stringify(prev); +- } else { +- throw new Error( +- "Unsupported previous source map format: " + prev.toString() +- ); +- } +- } else if (this.inline) { +- return this.decodeInline(this.annotation); +- } else if (this.annotation) { +- let map = this.annotation; +- if (file) map = join(dirname$1(file), map); +- return this.loadFile(map); +- } +- } +- startWith(string, start) { +- if (!string) return false; +- return string.substr(0, start.length) === start; +- } +- withContent() { +- return !!(this.consumer().sourcesContent && this.consumer().sourcesContent.length > 0); +- } +-}; +-var previousMap = PreviousMap$2; +-PreviousMap$2.default = PreviousMap$2; +-let { SourceMapConsumer: SourceMapConsumer$1, SourceMapGenerator: SourceMapGenerator$1 } = require$$2; +-let { fileURLToPath, pathToFileURL: pathToFileURL$1 } = require$$2; +-let { isAbsolute, resolve: resolve$1 } = require$$2; +-let { nanoid } = nonSecure; +-let terminalHighlight = require$$2; +-let CssSyntaxError$1 = cssSyntaxError; +-let PreviousMap$1 = previousMap; +-let fromOffsetCache = Symbol("fromOffsetCache"); +-let sourceMapAvailable$1 = Boolean(SourceMapConsumer$1 && SourceMapGenerator$1); +-let pathAvailable$1 = Boolean(resolve$1 && isAbsolute); +-let Input$4 = class Input2 { +- constructor(css, opts = {}) { +- if (css === null || typeof css === "undefined" || typeof css === "object" && !css.toString) { +- throw new Error(`PostCSS received ${css} instead of CSS string`); +- } +- this.css = css.toString(); +- if (this.css[0] === "\uFEFF" || this.css[0] === "￾") { +- this.hasBOM = true; +- this.css = this.css.slice(1); +- } else { +- this.hasBOM = false; +- } +- if (opts.from) { +- if (!pathAvailable$1 || /^\w+:\/\//.test(opts.from) || isAbsolute(opts.from)) { +- this.file = opts.from; +- } else { +- this.file = resolve$1(opts.from); +- } +- } +- if (pathAvailable$1 && sourceMapAvailable$1) { +- let map = new PreviousMap$1(this.css, opts); +- if (map.text) { +- this.map = map; +- let file = map.consumer().file; +- if (!this.file && file) this.file = this.mapResolve(file); +- } +- } +- if (!this.file) { +- this.id = ""; +- } +- if (this.map) this.map.file = this.from; +- } +- error(message, line, column, opts = {}) { +- let result2, endLine, endColumn; +- if (line && typeof line === "object") { +- let start = line; +- let end = column; +- if (typeof start.offset === "number") { +- let pos = this.fromOffset(start.offset); +- line = pos.line; +- column = pos.col; +- } else { +- line = start.line; +- column = start.column; +- } +- if (typeof end.offset === "number") { +- let pos = this.fromOffset(end.offset); +- endLine = pos.line; +- endColumn = pos.col; +- } else { +- endLine = end.line; +- endColumn = end.column; +- } +- } else if (!column) { +- let pos = this.fromOffset(line); +- line = pos.line; +- column = pos.col; +- } +- let origin = this.origin(line, column, endLine, endColumn); +- if (origin) { +- result2 = new CssSyntaxError$1( +- message, +- origin.endLine === void 0 ? origin.line : { column: origin.column, line: origin.line }, +- origin.endLine === void 0 ? origin.column : { column: origin.endColumn, line: origin.endLine }, +- origin.source, +- origin.file, +- opts.plugin +- ); +- } else { +- result2 = new CssSyntaxError$1( +- message, +- endLine === void 0 ? line : { column, line }, +- endLine === void 0 ? column : { column: endColumn, line: endLine }, +- this.css, +- this.file, +- opts.plugin +- ); +- } +- result2.input = { column, endColumn, endLine, line, source: this.css }; +- if (this.file) { +- if (pathToFileURL$1) { +- result2.input.url = pathToFileURL$1(this.file).toString(); +- } +- result2.input.file = this.file; +- } +- return result2; +- } +- fromOffset(offset) { +- let lastLine, lineToIndex; +- if (!this[fromOffsetCache]) { +- let lines = this.css.split("\n"); +- lineToIndex = new Array(lines.length); +- let prevIndex = 0; +- for (let i2 = 0, l2 = lines.length; i2 < l2; i2++) { +- lineToIndex[i2] = prevIndex; +- prevIndex += lines[i2].length + 1; +- } +- this[fromOffsetCache] = lineToIndex; +- } else { +- lineToIndex = this[fromOffsetCache]; +- } +- lastLine = lineToIndex[lineToIndex.length - 1]; +- let min = 0; +- if (offset >= lastLine) { +- min = lineToIndex.length - 1; +- } else { +- let max = lineToIndex.length - 2; +- let mid; +- while (min < max) { +- mid = min + (max - min >> 1); +- if (offset < lineToIndex[mid]) { +- max = mid - 1; +- } else if (offset >= lineToIndex[mid + 1]) { +- min = mid + 1; +- } else { +- min = mid; +- break; +- } +- } +- } +- return { +- col: offset - lineToIndex[min] + 1, +- line: min + 1 +- }; +- } +- mapResolve(file) { +- if (/^\w+:\/\//.test(file)) { +- return file; +- } +- return resolve$1(this.map.consumer().sourceRoot || this.map.root || ".", file); +- } +- origin(line, column, endLine, endColumn) { +- if (!this.map) return false; +- let consumer = this.map.consumer(); +- let from = consumer.originalPositionFor({ column, line }); +- if (!from.source) return false; +- let to; +- if (typeof endLine === "number") { +- to = consumer.originalPositionFor({ column: endColumn, line: endLine }); +- } +- let fromUrl; +- if (isAbsolute(from.source)) { +- fromUrl = pathToFileURL$1(from.source); +- } else { +- fromUrl = new URL( +- from.source, +- this.map.consumer().sourceRoot || pathToFileURL$1(this.map.mapFile) +- ); +- } +- let result2 = { +- column: from.column, +- endColumn: to && to.column, +- endLine: to && to.line, +- line: from.line, +- url: fromUrl.toString() +- }; +- if (fromUrl.protocol === "file:") { +- if (fileURLToPath) { +- result2.file = fileURLToPath(fromUrl); +- } else { +- throw new Error(`file: protocol is not available in this PostCSS build`); +- } +- } +- let source = consumer.sourceContentFor(from.source); +- if (source) result2.source = source; +- return result2; +- } +- toJSON() { +- let json = {}; +- for (let name of ["hasBOM", "css", "file", "id"]) { +- if (this[name] != null) { +- json[name] = this[name]; +- } +- } +- if (this.map) { +- json.map = { ...this.map }; +- if (json.map.consumerCache) { +- json.map.consumerCache = void 0; +- } +- } +- return json; +- } +- get from() { +- return this.file || this.id; +- } +-}; +-var input = Input$4; +-Input$4.default = Input$4; +-if (terminalHighlight && terminalHighlight.registerInput) { +- terminalHighlight.registerInput(Input$4); +-} +-let { SourceMapConsumer, SourceMapGenerator } = require$$2; +-let { dirname, relative, resolve, sep } = require$$2; +-let { pathToFileURL } = require$$2; +-let Input$3 = input; +-let sourceMapAvailable = Boolean(SourceMapConsumer && SourceMapGenerator); +-let pathAvailable = Boolean(dirname && resolve && relative && sep); +-let MapGenerator$2 = class MapGenerator2 { +- constructor(stringify2, root2, opts, cssString) { +- this.stringify = stringify2; +- this.mapOpts = opts.map || {}; +- this.root = root2; +- this.opts = opts; +- this.css = cssString; +- this.originalCSS = cssString; +- this.usesFileUrls = !this.mapOpts.from && this.mapOpts.absolute; +- this.memoizedFileURLs = /* @__PURE__ */ new Map(); +- this.memoizedPaths = /* @__PURE__ */ new Map(); +- this.memoizedURLs = /* @__PURE__ */ new Map(); +- } +- addAnnotation() { +- let content; +- if (this.isInline()) { +- content = "data:application/json;base64," + this.toBase64(this.map.toString()); +- } else if (typeof this.mapOpts.annotation === "string") { +- content = this.mapOpts.annotation; +- } else if (typeof this.mapOpts.annotation === "function") { +- content = this.mapOpts.annotation(this.opts.to, this.root); +- } else { +- content = this.outputFile() + ".map"; +- } +- let eol = "\n"; +- if (this.css.includes("\r\n")) eol = "\r\n"; +- this.css += eol + "/*# sourceMappingURL=" + content + " */"; +- } +- applyPrevMaps() { +- for (let prev of this.previous()) { +- let from = this.toUrl(this.path(prev.file)); +- let root2 = prev.root || dirname(prev.file); +- let map; +- if (this.mapOpts.sourcesContent === false) { +- map = new SourceMapConsumer(prev.text); +- if (map.sourcesContent) { +- map.sourcesContent = null; +- } +- } else { +- map = prev.consumer(); +- } +- this.map.applySourceMap(map, from, this.toUrl(this.path(root2))); +- } +- } +- clearAnnotation() { +- if (this.mapOpts.annotation === false) return; +- if (this.root) { +- let node2; +- for (let i2 = this.root.nodes.length - 1; i2 >= 0; i2--) { +- node2 = this.root.nodes[i2]; +- if (node2.type !== "comment") continue; +- if (node2.text.indexOf("# sourceMappingURL=") === 0) { +- this.root.removeChild(i2); +- } +- } +- } else if (this.css) { +- this.css = this.css.replace(/\n*?\/\*#[\S\s]*?\*\/$/gm, ""); +- } +- } +- generate() { +- this.clearAnnotation(); +- if (pathAvailable && sourceMapAvailable && this.isMap()) { +- return this.generateMap(); +- } else { +- let result2 = ""; +- this.stringify(this.root, (i2) => { +- result2 += i2; +- }); +- return [result2]; +- } +- } +- generateMap() { +- if (this.root) { +- this.generateString(); +- } else if (this.previous().length === 1) { +- let prev = this.previous()[0].consumer(); +- prev.file = this.outputFile(); +- this.map = SourceMapGenerator.fromSourceMap(prev, { +- ignoreInvalidMapping: true +- }); +- } else { +- this.map = new SourceMapGenerator({ +- file: this.outputFile(), +- ignoreInvalidMapping: true +- }); +- this.map.addMapping({ +- generated: { column: 0, line: 1 }, +- original: { column: 0, line: 1 }, +- source: this.opts.from ? this.toUrl(this.path(this.opts.from)) : "" +- }); +- } +- if (this.isSourcesContent()) this.setSourcesContent(); +- if (this.root && this.previous().length > 0) this.applyPrevMaps(); +- if (this.isAnnotation()) this.addAnnotation(); +- if (this.isInline()) { +- return [this.css]; +- } else { +- return [this.css, this.map]; +- } +- } +- generateString() { +- this.css = ""; +- this.map = new SourceMapGenerator({ +- file: this.outputFile(), +- ignoreInvalidMapping: true +- }); +- let line = 1; +- let column = 1; +- let noSource = ""; +- let mapping = { +- generated: { column: 0, line: 0 }, +- original: { column: 0, line: 0 }, +- source: "" +- }; +- let lines, last; +- this.stringify(this.root, (str, node2, type) => { +- this.css += str; +- if (node2 && type !== "end") { +- mapping.generated.line = line; +- mapping.generated.column = column - 1; +- if (node2.source && node2.source.start) { +- mapping.source = this.sourcePath(node2); +- mapping.original.line = node2.source.start.line; +- mapping.original.column = node2.source.start.column - 1; +- this.map.addMapping(mapping); +- } else { +- mapping.source = noSource; +- mapping.original.line = 1; +- mapping.original.column = 0; +- this.map.addMapping(mapping); +- } +- } +- lines = str.match(/\n/g); +- if (lines) { +- line += lines.length; +- last = str.lastIndexOf("\n"); +- column = str.length - last; +- } else { +- column += str.length; +- } +- if (node2 && type !== "start") { +- let p = node2.parent || { raws: {} }; +- let childless = node2.type === "decl" || node2.type === "atrule" && !node2.nodes; +- if (!childless || node2 !== p.last || p.raws.semicolon) { +- if (node2.source && node2.source.end) { +- mapping.source = this.sourcePath(node2); +- mapping.original.line = node2.source.end.line; +- mapping.original.column = node2.source.end.column - 1; +- mapping.generated.line = line; +- mapping.generated.column = column - 2; +- this.map.addMapping(mapping); +- } else { +- mapping.source = noSource; +- mapping.original.line = 1; +- mapping.original.column = 0; +- mapping.generated.line = line; +- mapping.generated.column = column - 1; +- this.map.addMapping(mapping); +- } +- } +- } +- }); +- } +- isAnnotation() { +- if (this.isInline()) { +- return true; +- } +- if (typeof this.mapOpts.annotation !== "undefined") { +- return this.mapOpts.annotation; +- } +- if (this.previous().length) { +- return this.previous().some((i2) => i2.annotation); +- } +- return true; +- } +- isInline() { +- if (typeof this.mapOpts.inline !== "undefined") { +- return this.mapOpts.inline; +- } +- let annotation = this.mapOpts.annotation; +- if (typeof annotation !== "undefined" && annotation !== true) { +- return false; +- } +- if (this.previous().length) { +- return this.previous().some((i2) => i2.inline); +- } +- return true; +- } +- isMap() { +- if (typeof this.opts.map !== "undefined") { +- return !!this.opts.map; +- } +- return this.previous().length > 0; +- } +- isSourcesContent() { +- if (typeof this.mapOpts.sourcesContent !== "undefined") { +- return this.mapOpts.sourcesContent; +- } +- if (this.previous().length) { +- return this.previous().some((i2) => i2.withContent()); +- } +- return true; +- } +- outputFile() { +- if (this.opts.to) { +- return this.path(this.opts.to); +- } else if (this.opts.from) { +- return this.path(this.opts.from); +- } else { +- return "to.css"; +- } +- } +- path(file) { +- if (this.mapOpts.absolute) return file; +- if (file.charCodeAt(0) === 60) return file; +- if (/^\w+:\/\//.test(file)) return file; +- let cached = this.memoizedPaths.get(file); +- if (cached) return cached; +- let from = this.opts.to ? dirname(this.opts.to) : "."; +- if (typeof this.mapOpts.annotation === "string") { +- from = dirname(resolve(from, this.mapOpts.annotation)); +- } +- let path = relative(from, file); +- this.memoizedPaths.set(file, path); +- return path; +- } +- previous() { +- if (!this.previousMaps) { +- this.previousMaps = []; +- if (this.root) { +- this.root.walk((node2) => { +- if (node2.source && node2.source.input.map) { +- let map = node2.source.input.map; +- if (!this.previousMaps.includes(map)) { +- this.previousMaps.push(map); +- } +- } +- }); +- } else { +- let input2 = new Input$3(this.originalCSS, this.opts); +- if (input2.map) this.previousMaps.push(input2.map); +- } +- } +- return this.previousMaps; +- } +- setSourcesContent() { +- let already = {}; +- if (this.root) { +- this.root.walk((node2) => { +- if (node2.source) { +- let from = node2.source.input.from; +- if (from && !already[from]) { +- already[from] = true; +- let fromUrl = this.usesFileUrls ? this.toFileUrl(from) : this.toUrl(this.path(from)); +- this.map.setSourceContent(fromUrl, node2.source.input.css); +- } +- } +- }); +- } else if (this.css) { +- let from = this.opts.from ? this.toUrl(this.path(this.opts.from)) : ""; +- this.map.setSourceContent(from, this.css); +- } +- } +- sourcePath(node2) { +- if (this.mapOpts.from) { +- return this.toUrl(this.mapOpts.from); +- } else if (this.usesFileUrls) { +- return this.toFileUrl(node2.source.input.from); +- } else { +- return this.toUrl(this.path(node2.source.input.from)); +- } +- } +- toBase64(str) { +- if (Buffer) { +- return Buffer.from(str).toString("base64"); +- } else { +- return window.btoa(unescape(encodeURIComponent(str))); +- } +- } +- toFileUrl(path) { +- let cached = this.memoizedFileURLs.get(path); +- if (cached) return cached; +- if (pathToFileURL) { +- let fileURL = pathToFileURL(path).toString(); +- this.memoizedFileURLs.set(path, fileURL); +- return fileURL; +- } else { +- throw new Error( +- "`map.absolute` option is not available in this PostCSS build" +- ); +- } +- } +- toUrl(path) { +- let cached = this.memoizedURLs.get(path); +- if (cached) return cached; +- if (sep === "\\") { +- path = path.replace(/\\/g, "/"); +- } +- let url = encodeURI(path).replace(/[#?]/g, encodeURIComponent); +- this.memoizedURLs.set(path, url); +- return url; +- } +-}; +-var mapGenerator = MapGenerator$2; +-let Node$2 = node; +-let Comment$4 = class Comment2 extends Node$2 { +- constructor(defaults) { +- super(defaults); +- this.type = "comment"; +- } +-}; +-var comment = Comment$4; +-Comment$4.default = Comment$4; +-let { isClean: isClean$1, my: my$1 } = symbols; +-let Declaration$3 = declaration; +-let Comment$3 = comment; +-let Node$1 = node; +-let parse$4, Rule$4, AtRule$4, Root$6; +-function cleanSource(nodes) { +- return nodes.map((i2) => { +- if (i2.nodes) i2.nodes = cleanSource(i2.nodes); +- delete i2.source; +- return i2; +- }); +-} +-function markDirtyUp(node2) { +- node2[isClean$1] = false; +- if (node2.proxyOf.nodes) { +- for (let i2 of node2.proxyOf.nodes) { +- markDirtyUp(i2); +- } +- } +-} +-let Container$7 = class Container2 extends Node$1 { +- append(...children) { +- for (let child of children) { +- let nodes = this.normalize(child, this.last); +- for (let node2 of nodes) this.proxyOf.nodes.push(node2); +- } +- this.markDirty(); +- return this; +- } +- cleanRaws(keepBetween) { +- super.cleanRaws(keepBetween); +- if (this.nodes) { +- for (let node2 of this.nodes) node2.cleanRaws(keepBetween); +- } +- } +- each(callback) { +- if (!this.proxyOf.nodes) return void 0; +- let iterator = this.getIterator(); +- let index2, result2; +- while (this.indexes[iterator] < this.proxyOf.nodes.length) { +- index2 = this.indexes[iterator]; +- result2 = callback(this.proxyOf.nodes[index2], index2); +- if (result2 === false) break; +- this.indexes[iterator] += 1; +- } +- delete this.indexes[iterator]; +- return result2; +- } +- every(condition) { +- return this.nodes.every(condition); +- } +- getIterator() { +- if (!this.lastEach) this.lastEach = 0; +- if (!this.indexes) this.indexes = {}; +- this.lastEach += 1; +- let iterator = this.lastEach; +- this.indexes[iterator] = 0; +- return iterator; +- } +- getProxyProcessor() { +- return { +- get(node2, prop) { +- if (prop === "proxyOf") { +- return node2; +- } else if (!node2[prop]) { +- return node2[prop]; +- } else if (prop === "each" || typeof prop === "string" && prop.startsWith("walk")) { +- return (...args) => { +- return node2[prop]( +- ...args.map((i2) => { +- if (typeof i2 === "function") { +- return (child, index2) => i2(child.toProxy(), index2); +- } else { +- return i2; +- } +- }) +- ); +- }; +- } else if (prop === "every" || prop === "some") { +- return (cb) => { +- return node2[prop]( +- (child, ...other) => cb(child.toProxy(), ...other) +- ); +- }; +- } else if (prop === "root") { +- return () => node2.root().toProxy(); +- } else if (prop === "nodes") { +- return node2.nodes.map((i2) => i2.toProxy()); +- } else if (prop === "first" || prop === "last") { +- return node2[prop].toProxy(); +- } else { +- return node2[prop]; +- } +- }, +- set(node2, prop, value) { +- if (node2[prop] === value) return true; +- node2[prop] = value; +- if (prop === "name" || prop === "params" || prop === "selector") { +- node2.markDirty(); +- } +- return true; +- } +- }; +- } +- index(child) { +- if (typeof child === "number") return child; +- if (child.proxyOf) child = child.proxyOf; +- return this.proxyOf.nodes.indexOf(child); +- } +- insertAfter(exist, add) { +- let existIndex = this.index(exist); +- let nodes = this.normalize(add, this.proxyOf.nodes[existIndex]).reverse(); +- existIndex = this.index(exist); +- for (let node2 of nodes) this.proxyOf.nodes.splice(existIndex + 1, 0, node2); +- let index2; +- for (let id in this.indexes) { +- index2 = this.indexes[id]; +- if (existIndex < index2) { +- this.indexes[id] = index2 + nodes.length; +- } +- } +- this.markDirty(); +- return this; +- } +- insertBefore(exist, add) { +- let existIndex = this.index(exist); +- let type = existIndex === 0 ? "prepend" : false; +- let nodes = this.normalize(add, this.proxyOf.nodes[existIndex], type).reverse(); +- existIndex = this.index(exist); +- for (let node2 of nodes) this.proxyOf.nodes.splice(existIndex, 0, node2); +- let index2; +- for (let id in this.indexes) { +- index2 = this.indexes[id]; +- if (existIndex <= index2) { +- this.indexes[id] = index2 + nodes.length; +- } +- } +- this.markDirty(); +- return this; +- } +- normalize(nodes, sample) { +- if (typeof nodes === "string") { +- nodes = cleanSource(parse$4(nodes).nodes); +- } else if (typeof nodes === "undefined") { +- nodes = []; +- } else if (Array.isArray(nodes)) { +- nodes = nodes.slice(0); +- for (let i2 of nodes) { +- if (i2.parent) i2.parent.removeChild(i2, "ignore"); +- } +- } else if (nodes.type === "root" && this.type !== "document") { +- nodes = nodes.nodes.slice(0); +- for (let i2 of nodes) { +- if (i2.parent) i2.parent.removeChild(i2, "ignore"); +- } +- } else if (nodes.type) { +- nodes = [nodes]; +- } else if (nodes.prop) { +- if (typeof nodes.value === "undefined") { +- throw new Error("Value field is missed in node creation"); +- } else if (typeof nodes.value !== "string") { +- nodes.value = String(nodes.value); +- } +- nodes = [new Declaration$3(nodes)]; +- } else if (nodes.selector) { +- nodes = [new Rule$4(nodes)]; +- } else if (nodes.name) { +- nodes = [new AtRule$4(nodes)]; +- } else if (nodes.text) { +- nodes = [new Comment$3(nodes)]; +- } else { +- throw new Error("Unknown node type in node creation"); +- } +- let processed = nodes.map((i2) => { +- if (!i2[my$1]) Container2.rebuild(i2); +- i2 = i2.proxyOf; +- if (i2.parent) i2.parent.removeChild(i2); +- if (i2[isClean$1]) markDirtyUp(i2); +- if (typeof i2.raws.before === "undefined") { +- if (sample && typeof sample.raws.before !== "undefined") { +- i2.raws.before = sample.raws.before.replace(/\S/g, ""); +- } +- } +- i2.parent = this.proxyOf; +- return i2; +- }); +- return processed; +- } +- prepend(...children) { +- children = children.reverse(); +- for (let child of children) { +- let nodes = this.normalize(child, this.first, "prepend").reverse(); +- for (let node2 of nodes) this.proxyOf.nodes.unshift(node2); +- for (let id in this.indexes) { +- this.indexes[id] = this.indexes[id] + nodes.length; +- } +- } +- this.markDirty(); +- return this; +- } +- push(child) { +- child.parent = this; +- this.proxyOf.nodes.push(child); +- return this; +- } +- removeAll() { +- for (let node2 of this.proxyOf.nodes) node2.parent = void 0; +- this.proxyOf.nodes = []; +- this.markDirty(); +- return this; +- } +- removeChild(child) { +- child = this.index(child); +- this.proxyOf.nodes[child].parent = void 0; +- this.proxyOf.nodes.splice(child, 1); +- let index2; +- for (let id in this.indexes) { +- index2 = this.indexes[id]; +- if (index2 >= child) { +- this.indexes[id] = index2 - 1; +- } +- } +- this.markDirty(); +- return this; +- } +- replaceValues(pattern, opts, callback) { +- if (!callback) { +- callback = opts; +- opts = {}; +- } +- this.walkDecls((decl) => { +- if (opts.props && !opts.props.includes(decl.prop)) return; +- if (opts.fast && !decl.value.includes(opts.fast)) return; +- decl.value = decl.value.replace(pattern, callback); +- }); +- this.markDirty(); +- return this; +- } +- some(condition) { +- return this.nodes.some(condition); +- } +- walk(callback) { +- return this.each((child, i2) => { +- let result2; +- try { +- result2 = callback(child, i2); +- } catch (e2) { +- throw child.addToError(e2); +- } +- if (result2 !== false && child.walk) { +- result2 = child.walk(callback); +- } +- return result2; +- }); +- } +- walkAtRules(name, callback) { +- if (!callback) { +- callback = name; +- return this.walk((child, i2) => { +- if (child.type === "atrule") { +- return callback(child, i2); +- } +- }); +- } +- if (name instanceof RegExp) { +- return this.walk((child, i2) => { +- if (child.type === "atrule" && name.test(child.name)) { +- return callback(child, i2); +- } +- }); +- } +- return this.walk((child, i2) => { +- if (child.type === "atrule" && child.name === name) { +- return callback(child, i2); +- } +- }); +- } +- walkComments(callback) { +- return this.walk((child, i2) => { +- if (child.type === "comment") { +- return callback(child, i2); +- } +- }); +- } +- walkDecls(prop, callback) { +- if (!callback) { +- callback = prop; +- return this.walk((child, i2) => { +- if (child.type === "decl") { +- return callback(child, i2); +- } +- }); +- } +- if (prop instanceof RegExp) { +- return this.walk((child, i2) => { +- if (child.type === "decl" && prop.test(child.prop)) { +- return callback(child, i2); +- } +- }); +- } +- return this.walk((child, i2) => { +- if (child.type === "decl" && child.prop === prop) { +- return callback(child, i2); +- } +- }); +- } +- walkRules(selector, callback) { +- if (!callback) { +- callback = selector; +- return this.walk((child, i2) => { +- if (child.type === "rule") { +- return callback(child, i2); +- } +- }); +- } +- if (selector instanceof RegExp) { +- return this.walk((child, i2) => { +- if (child.type === "rule" && selector.test(child.selector)) { +- return callback(child, i2); +- } +- }); +- } +- return this.walk((child, i2) => { +- if (child.type === "rule" && child.selector === selector) { +- return callback(child, i2); +- } +- }); +- } +- get first() { +- if (!this.proxyOf.nodes) return void 0; +- return this.proxyOf.nodes[0]; +- } +- get last() { +- if (!this.proxyOf.nodes) return void 0; +- return this.proxyOf.nodes[this.proxyOf.nodes.length - 1]; +- } +-}; +-Container$7.registerParse = (dependant) => { +- parse$4 = dependant; +-}; +-Container$7.registerRule = (dependant) => { +- Rule$4 = dependant; +-}; +-Container$7.registerAtRule = (dependant) => { +- AtRule$4 = dependant; +-}; +-Container$7.registerRoot = (dependant) => { +- Root$6 = dependant; +-}; +-var container = Container$7; +-Container$7.default = Container$7; +-Container$7.rebuild = (node2) => { +- if (node2.type === "atrule") { +- Object.setPrototypeOf(node2, AtRule$4.prototype); +- } else if (node2.type === "rule") { +- Object.setPrototypeOf(node2, Rule$4.prototype); +- } else if (node2.type === "decl") { +- Object.setPrototypeOf(node2, Declaration$3.prototype); +- } else if (node2.type === "comment") { +- Object.setPrototypeOf(node2, Comment$3.prototype); +- } else if (node2.type === "root") { +- Object.setPrototypeOf(node2, Root$6.prototype); +- } +- node2[my$1] = true; +- if (node2.nodes) { +- node2.nodes.forEach((child) => { +- Container$7.rebuild(child); +- }); +- } +-}; +-let Container$6 = container; +-let LazyResult$4, Processor$3; +-let Document$3 = class Document23 extends Container$6 { +- constructor(defaults) { +- super({ type: "document", ...defaults }); +- if (!this.nodes) { +- this.nodes = []; +- } +- } +- toResult(opts = {}) { +- let lazy = new LazyResult$4(new Processor$3(), this, opts); +- return lazy.stringify(); +- } +-}; +-Document$3.registerLazyResult = (dependant) => { +- LazyResult$4 = dependant; +-}; +-Document$3.registerProcessor = (dependant) => { +- Processor$3 = dependant; +-}; +-var document$1 = Document$3; +-Document$3.default = Document$3; +-let printed = {}; +-var warnOnce$2 = function warnOnce2(message) { +- if (printed[message]) return; +- printed[message] = true; +- if (typeof console !== "undefined" && console.warn) { +- console.warn(message); +- } +-}; +-let Warning$2 = class Warning2 { +- constructor(text, opts = {}) { +- this.type = "warning"; +- this.text = text; +- if (opts.node && opts.node.source) { +- let range = opts.node.rangeBy(opts); +- this.line = range.start.line; +- this.column = range.start.column; +- this.endLine = range.end.line; +- this.endColumn = range.end.column; +- } +- for (let opt in opts) this[opt] = opts[opt]; +- } +- toString() { +- if (this.node) { +- return this.node.error(this.text, { +- index: this.index, +- plugin: this.plugin, +- word: this.word +- }).message; +- } +- if (this.plugin) { +- return this.plugin + ": " + this.text; +- } +- return this.text; +- } +-}; +-var warning = Warning$2; +-Warning$2.default = Warning$2; +-let Warning$1 = warning; +-let Result$3 = class Result2 { +- constructor(processor2, root2, opts) { +- this.processor = processor2; +- this.messages = []; +- this.root = root2; +- this.opts = opts; +- this.css = void 0; +- this.map = void 0; +- } +- toString() { +- return this.css; +- } +- warn(text, opts = {}) { +- if (!opts.plugin) { +- if (this.lastPlugin && this.lastPlugin.postcssPlugin) { +- opts.plugin = this.lastPlugin.postcssPlugin; +- } +- } +- let warning2 = new Warning$1(text, opts); +- this.messages.push(warning2); +- return warning2; +- } +- warnings() { +- return this.messages.filter((i2) => i2.type === "warning"); +- } +- get content() { +- return this.css; +- } +-}; +-var result = Result$3; +-Result$3.default = Result$3; +-const SINGLE_QUOTE = "'".charCodeAt(0); +-const DOUBLE_QUOTE = '"'.charCodeAt(0); +-const BACKSLASH = "\\".charCodeAt(0); +-const SLASH = "/".charCodeAt(0); +-const NEWLINE = "\n".charCodeAt(0); +-const SPACE = " ".charCodeAt(0); +-const FEED = "\f".charCodeAt(0); +-const TAB = " ".charCodeAt(0); +-const CR = "\r".charCodeAt(0); +-const OPEN_SQUARE = "[".charCodeAt(0); +-const CLOSE_SQUARE = "]".charCodeAt(0); +-const OPEN_PARENTHESES = "(".charCodeAt(0); +-const CLOSE_PARENTHESES = ")".charCodeAt(0); +-const OPEN_CURLY = "{".charCodeAt(0); +-const CLOSE_CURLY = "}".charCodeAt(0); +-const SEMICOLON = ";".charCodeAt(0); +-const ASTERISK = "*".charCodeAt(0); +-const COLON = ":".charCodeAt(0); +-const AT = "@".charCodeAt(0); +-const RE_AT_END = /[\t\n\f\r "#'()/;[\\\]{}]/g; +-const RE_WORD_END = /[\t\n\f\r !"#'():;@[\\\]{}]|\/(?=\*)/g; +-const RE_BAD_BRACKET = /.[\r\n"'(/\\]/; +-const RE_HEX_ESCAPE = /[\da-f]/i; +-var tokenize = function tokenizer2(input2, options = {}) { +- let css = input2.css.valueOf(); +- let ignore = options.ignoreErrors; +- let code, next, quote, content, escape; +- let escaped, escapePos, prev, n2, currentToken; +- let length = css.length; +- let pos = 0; +- let buffer = []; +- let returned = []; +- function position() { +- return pos; +- } +- function unclosed(what) { +- throw input2.error("Unclosed " + what, pos); +- } +- function endOfFile() { +- return returned.length === 0 && pos >= length; +- } +- function nextToken(opts) { +- if (returned.length) return returned.pop(); +- if (pos >= length) return; +- let ignoreUnclosed = opts ? opts.ignoreUnclosed : false; +- code = css.charCodeAt(pos); +- switch (code) { +- case NEWLINE: +- case SPACE: +- case TAB: +- case CR: +- case FEED: { +- next = pos; +- do { +- next += 1; +- code = css.charCodeAt(next); +- } while (code === SPACE || code === NEWLINE || code === TAB || code === CR || code === FEED); +- currentToken = ["space", css.slice(pos, next)]; +- pos = next - 1; +- break; +- } +- case OPEN_SQUARE: +- case CLOSE_SQUARE: +- case OPEN_CURLY: +- case CLOSE_CURLY: +- case COLON: +- case SEMICOLON: +- case CLOSE_PARENTHESES: { +- let controlChar = String.fromCharCode(code); +- currentToken = [controlChar, controlChar, pos]; +- break; +- } +- case OPEN_PARENTHESES: { +- prev = buffer.length ? buffer.pop()[1] : ""; +- n2 = css.charCodeAt(pos + 1); +- if (prev === "url" && n2 !== SINGLE_QUOTE && n2 !== DOUBLE_QUOTE && n2 !== SPACE && n2 !== NEWLINE && n2 !== TAB && n2 !== FEED && n2 !== CR) { +- next = pos; +- do { +- escaped = false; +- next = css.indexOf(")", next + 1); +- if (next === -1) { +- if (ignore || ignoreUnclosed) { +- next = pos; +- break; +- } else { +- unclosed("bracket"); +- } +- } +- escapePos = next; +- while (css.charCodeAt(escapePos - 1) === BACKSLASH) { +- escapePos -= 1; +- escaped = !escaped; +- } +- } while (escaped); +- currentToken = ["brackets", css.slice(pos, next + 1), pos, next]; +- pos = next; +- } else { +- next = css.indexOf(")", pos + 1); +- content = css.slice(pos, next + 1); +- if (next === -1 || RE_BAD_BRACKET.test(content)) { +- currentToken = ["(", "(", pos]; +- } else { +- currentToken = ["brackets", content, pos, next]; +- pos = next; +- } +- } +- break; +- } +- case SINGLE_QUOTE: +- case DOUBLE_QUOTE: { +- quote = code === SINGLE_QUOTE ? "'" : '"'; +- next = pos; +- do { +- escaped = false; +- next = css.indexOf(quote, next + 1); +- if (next === -1) { +- if (ignore || ignoreUnclosed) { +- next = pos + 1; +- break; +- } else { +- unclosed("string"); +- } +- } +- escapePos = next; +- while (css.charCodeAt(escapePos - 1) === BACKSLASH) { +- escapePos -= 1; +- escaped = !escaped; +- } +- } while (escaped); +- currentToken = ["string", css.slice(pos, next + 1), pos, next]; +- pos = next; +- break; +- } +- case AT: { +- RE_AT_END.lastIndex = pos + 1; +- RE_AT_END.test(css); +- if (RE_AT_END.lastIndex === 0) { +- next = css.length - 1; +- } else { +- next = RE_AT_END.lastIndex - 2; +- } +- currentToken = ["at-word", css.slice(pos, next + 1), pos, next]; +- pos = next; +- break; +- } +- case BACKSLASH: { +- next = pos; +- escape = true; +- while (css.charCodeAt(next + 1) === BACKSLASH) { +- next += 1; +- escape = !escape; +- } +- code = css.charCodeAt(next + 1); +- if (escape && code !== SLASH && code !== SPACE && code !== NEWLINE && code !== TAB && code !== CR && code !== FEED) { +- next += 1; +- if (RE_HEX_ESCAPE.test(css.charAt(next))) { +- while (RE_HEX_ESCAPE.test(css.charAt(next + 1))) { +- next += 1; +- } +- if (css.charCodeAt(next + 1) === SPACE) { +- next += 1; +- } +- } +- } +- currentToken = ["word", css.slice(pos, next + 1), pos, next]; +- pos = next; +- break; +- } +- default: { +- if (code === SLASH && css.charCodeAt(pos + 1) === ASTERISK) { +- next = css.indexOf("*/", pos + 2) + 1; +- if (next === 0) { +- if (ignore || ignoreUnclosed) { +- next = css.length; +- } else { +- unclosed("comment"); +- } +- } +- currentToken = ["comment", css.slice(pos, next + 1), pos, next]; +- pos = next; +- } else { +- RE_WORD_END.lastIndex = pos + 1; +- RE_WORD_END.test(css); +- if (RE_WORD_END.lastIndex === 0) { +- next = css.length - 1; +- } else { +- next = RE_WORD_END.lastIndex - 2; +- } +- currentToken = ["word", css.slice(pos, next + 1), pos, next]; +- buffer.push(currentToken); +- pos = next; +- } +- break; +- } +- } +- pos++; +- return currentToken; +- } +- function back(token) { +- returned.push(token); +- } +- return { +- back, +- endOfFile, +- nextToken, +- position +- }; +-}; +-let Container$5 = container; +-let AtRule$3 = class AtRule2 extends Container$5 { +- constructor(defaults) { +- super(defaults); +- this.type = "atrule"; +- } +- append(...children) { +- if (!this.proxyOf.nodes) this.nodes = []; +- return super.append(...children); +- } +- prepend(...children) { +- if (!this.proxyOf.nodes) this.nodes = []; +- return super.prepend(...children); +- } +-}; +-var atRule = AtRule$3; +-AtRule$3.default = AtRule$3; +-Container$5.registerAtRule(AtRule$3); +-let Container$4 = container; +-let LazyResult$3, Processor$2; +-let Root$5 = class Root2 extends Container$4 { +- constructor(defaults) { +- super(defaults); +- this.type = "root"; +- if (!this.nodes) this.nodes = []; +- } +- normalize(child, sample, type) { +- let nodes = super.normalize(child); +- if (sample) { +- if (type === "prepend") { +- if (this.nodes.length > 1) { +- sample.raws.before = this.nodes[1].raws.before; +- } else { +- delete sample.raws.before; +- } +- } else if (this.first !== sample) { +- for (let node2 of nodes) { +- node2.raws.before = sample.raws.before; +- } +- } +- } +- return nodes; +- } +- removeChild(child, ignore) { +- let index2 = this.index(child); +- if (!ignore && index2 === 0 && this.nodes.length > 1) { +- this.nodes[1].raws.before = this.nodes[index2].raws.before; +- } +- return super.removeChild(child); +- } +- toResult(opts = {}) { +- let lazy = new LazyResult$3(new Processor$2(), this, opts); +- return lazy.stringify(); +- } +-}; +-Root$5.registerLazyResult = (dependant) => { +- LazyResult$3 = dependant; +-}; +-Root$5.registerProcessor = (dependant) => { +- Processor$2 = dependant; +-}; +-var root = Root$5; +-Root$5.default = Root$5; +-Container$4.registerRoot(Root$5); +-let list$2 = { +- comma(string) { +- return list$2.split(string, [","], true); +- }, +- space(string) { +- let spaces = [" ", "\n", " "]; +- return list$2.split(string, spaces); +- }, +- split(string, separators, last) { +- let array = []; +- let current = ""; +- let split = false; +- let func = 0; +- let inQuote = false; +- let prevQuote = ""; +- let escape = false; +- for (let letter of string) { +- if (escape) { +- escape = false; +- } else if (letter === "\\") { +- escape = true; +- } else if (inQuote) { +- if (letter === prevQuote) { +- inQuote = false; +- } +- } else if (letter === '"' || letter === "'") { +- inQuote = true; +- prevQuote = letter; +- } else if (letter === "(") { +- func += 1; +- } else if (letter === ")") { +- if (func > 0) func -= 1; +- } else if (func === 0) { +- if (separators.includes(letter)) split = true; +- } +- if (split) { +- if (current !== "") array.push(current.trim()); +- current = ""; +- split = false; +- } else { +- current += letter; +- } +- } +- if (last || current !== "") array.push(current.trim()); +- return array; +- } +-}; +-var list_1 = list$2; +-list$2.default = list$2; +-let Container$3 = container; +-let list$1 = list_1; +-let Rule$3 = class Rule2 extends Container$3 { +- constructor(defaults) { +- super(defaults); +- this.type = "rule"; +- if (!this.nodes) this.nodes = []; +- } +- get selectors() { +- return list$1.comma(this.selector); +- } +- set selectors(values) { +- let match = this.selector ? this.selector.match(/,\s*/) : null; +- let sep2 = match ? match[0] : "," + this.raw("between", "beforeOpen"); +- this.selector = values.join(sep2); +- } +-}; +-var rule = Rule$3; +-Rule$3.default = Rule$3; +-Container$3.registerRule(Rule$3); +-let Declaration$2 = declaration; +-let tokenizer22 = tokenize; +-let Comment$2 = comment; +-let AtRule$2 = atRule; +-let Root$4 = root; +-let Rule$2 = rule; +-const SAFE_COMMENT_NEIGHBOR = { +- empty: true, +- space: true +-}; +-function findLastWithPosition(tokens) { +- for (let i2 = tokens.length - 1; i2 >= 0; i2--) { +- let token = tokens[i2]; +- let pos = token[3] || token[2]; +- if (pos) return pos; +- } +-} +-let Parser$1 = class Parser2 { +- constructor(input2) { +- this.input = input2; +- this.root = new Root$4(); +- this.current = this.root; +- this.spaces = ""; +- this.semicolon = false; +- this.createTokenizer(); +- this.root.source = { input: input2, start: { column: 1, line: 1, offset: 0 } }; +- } +- atrule(token) { +- let node2 = new AtRule$2(); +- node2.name = token[1].slice(1); +- if (node2.name === "") { +- this.unnamedAtrule(node2, token); +- } +- this.init(node2, token[2]); +- let type; +- let prev; +- let shift; +- let last = false; +- let open = false; +- let params = []; +- let brackets = []; +- while (!this.tokenizer.endOfFile()) { +- token = this.tokenizer.nextToken(); +- type = token[0]; +- if (type === "(" || type === "[") { +- brackets.push(type === "(" ? ")" : "]"); +- } else if (type === "{" && brackets.length > 0) { +- brackets.push("}"); +- } else if (type === brackets[brackets.length - 1]) { +- brackets.pop(); +- } +- if (brackets.length === 0) { +- if (type === ";") { +- node2.source.end = this.getPosition(token[2]); +- node2.source.end.offset++; +- this.semicolon = true; +- break; +- } else if (type === "{") { +- open = true; +- break; +- } else if (type === "}") { +- if (params.length > 0) { +- shift = params.length - 1; +- prev = params[shift]; +- while (prev && prev[0] === "space") { +- prev = params[--shift]; +- } +- if (prev) { +- node2.source.end = this.getPosition(prev[3] || prev[2]); +- node2.source.end.offset++; +- } +- } +- this.end(token); +- break; +- } else { +- params.push(token); +- } +- } else { +- params.push(token); +- } +- if (this.tokenizer.endOfFile()) { +- last = true; +- break; +- } +- } +- node2.raws.between = this.spacesAndCommentsFromEnd(params); +- if (params.length) { +- node2.raws.afterName = this.spacesAndCommentsFromStart(params); +- this.raw(node2, "params", params); +- if (last) { +- token = params[params.length - 1]; +- node2.source.end = this.getPosition(token[3] || token[2]); +- node2.source.end.offset++; +- this.spaces = node2.raws.between; +- node2.raws.between = ""; +- } +- } else { +- node2.raws.afterName = ""; +- node2.params = ""; +- } +- if (open) { +- node2.nodes = []; +- this.current = node2; +- } +- } +- checkMissedSemicolon(tokens) { +- let colon = this.colon(tokens); +- if (colon === false) return; +- let founded = 0; +- let token; +- for (let j = colon - 1; j >= 0; j--) { +- token = tokens[j]; +- if (token[0] !== "space") { +- founded += 1; +- if (founded === 2) break; +- } +- } +- throw this.input.error( +- "Missed semicolon", +- token[0] === "word" ? token[3] + 1 : token[2] +- ); +- } +- colon(tokens) { +- let brackets = 0; +- let token, type, prev; +- for (let [i2, element] of tokens.entries()) { +- token = element; +- type = token[0]; +- if (type === "(") { +- brackets += 1; +- } +- if (type === ")") { +- brackets -= 1; +- } +- if (brackets === 0 && type === ":") { +- if (!prev) { +- this.doubleColon(token); +- } else if (prev[0] === "word" && prev[1] === "progid") { +- continue; +- } else { +- return i2; +- } +- } +- prev = token; +- } +- return false; +- } +- comment(token) { +- let node2 = new Comment$2(); +- this.init(node2, token[2]); +- node2.source.end = this.getPosition(token[3] || token[2]); +- node2.source.end.offset++; +- let text = token[1].slice(2, -2); +- if (/^\s*$/.test(text)) { +- node2.text = ""; +- node2.raws.left = text; +- node2.raws.right = ""; +- } else { +- let match = text.match(/^(\s*)([^]*\S)(\s*)$/); +- node2.text = match[2]; +- node2.raws.left = match[1]; +- node2.raws.right = match[3]; +- } +- } +- createTokenizer() { +- this.tokenizer = tokenizer22(this.input); +- } +- decl(tokens, customProperty) { +- let node2 = new Declaration$2(); +- this.init(node2, tokens[0][2]); +- let last = tokens[tokens.length - 1]; +- if (last[0] === ";") { +- this.semicolon = true; +- tokens.pop(); +- } +- node2.source.end = this.getPosition( +- last[3] || last[2] || findLastWithPosition(tokens) +- ); +- node2.source.end.offset++; +- while (tokens[0][0] !== "word") { +- if (tokens.length === 1) this.unknownWord(tokens); +- node2.raws.before += tokens.shift()[1]; +- } +- node2.source.start = this.getPosition(tokens[0][2]); +- node2.prop = ""; +- while (tokens.length) { +- let type = tokens[0][0]; +- if (type === ":" || type === "space" || type === "comment") { +- break; +- } +- node2.prop += tokens.shift()[1]; +- } +- node2.raws.between = ""; +- let token; +- while (tokens.length) { +- token = tokens.shift(); +- if (token[0] === ":") { +- node2.raws.between += token[1]; +- break; +- } else { +- if (token[0] === "word" && /\w/.test(token[1])) { +- this.unknownWord([token]); +- } +- node2.raws.between += token[1]; +- } +- } +- if (node2.prop[0] === "_" || node2.prop[0] === "*") { +- node2.raws.before += node2.prop[0]; +- node2.prop = node2.prop.slice(1); +- } +- let firstSpaces = []; +- let next; +- while (tokens.length) { +- next = tokens[0][0]; +- if (next !== "space" && next !== "comment") break; +- firstSpaces.push(tokens.shift()); +- } +- this.precheckMissedSemicolon(tokens); +- for (let i2 = tokens.length - 1; i2 >= 0; i2--) { +- token = tokens[i2]; +- if (token[1].toLowerCase() === "!important") { +- node2.important = true; +- let string = this.stringFrom(tokens, i2); +- string = this.spacesFromEnd(tokens) + string; +- if (string !== " !important") node2.raws.important = string; +- break; +- } else if (token[1].toLowerCase() === "important") { +- let cache = tokens.slice(0); +- let str = ""; +- for (let j = i2; j > 0; j--) { +- let type = cache[j][0]; +- if (str.trim().indexOf("!") === 0 && type !== "space") { +- break; +- } +- str = cache.pop()[1] + str; +- } +- if (str.trim().indexOf("!") === 0) { +- node2.important = true; +- node2.raws.important = str; +- tokens = cache; +- } +- } +- if (token[0] !== "space" && token[0] !== "comment") { +- break; +- } +- } +- let hasWord = tokens.some((i2) => i2[0] !== "space" && i2[0] !== "comment"); +- if (hasWord) { +- node2.raws.between += firstSpaces.map((i2) => i2[1]).join(""); +- firstSpaces = []; +- } +- this.raw(node2, "value", firstSpaces.concat(tokens), customProperty); +- if (node2.value.includes(":") && !customProperty) { +- this.checkMissedSemicolon(tokens); +- } +- } +- doubleColon(token) { +- throw this.input.error( +- "Double colon", +- { offset: token[2] }, +- { offset: token[2] + token[1].length } +- ); +- } +- emptyRule(token) { +- let node2 = new Rule$2(); +- this.init(node2, token[2]); +- node2.selector = ""; +- node2.raws.between = ""; +- this.current = node2; +- } +- end(token) { +- if (this.current.nodes && this.current.nodes.length) { +- this.current.raws.semicolon = this.semicolon; +- } +- this.semicolon = false; +- this.current.raws.after = (this.current.raws.after || "") + this.spaces; +- this.spaces = ""; +- if (this.current.parent) { +- this.current.source.end = this.getPosition(token[2]); +- this.current.source.end.offset++; +- this.current = this.current.parent; +- } else { +- this.unexpectedClose(token); +- } +- } +- endFile() { +- if (this.current.parent) this.unclosedBlock(); +- if (this.current.nodes && this.current.nodes.length) { +- this.current.raws.semicolon = this.semicolon; +- } +- this.current.raws.after = (this.current.raws.after || "") + this.spaces; +- this.root.source.end = this.getPosition(this.tokenizer.position()); +- } +- freeSemicolon(token) { +- this.spaces += token[1]; +- if (this.current.nodes) { +- let prev = this.current.nodes[this.current.nodes.length - 1]; +- if (prev && prev.type === "rule" && !prev.raws.ownSemicolon) { +- prev.raws.ownSemicolon = this.spaces; +- this.spaces = ""; +- } +- } +- } +- // Helpers +- getPosition(offset) { +- let pos = this.input.fromOffset(offset); +- return { +- column: pos.col, +- line: pos.line, +- offset +- }; +- } +- init(node2, offset) { +- this.current.push(node2); +- node2.source = { +- input: this.input, +- start: this.getPosition(offset) +- }; +- node2.raws.before = this.spaces; +- this.spaces = ""; +- if (node2.type !== "comment") this.semicolon = false; +- } +- other(start) { +- let end = false; +- let type = null; +- let colon = false; +- let bracket = null; +- let brackets = []; +- let customProperty = start[1].startsWith("--"); +- let tokens = []; +- let token = start; +- while (token) { +- type = token[0]; +- tokens.push(token); +- if (type === "(" || type === "[") { +- if (!bracket) bracket = token; +- brackets.push(type === "(" ? ")" : "]"); +- } else if (customProperty && colon && type === "{") { +- if (!bracket) bracket = token; +- brackets.push("}"); +- } else if (brackets.length === 0) { +- if (type === ";") { +- if (colon) { +- this.decl(tokens, customProperty); +- return; +- } else { +- break; +- } +- } else if (type === "{") { +- this.rule(tokens); +- return; +- } else if (type === "}") { +- this.tokenizer.back(tokens.pop()); +- end = true; +- break; +- } else if (type === ":") { +- colon = true; +- } +- } else if (type === brackets[brackets.length - 1]) { +- brackets.pop(); +- if (brackets.length === 0) bracket = null; +- } +- token = this.tokenizer.nextToken(); +- } +- if (this.tokenizer.endOfFile()) end = true; +- if (brackets.length > 0) this.unclosedBracket(bracket); +- if (end && colon) { +- if (!customProperty) { +- while (tokens.length) { +- token = tokens[tokens.length - 1][0]; +- if (token !== "space" && token !== "comment") break; +- this.tokenizer.back(tokens.pop()); +- } +- } +- this.decl(tokens, customProperty); +- } else { +- this.unknownWord(tokens); +- } +- } +- parse() { +- let token; +- while (!this.tokenizer.endOfFile()) { +- token = this.tokenizer.nextToken(); +- switch (token[0]) { +- case "space": +- this.spaces += token[1]; +- break; +- case ";": +- this.freeSemicolon(token); +- break; +- case "}": +- this.end(token); +- break; +- case "comment": +- this.comment(token); +- break; +- case "at-word": +- this.atrule(token); +- break; +- case "{": +- this.emptyRule(token); +- break; +- default: +- this.other(token); +- break; +- } +- } +- this.endFile(); +- } +- precheckMissedSemicolon() { +- } +- raw(node2, prop, tokens, customProperty) { +- let token, type; +- let length = tokens.length; +- let value = ""; +- let clean = true; +- let next, prev; +- for (let i2 = 0; i2 < length; i2 += 1) { +- token = tokens[i2]; +- type = token[0]; +- if (type === "space" && i2 === length - 1 && !customProperty) { +- clean = false; +- } else if (type === "comment") { +- prev = tokens[i2 - 1] ? tokens[i2 - 1][0] : "empty"; +- next = tokens[i2 + 1] ? tokens[i2 + 1][0] : "empty"; +- if (!SAFE_COMMENT_NEIGHBOR[prev] && !SAFE_COMMENT_NEIGHBOR[next]) { +- if (value.slice(-1) === ",") { +- clean = false; +- } else { +- value += token[1]; +- } +- } else { +- clean = false; +- } +- } else { +- value += token[1]; +- } +- } +- if (!clean) { +- let raw = tokens.reduce((all, i2) => all + i2[1], ""); +- node2.raws[prop] = { raw, value }; +- } +- node2[prop] = value; +- } +- rule(tokens) { +- tokens.pop(); +- let node2 = new Rule$2(); +- this.init(node2, tokens[0][2]); +- node2.raws.between = this.spacesAndCommentsFromEnd(tokens); +- this.raw(node2, "selector", tokens); +- this.current = node2; +- } +- spacesAndCommentsFromEnd(tokens) { +- let lastTokenType; +- let spaces = ""; +- while (tokens.length) { +- lastTokenType = tokens[tokens.length - 1][0]; +- if (lastTokenType !== "space" && lastTokenType !== "comment") break; +- spaces = tokens.pop()[1] + spaces; +- } +- return spaces; +- } +- // Errors +- spacesAndCommentsFromStart(tokens) { +- let next; +- let spaces = ""; +- while (tokens.length) { +- next = tokens[0][0]; +- if (next !== "space" && next !== "comment") break; +- spaces += tokens.shift()[1]; +- } +- return spaces; +- } +- spacesFromEnd(tokens) { +- let lastTokenType; +- let spaces = ""; +- while (tokens.length) { +- lastTokenType = tokens[tokens.length - 1][0]; +- if (lastTokenType !== "space") break; +- spaces = tokens.pop()[1] + spaces; +- } +- return spaces; +- } +- stringFrom(tokens, from) { +- let result2 = ""; +- for (let i2 = from; i2 < tokens.length; i2++) { +- result2 += tokens[i2][1]; +- } +- tokens.splice(from, tokens.length - from); +- return result2; +- } +- unclosedBlock() { +- let pos = this.current.source.start; +- throw this.input.error("Unclosed block", pos.line, pos.column); +- } +- unclosedBracket(bracket) { +- throw this.input.error( +- "Unclosed bracket", +- { offset: bracket[2] }, +- { offset: bracket[2] + 1 } +- ); +- } +- unexpectedClose(token) { +- throw this.input.error( +- "Unexpected }", +- { offset: token[2] }, +- { offset: token[2] + 1 } +- ); +- } +- unknownWord(tokens) { +- throw this.input.error( +- "Unknown word", +- { offset: tokens[0][2] }, +- { offset: tokens[0][2] + tokens[0][1].length } +- ); +- } +- unnamedAtrule(node2, token) { +- throw this.input.error( +- "At-rule without name", +- { offset: token[2] }, +- { offset: token[2] + token[1].length } +- ); +- } +-}; +-var parser = Parser$1; +-let Container$2 = container; +-let Parser22 = parser; +-let Input$2 = input; +-function parse$3(css, opts) { +- let input2 = new Input$2(css, opts); +- let parser2 = new Parser22(input2); +- try { +- parser2.parse(); +- } catch (e2) { +- if (process.env.NODE_ENV !== "production") { +- if (e2.name === "CssSyntaxError" && opts && opts.from) { +- if (/\.scss$/i.test(opts.from)) { +- e2.message += "\nYou tried to parse SCSS with the standard CSS parser; try again with the postcss-scss parser"; +- } else if (/\.sass/i.test(opts.from)) { +- e2.message += "\nYou tried to parse Sass with the standard CSS parser; try again with the postcss-sass parser"; +- } else if (/\.less$/i.test(opts.from)) { +- e2.message += "\nYou tried to parse Less with the standard CSS parser; try again with the postcss-less parser"; +- } +- } +- } +- throw e2; +- } +- return parser2.root; +-} +-var parse_1 = parse$3; +-parse$3.default = parse$3; +-Container$2.registerParse(parse$3); +-let { isClean, my } = symbols; +-let MapGenerator$1 = mapGenerator; +-let stringify$2 = stringify_1; +-let Container$1 = container; +-let Document$2 = document$1; +-let warnOnce$1 = warnOnce$2; +-let Result$2 = result; +-let parse$2 = parse_1; +-let Root$3 = root; +-const TYPE_TO_CLASS_NAME = { +- atrule: "AtRule", +- comment: "Comment", +- decl: "Declaration", +- document: "Document", +- root: "Root", +- rule: "Rule" +-}; +-const PLUGIN_PROPS = { +- AtRule: true, +- AtRuleExit: true, +- Comment: true, +- CommentExit: true, +- Declaration: true, +- DeclarationExit: true, +- Document: true, +- DocumentExit: true, +- Once: true, +- OnceExit: true, +- postcssPlugin: true, +- prepare: true, +- Root: true, +- RootExit: true, +- Rule: true, +- RuleExit: true +-}; +-const NOT_VISITORS = { +- Once: true, +- postcssPlugin: true, +- prepare: true +-}; +-const CHILDREN = 0; +-function isPromise(obj) { +- return typeof obj === "object" && typeof obj.then === "function"; +-} +-function getEvents(node2) { +- let key = false; +- let type = TYPE_TO_CLASS_NAME[node2.type]; +- if (node2.type === "decl") { +- key = node2.prop.toLowerCase(); +- } else if (node2.type === "atrule") { +- key = node2.name.toLowerCase(); +- } +- if (key && node2.append) { +- return [ +- type, +- type + "-" + key, +- CHILDREN, +- type + "Exit", +- type + "Exit-" + key +- ]; +- } else if (key) { +- return [type, type + "-" + key, type + "Exit", type + "Exit-" + key]; +- } else if (node2.append) { +- return [type, CHILDREN, type + "Exit"]; +- } else { +- return [type, type + "Exit"]; +- } +-} +-function toStack(node2) { +- let events; +- if (node2.type === "document") { +- events = ["Document", CHILDREN, "DocumentExit"]; +- } else if (node2.type === "root") { +- events = ["Root", CHILDREN, "RootExit"]; +- } else { +- events = getEvents(node2); +- } +- return { +- eventIndex: 0, +- events, +- iterator: 0, +- node: node2, +- visitorIndex: 0, +- visitors: [] +- }; +-} +-function cleanMarks(node2) { +- node2[isClean] = false; +- if (node2.nodes) node2.nodes.forEach((i2) => cleanMarks(i2)); +- return node2; +-} +-let postcss$2 = {}; +-let LazyResult$2 = class LazyResult2 { +- constructor(processor2, css, opts) { +- this.stringified = false; +- this.processed = false; +- let root2; +- if (typeof css === "object" && css !== null && (css.type === "root" || css.type === "document")) { +- root2 = cleanMarks(css); +- } else if (css instanceof LazyResult2 || css instanceof Result$2) { +- root2 = cleanMarks(css.root); +- if (css.map) { +- if (typeof opts.map === "undefined") opts.map = {}; +- if (!opts.map.inline) opts.map.inline = false; +- opts.map.prev = css.map; +- } +- } else { +- let parser2 = parse$2; +- if (opts.syntax) parser2 = opts.syntax.parse; +- if (opts.parser) parser2 = opts.parser; +- if (parser2.parse) parser2 = parser2.parse; +- try { +- root2 = parser2(css, opts); +- } catch (error) { +- this.processed = true; +- this.error = error; +- } +- if (root2 && !root2[my]) { +- Container$1.rebuild(root2); +- } +- } +- this.result = new Result$2(processor2, root2, opts); +- this.helpers = { ...postcss$2, postcss: postcss$2, result: this.result }; +- this.plugins = this.processor.plugins.map((plugin22) => { +- if (typeof plugin22 === "object" && plugin22.prepare) { +- return { ...plugin22, ...plugin22.prepare(this.result) }; +- } else { +- return plugin22; +- } +- }); +- } +- async() { +- if (this.error) return Promise.reject(this.error); +- if (this.processed) return Promise.resolve(this.result); +- if (!this.processing) { +- this.processing = this.runAsync(); +- } +- return this.processing; +- } +- catch(onRejected) { +- return this.async().catch(onRejected); +- } +- finally(onFinally) { +- return this.async().then(onFinally, onFinally); +- } +- getAsyncError() { +- throw new Error("Use process(css).then(cb) to work with async plugins"); +- } +- handleError(error, node2) { +- let plugin22 = this.result.lastPlugin; +- try { +- if (node2) node2.addToError(error); +- this.error = error; +- if (error.name === "CssSyntaxError" && !error.plugin) { +- error.plugin = plugin22.postcssPlugin; +- error.setMessage(); +- } else if (plugin22.postcssVersion) { +- if (process.env.NODE_ENV !== "production") { +- let pluginName = plugin22.postcssPlugin; +- let pluginVer = plugin22.postcssVersion; +- let runtimeVer = this.result.processor.version; +- let a2 = pluginVer.split("."); +- let b = runtimeVer.split("."); +- if (a2[0] !== b[0] || parseInt(a2[1]) > parseInt(b[1])) { +- console.error( +- "Unknown error from PostCSS plugin. Your current PostCSS version is " + runtimeVer + ", but " + pluginName + " uses " + pluginVer + ". Perhaps this is the source of the error below." +- ); +- } +- } +- } +- } catch (err) { +- if (console && console.error) console.error(err); +- } +- return error; +- } +- prepareVisitors() { +- this.listeners = {}; +- let add = (plugin22, type, cb) => { +- if (!this.listeners[type]) this.listeners[type] = []; +- this.listeners[type].push([plugin22, cb]); +- }; +- for (let plugin22 of this.plugins) { +- if (typeof plugin22 === "object") { +- for (let event in plugin22) { +- if (!PLUGIN_PROPS[event] && /^[A-Z]/.test(event)) { +- throw new Error( +- `Unknown event ${event} in ${plugin22.postcssPlugin}. Try to update PostCSS (${this.processor.version} now).` +- ); +- } +- if (!NOT_VISITORS[event]) { +- if (typeof plugin22[event] === "object") { +- for (let filter in plugin22[event]) { +- if (filter === "*") { +- add(plugin22, event, plugin22[event][filter]); +- } else { +- add( +- plugin22, +- event + "-" + filter.toLowerCase(), +- plugin22[event][filter] +- ); +- } +- } +- } else if (typeof plugin22[event] === "function") { +- add(plugin22, event, plugin22[event]); +- } +- } +- } +- } +- } +- this.hasListener = Object.keys(this.listeners).length > 0; +- } +- async runAsync() { +- this.plugin = 0; +- for (let i2 = 0; i2 < this.plugins.length; i2++) { +- let plugin22 = this.plugins[i2]; +- let promise = this.runOnRoot(plugin22); +- if (isPromise(promise)) { +- try { +- await promise; +- } catch (error) { +- throw this.handleError(error); +- } +- } +- } +- this.prepareVisitors(); +- if (this.hasListener) { +- let root2 = this.result.root; +- while (!root2[isClean]) { +- root2[isClean] = true; +- let stack = [toStack(root2)]; +- while (stack.length > 0) { +- let promise = this.visitTick(stack); +- if (isPromise(promise)) { +- try { +- await promise; +- } catch (e2) { +- let node2 = stack[stack.length - 1].node; +- throw this.handleError(e2, node2); +- } +- } +- } +- } +- if (this.listeners.OnceExit) { +- for (let [plugin22, visitor] of this.listeners.OnceExit) { +- this.result.lastPlugin = plugin22; +- try { +- if (root2.type === "document") { +- let roots = root2.nodes.map( +- (subRoot) => visitor(subRoot, this.helpers) +- ); +- await Promise.all(roots); +- } else { +- await visitor(root2, this.helpers); +- } +- } catch (e2) { +- throw this.handleError(e2); +- } +- } +- } +- } +- this.processed = true; +- return this.stringify(); +- } +- runOnRoot(plugin22) { +- this.result.lastPlugin = plugin22; +- try { +- if (typeof plugin22 === "object" && plugin22.Once) { +- if (this.result.root.type === "document") { +- let roots = this.result.root.nodes.map( +- (root2) => plugin22.Once(root2, this.helpers) +- ); +- if (isPromise(roots[0])) { +- return Promise.all(roots); +- } +- return roots; +- } +- return plugin22.Once(this.result.root, this.helpers); +- } else if (typeof plugin22 === "function") { +- return plugin22(this.result.root, this.result); +- } +- } catch (error) { +- throw this.handleError(error); +- } +- } +- stringify() { +- if (this.error) throw this.error; +- if (this.stringified) return this.result; +- this.stringified = true; +- this.sync(); +- let opts = this.result.opts; +- let str = stringify$2; +- if (opts.syntax) str = opts.syntax.stringify; +- if (opts.stringifier) str = opts.stringifier; +- if (str.stringify) str = str.stringify; +- let map = new MapGenerator$1(str, this.result.root, this.result.opts); +- let data = map.generate(); +- this.result.css = data[0]; +- this.result.map = data[1]; +- return this.result; +- } +- sync() { +- if (this.error) throw this.error; +- if (this.processed) return this.result; +- this.processed = true; +- if (this.processing) { +- throw this.getAsyncError(); +- } +- for (let plugin22 of this.plugins) { +- let promise = this.runOnRoot(plugin22); +- if (isPromise(promise)) { +- throw this.getAsyncError(); +- } +- } +- this.prepareVisitors(); +- if (this.hasListener) { +- let root2 = this.result.root; +- while (!root2[isClean]) { +- root2[isClean] = true; +- this.walkSync(root2); +- } +- if (this.listeners.OnceExit) { +- if (root2.type === "document") { +- for (let subRoot of root2.nodes) { +- this.visitSync(this.listeners.OnceExit, subRoot); +- } +- } else { +- this.visitSync(this.listeners.OnceExit, root2); +- } +- } +- } +- return this.result; +- } +- then(onFulfilled, onRejected) { +- if (process.env.NODE_ENV !== "production") { +- if (!("from" in this.opts)) { +- warnOnce$1( +- "Without `from` option PostCSS could generate wrong source map and will not find Browserslist config. Set it to CSS file path or to `undefined` to prevent this warning." +- ); +- } +- } +- return this.async().then(onFulfilled, onRejected); +- } +- toString() { +- return this.css; +- } +- visitSync(visitors, node2) { +- for (let [plugin22, visitor] of visitors) { +- this.result.lastPlugin = plugin22; +- let promise; +- try { +- promise = visitor(node2, this.helpers); +- } catch (e2) { +- throw this.handleError(e2, node2.proxyOf); +- } +- if (node2.type !== "root" && node2.type !== "document" && !node2.parent) { +- return true; +- } +- if (isPromise(promise)) { +- throw this.getAsyncError(); +- } +- } +- } +- visitTick(stack) { +- let visit2 = stack[stack.length - 1]; +- let { node: node2, visitors } = visit2; +- if (node2.type !== "root" && node2.type !== "document" && !node2.parent) { +- stack.pop(); +- return; +- } +- if (visitors.length > 0 && visit2.visitorIndex < visitors.length) { +- let [plugin22, visitor] = visitors[visit2.visitorIndex]; +- visit2.visitorIndex += 1; +- if (visit2.visitorIndex === visitors.length) { +- visit2.visitors = []; +- visit2.visitorIndex = 0; +- } +- this.result.lastPlugin = plugin22; +- try { +- return visitor(node2.toProxy(), this.helpers); +- } catch (e2) { +- throw this.handleError(e2, node2); +- } +- } +- if (visit2.iterator !== 0) { +- let iterator = visit2.iterator; +- let child; +- while (child = node2.nodes[node2.indexes[iterator]]) { +- node2.indexes[iterator] += 1; +- if (!child[isClean]) { +- child[isClean] = true; +- stack.push(toStack(child)); +- return; +- } +- } +- visit2.iterator = 0; +- delete node2.indexes[iterator]; +- } +- let events = visit2.events; +- while (visit2.eventIndex < events.length) { +- let event = events[visit2.eventIndex]; +- visit2.eventIndex += 1; +- if (event === CHILDREN) { +- if (node2.nodes && node2.nodes.length) { +- node2[isClean] = true; +- visit2.iterator = node2.getIterator(); +- } +- return; +- } else if (this.listeners[event]) { +- visit2.visitors = this.listeners[event]; +- return; +- } +- } +- stack.pop(); +- } +- walkSync(node2) { +- node2[isClean] = true; +- let events = getEvents(node2); +- for (let event of events) { +- if (event === CHILDREN) { +- if (node2.nodes) { +- node2.each((child) => { +- if (!child[isClean]) this.walkSync(child); +- }); +- } +- } else { +- let visitors = this.listeners[event]; +- if (visitors) { +- if (this.visitSync(visitors, node2.toProxy())) return; +- } +- } +- } +- } +- warnings() { +- return this.sync().warnings(); +- } +- get content() { +- return this.stringify().content; +- } +- get css() { +- return this.stringify().css; +- } +- get map() { +- return this.stringify().map; +- } +- get messages() { +- return this.sync().messages; +- } +- get opts() { +- return this.result.opts; +- } +- get processor() { +- return this.result.processor; +- } +- get root() { +- return this.sync().root; +- } +- get [Symbol.toStringTag]() { +- return "LazyResult"; +- } +-}; +-LazyResult$2.registerPostcss = (dependant) => { +- postcss$2 = dependant; +-}; +-var lazyResult = LazyResult$2; +-LazyResult$2.default = LazyResult$2; +-Root$3.registerLazyResult(LazyResult$2); +-Document$2.registerLazyResult(LazyResult$2); +-let MapGenerator22 = mapGenerator; +-let stringify$1 = stringify_1; +-let warnOnce22 = warnOnce$2; +-let parse$1 = parse_1; +-const Result$1 = result; +-let NoWorkResult$1 = class NoWorkResult2 { +- constructor(processor2, css, opts) { +- css = css.toString(); +- this.stringified = false; +- this._processor = processor2; +- this._css = css; +- this._opts = opts; +- this._map = void 0; +- let root2; +- let str = stringify$1; +- this.result = new Result$1(this._processor, root2, this._opts); +- this.result.css = css; +- let self = this; +- Object.defineProperty(this.result, "root", { +- get() { +- return self.root; +- } +- }); +- let map = new MapGenerator22(str, root2, this._opts, css); +- if (map.isMap()) { +- let [generatedCSS, generatedMap] = map.generate(); +- if (generatedCSS) { +- this.result.css = generatedCSS; +- } +- if (generatedMap) { +- this.result.map = generatedMap; +- } +- } else { +- map.clearAnnotation(); +- this.result.css = map.css; +- } +- } +- async() { +- if (this.error) return Promise.reject(this.error); +- return Promise.resolve(this.result); +- } +- catch(onRejected) { +- return this.async().catch(onRejected); +- } +- finally(onFinally) { +- return this.async().then(onFinally, onFinally); +- } +- sync() { +- if (this.error) throw this.error; +- return this.result; +- } +- then(onFulfilled, onRejected) { +- if (process.env.NODE_ENV !== "production") { +- if (!("from" in this._opts)) { +- warnOnce22( +- "Without `from` option PostCSS could generate wrong source map and will not find Browserslist config. Set it to CSS file path or to `undefined` to prevent this warning." +- ); +- } +- } +- return this.async().then(onFulfilled, onRejected); +- } +- toString() { +- return this._css; +- } +- warnings() { +- return []; +- } +- get content() { +- return this.result.css; +- } +- get css() { +- return this.result.css; +- } +- get map() { +- return this.result.map; +- } +- get messages() { +- return []; +- } +- get opts() { +- return this.result.opts; +- } +- get processor() { +- return this.result.processor; +- } +- get root() { +- if (this._root) { +- return this._root; +- } +- let root2; +- let parser2 = parse$1; +- try { +- root2 = parser2(this._css, this._opts); +- } catch (error) { +- this.error = error; +- } +- if (this.error) { +- throw this.error; +- } else { +- this._root = root2; +- return root2; +- } +- } +- get [Symbol.toStringTag]() { +- return "NoWorkResult"; +- } +-}; +-var noWorkResult = NoWorkResult$1; +-NoWorkResult$1.default = NoWorkResult$1; +-let NoWorkResult22 = noWorkResult; +-let LazyResult$1 = lazyResult; +-let Document$1 = document$1; +-let Root$2 = root; +-let Processor$1 = class Processor2 { +- constructor(plugins = []) { +- this.version = "8.4.38"; +- this.plugins = this.normalize(plugins); +- } +- normalize(plugins) { +- let normalized = []; +- for (let i2 of plugins) { +- if (i2.postcss === true) { +- i2 = i2(); +- } else if (i2.postcss) { +- i2 = i2.postcss; +- } +- if (typeof i2 === "object" && Array.isArray(i2.plugins)) { +- normalized = normalized.concat(i2.plugins); +- } else if (typeof i2 === "object" && i2.postcssPlugin) { +- normalized.push(i2); +- } else if (typeof i2 === "function") { +- normalized.push(i2); +- } else if (typeof i2 === "object" && (i2.parse || i2.stringify)) { +- if (process.env.NODE_ENV !== "production") { +- throw new Error( +- "PostCSS syntaxes cannot be used as plugins. Instead, please use one of the syntax/parser/stringifier options as outlined in your PostCSS runner documentation." +- ); +- } +- } else { +- throw new Error(i2 + " is not a PostCSS plugin"); +- } +- } +- return normalized; +- } +- process(css, opts = {}) { +- if (!this.plugins.length && !opts.parser && !opts.stringifier && !opts.syntax) { +- return new NoWorkResult22(this, css, opts); +- } else { +- return new LazyResult$1(this, css, opts); +- } +- } +- use(plugin22) { +- this.plugins = this.plugins.concat(this.normalize([plugin22])); +- return this; +- } +-}; +-var processor = Processor$1; +-Processor$1.default = Processor$1; +-Root$2.registerProcessor(Processor$1); +-Document$1.registerProcessor(Processor$1); +-let Declaration$1 = declaration; +-let PreviousMap22 = previousMap; +-let Comment$1 = comment; +-let AtRule$1 = atRule; +-let Input$1 = input; +-let Root$1 = root; +-let Rule$1 = rule; +-function fromJSON$1(json, inputs) { +- if (Array.isArray(json)) return json.map((n2) => fromJSON$1(n2)); +- let { inputs: ownInputs, ...defaults } = json; +- if (ownInputs) { +- inputs = []; +- for (let input2 of ownInputs) { +- let inputHydrated = { ...input2, __proto__: Input$1.prototype }; +- if (inputHydrated.map) { +- inputHydrated.map = { +- ...inputHydrated.map, +- __proto__: PreviousMap22.prototype +- }; +- } +- inputs.push(inputHydrated); +- } +- } +- if (defaults.nodes) { +- defaults.nodes = json.nodes.map((n2) => fromJSON$1(n2, inputs)); +- } +- if (defaults.source) { +- let { inputId, ...source } = defaults.source; +- defaults.source = source; +- if (inputId != null) { +- defaults.source.input = inputs[inputId]; +- } +- } +- if (defaults.type === "root") { +- return new Root$1(defaults); +- } else if (defaults.type === "decl") { +- return new Declaration$1(defaults); +- } else if (defaults.type === "rule") { +- return new Rule$1(defaults); +- } else if (defaults.type === "comment") { +- return new Comment$1(defaults); +- } else if (defaults.type === "atrule") { +- return new AtRule$1(defaults); +- } else { +- throw new Error("Unknown node type: " + json.type); +- } +-} +-var fromJSON_1 = fromJSON$1; +-fromJSON$1.default = fromJSON$1; +-let CssSyntaxError22 = cssSyntaxError; +-let Declaration22 = declaration; +-let LazyResult22 = lazyResult; +-let Container22 = container; +-let Processor22 = processor; +-let stringify = stringify_1; +-let fromJSON = fromJSON_1; +-let Document222 = document$1; +-let Warning22 = warning; +-let Comment22 = comment; +-let AtRule22 = atRule; +-let Result22 = result; +-let Input22 = input; +-let parse = parse_1; +-let list = list_1; +-let Rule22 = rule; +-let Root22 = root; +-let Node22 = node; +-function postcss(...plugins) { +- if (plugins.length === 1 && Array.isArray(plugins[0])) { +- plugins = plugins[0]; +- } +- return new Processor22(plugins); +-} +-postcss.plugin = function plugin2(name, initializer) { +- let warningPrinted = false; +- function creator(...args) { +- if (console && console.warn && !warningPrinted) { +- warningPrinted = true; +- console.warn( +- name + ": postcss.plugin was deprecated. Migration guide:\nhttps://evilmartians.com/chronicles/postcss-8-plugin-migration" +- ); +- if (process.env.LANG && process.env.LANG.startsWith("cn")) { +- console.warn( +- name + ": 里面 postcss.plugin 被弃用. 迁移指南:\nhttps://www.w3ctech.com/topic/2226" +- ); +- } +- } +- let transformer = initializer(...args); +- transformer.postcssPlugin = name; +- transformer.postcssVersion = new Processor22().version; +- return transformer; +- } +- let cache; +- Object.defineProperty(creator, "postcss", { +- get() { +- if (!cache) cache = creator(); +- return cache; +- } +- }); +- creator.process = function(css, processOpts, pluginOpts) { +- return postcss([creator(pluginOpts)]).process(css, processOpts); +- }; +- return creator; +-}; +-postcss.stringify = stringify; +-postcss.parse = parse; +-postcss.fromJSON = fromJSON; +-postcss.list = list; +-postcss.comment = (defaults) => new Comment22(defaults); +-postcss.atRule = (defaults) => new AtRule22(defaults); +-postcss.decl = (defaults) => new Declaration22(defaults); +-postcss.rule = (defaults) => new Rule22(defaults); +-postcss.root = (defaults) => new Root22(defaults); +-postcss.document = (defaults) => new Document222(defaults); +-postcss.CssSyntaxError = CssSyntaxError22; +-postcss.Declaration = Declaration22; +-postcss.Container = Container22; +-postcss.Processor = Processor22; +-postcss.Document = Document222; +-postcss.Comment = Comment22; +-postcss.Warning = Warning22; +-postcss.AtRule = AtRule22; +-postcss.Result = Result22; +-postcss.Input = Input22; +-postcss.Rule = Rule22; +-postcss.Root = Root22; +-postcss.Node = Node22; +-LazyResult22.registerPostcss(postcss); +-var postcss_1 = postcss; +-postcss.default = postcss; +-const postcss$1 = /* @__PURE__ */ getDefaultExportFromCjs(postcss_1); +-postcss$1.stringify; +-postcss$1.fromJSON; +-postcss$1.plugin; +-postcss$1.parse; +-postcss$1.list; +-postcss$1.document; +-postcss$1.comment; +-postcss$1.atRule; +-postcss$1.rule; +-postcss$1.decl; +-postcss$1.root; +-postcss$1.CssSyntaxError; +-postcss$1.Declaration; +-postcss$1.Container; +-postcss$1.Processor; +-postcss$1.Document; +-postcss$1.Comment; +-postcss$1.Warning; +-postcss$1.AtRule; +-postcss$1.Result; +-postcss$1.Input; +-postcss$1.Rule; +-postcss$1.Root; +-postcss$1.Node; + class BaseRRNode { + // eslint-disable-next-line @typescript-eslint/no-unused-vars, @typescript-eslint/no-explicit-any + constructor(..._args) { diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml index 167ca724e..ab12253a4 100644 --- a/pnpm-lock.yaml +++ b/pnpm-lock.yaml @@ -4,6 +4,11 @@ settings: autoInstallPeers: true excludeLinksFromLockfile: false +patchedDependencies: + '@rrweb/record@2.0.0-alpha.17': + hash: or7biymn4kjyhnfwbz74vqezxa + path: patches/@rrweb__record@2.0.0-alpha.17.patch + dependencies: core-js: specifier: ^3.38.1 @@ -63,7 +68,7 @@ devDependencies: version: 12.1.1(rollup@4.24.0)(tslib@2.5.0)(typescript@5.5.4) '@rrweb/record': specifier: 2.0.0-alpha.17 - version: 2.0.0-alpha.17 + version: 2.0.0-alpha.17(patch_hash=or7biymn4kjyhnfwbz74vqezxa) '@rrweb/rrweb-plugin-console-record': specifier: 2.0.0-alpha.17 version: 2.0.0-alpha.17(rrweb@2.0.0-alpha.17) @@ -2794,12 +2799,13 @@ packages: dev: true optional: true - /@rrweb/record@2.0.0-alpha.17: + /@rrweb/record@2.0.0-alpha.17(patch_hash=or7biymn4kjyhnfwbz74vqezxa): resolution: {integrity: sha512-Je+lzjeWMF8/I0IDoXFzkGPKT8j7AkaBup5YcwUHlkp18VhLVze416MvI6915teE27uUA2ScXMXzG0Yiu5VTIw==} dependencies: '@rrweb/types': 2.0.0-alpha.17 rrweb: 2.0.0-alpha.17 dev: true + patched: true /@rrweb/rrweb-plugin-console-record@2.0.0-alpha.17(rrweb@2.0.0-alpha.17): resolution: {integrity: sha512-tjNJ3wWUDMMf275xr4Rb5tVYF2UR+wXvSxnyS9tRKnRa574PQQvx7sGbqM/O9AytYjnbiTrAMqNR7OFysGCMwQ==} From ff51836ade1def1f6c620013bdb56fc13a4c90c8 Mon Sep 17 00:00:00 2001 From: Paul D'Ambra Date: Wed, 23 Oct 2024 13:08:12 +0200 Subject: [PATCH 10/21] try something --- rollup.config.js | 3 +++ 1 file changed, 3 insertions(+) diff --git a/rollup.config.js b/rollup.config.js index 648cdd8bb..7cbca7166 100644 --- a/rollup.config.js +++ b/rollup.config.js @@ -81,6 +81,9 @@ const entrypointTargets = entrypoints.map((file) => { }, ], plugins: [...pluginsForThisFile, visualizer({ filename: `bundle-stats-${fileName}.html` })], + treeshake: { + moduleSideEffects: false, // assume imported modules have no side effects, this might break things + }, } }) From 4542f55fadf3b80b4ff6d0f2ff34b51c0307807e Mon Sep 17 00:00:00 2001 From: Paul D'Ambra Date: Wed, 23 Oct 2024 13:17:39 +0200 Subject: [PATCH 11/21] try something less risky --- rollup.config.js | 5 ++--- 1 file changed, 2 insertions(+), 3 deletions(-) diff --git a/rollup.config.js b/rollup.config.js index 7cbca7166..583ce2855 100644 --- a/rollup.config.js +++ b/rollup.config.js @@ -81,9 +81,8 @@ const entrypointTargets = entrypoints.map((file) => { }, ], plugins: [...pluginsForThisFile, visualizer({ filename: `bundle-stats-${fileName}.html` })], - treeshake: { - moduleSideEffects: false, // assume imported modules have no side effects, this might break things - }, + // we know that recorder doesn't use postcss, but the bundler can't determine that + external: ['postcss'], } }) From db53c807fc8b4d0f1125a44e67df9bc557bb22fc Mon Sep 17 00:00:00 2001 From: David Newell Date: Wed, 23 Oct 2024 15:23:17 +0100 Subject: [PATCH 12/21] revert to minimal changes --- package.json | 5 +- patches/@rrweb__record@2.0.0-alpha.17.patch | 7085 ----------------- patches/rrweb@2.0.0-alpha.17.patch | 81 + playground/segment/server.js | 2 +- pnpm-lock.yaml | 28 +- .../replay/sessionrecording-utils.ts | 13 +- src/types.ts | 5 +- 7 files changed, 107 insertions(+), 7112 deletions(-) delete mode 100644 patches/@rrweb__record@2.0.0-alpha.17.patch create mode 100644 patches/rrweb@2.0.0-alpha.17.patch diff --git a/package.json b/package.json index 719f1ed9c..589235fae 100644 --- a/package.json +++ b/package.json @@ -58,7 +58,6 @@ "@rollup/plugin-node-resolve": "^15.3.0", "@rollup/plugin-terser": "^0.4.4", "@rollup/plugin-typescript": "^12.1.1", - "@rrweb/record": "2.0.0-alpha.17", "@rrweb/rrweb-plugin-console-record": "2.0.0-alpha.17", "@rrweb/types": "2.0.0-alpha.17", "@sentry/types": "8.7.0", @@ -105,6 +104,8 @@ "rollup": "^4.24.0", "rollup-plugin-dts": "^6.1.1", "rollup-plugin-visualizer": "^5.12.0", + "rrweb": "2.0.0-alpha.17", + "rrweb-snapshot": "2.0.0-alpha.17", "sinon": "9.0.2", "testcafe": "1.19.0", "testcafe-browser-provider-browserstack": "1.14.0", @@ -126,7 +127,7 @@ ], "pnpm": { "patchedDependencies": { - "@rrweb/record@2.0.0-alpha.17": "patches/@rrweb__record@2.0.0-alpha.17.patch" + "rrweb@2.0.0-alpha.17": "patches/rrweb@2.0.0-alpha.17.patch" } } } diff --git a/patches/@rrweb__record@2.0.0-alpha.17.patch b/patches/@rrweb__record@2.0.0-alpha.17.patch deleted file mode 100644 index bc9a5b25b..000000000 --- a/patches/@rrweb__record@2.0.0-alpha.17.patch +++ /dev/null @@ -1,7085 +0,0 @@ -diff --git a/dist/record.js b/dist/record.js -index 46ec389fefb698243008b39db65470dbdf0a3857..ab4f489bda64cb992c184b727a9175de7a646f2d 100644 ---- a/dist/record.js -+++ b/dist/record.js -@@ -1336,7080 +1336,6 @@ function getAugmentedNamespace$1(n2) { - }); - return a2; - } --var picocolors_browser$1 = { exports: {} }; --var x$1 = String; --var create$1 = function() { -- return { isColorSupported: false, reset: x$1, bold: x$1, dim: x$1, italic: x$1, underline: x$1, inverse: x$1, hidden: x$1, strikethrough: x$1, black: x$1, red: x$1, green: x$1, yellow: x$1, blue: x$1, magenta: x$1, cyan: x$1, white: x$1, gray: x$1, bgBlack: x$1, bgRed: x$1, bgGreen: x$1, bgYellow: x$1, bgBlue: x$1, bgMagenta: x$1, bgCyan: x$1, bgWhite: x$1 }; --}; --picocolors_browser$1.exports = create$1(); --picocolors_browser$1.exports.createColors = create$1; --var picocolors_browserExports$1 = picocolors_browser$1.exports; --const __viteBrowserExternal$2 = {}; --const __viteBrowserExternal$1$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({ -- __proto__: null, -- default: __viteBrowserExternal$2 --}, Symbol.toStringTag, { value: "Module" })); --const require$$2$1 = /* @__PURE__ */ getAugmentedNamespace$1(__viteBrowserExternal$1$1); --let pico$1 = picocolors_browserExports$1; --let terminalHighlight$1$1 = require$$2$1; --let CssSyntaxError$3$1 = class CssSyntaxError extends Error { -- constructor(message, line, column, source, file, plugin22) { -- super(message); -- this.name = "CssSyntaxError"; -- this.reason = message; -- if (file) { -- this.file = file; -- } -- if (source) { -- this.source = source; -- } -- if (plugin22) { -- this.plugin = plugin22; -- } -- if (typeof line !== "undefined" && typeof column !== "undefined") { -- if (typeof line === "number") { -- this.line = line; -- this.column = column; -- } else { -- this.line = line.line; -- this.column = line.column; -- this.endLine = column.line; -- this.endColumn = column.column; -- } -- } -- this.setMessage(); -- if (Error.captureStackTrace) { -- Error.captureStackTrace(this, CssSyntaxError); -- } -- } -- setMessage() { -- this.message = this.plugin ? this.plugin + ": " : ""; -- this.message += this.file ? this.file : ""; -- if (typeof this.line !== "undefined") { -- this.message += ":" + this.line + ":" + this.column; -- } -- this.message += ": " + this.reason; -- } -- showSourceCode(color) { -- if (!this.source) return ""; -- let css = this.source; -- if (color == null) color = pico$1.isColorSupported; -- if (terminalHighlight$1$1) { -- if (color) css = terminalHighlight$1$1(css); -- } -- let lines = css.split(/\r?\n/); -- let start = Math.max(this.line - 3, 0); -- let end = Math.min(this.line + 2, lines.length); -- let maxWidth = String(end).length; -- let mark, aside; -- if (color) { -- let { bold, gray, red } = pico$1.createColors(true); -- mark = (text) => bold(red(text)); -- aside = (text) => gray(text); -- } else { -- mark = aside = (str) => str; -- } -- return lines.slice(start, end).map((line, index2) => { -- let number = start + 1 + index2; -- let gutter = " " + (" " + number).slice(-maxWidth) + " | "; -- if (number === this.line) { -- let spacing = aside(gutter.replace(/\d/g, " ")) + line.slice(0, this.column - 1).replace(/[^\t]/g, " "); -- return mark(">") + aside(gutter) + line + "\n " + spacing + mark("^"); -- } -- return " " + aside(gutter) + line; -- }).join("\n"); -- } -- toString() { -- let code = this.showSourceCode(); -- if (code) { -- code = "\n\n" + code + "\n"; -- } -- return this.name + ": " + this.message + code; -- } --}; --var cssSyntaxError$1 = CssSyntaxError$3$1; --CssSyntaxError$3$1.default = CssSyntaxError$3$1; --var symbols$1 = {}; --symbols$1.isClean = Symbol("isClean"); --symbols$1.my = Symbol("my"); --const DEFAULT_RAW$1 = { -- after: "\n", -- beforeClose: "\n", -- beforeComment: "\n", -- beforeDecl: "\n", -- beforeOpen: " ", -- beforeRule: "\n", -- colon: ": ", -- commentLeft: " ", -- commentRight: " ", -- emptyBody: "", -- indent: " ", -- semicolon: false --}; --function capitalize$1(str) { -- return str[0].toUpperCase() + str.slice(1); --} --let Stringifier$2$1 = class Stringifier { -- constructor(builder) { -- this.builder = builder; -- } -- atrule(node2, semicolon) { -- let name = "@" + node2.name; -- let params = node2.params ? this.rawValue(node2, "params") : ""; -- if (typeof node2.raws.afterName !== "undefined") { -- name += node2.raws.afterName; -- } else if (params) { -- name += " "; -- } -- if (node2.nodes) { -- this.block(node2, name + params); -- } else { -- let end = (node2.raws.between || "") + (semicolon ? ";" : ""); -- this.builder(name + params + end, node2); -- } -- } -- beforeAfter(node2, detect) { -- let value; -- if (node2.type === "decl") { -- value = this.raw(node2, null, "beforeDecl"); -- } else if (node2.type === "comment") { -- value = this.raw(node2, null, "beforeComment"); -- } else if (detect === "before") { -- value = this.raw(node2, null, "beforeRule"); -- } else { -- value = this.raw(node2, null, "beforeClose"); -- } -- let buf = node2.parent; -- let depth = 0; -- while (buf && buf.type !== "root") { -- depth += 1; -- buf = buf.parent; -- } -- if (value.includes("\n")) { -- let indent = this.raw(node2, null, "indent"); -- if (indent.length) { -- for (let step = 0; step < depth; step++) value += indent; -- } -- } -- return value; -- } -- block(node2, start) { -- let between = this.raw(node2, "between", "beforeOpen"); -- this.builder(start + between + "{", node2, "start"); -- let after; -- if (node2.nodes && node2.nodes.length) { -- this.body(node2); -- after = this.raw(node2, "after"); -- } else { -- after = this.raw(node2, "after", "emptyBody"); -- } -- if (after) this.builder(after); -- this.builder("}", node2, "end"); -- } -- body(node2) { -- let last = node2.nodes.length - 1; -- while (last > 0) { -- if (node2.nodes[last].type !== "comment") break; -- last -= 1; -- } -- let semicolon = this.raw(node2, "semicolon"); -- for (let i2 = 0; i2 < node2.nodes.length; i2++) { -- let child = node2.nodes[i2]; -- let before = this.raw(child, "before"); -- if (before) this.builder(before); -- this.stringify(child, last !== i2 || semicolon); -- } -- } -- comment(node2) { -- let left = this.raw(node2, "left", "commentLeft"); -- let right = this.raw(node2, "right", "commentRight"); -- this.builder("/*" + left + node2.text + right + "*/", node2); -- } -- decl(node2, semicolon) { -- let between = this.raw(node2, "between", "colon"); -- let string = node2.prop + between + this.rawValue(node2, "value"); -- if (node2.important) { -- string += node2.raws.important || " !important"; -- } -- if (semicolon) string += ";"; -- this.builder(string, node2); -- } -- document(node2) { -- this.body(node2); -- } -- raw(node2, own, detect) { -- let value; -- if (!detect) detect = own; -- if (own) { -- value = node2.raws[own]; -- if (typeof value !== "undefined") return value; -- } -- let parent = node2.parent; -- if (detect === "before") { -- if (!parent || parent.type === "root" && parent.first === node2) { -- return ""; -- } -- if (parent && parent.type === "document") { -- return ""; -- } -- } -- if (!parent) return DEFAULT_RAW$1[detect]; -- let root2 = node2.root(); -- if (!root2.rawCache) root2.rawCache = {}; -- if (typeof root2.rawCache[detect] !== "undefined") { -- return root2.rawCache[detect]; -- } -- if (detect === "before" || detect === "after") { -- return this.beforeAfter(node2, detect); -- } else { -- let method = "raw" + capitalize$1(detect); -- if (this[method]) { -- value = this[method](root2, node2); -- } else { -- root2.walk((i2) => { -- value = i2.raws[own]; -- if (typeof value !== "undefined") return false; -- }); -- } -- } -- if (typeof value === "undefined") value = DEFAULT_RAW$1[detect]; -- root2.rawCache[detect] = value; -- return value; -- } -- rawBeforeClose(root2) { -- let value; -- root2.walk((i2) => { -- if (i2.nodes && i2.nodes.length > 0) { -- if (typeof i2.raws.after !== "undefined") { -- value = i2.raws.after; -- if (value.includes("\n")) { -- value = value.replace(/[^\n]+$/, ""); -- } -- return false; -- } -- } -- }); -- if (value) value = value.replace(/\S/g, ""); -- return value; -- } -- rawBeforeComment(root2, node2) { -- let value; -- root2.walkComments((i2) => { -- if (typeof i2.raws.before !== "undefined") { -- value = i2.raws.before; -- if (value.includes("\n")) { -- value = value.replace(/[^\n]+$/, ""); -- } -- return false; -- } -- }); -- if (typeof value === "undefined") { -- value = this.raw(node2, null, "beforeDecl"); -- } else if (value) { -- value = value.replace(/\S/g, ""); -- } -- return value; -- } -- rawBeforeDecl(root2, node2) { -- let value; -- root2.walkDecls((i2) => { -- if (typeof i2.raws.before !== "undefined") { -- value = i2.raws.before; -- if (value.includes("\n")) { -- value = value.replace(/[^\n]+$/, ""); -- } -- return false; -- } -- }); -- if (typeof value === "undefined") { -- value = this.raw(node2, null, "beforeRule"); -- } else if (value) { -- value = value.replace(/\S/g, ""); -- } -- return value; -- } -- rawBeforeOpen(root2) { -- let value; -- root2.walk((i2) => { -- if (i2.type !== "decl") { -- value = i2.raws.between; -- if (typeof value !== "undefined") return false; -- } -- }); -- return value; -- } -- rawBeforeRule(root2) { -- let value; -- root2.walk((i2) => { -- if (i2.nodes && (i2.parent !== root2 || root2.first !== i2)) { -- if (typeof i2.raws.before !== "undefined") { -- value = i2.raws.before; -- if (value.includes("\n")) { -- value = value.replace(/[^\n]+$/, ""); -- } -- return false; -- } -- } -- }); -- if (value) value = value.replace(/\S/g, ""); -- return value; -- } -- rawColon(root2) { -- let value; -- root2.walkDecls((i2) => { -- if (typeof i2.raws.between !== "undefined") { -- value = i2.raws.between.replace(/[^\s:]/g, ""); -- return false; -- } -- }); -- return value; -- } -- rawEmptyBody(root2) { -- let value; -- root2.walk((i2) => { -- if (i2.nodes && i2.nodes.length === 0) { -- value = i2.raws.after; -- if (typeof value !== "undefined") return false; -- } -- }); -- return value; -- } -- rawIndent(root2) { -- if (root2.raws.indent) return root2.raws.indent; -- let value; -- root2.walk((i2) => { -- let p = i2.parent; -- if (p && p !== root2 && p.parent && p.parent === root2) { -- if (typeof i2.raws.before !== "undefined") { -- let parts = i2.raws.before.split("\n"); -- value = parts[parts.length - 1]; -- value = value.replace(/\S/g, ""); -- return false; -- } -- } -- }); -- return value; -- } -- rawSemicolon(root2) { -- let value; -- root2.walk((i2) => { -- if (i2.nodes && i2.nodes.length && i2.last.type === "decl") { -- value = i2.raws.semicolon; -- if (typeof value !== "undefined") return false; -- } -- }); -- return value; -- } -- rawValue(node2, prop) { -- let value = node2[prop]; -- let raw = node2.raws[prop]; -- if (raw && raw.value === value) { -- return raw.raw; -- } -- return value; -- } -- root(node2) { -- this.body(node2); -- if (node2.raws.after) this.builder(node2.raws.after); -- } -- rule(node2) { -- this.block(node2, this.rawValue(node2, "selector")); -- if (node2.raws.ownSemicolon) { -- this.builder(node2.raws.ownSemicolon, node2, "end"); -- } -- } -- stringify(node2, semicolon) { -- if (!this[node2.type]) { -- throw new Error( -- "Unknown AST node type " + node2.type + ". Maybe you need to change PostCSS stringifier." -- ); -- } -- this[node2.type](node2, semicolon); -- } --}; --var stringifier$1 = Stringifier$2$1; --Stringifier$2$1.default = Stringifier$2$1; --let Stringifier$1$1 = stringifier$1; --function stringify$4$1(node2, builder) { -- let str = new Stringifier$1$1(builder); -- str.stringify(node2); --} --var stringify_1$1 = stringify$4$1; --stringify$4$1.default = stringify$4$1; --let { isClean: isClean$2$1, my: my$2$1 } = symbols$1; --let CssSyntaxError$2$1 = cssSyntaxError$1; --let Stringifier2$1 = stringifier$1; --let stringify$3$1 = stringify_1$1; --function cloneNode$1(obj, parent) { -- let cloned = new obj.constructor(); -- for (let i2 in obj) { -- if (!Object.prototype.hasOwnProperty.call(obj, i2)) { -- continue; -- } -- if (i2 === "proxyCache") continue; -- let value = obj[i2]; -- let type = typeof value; -- if (i2 === "parent" && type === "object") { -- if (parent) cloned[i2] = parent; -- } else if (i2 === "source") { -- cloned[i2] = value; -- } else if (Array.isArray(value)) { -- cloned[i2] = value.map((j) => cloneNode$1(j, cloned)); -- } else { -- if (type === "object" && value !== null) value = cloneNode$1(value); -- cloned[i2] = value; -- } -- } -- return cloned; --} --let Node$4$1 = class Node2 { -- constructor(defaults = {}) { -- this.raws = {}; -- this[isClean$2$1] = false; -- this[my$2$1] = true; -- for (let name in defaults) { -- if (name === "nodes") { -- this.nodes = []; -- for (let node2 of defaults[name]) { -- if (typeof node2.clone === "function") { -- this.append(node2.clone()); -- } else { -- this.append(node2); -- } -- } -- } else { -- this[name] = defaults[name]; -- } -- } -- } -- addToError(error) { -- error.postcssNode = this; -- if (error.stack && this.source && /\n\s{4}at /.test(error.stack)) { -- let s2 = this.source; -- error.stack = error.stack.replace( -- /\n\s{4}at /, -- `$&${s2.input.from}:${s2.start.line}:${s2.start.column}$&` -- ); -- } -- return error; -- } -- after(add) { -- this.parent.insertAfter(this, add); -- return this; -- } -- assign(overrides = {}) { -- for (let name in overrides) { -- this[name] = overrides[name]; -- } -- return this; -- } -- before(add) { -- this.parent.insertBefore(this, add); -- return this; -- } -- cleanRaws(keepBetween) { -- delete this.raws.before; -- delete this.raws.after; -- if (!keepBetween) delete this.raws.between; -- } -- clone(overrides = {}) { -- let cloned = cloneNode$1(this); -- for (let name in overrides) { -- cloned[name] = overrides[name]; -- } -- return cloned; -- } -- cloneAfter(overrides = {}) { -- let cloned = this.clone(overrides); -- this.parent.insertAfter(this, cloned); -- return cloned; -- } -- cloneBefore(overrides = {}) { -- let cloned = this.clone(overrides); -- this.parent.insertBefore(this, cloned); -- return cloned; -- } -- error(message, opts = {}) { -- if (this.source) { -- let { end, start } = this.rangeBy(opts); -- return this.source.input.error( -- message, -- { column: start.column, line: start.line }, -- { column: end.column, line: end.line }, -- opts -- ); -- } -- return new CssSyntaxError$2$1(message); -- } -- getProxyProcessor() { -- return { -- get(node2, prop) { -- if (prop === "proxyOf") { -- return node2; -- } else if (prop === "root") { -- return () => node2.root().toProxy(); -- } else { -- return node2[prop]; -- } -- }, -- set(node2, prop, value) { -- if (node2[prop] === value) return true; -- node2[prop] = value; -- if (prop === "prop" || prop === "value" || prop === "name" || prop === "params" || prop === "important" || /* c8 ignore next */ -- prop === "text") { -- node2.markDirty(); -- } -- return true; -- } -- }; -- } -- markDirty() { -- if (this[isClean$2$1]) { -- this[isClean$2$1] = false; -- let next = this; -- while (next = next.parent) { -- next[isClean$2$1] = false; -- } -- } -- } -- next() { -- if (!this.parent) return void 0; -- let index2 = this.parent.index(this); -- return this.parent.nodes[index2 + 1]; -- } -- positionBy(opts, stringRepresentation) { -- let pos = this.source.start; -- if (opts.index) { -- pos = this.positionInside(opts.index, stringRepresentation); -- } else if (opts.word) { -- stringRepresentation = this.toString(); -- let index2 = stringRepresentation.indexOf(opts.word); -- if (index2 !== -1) pos = this.positionInside(index2, stringRepresentation); -- } -- return pos; -- } -- positionInside(index2, stringRepresentation) { -- let string = stringRepresentation || this.toString(); -- let column = this.source.start.column; -- let line = this.source.start.line; -- for (let i2 = 0; i2 < index2; i2++) { -- if (string[i2] === "\n") { -- column = 1; -- line += 1; -- } else { -- column += 1; -- } -- } -- return { column, line }; -- } -- prev() { -- if (!this.parent) return void 0; -- let index2 = this.parent.index(this); -- return this.parent.nodes[index2 - 1]; -- } -- rangeBy(opts) { -- let start = { -- column: this.source.start.column, -- line: this.source.start.line -- }; -- let end = this.source.end ? { -- column: this.source.end.column + 1, -- line: this.source.end.line -- } : { -- column: start.column + 1, -- line: start.line -- }; -- if (opts.word) { -- let stringRepresentation = this.toString(); -- let index2 = stringRepresentation.indexOf(opts.word); -- if (index2 !== -1) { -- start = this.positionInside(index2, stringRepresentation); -- end = this.positionInside(index2 + opts.word.length, stringRepresentation); -- } -- } else { -- if (opts.start) { -- start = { -- column: opts.start.column, -- line: opts.start.line -- }; -- } else if (opts.index) { -- start = this.positionInside(opts.index); -- } -- if (opts.end) { -- end = { -- column: opts.end.column, -- line: opts.end.line -- }; -- } else if (typeof opts.endIndex === "number") { -- end = this.positionInside(opts.endIndex); -- } else if (opts.index) { -- end = this.positionInside(opts.index + 1); -- } -- } -- if (end.line < start.line || end.line === start.line && end.column <= start.column) { -- end = { column: start.column + 1, line: start.line }; -- } -- return { end, start }; -- } -- raw(prop, defaultType) { -- let str = new Stringifier2$1(); -- return str.raw(this, prop, defaultType); -- } -- remove() { -- if (this.parent) { -- this.parent.removeChild(this); -- } -- this.parent = void 0; -- return this; -- } -- replaceWith(...nodes) { -- if (this.parent) { -- let bookmark = this; -- let foundSelf = false; -- for (let node2 of nodes) { -- if (node2 === this) { -- foundSelf = true; -- } else if (foundSelf) { -- this.parent.insertAfter(bookmark, node2); -- bookmark = node2; -- } else { -- this.parent.insertBefore(bookmark, node2); -- } -- } -- if (!foundSelf) { -- this.remove(); -- } -- } -- return this; -- } -- root() { -- let result2 = this; -- while (result2.parent && result2.parent.type !== "document") { -- result2 = result2.parent; -- } -- return result2; -- } -- toJSON(_, inputs) { -- let fixed = {}; -- let emitInputs = inputs == null; -- inputs = inputs || /* @__PURE__ */ new Map(); -- let inputsNextIndex = 0; -- for (let name in this) { -- if (!Object.prototype.hasOwnProperty.call(this, name)) { -- continue; -- } -- if (name === "parent" || name === "proxyCache") continue; -- let value = this[name]; -- if (Array.isArray(value)) { -- fixed[name] = value.map((i2) => { -- if (typeof i2 === "object" && i2.toJSON) { -- return i2.toJSON(null, inputs); -- } else { -- return i2; -- } -- }); -- } else if (typeof value === "object" && value.toJSON) { -- fixed[name] = value.toJSON(null, inputs); -- } else if (name === "source") { -- let inputId = inputs.get(value.input); -- if (inputId == null) { -- inputId = inputsNextIndex; -- inputs.set(value.input, inputsNextIndex); -- inputsNextIndex++; -- } -- fixed[name] = { -- end: value.end, -- inputId, -- start: value.start -- }; -- } else { -- fixed[name] = value; -- } -- } -- if (emitInputs) { -- fixed.inputs = [...inputs.keys()].map((input2) => input2.toJSON()); -- } -- return fixed; -- } -- toProxy() { -- if (!this.proxyCache) { -- this.proxyCache = new Proxy(this, this.getProxyProcessor()); -- } -- return this.proxyCache; -- } -- toString(stringifier2 = stringify$3$1) { -- if (stringifier2.stringify) stringifier2 = stringifier2.stringify; -- let result2 = ""; -- stringifier2(this, (i2) => { -- result2 += i2; -- }); -- return result2; -- } -- warn(result2, text, opts) { -- let data = { node: this }; -- for (let i2 in opts) data[i2] = opts[i2]; -- return result2.warn(text, data); -- } -- get proxyOf() { -- return this; -- } --}; --var node$1 = Node$4$1; --Node$4$1.default = Node$4$1; --let Node$3$1 = node$1; --let Declaration$4$1 = class Declaration extends Node$3$1 { -- constructor(defaults) { -- if (defaults && typeof defaults.value !== "undefined" && typeof defaults.value !== "string") { -- defaults = { ...defaults, value: String(defaults.value) }; -- } -- super(defaults); -- this.type = "decl"; -- } -- get variable() { -- return this.prop.startsWith("--") || this.prop[0] === "$"; -- } --}; --var declaration$1 = Declaration$4$1; --Declaration$4$1.default = Declaration$4$1; --let urlAlphabet$1 = "useandom-26T198340PX75pxJACKVERYMINDBUSHWOLF_GQZbfghjklqvwyzrict"; --let customAlphabet$1 = (alphabet, defaultSize = 21) => { -- return (size = defaultSize) => { -- let id = ""; -- let i2 = size; -- while (i2--) { -- id += alphabet[Math.random() * alphabet.length | 0]; -- } -- return id; -- }; --}; --let nanoid$1$1 = (size = 21) => { -- let id = ""; -- let i2 = size; -- while (i2--) { -- id += urlAlphabet$1[Math.random() * 64 | 0]; -- } -- return id; --}; --var nonSecure$1 = { nanoid: nanoid$1$1, customAlphabet: customAlphabet$1 }; --let { SourceMapConsumer: SourceMapConsumer$2$1, SourceMapGenerator: SourceMapGenerator$2$1 } = require$$2$1; --let { existsSync: existsSync$1, readFileSync: readFileSync$1 } = require$$2$1; --let { dirname: dirname$1$1, join: join$1 } = require$$2$1; --function fromBase64$1(str) { -- if (Buffer) { -- return Buffer.from(str, "base64").toString(); -- } else { -- return window.atob(str); -- } --} --let PreviousMap$2$1 = class PreviousMap { -- constructor(css, opts) { -- if (opts.map === false) return; -- this.loadAnnotation(css); -- this.inline = this.startWith(this.annotation, "data:"); -- let prev = opts.map ? opts.map.prev : void 0; -- let text = this.loadMap(opts.from, prev); -- if (!this.mapFile && opts.from) { -- this.mapFile = opts.from; -- } -- if (this.mapFile) this.root = dirname$1$1(this.mapFile); -- if (text) this.text = text; -- } -- consumer() { -- if (!this.consumerCache) { -- this.consumerCache = new SourceMapConsumer$2$1(this.text); -- } -- return this.consumerCache; -- } -- decodeInline(text) { -- let baseCharsetUri = /^data:application\/json;charset=utf-?8;base64,/; -- let baseUri = /^data:application\/json;base64,/; -- let charsetUri = /^data:application\/json;charset=utf-?8,/; -- let uri = /^data:application\/json,/; -- if (charsetUri.test(text) || uri.test(text)) { -- return decodeURIComponent(text.substr(RegExp.lastMatch.length)); -- } -- if (baseCharsetUri.test(text) || baseUri.test(text)) { -- return fromBase64$1(text.substr(RegExp.lastMatch.length)); -- } -- let encoding = text.match(/data:application\/json;([^,]+),/)[1]; -- throw new Error("Unsupported source map encoding " + encoding); -- } -- getAnnotationURL(sourceMapString) { -- return sourceMapString.replace(/^\/\*\s*# sourceMappingURL=/, "").trim(); -- } -- isMap(map) { -- if (typeof map !== "object") return false; -- return typeof map.mappings === "string" || typeof map._mappings === "string" || Array.isArray(map.sections); -- } -- loadAnnotation(css) { -- let comments = css.match(/\/\*\s*# sourceMappingURL=/gm); -- if (!comments) return; -- let start = css.lastIndexOf(comments.pop()); -- let end = css.indexOf("*/", start); -- if (start > -1 && end > -1) { -- this.annotation = this.getAnnotationURL(css.substring(start, end)); -- } -- } -- loadFile(path) { -- this.root = dirname$1$1(path); -- if (existsSync$1(path)) { -- this.mapFile = path; -- return readFileSync$1(path, "utf-8").toString().trim(); -- } -- } -- loadMap(file, prev) { -- if (prev === false) return false; -- if (prev) { -- if (typeof prev === "string") { -- return prev; -- } else if (typeof prev === "function") { -- let prevPath = prev(file); -- if (prevPath) { -- let map = this.loadFile(prevPath); -- if (!map) { -- throw new Error( -- "Unable to load previous source map: " + prevPath.toString() -- ); -- } -- return map; -- } -- } else if (prev instanceof SourceMapConsumer$2$1) { -- return SourceMapGenerator$2$1.fromSourceMap(prev).toString(); -- } else if (prev instanceof SourceMapGenerator$2$1) { -- return prev.toString(); -- } else if (this.isMap(prev)) { -- return JSON.stringify(prev); -- } else { -- throw new Error( -- "Unsupported previous source map format: " + prev.toString() -- ); -- } -- } else if (this.inline) { -- return this.decodeInline(this.annotation); -- } else if (this.annotation) { -- let map = this.annotation; -- if (file) map = join$1(dirname$1$1(file), map); -- return this.loadFile(map); -- } -- } -- startWith(string, start) { -- if (!string) return false; -- return string.substr(0, start.length) === start; -- } -- withContent() { -- return !!(this.consumer().sourcesContent && this.consumer().sourcesContent.length > 0); -- } --}; --var previousMap$1 = PreviousMap$2$1; --PreviousMap$2$1.default = PreviousMap$2$1; --let { SourceMapConsumer: SourceMapConsumer$1$1, SourceMapGenerator: SourceMapGenerator$1$1 } = require$$2$1; --let { fileURLToPath: fileURLToPath$1, pathToFileURL: pathToFileURL$1$1 } = require$$2$1; --let { isAbsolute: isAbsolute$1, resolve: resolve$1$1 } = require$$2$1; --let { nanoid: nanoid$2 } = nonSecure$1; --let terminalHighlight$2 = require$$2$1; --let CssSyntaxError$1$1 = cssSyntaxError$1; --let PreviousMap$1$1 = previousMap$1; --let fromOffsetCache$1 = Symbol("fromOffsetCache"); --let sourceMapAvailable$1$1 = Boolean(SourceMapConsumer$1$1 && SourceMapGenerator$1$1); --let pathAvailable$1$1 = Boolean(resolve$1$1 && isAbsolute$1); --let Input$4$1 = class Input { -- constructor(css, opts = {}) { -- if (css === null || typeof css === "undefined" || typeof css === "object" && !css.toString) { -- throw new Error(`PostCSS received ${css} instead of CSS string`); -- } -- this.css = css.toString(); -- if (this.css[0] === "\uFEFF" || this.css[0] === "￾") { -- this.hasBOM = true; -- this.css = this.css.slice(1); -- } else { -- this.hasBOM = false; -- } -- if (opts.from) { -- if (!pathAvailable$1$1 || /^\w+:\/\//.test(opts.from) || isAbsolute$1(opts.from)) { -- this.file = opts.from; -- } else { -- this.file = resolve$1$1(opts.from); -- } -- } -- if (pathAvailable$1$1 && sourceMapAvailable$1$1) { -- let map = new PreviousMap$1$1(this.css, opts); -- if (map.text) { -- this.map = map; -- let file = map.consumer().file; -- if (!this.file && file) this.file = this.mapResolve(file); -- } -- } -- if (!this.file) { -- this.id = ""; -- } -- if (this.map) this.map.file = this.from; -- } -- error(message, line, column, opts = {}) { -- let result2, endLine, endColumn; -- if (line && typeof line === "object") { -- let start = line; -- let end = column; -- if (typeof start.offset === "number") { -- let pos = this.fromOffset(start.offset); -- line = pos.line; -- column = pos.col; -- } else { -- line = start.line; -- column = start.column; -- } -- if (typeof end.offset === "number") { -- let pos = this.fromOffset(end.offset); -- endLine = pos.line; -- endColumn = pos.col; -- } else { -- endLine = end.line; -- endColumn = end.column; -- } -- } else if (!column) { -- let pos = this.fromOffset(line); -- line = pos.line; -- column = pos.col; -- } -- let origin = this.origin(line, column, endLine, endColumn); -- if (origin) { -- result2 = new CssSyntaxError$1$1( -- message, -- origin.endLine === void 0 ? origin.line : { column: origin.column, line: origin.line }, -- origin.endLine === void 0 ? origin.column : { column: origin.endColumn, line: origin.endLine }, -- origin.source, -- origin.file, -- opts.plugin -- ); -- } else { -- result2 = new CssSyntaxError$1$1( -- message, -- endLine === void 0 ? line : { column, line }, -- endLine === void 0 ? column : { column: endColumn, line: endLine }, -- this.css, -- this.file, -- opts.plugin -- ); -- } -- result2.input = { column, endColumn, endLine, line, source: this.css }; -- if (this.file) { -- if (pathToFileURL$1$1) { -- result2.input.url = pathToFileURL$1$1(this.file).toString(); -- } -- result2.input.file = this.file; -- } -- return result2; -- } -- fromOffset(offset) { -- let lastLine, lineToIndex; -- if (!this[fromOffsetCache$1]) { -- let lines = this.css.split("\n"); -- lineToIndex = new Array(lines.length); -- let prevIndex = 0; -- for (let i2 = 0, l2 = lines.length; i2 < l2; i2++) { -- lineToIndex[i2] = prevIndex; -- prevIndex += lines[i2].length + 1; -- } -- this[fromOffsetCache$1] = lineToIndex; -- } else { -- lineToIndex = this[fromOffsetCache$1]; -- } -- lastLine = lineToIndex[lineToIndex.length - 1]; -- let min = 0; -- if (offset >= lastLine) { -- min = lineToIndex.length - 1; -- } else { -- let max = lineToIndex.length - 2; -- let mid; -- while (min < max) { -- mid = min + (max - min >> 1); -- if (offset < lineToIndex[mid]) { -- max = mid - 1; -- } else if (offset >= lineToIndex[mid + 1]) { -- min = mid + 1; -- } else { -- min = mid; -- break; -- } -- } -- } -- return { -- col: offset - lineToIndex[min] + 1, -- line: min + 1 -- }; -- } -- mapResolve(file) { -- if (/^\w+:\/\//.test(file)) { -- return file; -- } -- return resolve$1$1(this.map.consumer().sourceRoot || this.map.root || ".", file); -- } -- origin(line, column, endLine, endColumn) { -- if (!this.map) return false; -- let consumer = this.map.consumer(); -- let from = consumer.originalPositionFor({ column, line }); -- if (!from.source) return false; -- let to; -- if (typeof endLine === "number") { -- to = consumer.originalPositionFor({ column: endColumn, line: endLine }); -- } -- let fromUrl; -- if (isAbsolute$1(from.source)) { -- fromUrl = pathToFileURL$1$1(from.source); -- } else { -- fromUrl = new URL( -- from.source, -- this.map.consumer().sourceRoot || pathToFileURL$1$1(this.map.mapFile) -- ); -- } -- let result2 = { -- column: from.column, -- endColumn: to && to.column, -- endLine: to && to.line, -- line: from.line, -- url: fromUrl.toString() -- }; -- if (fromUrl.protocol === "file:") { -- if (fileURLToPath$1) { -- result2.file = fileURLToPath$1(fromUrl); -- } else { -- throw new Error(`file: protocol is not available in this PostCSS build`); -- } -- } -- let source = consumer.sourceContentFor(from.source); -- if (source) result2.source = source; -- return result2; -- } -- toJSON() { -- let json = {}; -- for (let name of ["hasBOM", "css", "file", "id"]) { -- if (this[name] != null) { -- json[name] = this[name]; -- } -- } -- if (this.map) { -- json.map = { ...this.map }; -- if (json.map.consumerCache) { -- json.map.consumerCache = void 0; -- } -- } -- return json; -- } -- get from() { -- return this.file || this.id; -- } --}; --var input$1 = Input$4$1; --Input$4$1.default = Input$4$1; --if (terminalHighlight$2 && terminalHighlight$2.registerInput) { -- terminalHighlight$2.registerInput(Input$4$1); --} --let { SourceMapConsumer: SourceMapConsumer$3, SourceMapGenerator: SourceMapGenerator$3 } = require$$2$1; --let { dirname: dirname$2, relative: relative$1, resolve: resolve$2, sep: sep$1 } = require$$2$1; --let { pathToFileURL: pathToFileURL$2 } = require$$2$1; --let Input$3$1 = input$1; --let sourceMapAvailable$2 = Boolean(SourceMapConsumer$3 && SourceMapGenerator$3); --let pathAvailable$2 = Boolean(dirname$2 && resolve$2 && relative$1 && sep$1); --let MapGenerator$2$1 = class MapGenerator { -- constructor(stringify2, root2, opts, cssString) { -- this.stringify = stringify2; -- this.mapOpts = opts.map || {}; -- this.root = root2; -- this.opts = opts; -- this.css = cssString; -- this.originalCSS = cssString; -- this.usesFileUrls = !this.mapOpts.from && this.mapOpts.absolute; -- this.memoizedFileURLs = /* @__PURE__ */ new Map(); -- this.memoizedPaths = /* @__PURE__ */ new Map(); -- this.memoizedURLs = /* @__PURE__ */ new Map(); -- } -- addAnnotation() { -- let content; -- if (this.isInline()) { -- content = "data:application/json;base64," + this.toBase64(this.map.toString()); -- } else if (typeof this.mapOpts.annotation === "string") { -- content = this.mapOpts.annotation; -- } else if (typeof this.mapOpts.annotation === "function") { -- content = this.mapOpts.annotation(this.opts.to, this.root); -- } else { -- content = this.outputFile() + ".map"; -- } -- let eol = "\n"; -- if (this.css.includes("\r\n")) eol = "\r\n"; -- this.css += eol + "/*# sourceMappingURL=" + content + " */"; -- } -- applyPrevMaps() { -- for (let prev of this.previous()) { -- let from = this.toUrl(this.path(prev.file)); -- let root2 = prev.root || dirname$2(prev.file); -- let map; -- if (this.mapOpts.sourcesContent === false) { -- map = new SourceMapConsumer$3(prev.text); -- if (map.sourcesContent) { -- map.sourcesContent = null; -- } -- } else { -- map = prev.consumer(); -- } -- this.map.applySourceMap(map, from, this.toUrl(this.path(root2))); -- } -- } -- clearAnnotation() { -- if (this.mapOpts.annotation === false) return; -- if (this.root) { -- let node2; -- for (let i2 = this.root.nodes.length - 1; i2 >= 0; i2--) { -- node2 = this.root.nodes[i2]; -- if (node2.type !== "comment") continue; -- if (node2.text.indexOf("# sourceMappingURL=") === 0) { -- this.root.removeChild(i2); -- } -- } -- } else if (this.css) { -- this.css = this.css.replace(/\n*?\/\*#[\S\s]*?\*\/$/gm, ""); -- } -- } -- generate() { -- this.clearAnnotation(); -- if (pathAvailable$2 && sourceMapAvailable$2 && this.isMap()) { -- return this.generateMap(); -- } else { -- let result2 = ""; -- this.stringify(this.root, (i2) => { -- result2 += i2; -- }); -- return [result2]; -- } -- } -- generateMap() { -- if (this.root) { -- this.generateString(); -- } else if (this.previous().length === 1) { -- let prev = this.previous()[0].consumer(); -- prev.file = this.outputFile(); -- this.map = SourceMapGenerator$3.fromSourceMap(prev, { -- ignoreInvalidMapping: true -- }); -- } else { -- this.map = new SourceMapGenerator$3({ -- file: this.outputFile(), -- ignoreInvalidMapping: true -- }); -- this.map.addMapping({ -- generated: { column: 0, line: 1 }, -- original: { column: 0, line: 1 }, -- source: this.opts.from ? this.toUrl(this.path(this.opts.from)) : "" -- }); -- } -- if (this.isSourcesContent()) this.setSourcesContent(); -- if (this.root && this.previous().length > 0) this.applyPrevMaps(); -- if (this.isAnnotation()) this.addAnnotation(); -- if (this.isInline()) { -- return [this.css]; -- } else { -- return [this.css, this.map]; -- } -- } -- generateString() { -- this.css = ""; -- this.map = new SourceMapGenerator$3({ -- file: this.outputFile(), -- ignoreInvalidMapping: true -- }); -- let line = 1; -- let column = 1; -- let noSource = ""; -- let mapping = { -- generated: { column: 0, line: 0 }, -- original: { column: 0, line: 0 }, -- source: "" -- }; -- let lines, last; -- this.stringify(this.root, (str, node2, type) => { -- this.css += str; -- if (node2 && type !== "end") { -- mapping.generated.line = line; -- mapping.generated.column = column - 1; -- if (node2.source && node2.source.start) { -- mapping.source = this.sourcePath(node2); -- mapping.original.line = node2.source.start.line; -- mapping.original.column = node2.source.start.column - 1; -- this.map.addMapping(mapping); -- } else { -- mapping.source = noSource; -- mapping.original.line = 1; -- mapping.original.column = 0; -- this.map.addMapping(mapping); -- } -- } -- lines = str.match(/\n/g); -- if (lines) { -- line += lines.length; -- last = str.lastIndexOf("\n"); -- column = str.length - last; -- } else { -- column += str.length; -- } -- if (node2 && type !== "start") { -- let p = node2.parent || { raws: {} }; -- let childless = node2.type === "decl" || node2.type === "atrule" && !node2.nodes; -- if (!childless || node2 !== p.last || p.raws.semicolon) { -- if (node2.source && node2.source.end) { -- mapping.source = this.sourcePath(node2); -- mapping.original.line = node2.source.end.line; -- mapping.original.column = node2.source.end.column - 1; -- mapping.generated.line = line; -- mapping.generated.column = column - 2; -- this.map.addMapping(mapping); -- } else { -- mapping.source = noSource; -- mapping.original.line = 1; -- mapping.original.column = 0; -- mapping.generated.line = line; -- mapping.generated.column = column - 1; -- this.map.addMapping(mapping); -- } -- } -- } -- }); -- } -- isAnnotation() { -- if (this.isInline()) { -- return true; -- } -- if (typeof this.mapOpts.annotation !== "undefined") { -- return this.mapOpts.annotation; -- } -- if (this.previous().length) { -- return this.previous().some((i2) => i2.annotation); -- } -- return true; -- } -- isInline() { -- if (typeof this.mapOpts.inline !== "undefined") { -- return this.mapOpts.inline; -- } -- let annotation = this.mapOpts.annotation; -- if (typeof annotation !== "undefined" && annotation !== true) { -- return false; -- } -- if (this.previous().length) { -- return this.previous().some((i2) => i2.inline); -- } -- return true; -- } -- isMap() { -- if (typeof this.opts.map !== "undefined") { -- return !!this.opts.map; -- } -- return this.previous().length > 0; -- } -- isSourcesContent() { -- if (typeof this.mapOpts.sourcesContent !== "undefined") { -- return this.mapOpts.sourcesContent; -- } -- if (this.previous().length) { -- return this.previous().some((i2) => i2.withContent()); -- } -- return true; -- } -- outputFile() { -- if (this.opts.to) { -- return this.path(this.opts.to); -- } else if (this.opts.from) { -- return this.path(this.opts.from); -- } else { -- return "to.css"; -- } -- } -- path(file) { -- if (this.mapOpts.absolute) return file; -- if (file.charCodeAt(0) === 60) return file; -- if (/^\w+:\/\//.test(file)) return file; -- let cached = this.memoizedPaths.get(file); -- if (cached) return cached; -- let from = this.opts.to ? dirname$2(this.opts.to) : "."; -- if (typeof this.mapOpts.annotation === "string") { -- from = dirname$2(resolve$2(from, this.mapOpts.annotation)); -- } -- let path = relative$1(from, file); -- this.memoizedPaths.set(file, path); -- return path; -- } -- previous() { -- if (!this.previousMaps) { -- this.previousMaps = []; -- if (this.root) { -- this.root.walk((node2) => { -- if (node2.source && node2.source.input.map) { -- let map = node2.source.input.map; -- if (!this.previousMaps.includes(map)) { -- this.previousMaps.push(map); -- } -- } -- }); -- } else { -- let input2 = new Input$3$1(this.originalCSS, this.opts); -- if (input2.map) this.previousMaps.push(input2.map); -- } -- } -- return this.previousMaps; -- } -- setSourcesContent() { -- let already = {}; -- if (this.root) { -- this.root.walk((node2) => { -- if (node2.source) { -- let from = node2.source.input.from; -- if (from && !already[from]) { -- already[from] = true; -- let fromUrl = this.usesFileUrls ? this.toFileUrl(from) : this.toUrl(this.path(from)); -- this.map.setSourceContent(fromUrl, node2.source.input.css); -- } -- } -- }); -- } else if (this.css) { -- let from = this.opts.from ? this.toUrl(this.path(this.opts.from)) : ""; -- this.map.setSourceContent(from, this.css); -- } -- } -- sourcePath(node2) { -- if (this.mapOpts.from) { -- return this.toUrl(this.mapOpts.from); -- } else if (this.usesFileUrls) { -- return this.toFileUrl(node2.source.input.from); -- } else { -- return this.toUrl(this.path(node2.source.input.from)); -- } -- } -- toBase64(str) { -- if (Buffer) { -- return Buffer.from(str).toString("base64"); -- } else { -- return window.btoa(unescape(encodeURIComponent(str))); -- } -- } -- toFileUrl(path) { -- let cached = this.memoizedFileURLs.get(path); -- if (cached) return cached; -- if (pathToFileURL$2) { -- let fileURL = pathToFileURL$2(path).toString(); -- this.memoizedFileURLs.set(path, fileURL); -- return fileURL; -- } else { -- throw new Error( -- "`map.absolute` option is not available in this PostCSS build" -- ); -- } -- } -- toUrl(path) { -- let cached = this.memoizedURLs.get(path); -- if (cached) return cached; -- if (sep$1 === "\\") { -- path = path.replace(/\\/g, "/"); -- } -- let url = encodeURI(path).replace(/[#?]/g, encodeURIComponent); -- this.memoizedURLs.set(path, url); -- return url; -- } --}; --var mapGenerator$1 = MapGenerator$2$1; --let Node$2$1 = node$1; --let Comment$4$1 = class Comment extends Node$2$1 { -- constructor(defaults) { -- super(defaults); -- this.type = "comment"; -- } --}; --var comment$1 = Comment$4$1; --Comment$4$1.default = Comment$4$1; --let { isClean: isClean$1$1, my: my$1$1 } = symbols$1; --let Declaration$3$1 = declaration$1; --let Comment$3$1 = comment$1; --let Node$1$1 = node$1; --let parse$4$1, Rule$4$1, AtRule$4$1, Root$6$1; --function cleanSource$1(nodes) { -- return nodes.map((i2) => { -- if (i2.nodes) i2.nodes = cleanSource$1(i2.nodes); -- delete i2.source; -- return i2; -- }); --} --function markDirtyUp$1(node2) { -- node2[isClean$1$1] = false; -- if (node2.proxyOf.nodes) { -- for (let i2 of node2.proxyOf.nodes) { -- markDirtyUp$1(i2); -- } -- } --} --let Container$7$1 = class Container extends Node$1$1 { -- append(...children) { -- for (let child of children) { -- let nodes = this.normalize(child, this.last); -- for (let node2 of nodes) this.proxyOf.nodes.push(node2); -- } -- this.markDirty(); -- return this; -- } -- cleanRaws(keepBetween) { -- super.cleanRaws(keepBetween); -- if (this.nodes) { -- for (let node2 of this.nodes) node2.cleanRaws(keepBetween); -- } -- } -- each(callback) { -- if (!this.proxyOf.nodes) return void 0; -- let iterator = this.getIterator(); -- let index2, result2; -- while (this.indexes[iterator] < this.proxyOf.nodes.length) { -- index2 = this.indexes[iterator]; -- result2 = callback(this.proxyOf.nodes[index2], index2); -- if (result2 === false) break; -- this.indexes[iterator] += 1; -- } -- delete this.indexes[iterator]; -- return result2; -- } -- every(condition) { -- return this.nodes.every(condition); -- } -- getIterator() { -- if (!this.lastEach) this.lastEach = 0; -- if (!this.indexes) this.indexes = {}; -- this.lastEach += 1; -- let iterator = this.lastEach; -- this.indexes[iterator] = 0; -- return iterator; -- } -- getProxyProcessor() { -- return { -- get(node2, prop) { -- if (prop === "proxyOf") { -- return node2; -- } else if (!node2[prop]) { -- return node2[prop]; -- } else if (prop === "each" || typeof prop === "string" && prop.startsWith("walk")) { -- return (...args) => { -- return node2[prop]( -- ...args.map((i2) => { -- if (typeof i2 === "function") { -- return (child, index2) => i2(child.toProxy(), index2); -- } else { -- return i2; -- } -- }) -- ); -- }; -- } else if (prop === "every" || prop === "some") { -- return (cb) => { -- return node2[prop]( -- (child, ...other) => cb(child.toProxy(), ...other) -- ); -- }; -- } else if (prop === "root") { -- return () => node2.root().toProxy(); -- } else if (prop === "nodes") { -- return node2.nodes.map((i2) => i2.toProxy()); -- } else if (prop === "first" || prop === "last") { -- return node2[prop].toProxy(); -- } else { -- return node2[prop]; -- } -- }, -- set(node2, prop, value) { -- if (node2[prop] === value) return true; -- node2[prop] = value; -- if (prop === "name" || prop === "params" || prop === "selector") { -- node2.markDirty(); -- } -- return true; -- } -- }; -- } -- index(child) { -- if (typeof child === "number") return child; -- if (child.proxyOf) child = child.proxyOf; -- return this.proxyOf.nodes.indexOf(child); -- } -- insertAfter(exist, add) { -- let existIndex = this.index(exist); -- let nodes = this.normalize(add, this.proxyOf.nodes[existIndex]).reverse(); -- existIndex = this.index(exist); -- for (let node2 of nodes) this.proxyOf.nodes.splice(existIndex + 1, 0, node2); -- let index2; -- for (let id in this.indexes) { -- index2 = this.indexes[id]; -- if (existIndex < index2) { -- this.indexes[id] = index2 + nodes.length; -- } -- } -- this.markDirty(); -- return this; -- } -- insertBefore(exist, add) { -- let existIndex = this.index(exist); -- let type = existIndex === 0 ? "prepend" : false; -- let nodes = this.normalize(add, this.proxyOf.nodes[existIndex], type).reverse(); -- existIndex = this.index(exist); -- for (let node2 of nodes) this.proxyOf.nodes.splice(existIndex, 0, node2); -- let index2; -- for (let id in this.indexes) { -- index2 = this.indexes[id]; -- if (existIndex <= index2) { -- this.indexes[id] = index2 + nodes.length; -- } -- } -- this.markDirty(); -- return this; -- } -- normalize(nodes, sample) { -- if (typeof nodes === "string") { -- nodes = cleanSource$1(parse$4$1(nodes).nodes); -- } else if (typeof nodes === "undefined") { -- nodes = []; -- } else if (Array.isArray(nodes)) { -- nodes = nodes.slice(0); -- for (let i2 of nodes) { -- if (i2.parent) i2.parent.removeChild(i2, "ignore"); -- } -- } else if (nodes.type === "root" && this.type !== "document") { -- nodes = nodes.nodes.slice(0); -- for (let i2 of nodes) { -- if (i2.parent) i2.parent.removeChild(i2, "ignore"); -- } -- } else if (nodes.type) { -- nodes = [nodes]; -- } else if (nodes.prop) { -- if (typeof nodes.value === "undefined") { -- throw new Error("Value field is missed in node creation"); -- } else if (typeof nodes.value !== "string") { -- nodes.value = String(nodes.value); -- } -- nodes = [new Declaration$3$1(nodes)]; -- } else if (nodes.selector) { -- nodes = [new Rule$4$1(nodes)]; -- } else if (nodes.name) { -- nodes = [new AtRule$4$1(nodes)]; -- } else if (nodes.text) { -- nodes = [new Comment$3$1(nodes)]; -- } else { -- throw new Error("Unknown node type in node creation"); -- } -- let processed = nodes.map((i2) => { -- if (!i2[my$1$1]) Container.rebuild(i2); -- i2 = i2.proxyOf; -- if (i2.parent) i2.parent.removeChild(i2); -- if (i2[isClean$1$1]) markDirtyUp$1(i2); -- if (typeof i2.raws.before === "undefined") { -- if (sample && typeof sample.raws.before !== "undefined") { -- i2.raws.before = sample.raws.before.replace(/\S/g, ""); -- } -- } -- i2.parent = this.proxyOf; -- return i2; -- }); -- return processed; -- } -- prepend(...children) { -- children = children.reverse(); -- for (let child of children) { -- let nodes = this.normalize(child, this.first, "prepend").reverse(); -- for (let node2 of nodes) this.proxyOf.nodes.unshift(node2); -- for (let id in this.indexes) { -- this.indexes[id] = this.indexes[id] + nodes.length; -- } -- } -- this.markDirty(); -- return this; -- } -- push(child) { -- child.parent = this; -- this.proxyOf.nodes.push(child); -- return this; -- } -- removeAll() { -- for (let node2 of this.proxyOf.nodes) node2.parent = void 0; -- this.proxyOf.nodes = []; -- this.markDirty(); -- return this; -- } -- removeChild(child) { -- child = this.index(child); -- this.proxyOf.nodes[child].parent = void 0; -- this.proxyOf.nodes.splice(child, 1); -- let index2; -- for (let id in this.indexes) { -- index2 = this.indexes[id]; -- if (index2 >= child) { -- this.indexes[id] = index2 - 1; -- } -- } -- this.markDirty(); -- return this; -- } -- replaceValues(pattern, opts, callback) { -- if (!callback) { -- callback = opts; -- opts = {}; -- } -- this.walkDecls((decl) => { -- if (opts.props && !opts.props.includes(decl.prop)) return; -- if (opts.fast && !decl.value.includes(opts.fast)) return; -- decl.value = decl.value.replace(pattern, callback); -- }); -- this.markDirty(); -- return this; -- } -- some(condition) { -- return this.nodes.some(condition); -- } -- walk(callback) { -- return this.each((child, i2) => { -- let result2; -- try { -- result2 = callback(child, i2); -- } catch (e2) { -- throw child.addToError(e2); -- } -- if (result2 !== false && child.walk) { -- result2 = child.walk(callback); -- } -- return result2; -- }); -- } -- walkAtRules(name, callback) { -- if (!callback) { -- callback = name; -- return this.walk((child, i2) => { -- if (child.type === "atrule") { -- return callback(child, i2); -- } -- }); -- } -- if (name instanceof RegExp) { -- return this.walk((child, i2) => { -- if (child.type === "atrule" && name.test(child.name)) { -- return callback(child, i2); -- } -- }); -- } -- return this.walk((child, i2) => { -- if (child.type === "atrule" && child.name === name) { -- return callback(child, i2); -- } -- }); -- } -- walkComments(callback) { -- return this.walk((child, i2) => { -- if (child.type === "comment") { -- return callback(child, i2); -- } -- }); -- } -- walkDecls(prop, callback) { -- if (!callback) { -- callback = prop; -- return this.walk((child, i2) => { -- if (child.type === "decl") { -- return callback(child, i2); -- } -- }); -- } -- if (prop instanceof RegExp) { -- return this.walk((child, i2) => { -- if (child.type === "decl" && prop.test(child.prop)) { -- return callback(child, i2); -- } -- }); -- } -- return this.walk((child, i2) => { -- if (child.type === "decl" && child.prop === prop) { -- return callback(child, i2); -- } -- }); -- } -- walkRules(selector, callback) { -- if (!callback) { -- callback = selector; -- return this.walk((child, i2) => { -- if (child.type === "rule") { -- return callback(child, i2); -- } -- }); -- } -- if (selector instanceof RegExp) { -- return this.walk((child, i2) => { -- if (child.type === "rule" && selector.test(child.selector)) { -- return callback(child, i2); -- } -- }); -- } -- return this.walk((child, i2) => { -- if (child.type === "rule" && child.selector === selector) { -- return callback(child, i2); -- } -- }); -- } -- get first() { -- if (!this.proxyOf.nodes) return void 0; -- return this.proxyOf.nodes[0]; -- } -- get last() { -- if (!this.proxyOf.nodes) return void 0; -- return this.proxyOf.nodes[this.proxyOf.nodes.length - 1]; -- } --}; --Container$7$1.registerParse = (dependant) => { -- parse$4$1 = dependant; --}; --Container$7$1.registerRule = (dependant) => { -- Rule$4$1 = dependant; --}; --Container$7$1.registerAtRule = (dependant) => { -- AtRule$4$1 = dependant; --}; --Container$7$1.registerRoot = (dependant) => { -- Root$6$1 = dependant; --}; --var container$1 = Container$7$1; --Container$7$1.default = Container$7$1; --Container$7$1.rebuild = (node2) => { -- if (node2.type === "atrule") { -- Object.setPrototypeOf(node2, AtRule$4$1.prototype); -- } else if (node2.type === "rule") { -- Object.setPrototypeOf(node2, Rule$4$1.prototype); -- } else if (node2.type === "decl") { -- Object.setPrototypeOf(node2, Declaration$3$1.prototype); -- } else if (node2.type === "comment") { -- Object.setPrototypeOf(node2, Comment$3$1.prototype); -- } else if (node2.type === "root") { -- Object.setPrototypeOf(node2, Root$6$1.prototype); -- } -- node2[my$1$1] = true; -- if (node2.nodes) { -- node2.nodes.forEach((child) => { -- Container$7$1.rebuild(child); -- }); -- } --}; --let Container$6$1 = container$1; --let LazyResult$4$1, Processor$3$1; --let Document$3$1 = class Document2 extends Container$6$1 { -- constructor(defaults) { -- super({ type: "document", ...defaults }); -- if (!this.nodes) { -- this.nodes = []; -- } -- } -- toResult(opts = {}) { -- let lazy = new LazyResult$4$1(new Processor$3$1(), this, opts); -- return lazy.stringify(); -- } --}; --Document$3$1.registerLazyResult = (dependant) => { -- LazyResult$4$1 = dependant; --}; --Document$3$1.registerProcessor = (dependant) => { -- Processor$3$1 = dependant; --}; --var document$1$1 = Document$3$1; --Document$3$1.default = Document$3$1; --let printed$1 = {}; --var warnOnce$2$1 = function warnOnce(message) { -- if (printed$1[message]) return; -- printed$1[message] = true; -- if (typeof console !== "undefined" && console.warn) { -- console.warn(message); -- } --}; --let Warning$2$1 = class Warning { -- constructor(text, opts = {}) { -- this.type = "warning"; -- this.text = text; -- if (opts.node && opts.node.source) { -- let range = opts.node.rangeBy(opts); -- this.line = range.start.line; -- this.column = range.start.column; -- this.endLine = range.end.line; -- this.endColumn = range.end.column; -- } -- for (let opt in opts) this[opt] = opts[opt]; -- } -- toString() { -- if (this.node) { -- return this.node.error(this.text, { -- index: this.index, -- plugin: this.plugin, -- word: this.word -- }).message; -- } -- if (this.plugin) { -- return this.plugin + ": " + this.text; -- } -- return this.text; -- } --}; --var warning$1 = Warning$2$1; --Warning$2$1.default = Warning$2$1; --let Warning$1$1 = warning$1; --let Result$3$1 = class Result { -- constructor(processor2, root2, opts) { -- this.processor = processor2; -- this.messages = []; -- this.root = root2; -- this.opts = opts; -- this.css = void 0; -- this.map = void 0; -- } -- toString() { -- return this.css; -- } -- warn(text, opts = {}) { -- if (!opts.plugin) { -- if (this.lastPlugin && this.lastPlugin.postcssPlugin) { -- opts.plugin = this.lastPlugin.postcssPlugin; -- } -- } -- let warning2 = new Warning$1$1(text, opts); -- this.messages.push(warning2); -- return warning2; -- } -- warnings() { -- return this.messages.filter((i2) => i2.type === "warning"); -- } -- get content() { -- return this.css; -- } --}; --var result$1 = Result$3$1; --Result$3$1.default = Result$3$1; --const SINGLE_QUOTE$1 = "'".charCodeAt(0); --const DOUBLE_QUOTE$1 = '"'.charCodeAt(0); --const BACKSLASH$1 = "\\".charCodeAt(0); --const SLASH$1 = "/".charCodeAt(0); --const NEWLINE$1 = "\n".charCodeAt(0); --const SPACE$1 = " ".charCodeAt(0); --const FEED$1 = "\f".charCodeAt(0); --const TAB$1 = " ".charCodeAt(0); --const CR$1 = "\r".charCodeAt(0); --const OPEN_SQUARE$1 = "[".charCodeAt(0); --const CLOSE_SQUARE$1 = "]".charCodeAt(0); --const OPEN_PARENTHESES$1 = "(".charCodeAt(0); --const CLOSE_PARENTHESES$1 = ")".charCodeAt(0); --const OPEN_CURLY$1 = "{".charCodeAt(0); --const CLOSE_CURLY$1 = "}".charCodeAt(0); --const SEMICOLON$1 = ";".charCodeAt(0); --const ASTERISK$1 = "*".charCodeAt(0); --const COLON$1 = ":".charCodeAt(0); --const AT$1 = "@".charCodeAt(0); --const RE_AT_END$1 = /[\t\n\f\r "#'()/;[\\\]{}]/g; --const RE_WORD_END$1 = /[\t\n\f\r !"#'():;@[\\\]{}]|\/(?=\*)/g; --const RE_BAD_BRACKET$1 = /.[\r\n"'(/\\]/; --const RE_HEX_ESCAPE$1 = /[\da-f]/i; --var tokenize$1 = function tokenizer(input2, options = {}) { -- let css = input2.css.valueOf(); -- let ignore = options.ignoreErrors; -- let code, next, quote, content, escape; -- let escaped, escapePos, prev, n2, currentToken; -- let length = css.length; -- let pos = 0; -- let buffer = []; -- let returned = []; -- function position() { -- return pos; -- } -- function unclosed(what) { -- throw input2.error("Unclosed " + what, pos); -- } -- function endOfFile() { -- return returned.length === 0 && pos >= length; -- } -- function nextToken(opts) { -- if (returned.length) return returned.pop(); -- if (pos >= length) return; -- let ignoreUnclosed = opts ? opts.ignoreUnclosed : false; -- code = css.charCodeAt(pos); -- switch (code) { -- case NEWLINE$1: -- case SPACE$1: -- case TAB$1: -- case CR$1: -- case FEED$1: { -- next = pos; -- do { -- next += 1; -- code = css.charCodeAt(next); -- } while (code === SPACE$1 || code === NEWLINE$1 || code === TAB$1 || code === CR$1 || code === FEED$1); -- currentToken = ["space", css.slice(pos, next)]; -- pos = next - 1; -- break; -- } -- case OPEN_SQUARE$1: -- case CLOSE_SQUARE$1: -- case OPEN_CURLY$1: -- case CLOSE_CURLY$1: -- case COLON$1: -- case SEMICOLON$1: -- case CLOSE_PARENTHESES$1: { -- let controlChar = String.fromCharCode(code); -- currentToken = [controlChar, controlChar, pos]; -- break; -- } -- case OPEN_PARENTHESES$1: { -- prev = buffer.length ? buffer.pop()[1] : ""; -- n2 = css.charCodeAt(pos + 1); -- if (prev === "url" && n2 !== SINGLE_QUOTE$1 && n2 !== DOUBLE_QUOTE$1 && n2 !== SPACE$1 && n2 !== NEWLINE$1 && n2 !== TAB$1 && n2 !== FEED$1 && n2 !== CR$1) { -- next = pos; -- do { -- escaped = false; -- next = css.indexOf(")", next + 1); -- if (next === -1) { -- if (ignore || ignoreUnclosed) { -- next = pos; -- break; -- } else { -- unclosed("bracket"); -- } -- } -- escapePos = next; -- while (css.charCodeAt(escapePos - 1) === BACKSLASH$1) { -- escapePos -= 1; -- escaped = !escaped; -- } -- } while (escaped); -- currentToken = ["brackets", css.slice(pos, next + 1), pos, next]; -- pos = next; -- } else { -- next = css.indexOf(")", pos + 1); -- content = css.slice(pos, next + 1); -- if (next === -1 || RE_BAD_BRACKET$1.test(content)) { -- currentToken = ["(", "(", pos]; -- } else { -- currentToken = ["brackets", content, pos, next]; -- pos = next; -- } -- } -- break; -- } -- case SINGLE_QUOTE$1: -- case DOUBLE_QUOTE$1: { -- quote = code === SINGLE_QUOTE$1 ? "'" : '"'; -- next = pos; -- do { -- escaped = false; -- next = css.indexOf(quote, next + 1); -- if (next === -1) { -- if (ignore || ignoreUnclosed) { -- next = pos + 1; -- break; -- } else { -- unclosed("string"); -- } -- } -- escapePos = next; -- while (css.charCodeAt(escapePos - 1) === BACKSLASH$1) { -- escapePos -= 1; -- escaped = !escaped; -- } -- } while (escaped); -- currentToken = ["string", css.slice(pos, next + 1), pos, next]; -- pos = next; -- break; -- } -- case AT$1: { -- RE_AT_END$1.lastIndex = pos + 1; -- RE_AT_END$1.test(css); -- if (RE_AT_END$1.lastIndex === 0) { -- next = css.length - 1; -- } else { -- next = RE_AT_END$1.lastIndex - 2; -- } -- currentToken = ["at-word", css.slice(pos, next + 1), pos, next]; -- pos = next; -- break; -- } -- case BACKSLASH$1: { -- next = pos; -- escape = true; -- while (css.charCodeAt(next + 1) === BACKSLASH$1) { -- next += 1; -- escape = !escape; -- } -- code = css.charCodeAt(next + 1); -- if (escape && code !== SLASH$1 && code !== SPACE$1 && code !== NEWLINE$1 && code !== TAB$1 && code !== CR$1 && code !== FEED$1) { -- next += 1; -- if (RE_HEX_ESCAPE$1.test(css.charAt(next))) { -- while (RE_HEX_ESCAPE$1.test(css.charAt(next + 1))) { -- next += 1; -- } -- if (css.charCodeAt(next + 1) === SPACE$1) { -- next += 1; -- } -- } -- } -- currentToken = ["word", css.slice(pos, next + 1), pos, next]; -- pos = next; -- break; -- } -- default: { -- if (code === SLASH$1 && css.charCodeAt(pos + 1) === ASTERISK$1) { -- next = css.indexOf("*/", pos + 2) + 1; -- if (next === 0) { -- if (ignore || ignoreUnclosed) { -- next = css.length; -- } else { -- unclosed("comment"); -- } -- } -- currentToken = ["comment", css.slice(pos, next + 1), pos, next]; -- pos = next; -- } else { -- RE_WORD_END$1.lastIndex = pos + 1; -- RE_WORD_END$1.test(css); -- if (RE_WORD_END$1.lastIndex === 0) { -- next = css.length - 1; -- } else { -- next = RE_WORD_END$1.lastIndex - 2; -- } -- currentToken = ["word", css.slice(pos, next + 1), pos, next]; -- buffer.push(currentToken); -- pos = next; -- } -- break; -- } -- } -- pos++; -- return currentToken; -- } -- function back(token) { -- returned.push(token); -- } -- return { -- back, -- endOfFile, -- nextToken, -- position -- }; --}; --let Container$5$1 = container$1; --let AtRule$3$1 = class AtRule extends Container$5$1 { -- constructor(defaults) { -- super(defaults); -- this.type = "atrule"; -- } -- append(...children) { -- if (!this.proxyOf.nodes) this.nodes = []; -- return super.append(...children); -- } -- prepend(...children) { -- if (!this.proxyOf.nodes) this.nodes = []; -- return super.prepend(...children); -- } --}; --var atRule$1 = AtRule$3$1; --AtRule$3$1.default = AtRule$3$1; --Container$5$1.registerAtRule(AtRule$3$1); --let Container$4$1 = container$1; --let LazyResult$3$1, Processor$2$1; --let Root$5$1 = class Root extends Container$4$1 { -- constructor(defaults) { -- super(defaults); -- this.type = "root"; -- if (!this.nodes) this.nodes = []; -- } -- normalize(child, sample, type) { -- let nodes = super.normalize(child); -- if (sample) { -- if (type === "prepend") { -- if (this.nodes.length > 1) { -- sample.raws.before = this.nodes[1].raws.before; -- } else { -- delete sample.raws.before; -- } -- } else if (this.first !== sample) { -- for (let node2 of nodes) { -- node2.raws.before = sample.raws.before; -- } -- } -- } -- return nodes; -- } -- removeChild(child, ignore) { -- let index2 = this.index(child); -- if (!ignore && index2 === 0 && this.nodes.length > 1) { -- this.nodes[1].raws.before = this.nodes[index2].raws.before; -- } -- return super.removeChild(child); -- } -- toResult(opts = {}) { -- let lazy = new LazyResult$3$1(new Processor$2$1(), this, opts); -- return lazy.stringify(); -- } --}; --Root$5$1.registerLazyResult = (dependant) => { -- LazyResult$3$1 = dependant; --}; --Root$5$1.registerProcessor = (dependant) => { -- Processor$2$1 = dependant; --}; --var root$1 = Root$5$1; --Root$5$1.default = Root$5$1; --Container$4$1.registerRoot(Root$5$1); --let list$2$1 = { -- comma(string) { -- return list$2$1.split(string, [","], true); -- }, -- space(string) { -- let spaces = [" ", "\n", " "]; -- return list$2$1.split(string, spaces); -- }, -- split(string, separators, last) { -- let array = []; -- let current = ""; -- let split = false; -- let func = 0; -- let inQuote = false; -- let prevQuote = ""; -- let escape = false; -- for (let letter of string) { -- if (escape) { -- escape = false; -- } else if (letter === "\\") { -- escape = true; -- } else if (inQuote) { -- if (letter === prevQuote) { -- inQuote = false; -- } -- } else if (letter === '"' || letter === "'") { -- inQuote = true; -- prevQuote = letter; -- } else if (letter === "(") { -- func += 1; -- } else if (letter === ")") { -- if (func > 0) func -= 1; -- } else if (func === 0) { -- if (separators.includes(letter)) split = true; -- } -- if (split) { -- if (current !== "") array.push(current.trim()); -- current = ""; -- split = false; -- } else { -- current += letter; -- } -- } -- if (last || current !== "") array.push(current.trim()); -- return array; -- } --}; --var list_1$1 = list$2$1; --list$2$1.default = list$2$1; --let Container$3$1 = container$1; --let list$1$1 = list_1$1; --let Rule$3$1 = class Rule extends Container$3$1 { -- constructor(defaults) { -- super(defaults); -- this.type = "rule"; -- if (!this.nodes) this.nodes = []; -- } -- get selectors() { -- return list$1$1.comma(this.selector); -- } -- set selectors(values) { -- let match = this.selector ? this.selector.match(/,\s*/) : null; -- let sep2 = match ? match[0] : "," + this.raw("between", "beforeOpen"); -- this.selector = values.join(sep2); -- } --}; --var rule$1 = Rule$3$1; --Rule$3$1.default = Rule$3$1; --Container$3$1.registerRule(Rule$3$1); --let Declaration$2$1 = declaration$1; --let tokenizer2$1 = tokenize$1; --let Comment$2$1 = comment$1; --let AtRule$2$1 = atRule$1; --let Root$4$1 = root$1; --let Rule$2$1 = rule$1; --const SAFE_COMMENT_NEIGHBOR$1 = { -- empty: true, -- space: true --}; --function findLastWithPosition$1(tokens) { -- for (let i2 = tokens.length - 1; i2 >= 0; i2--) { -- let token = tokens[i2]; -- let pos = token[3] || token[2]; -- if (pos) return pos; -- } --} --let Parser$1$1 = class Parser { -- constructor(input2) { -- this.input = input2; -- this.root = new Root$4$1(); -- this.current = this.root; -- this.spaces = ""; -- this.semicolon = false; -- this.createTokenizer(); -- this.root.source = { input: input2, start: { column: 1, line: 1, offset: 0 } }; -- } -- atrule(token) { -- let node2 = new AtRule$2$1(); -- node2.name = token[1].slice(1); -- if (node2.name === "") { -- this.unnamedAtrule(node2, token); -- } -- this.init(node2, token[2]); -- let type; -- let prev; -- let shift; -- let last = false; -- let open = false; -- let params = []; -- let brackets = []; -- while (!this.tokenizer.endOfFile()) { -- token = this.tokenizer.nextToken(); -- type = token[0]; -- if (type === "(" || type === "[") { -- brackets.push(type === "(" ? ")" : "]"); -- } else if (type === "{" && brackets.length > 0) { -- brackets.push("}"); -- } else if (type === brackets[brackets.length - 1]) { -- brackets.pop(); -- } -- if (brackets.length === 0) { -- if (type === ";") { -- node2.source.end = this.getPosition(token[2]); -- node2.source.end.offset++; -- this.semicolon = true; -- break; -- } else if (type === "{") { -- open = true; -- break; -- } else if (type === "}") { -- if (params.length > 0) { -- shift = params.length - 1; -- prev = params[shift]; -- while (prev && prev[0] === "space") { -- prev = params[--shift]; -- } -- if (prev) { -- node2.source.end = this.getPosition(prev[3] || prev[2]); -- node2.source.end.offset++; -- } -- } -- this.end(token); -- break; -- } else { -- params.push(token); -- } -- } else { -- params.push(token); -- } -- if (this.tokenizer.endOfFile()) { -- last = true; -- break; -- } -- } -- node2.raws.between = this.spacesAndCommentsFromEnd(params); -- if (params.length) { -- node2.raws.afterName = this.spacesAndCommentsFromStart(params); -- this.raw(node2, "params", params); -- if (last) { -- token = params[params.length - 1]; -- node2.source.end = this.getPosition(token[3] || token[2]); -- node2.source.end.offset++; -- this.spaces = node2.raws.between; -- node2.raws.between = ""; -- } -- } else { -- node2.raws.afterName = ""; -- node2.params = ""; -- } -- if (open) { -- node2.nodes = []; -- this.current = node2; -- } -- } -- checkMissedSemicolon(tokens) { -- let colon = this.colon(tokens); -- if (colon === false) return; -- let founded = 0; -- let token; -- for (let j = colon - 1; j >= 0; j--) { -- token = tokens[j]; -- if (token[0] !== "space") { -- founded += 1; -- if (founded === 2) break; -- } -- } -- throw this.input.error( -- "Missed semicolon", -- token[0] === "word" ? token[3] + 1 : token[2] -- ); -- } -- colon(tokens) { -- let brackets = 0; -- let token, type, prev; -- for (let [i2, element] of tokens.entries()) { -- token = element; -- type = token[0]; -- if (type === "(") { -- brackets += 1; -- } -- if (type === ")") { -- brackets -= 1; -- } -- if (brackets === 0 && type === ":") { -- if (!prev) { -- this.doubleColon(token); -- } else if (prev[0] === "word" && prev[1] === "progid") { -- continue; -- } else { -- return i2; -- } -- } -- prev = token; -- } -- return false; -- } -- comment(token) { -- let node2 = new Comment$2$1(); -- this.init(node2, token[2]); -- node2.source.end = this.getPosition(token[3] || token[2]); -- node2.source.end.offset++; -- let text = token[1].slice(2, -2); -- if (/^\s*$/.test(text)) { -- node2.text = ""; -- node2.raws.left = text; -- node2.raws.right = ""; -- } else { -- let match = text.match(/^(\s*)([^]*\S)(\s*)$/); -- node2.text = match[2]; -- node2.raws.left = match[1]; -- node2.raws.right = match[3]; -- } -- } -- createTokenizer() { -- this.tokenizer = tokenizer2$1(this.input); -- } -- decl(tokens, customProperty) { -- let node2 = new Declaration$2$1(); -- this.init(node2, tokens[0][2]); -- let last = tokens[tokens.length - 1]; -- if (last[0] === ";") { -- this.semicolon = true; -- tokens.pop(); -- } -- node2.source.end = this.getPosition( -- last[3] || last[2] || findLastWithPosition$1(tokens) -- ); -- node2.source.end.offset++; -- while (tokens[0][0] !== "word") { -- if (tokens.length === 1) this.unknownWord(tokens); -- node2.raws.before += tokens.shift()[1]; -- } -- node2.source.start = this.getPosition(tokens[0][2]); -- node2.prop = ""; -- while (tokens.length) { -- let type = tokens[0][0]; -- if (type === ":" || type === "space" || type === "comment") { -- break; -- } -- node2.prop += tokens.shift()[1]; -- } -- node2.raws.between = ""; -- let token; -- while (tokens.length) { -- token = tokens.shift(); -- if (token[0] === ":") { -- node2.raws.between += token[1]; -- break; -- } else { -- if (token[0] === "word" && /\w/.test(token[1])) { -- this.unknownWord([token]); -- } -- node2.raws.between += token[1]; -- } -- } -- if (node2.prop[0] === "_" || node2.prop[0] === "*") { -- node2.raws.before += node2.prop[0]; -- node2.prop = node2.prop.slice(1); -- } -- let firstSpaces = []; -- let next; -- while (tokens.length) { -- next = tokens[0][0]; -- if (next !== "space" && next !== "comment") break; -- firstSpaces.push(tokens.shift()); -- } -- this.precheckMissedSemicolon(tokens); -- for (let i2 = tokens.length - 1; i2 >= 0; i2--) { -- token = tokens[i2]; -- if (token[1].toLowerCase() === "!important") { -- node2.important = true; -- let string = this.stringFrom(tokens, i2); -- string = this.spacesFromEnd(tokens) + string; -- if (string !== " !important") node2.raws.important = string; -- break; -- } else if (token[1].toLowerCase() === "important") { -- let cache = tokens.slice(0); -- let str = ""; -- for (let j = i2; j > 0; j--) { -- let type = cache[j][0]; -- if (str.trim().indexOf("!") === 0 && type !== "space") { -- break; -- } -- str = cache.pop()[1] + str; -- } -- if (str.trim().indexOf("!") === 0) { -- node2.important = true; -- node2.raws.important = str; -- tokens = cache; -- } -- } -- if (token[0] !== "space" && token[0] !== "comment") { -- break; -- } -- } -- let hasWord = tokens.some((i2) => i2[0] !== "space" && i2[0] !== "comment"); -- if (hasWord) { -- node2.raws.between += firstSpaces.map((i2) => i2[1]).join(""); -- firstSpaces = []; -- } -- this.raw(node2, "value", firstSpaces.concat(tokens), customProperty); -- if (node2.value.includes(":") && !customProperty) { -- this.checkMissedSemicolon(tokens); -- } -- } -- doubleColon(token) { -- throw this.input.error( -- "Double colon", -- { offset: token[2] }, -- { offset: token[2] + token[1].length } -- ); -- } -- emptyRule(token) { -- let node2 = new Rule$2$1(); -- this.init(node2, token[2]); -- node2.selector = ""; -- node2.raws.between = ""; -- this.current = node2; -- } -- end(token) { -- if (this.current.nodes && this.current.nodes.length) { -- this.current.raws.semicolon = this.semicolon; -- } -- this.semicolon = false; -- this.current.raws.after = (this.current.raws.after || "") + this.spaces; -- this.spaces = ""; -- if (this.current.parent) { -- this.current.source.end = this.getPosition(token[2]); -- this.current.source.end.offset++; -- this.current = this.current.parent; -- } else { -- this.unexpectedClose(token); -- } -- } -- endFile() { -- if (this.current.parent) this.unclosedBlock(); -- if (this.current.nodes && this.current.nodes.length) { -- this.current.raws.semicolon = this.semicolon; -- } -- this.current.raws.after = (this.current.raws.after || "") + this.spaces; -- this.root.source.end = this.getPosition(this.tokenizer.position()); -- } -- freeSemicolon(token) { -- this.spaces += token[1]; -- if (this.current.nodes) { -- let prev = this.current.nodes[this.current.nodes.length - 1]; -- if (prev && prev.type === "rule" && !prev.raws.ownSemicolon) { -- prev.raws.ownSemicolon = this.spaces; -- this.spaces = ""; -- } -- } -- } -- // Helpers -- getPosition(offset) { -- let pos = this.input.fromOffset(offset); -- return { -- column: pos.col, -- line: pos.line, -- offset -- }; -- } -- init(node2, offset) { -- this.current.push(node2); -- node2.source = { -- input: this.input, -- start: this.getPosition(offset) -- }; -- node2.raws.before = this.spaces; -- this.spaces = ""; -- if (node2.type !== "comment") this.semicolon = false; -- } -- other(start) { -- let end = false; -- let type = null; -- let colon = false; -- let bracket = null; -- let brackets = []; -- let customProperty = start[1].startsWith("--"); -- let tokens = []; -- let token = start; -- while (token) { -- type = token[0]; -- tokens.push(token); -- if (type === "(" || type === "[") { -- if (!bracket) bracket = token; -- brackets.push(type === "(" ? ")" : "]"); -- } else if (customProperty && colon && type === "{") { -- if (!bracket) bracket = token; -- brackets.push("}"); -- } else if (brackets.length === 0) { -- if (type === ";") { -- if (colon) { -- this.decl(tokens, customProperty); -- return; -- } else { -- break; -- } -- } else if (type === "{") { -- this.rule(tokens); -- return; -- } else if (type === "}") { -- this.tokenizer.back(tokens.pop()); -- end = true; -- break; -- } else if (type === ":") { -- colon = true; -- } -- } else if (type === brackets[brackets.length - 1]) { -- brackets.pop(); -- if (brackets.length === 0) bracket = null; -- } -- token = this.tokenizer.nextToken(); -- } -- if (this.tokenizer.endOfFile()) end = true; -- if (brackets.length > 0) this.unclosedBracket(bracket); -- if (end && colon) { -- if (!customProperty) { -- while (tokens.length) { -- token = tokens[tokens.length - 1][0]; -- if (token !== "space" && token !== "comment") break; -- this.tokenizer.back(tokens.pop()); -- } -- } -- this.decl(tokens, customProperty); -- } else { -- this.unknownWord(tokens); -- } -- } -- parse() { -- let token; -- while (!this.tokenizer.endOfFile()) { -- token = this.tokenizer.nextToken(); -- switch (token[0]) { -- case "space": -- this.spaces += token[1]; -- break; -- case ";": -- this.freeSemicolon(token); -- break; -- case "}": -- this.end(token); -- break; -- case "comment": -- this.comment(token); -- break; -- case "at-word": -- this.atrule(token); -- break; -- case "{": -- this.emptyRule(token); -- break; -- default: -- this.other(token); -- break; -- } -- } -- this.endFile(); -- } -- precheckMissedSemicolon() { -- } -- raw(node2, prop, tokens, customProperty) { -- let token, type; -- let length = tokens.length; -- let value = ""; -- let clean = true; -- let next, prev; -- for (let i2 = 0; i2 < length; i2 += 1) { -- token = tokens[i2]; -- type = token[0]; -- if (type === "space" && i2 === length - 1 && !customProperty) { -- clean = false; -- } else if (type === "comment") { -- prev = tokens[i2 - 1] ? tokens[i2 - 1][0] : "empty"; -- next = tokens[i2 + 1] ? tokens[i2 + 1][0] : "empty"; -- if (!SAFE_COMMENT_NEIGHBOR$1[prev] && !SAFE_COMMENT_NEIGHBOR$1[next]) { -- if (value.slice(-1) === ",") { -- clean = false; -- } else { -- value += token[1]; -- } -- } else { -- clean = false; -- } -- } else { -- value += token[1]; -- } -- } -- if (!clean) { -- let raw = tokens.reduce((all, i2) => all + i2[1], ""); -- node2.raws[prop] = { raw, value }; -- } -- node2[prop] = value; -- } -- rule(tokens) { -- tokens.pop(); -- let node2 = new Rule$2$1(); -- this.init(node2, tokens[0][2]); -- node2.raws.between = this.spacesAndCommentsFromEnd(tokens); -- this.raw(node2, "selector", tokens); -- this.current = node2; -- } -- spacesAndCommentsFromEnd(tokens) { -- let lastTokenType; -- let spaces = ""; -- while (tokens.length) { -- lastTokenType = tokens[tokens.length - 1][0]; -- if (lastTokenType !== "space" && lastTokenType !== "comment") break; -- spaces = tokens.pop()[1] + spaces; -- } -- return spaces; -- } -- // Errors -- spacesAndCommentsFromStart(tokens) { -- let next; -- let spaces = ""; -- while (tokens.length) { -- next = tokens[0][0]; -- if (next !== "space" && next !== "comment") break; -- spaces += tokens.shift()[1]; -- } -- return spaces; -- } -- spacesFromEnd(tokens) { -- let lastTokenType; -- let spaces = ""; -- while (tokens.length) { -- lastTokenType = tokens[tokens.length - 1][0]; -- if (lastTokenType !== "space") break; -- spaces = tokens.pop()[1] + spaces; -- } -- return spaces; -- } -- stringFrom(tokens, from) { -- let result2 = ""; -- for (let i2 = from; i2 < tokens.length; i2++) { -- result2 += tokens[i2][1]; -- } -- tokens.splice(from, tokens.length - from); -- return result2; -- } -- unclosedBlock() { -- let pos = this.current.source.start; -- throw this.input.error("Unclosed block", pos.line, pos.column); -- } -- unclosedBracket(bracket) { -- throw this.input.error( -- "Unclosed bracket", -- { offset: bracket[2] }, -- { offset: bracket[2] + 1 } -- ); -- } -- unexpectedClose(token) { -- throw this.input.error( -- "Unexpected }", -- { offset: token[2] }, -- { offset: token[2] + 1 } -- ); -- } -- unknownWord(tokens) { -- throw this.input.error( -- "Unknown word", -- { offset: tokens[0][2] }, -- { offset: tokens[0][2] + tokens[0][1].length } -- ); -- } -- unnamedAtrule(node2, token) { -- throw this.input.error( -- "At-rule without name", -- { offset: token[2] }, -- { offset: token[2] + token[1].length } -- ); -- } --}; --var parser$1 = Parser$1$1; --let Container$2$1 = container$1; --let Parser2$1 = parser$1; --let Input$2$1 = input$1; --function parse$3$1(css, opts) { -- let input2 = new Input$2$1(css, opts); -- let parser2 = new Parser2$1(input2); -- try { -- parser2.parse(); -- } catch (e2) { -- if (process.env.NODE_ENV !== "production") { -- if (e2.name === "CssSyntaxError" && opts && opts.from) { -- if (/\.scss$/i.test(opts.from)) { -- e2.message += "\nYou tried to parse SCSS with the standard CSS parser; try again with the postcss-scss parser"; -- } else if (/\.sass/i.test(opts.from)) { -- e2.message += "\nYou tried to parse Sass with the standard CSS parser; try again with the postcss-sass parser"; -- } else if (/\.less$/i.test(opts.from)) { -- e2.message += "\nYou tried to parse Less with the standard CSS parser; try again with the postcss-less parser"; -- } -- } -- } -- throw e2; -- } -- return parser2.root; --} --var parse_1$1 = parse$3$1; --parse$3$1.default = parse$3$1; --Container$2$1.registerParse(parse$3$1); --let { isClean: isClean$3, my: my$3 } = symbols$1; --let MapGenerator$1$1 = mapGenerator$1; --let stringify$2$1 = stringify_1$1; --let Container$1$1 = container$1; --let Document$2$1 = document$1$1; --let warnOnce$1$1 = warnOnce$2$1; --let Result$2$1 = result$1; --let parse$2$1 = parse_1$1; --let Root$3$1 = root$1; --const TYPE_TO_CLASS_NAME$1 = { -- atrule: "AtRule", -- comment: "Comment", -- decl: "Declaration", -- document: "Document", -- root: "Root", -- rule: "Rule" --}; --const PLUGIN_PROPS$1 = { -- AtRule: true, -- AtRuleExit: true, -- Comment: true, -- CommentExit: true, -- Declaration: true, -- DeclarationExit: true, -- Document: true, -- DocumentExit: true, -- Once: true, -- OnceExit: true, -- postcssPlugin: true, -- prepare: true, -- Root: true, -- RootExit: true, -- Rule: true, -- RuleExit: true --}; --const NOT_VISITORS$1 = { -- Once: true, -- postcssPlugin: true, -- prepare: true --}; --const CHILDREN$1 = 0; --function isPromise$1(obj) { -- return typeof obj === "object" && typeof obj.then === "function"; --} --function getEvents$1(node2) { -- let key = false; -- let type = TYPE_TO_CLASS_NAME$1[node2.type]; -- if (node2.type === "decl") { -- key = node2.prop.toLowerCase(); -- } else if (node2.type === "atrule") { -- key = node2.name.toLowerCase(); -- } -- if (key && node2.append) { -- return [ -- type, -- type + "-" + key, -- CHILDREN$1, -- type + "Exit", -- type + "Exit-" + key -- ]; -- } else if (key) { -- return [type, type + "-" + key, type + "Exit", type + "Exit-" + key]; -- } else if (node2.append) { -- return [type, CHILDREN$1, type + "Exit"]; -- } else { -- return [type, type + "Exit"]; -- } --} --function toStack$1(node2) { -- let events; -- if (node2.type === "document") { -- events = ["Document", CHILDREN$1, "DocumentExit"]; -- } else if (node2.type === "root") { -- events = ["Root", CHILDREN$1, "RootExit"]; -- } else { -- events = getEvents$1(node2); -- } -- return { -- eventIndex: 0, -- events, -- iterator: 0, -- node: node2, -- visitorIndex: 0, -- visitors: [] -- }; --} --function cleanMarks$1(node2) { -- node2[isClean$3] = false; -- if (node2.nodes) node2.nodes.forEach((i2) => cleanMarks$1(i2)); -- return node2; --} --let postcss$2$1 = {}; --let LazyResult$2$1 = class LazyResult { -- constructor(processor2, css, opts) { -- this.stringified = false; -- this.processed = false; -- let root2; -- if (typeof css === "object" && css !== null && (css.type === "root" || css.type === "document")) { -- root2 = cleanMarks$1(css); -- } else if (css instanceof LazyResult || css instanceof Result$2$1) { -- root2 = cleanMarks$1(css.root); -- if (css.map) { -- if (typeof opts.map === "undefined") opts.map = {}; -- if (!opts.map.inline) opts.map.inline = false; -- opts.map.prev = css.map; -- } -- } else { -- let parser2 = parse$2$1; -- if (opts.syntax) parser2 = opts.syntax.parse; -- if (opts.parser) parser2 = opts.parser; -- if (parser2.parse) parser2 = parser2.parse; -- try { -- root2 = parser2(css, opts); -- } catch (error) { -- this.processed = true; -- this.error = error; -- } -- if (root2 && !root2[my$3]) { -- Container$1$1.rebuild(root2); -- } -- } -- this.result = new Result$2$1(processor2, root2, opts); -- this.helpers = { ...postcss$2$1, postcss: postcss$2$1, result: this.result }; -- this.plugins = this.processor.plugins.map((plugin22) => { -- if (typeof plugin22 === "object" && plugin22.prepare) { -- return { ...plugin22, ...plugin22.prepare(this.result) }; -- } else { -- return plugin22; -- } -- }); -- } -- async() { -- if (this.error) return Promise.reject(this.error); -- if (this.processed) return Promise.resolve(this.result); -- if (!this.processing) { -- this.processing = this.runAsync(); -- } -- return this.processing; -- } -- catch(onRejected) { -- return this.async().catch(onRejected); -- } -- finally(onFinally) { -- return this.async().then(onFinally, onFinally); -- } -- getAsyncError() { -- throw new Error("Use process(css).then(cb) to work with async plugins"); -- } -- handleError(error, node2) { -- let plugin22 = this.result.lastPlugin; -- try { -- if (node2) node2.addToError(error); -- this.error = error; -- if (error.name === "CssSyntaxError" && !error.plugin) { -- error.plugin = plugin22.postcssPlugin; -- error.setMessage(); -- } else if (plugin22.postcssVersion) { -- if (process.env.NODE_ENV !== "production") { -- let pluginName = plugin22.postcssPlugin; -- let pluginVer = plugin22.postcssVersion; -- let runtimeVer = this.result.processor.version; -- let a2 = pluginVer.split("."); -- let b = runtimeVer.split("."); -- if (a2[0] !== b[0] || parseInt(a2[1]) > parseInt(b[1])) { -- console.error( -- "Unknown error from PostCSS plugin. Your current PostCSS version is " + runtimeVer + ", but " + pluginName + " uses " + pluginVer + ". Perhaps this is the source of the error below." -- ); -- } -- } -- } -- } catch (err) { -- if (console && console.error) console.error(err); -- } -- return error; -- } -- prepareVisitors() { -- this.listeners = {}; -- let add = (plugin22, type, cb) => { -- if (!this.listeners[type]) this.listeners[type] = []; -- this.listeners[type].push([plugin22, cb]); -- }; -- for (let plugin22 of this.plugins) { -- if (typeof plugin22 === "object") { -- for (let event in plugin22) { -- if (!PLUGIN_PROPS$1[event] && /^[A-Z]/.test(event)) { -- throw new Error( -- `Unknown event ${event} in ${plugin22.postcssPlugin}. Try to update PostCSS (${this.processor.version} now).` -- ); -- } -- if (!NOT_VISITORS$1[event]) { -- if (typeof plugin22[event] === "object") { -- for (let filter in plugin22[event]) { -- if (filter === "*") { -- add(plugin22, event, plugin22[event][filter]); -- } else { -- add( -- plugin22, -- event + "-" + filter.toLowerCase(), -- plugin22[event][filter] -- ); -- } -- } -- } else if (typeof plugin22[event] === "function") { -- add(plugin22, event, plugin22[event]); -- } -- } -- } -- } -- } -- this.hasListener = Object.keys(this.listeners).length > 0; -- } -- async runAsync() { -- this.plugin = 0; -- for (let i2 = 0; i2 < this.plugins.length; i2++) { -- let plugin22 = this.plugins[i2]; -- let promise = this.runOnRoot(plugin22); -- if (isPromise$1(promise)) { -- try { -- await promise; -- } catch (error) { -- throw this.handleError(error); -- } -- } -- } -- this.prepareVisitors(); -- if (this.hasListener) { -- let root2 = this.result.root; -- while (!root2[isClean$3]) { -- root2[isClean$3] = true; -- let stack = [toStack$1(root2)]; -- while (stack.length > 0) { -- let promise = this.visitTick(stack); -- if (isPromise$1(promise)) { -- try { -- await promise; -- } catch (e2) { -- let node2 = stack[stack.length - 1].node; -- throw this.handleError(e2, node2); -- } -- } -- } -- } -- if (this.listeners.OnceExit) { -- for (let [plugin22, visitor] of this.listeners.OnceExit) { -- this.result.lastPlugin = plugin22; -- try { -- if (root2.type === "document") { -- let roots = root2.nodes.map( -- (subRoot) => visitor(subRoot, this.helpers) -- ); -- await Promise.all(roots); -- } else { -- await visitor(root2, this.helpers); -- } -- } catch (e2) { -- throw this.handleError(e2); -- } -- } -- } -- } -- this.processed = true; -- return this.stringify(); -- } -- runOnRoot(plugin22) { -- this.result.lastPlugin = plugin22; -- try { -- if (typeof plugin22 === "object" && plugin22.Once) { -- if (this.result.root.type === "document") { -- let roots = this.result.root.nodes.map( -- (root2) => plugin22.Once(root2, this.helpers) -- ); -- if (isPromise$1(roots[0])) { -- return Promise.all(roots); -- } -- return roots; -- } -- return plugin22.Once(this.result.root, this.helpers); -- } else if (typeof plugin22 === "function") { -- return plugin22(this.result.root, this.result); -- } -- } catch (error) { -- throw this.handleError(error); -- } -- } -- stringify() { -- if (this.error) throw this.error; -- if (this.stringified) return this.result; -- this.stringified = true; -- this.sync(); -- let opts = this.result.opts; -- let str = stringify$2$1; -- if (opts.syntax) str = opts.syntax.stringify; -- if (opts.stringifier) str = opts.stringifier; -- if (str.stringify) str = str.stringify; -- let map = new MapGenerator$1$1(str, this.result.root, this.result.opts); -- let data = map.generate(); -- this.result.css = data[0]; -- this.result.map = data[1]; -- return this.result; -- } -- sync() { -- if (this.error) throw this.error; -- if (this.processed) return this.result; -- this.processed = true; -- if (this.processing) { -- throw this.getAsyncError(); -- } -- for (let plugin22 of this.plugins) { -- let promise = this.runOnRoot(plugin22); -- if (isPromise$1(promise)) { -- throw this.getAsyncError(); -- } -- } -- this.prepareVisitors(); -- if (this.hasListener) { -- let root2 = this.result.root; -- while (!root2[isClean$3]) { -- root2[isClean$3] = true; -- this.walkSync(root2); -- } -- if (this.listeners.OnceExit) { -- if (root2.type === "document") { -- for (let subRoot of root2.nodes) { -- this.visitSync(this.listeners.OnceExit, subRoot); -- } -- } else { -- this.visitSync(this.listeners.OnceExit, root2); -- } -- } -- } -- return this.result; -- } -- then(onFulfilled, onRejected) { -- if (process.env.NODE_ENV !== "production") { -- if (!("from" in this.opts)) { -- warnOnce$1$1( -- "Without `from` option PostCSS could generate wrong source map and will not find Browserslist config. Set it to CSS file path or to `undefined` to prevent this warning." -- ); -- } -- } -- return this.async().then(onFulfilled, onRejected); -- } -- toString() { -- return this.css; -- } -- visitSync(visitors, node2) { -- for (let [plugin22, visitor] of visitors) { -- this.result.lastPlugin = plugin22; -- let promise; -- try { -- promise = visitor(node2, this.helpers); -- } catch (e2) { -- throw this.handleError(e2, node2.proxyOf); -- } -- if (node2.type !== "root" && node2.type !== "document" && !node2.parent) { -- return true; -- } -- if (isPromise$1(promise)) { -- throw this.getAsyncError(); -- } -- } -- } -- visitTick(stack) { -- let visit2 = stack[stack.length - 1]; -- let { node: node2, visitors } = visit2; -- if (node2.type !== "root" && node2.type !== "document" && !node2.parent) { -- stack.pop(); -- return; -- } -- if (visitors.length > 0 && visit2.visitorIndex < visitors.length) { -- let [plugin22, visitor] = visitors[visit2.visitorIndex]; -- visit2.visitorIndex += 1; -- if (visit2.visitorIndex === visitors.length) { -- visit2.visitors = []; -- visit2.visitorIndex = 0; -- } -- this.result.lastPlugin = plugin22; -- try { -- return visitor(node2.toProxy(), this.helpers); -- } catch (e2) { -- throw this.handleError(e2, node2); -- } -- } -- if (visit2.iterator !== 0) { -- let iterator = visit2.iterator; -- let child; -- while (child = node2.nodes[node2.indexes[iterator]]) { -- node2.indexes[iterator] += 1; -- if (!child[isClean$3]) { -- child[isClean$3] = true; -- stack.push(toStack$1(child)); -- return; -- } -- } -- visit2.iterator = 0; -- delete node2.indexes[iterator]; -- } -- let events = visit2.events; -- while (visit2.eventIndex < events.length) { -- let event = events[visit2.eventIndex]; -- visit2.eventIndex += 1; -- if (event === CHILDREN$1) { -- if (node2.nodes && node2.nodes.length) { -- node2[isClean$3] = true; -- visit2.iterator = node2.getIterator(); -- } -- return; -- } else if (this.listeners[event]) { -- visit2.visitors = this.listeners[event]; -- return; -- } -- } -- stack.pop(); -- } -- walkSync(node2) { -- node2[isClean$3] = true; -- let events = getEvents$1(node2); -- for (let event of events) { -- if (event === CHILDREN$1) { -- if (node2.nodes) { -- node2.each((child) => { -- if (!child[isClean$3]) this.walkSync(child); -- }); -- } -- } else { -- let visitors = this.listeners[event]; -- if (visitors) { -- if (this.visitSync(visitors, node2.toProxy())) return; -- } -- } -- } -- } -- warnings() { -- return this.sync().warnings(); -- } -- get content() { -- return this.stringify().content; -- } -- get css() { -- return this.stringify().css; -- } -- get map() { -- return this.stringify().map; -- } -- get messages() { -- return this.sync().messages; -- } -- get opts() { -- return this.result.opts; -- } -- get processor() { -- return this.result.processor; -- } -- get root() { -- return this.sync().root; -- } -- get [Symbol.toStringTag]() { -- return "LazyResult"; -- } --}; --LazyResult$2$1.registerPostcss = (dependant) => { -- postcss$2$1 = dependant; --}; --var lazyResult$1 = LazyResult$2$1; --LazyResult$2$1.default = LazyResult$2$1; --Root$3$1.registerLazyResult(LazyResult$2$1); --Document$2$1.registerLazyResult(LazyResult$2$1); --let MapGenerator2$1 = mapGenerator$1; --let stringify$1$1 = stringify_1$1; --let warnOnce2$1 = warnOnce$2$1; --let parse$1$1 = parse_1$1; --const Result$1$1 = result$1; --let NoWorkResult$1$1 = class NoWorkResult { -- constructor(processor2, css, opts) { -- css = css.toString(); -- this.stringified = false; -- this._processor = processor2; -- this._css = css; -- this._opts = opts; -- this._map = void 0; -- let root2; -- let str = stringify$1$1; -- this.result = new Result$1$1(this._processor, root2, this._opts); -- this.result.css = css; -- let self = this; -- Object.defineProperty(this.result, "root", { -- get() { -- return self.root; -- } -- }); -- let map = new MapGenerator2$1(str, root2, this._opts, css); -- if (map.isMap()) { -- let [generatedCSS, generatedMap] = map.generate(); -- if (generatedCSS) { -- this.result.css = generatedCSS; -- } -- if (generatedMap) { -- this.result.map = generatedMap; -- } -- } else { -- map.clearAnnotation(); -- this.result.css = map.css; -- } -- } -- async() { -- if (this.error) return Promise.reject(this.error); -- return Promise.resolve(this.result); -- } -- catch(onRejected) { -- return this.async().catch(onRejected); -- } -- finally(onFinally) { -- return this.async().then(onFinally, onFinally); -- } -- sync() { -- if (this.error) throw this.error; -- return this.result; -- } -- then(onFulfilled, onRejected) { -- if (process.env.NODE_ENV !== "production") { -- if (!("from" in this._opts)) { -- warnOnce2$1( -- "Without `from` option PostCSS could generate wrong source map and will not find Browserslist config. Set it to CSS file path or to `undefined` to prevent this warning." -- ); -- } -- } -- return this.async().then(onFulfilled, onRejected); -- } -- toString() { -- return this._css; -- } -- warnings() { -- return []; -- } -- get content() { -- return this.result.css; -- } -- get css() { -- return this.result.css; -- } -- get map() { -- return this.result.map; -- } -- get messages() { -- return []; -- } -- get opts() { -- return this.result.opts; -- } -- get processor() { -- return this.result.processor; -- } -- get root() { -- if (this._root) { -- return this._root; -- } -- let root2; -- let parser2 = parse$1$1; -- try { -- root2 = parser2(this._css, this._opts); -- } catch (error) { -- this.error = error; -- } -- if (this.error) { -- throw this.error; -- } else { -- this._root = root2; -- return root2; -- } -- } -- get [Symbol.toStringTag]() { -- return "NoWorkResult"; -- } --}; --var noWorkResult$1 = NoWorkResult$1$1; --NoWorkResult$1$1.default = NoWorkResult$1$1; --let NoWorkResult2$1 = noWorkResult$1; --let LazyResult$1$1 = lazyResult$1; --let Document$1$1 = document$1$1; --let Root$2$1 = root$1; --let Processor$1$1 = class Processor { -- constructor(plugins = []) { -- this.version = "8.4.38"; -- this.plugins = this.normalize(plugins); -- } -- normalize(plugins) { -- let normalized = []; -- for (let i2 of plugins) { -- if (i2.postcss === true) { -- i2 = i2(); -- } else if (i2.postcss) { -- i2 = i2.postcss; -- } -- if (typeof i2 === "object" && Array.isArray(i2.plugins)) { -- normalized = normalized.concat(i2.plugins); -- } else if (typeof i2 === "object" && i2.postcssPlugin) { -- normalized.push(i2); -- } else if (typeof i2 === "function") { -- normalized.push(i2); -- } else if (typeof i2 === "object" && (i2.parse || i2.stringify)) { -- if (process.env.NODE_ENV !== "production") { -- throw new Error( -- "PostCSS syntaxes cannot be used as plugins. Instead, please use one of the syntax/parser/stringifier options as outlined in your PostCSS runner documentation." -- ); -- } -- } else { -- throw new Error(i2 + " is not a PostCSS plugin"); -- } -- } -- return normalized; -- } -- process(css, opts = {}) { -- if (!this.plugins.length && !opts.parser && !opts.stringifier && !opts.syntax) { -- return new NoWorkResult2$1(this, css, opts); -- } else { -- return new LazyResult$1$1(this, css, opts); -- } -- } -- use(plugin22) { -- this.plugins = this.plugins.concat(this.normalize([plugin22])); -- return this; -- } --}; --var processor$1 = Processor$1$1; --Processor$1$1.default = Processor$1$1; --Root$2$1.registerProcessor(Processor$1$1); --Document$1$1.registerProcessor(Processor$1$1); --let Declaration$1$1 = declaration$1; --let PreviousMap2$1 = previousMap$1; --let Comment$1$1 = comment$1; --let AtRule$1$1 = atRule$1; --let Input$1$1 = input$1; --let Root$1$1 = root$1; --let Rule$1$1 = rule$1; --function fromJSON$1$1(json, inputs) { -- if (Array.isArray(json)) return json.map((n2) => fromJSON$1$1(n2)); -- let { inputs: ownInputs, ...defaults } = json; -- if (ownInputs) { -- inputs = []; -- for (let input2 of ownInputs) { -- let inputHydrated = { ...input2, __proto__: Input$1$1.prototype }; -- if (inputHydrated.map) { -- inputHydrated.map = { -- ...inputHydrated.map, -- __proto__: PreviousMap2$1.prototype -- }; -- } -- inputs.push(inputHydrated); -- } -- } -- if (defaults.nodes) { -- defaults.nodes = json.nodes.map((n2) => fromJSON$1$1(n2, inputs)); -- } -- if (defaults.source) { -- let { inputId, ...source } = defaults.source; -- defaults.source = source; -- if (inputId != null) { -- defaults.source.input = inputs[inputId]; -- } -- } -- if (defaults.type === "root") { -- return new Root$1$1(defaults); -- } else if (defaults.type === "decl") { -- return new Declaration$1$1(defaults); -- } else if (defaults.type === "rule") { -- return new Rule$1$1(defaults); -- } else if (defaults.type === "comment") { -- return new Comment$1$1(defaults); -- } else if (defaults.type === "atrule") { -- return new AtRule$1$1(defaults); -- } else { -- throw new Error("Unknown node type: " + json.type); -- } --} --var fromJSON_1$1 = fromJSON$1$1; --fromJSON$1$1.default = fromJSON$1$1; --let CssSyntaxError2$1 = cssSyntaxError$1; --let Declaration2$1 = declaration$1; --let LazyResult2$1 = lazyResult$1; --let Container2$1 = container$1; --let Processor2$1 = processor$1; --let stringify$5 = stringify_1$1; --let fromJSON$2 = fromJSON_1$1; --let Document22 = document$1$1; --let Warning2$1 = warning$1; --let Comment2$1 = comment$1; --let AtRule2$1 = atRule$1; --let Result2$1 = result$1; --let Input2$1 = input$1; --let parse$5 = parse_1$1; --let list$3 = list_1$1; --let Rule2$1 = rule$1; --let Root2$1 = root$1; --let Node2$1 = node$1; --function postcss$3(...plugins) { -- if (plugins.length === 1 && Array.isArray(plugins[0])) { -- plugins = plugins[0]; -- } -- return new Processor2$1(plugins); --} --postcss$3.plugin = function plugin(name, initializer) { -- let warningPrinted = false; -- function creator(...args) { -- if (console && console.warn && !warningPrinted) { -- warningPrinted = true; -- console.warn( -- name + ": postcss.plugin was deprecated. Migration guide:\nhttps://evilmartians.com/chronicles/postcss-8-plugin-migration" -- ); -- if (process.env.LANG && process.env.LANG.startsWith("cn")) { -- console.warn( -- name + ": 里面 postcss.plugin 被弃用. 迁移指南:\nhttps://www.w3ctech.com/topic/2226" -- ); -- } -- } -- let transformer = initializer(...args); -- transformer.postcssPlugin = name; -- transformer.postcssVersion = new Processor2$1().version; -- return transformer; -- } -- let cache; -- Object.defineProperty(creator, "postcss", { -- get() { -- if (!cache) cache = creator(); -- return cache; -- } -- }); -- creator.process = function(css, processOpts, pluginOpts) { -- return postcss$3([creator(pluginOpts)]).process(css, processOpts); -- }; -- return creator; --}; --postcss$3.stringify = stringify$5; --postcss$3.parse = parse$5; --postcss$3.fromJSON = fromJSON$2; --postcss$3.list = list$3; --postcss$3.comment = (defaults) => new Comment2$1(defaults); --postcss$3.atRule = (defaults) => new AtRule2$1(defaults); --postcss$3.decl = (defaults) => new Declaration2$1(defaults); --postcss$3.rule = (defaults) => new Rule2$1(defaults); --postcss$3.root = (defaults) => new Root2$1(defaults); --postcss$3.document = (defaults) => new Document22(defaults); --postcss$3.CssSyntaxError = CssSyntaxError2$1; --postcss$3.Declaration = Declaration2$1; --postcss$3.Container = Container2$1; --postcss$3.Processor = Processor2$1; --postcss$3.Document = Document22; --postcss$3.Comment = Comment2$1; --postcss$3.Warning = Warning2$1; --postcss$3.AtRule = AtRule2$1; --postcss$3.Result = Result2$1; --postcss$3.Input = Input2$1; --postcss$3.Rule = Rule2$1; --postcss$3.Root = Root2$1; --postcss$3.Node = Node2$1; --LazyResult2$1.registerPostcss(postcss$3); --var postcss_1$1 = postcss$3; --postcss$3.default = postcss$3; --const postcss$1$1 = /* @__PURE__ */ getDefaultExportFromCjs$1(postcss_1$1); --postcss$1$1.stringify; --postcss$1$1.fromJSON; --postcss$1$1.plugin; --postcss$1$1.parse; --postcss$1$1.list; --postcss$1$1.document; --postcss$1$1.comment; --postcss$1$1.atRule; --postcss$1$1.rule; --postcss$1$1.decl; --postcss$1$1.root; --postcss$1$1.CssSyntaxError; --postcss$1$1.Declaration; --postcss$1$1.Container; --postcss$1$1.Processor; --postcss$1$1.Document; --postcss$1$1.Comment; --postcss$1$1.Warning; --postcss$1$1.AtRule; --postcss$1$1.Result; --postcss$1$1.Input; --postcss$1$1.Rule; --postcss$1$1.Root; --postcss$1$1.Node; --var __defProp2 = Object.defineProperty; --var __defNormalProp2 = (obj, key, value) => key in obj ? __defProp2(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value; --var __publicField2 = (obj, key, value) => __defNormalProp2(obj, typeof key !== "symbol" ? key + "" : key, value); --function getDefaultExportFromCjs(x2) { -- return x2 && x2.__esModule && Object.prototype.hasOwnProperty.call(x2, "default") ? x2["default"] : x2; --} --function getAugmentedNamespace(n2) { -- if (n2.__esModule) return n2; -- var f2 = n2.default; -- if (typeof f2 == "function") { -- var a2 = function a22() { -- if (this instanceof a22) { -- return Reflect.construct(f2, arguments, this.constructor); -- } -- return f2.apply(this, arguments); -- }; -- a2.prototype = f2.prototype; -- } else a2 = {}; -- Object.defineProperty(a2, "__esModule", { value: true }); -- Object.keys(n2).forEach(function(k) { -- var d = Object.getOwnPropertyDescriptor(n2, k); -- Object.defineProperty(a2, k, d.get ? d : { -- enumerable: true, -- get: function() { -- return n2[k]; -- } -- }); -- }); -- return a2; --} --var picocolors_browser = { exports: {} }; --var x = String; --var create = function() { -- return { isColorSupported: false, reset: x, bold: x, dim: x, italic: x, underline: x, inverse: x, hidden: x, strikethrough: x, black: x, red: x, green: x, yellow: x, blue: x, magenta: x, cyan: x, white: x, gray: x, bgBlack: x, bgRed: x, bgGreen: x, bgYellow: x, bgBlue: x, bgMagenta: x, bgCyan: x, bgWhite: x }; --}; --picocolors_browser.exports = create(); --picocolors_browser.exports.createColors = create; --var picocolors_browserExports = picocolors_browser.exports; --const __viteBrowserExternal = {}; --const __viteBrowserExternal$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({ -- __proto__: null, -- default: __viteBrowserExternal --}, Symbol.toStringTag, { value: "Module" })); --const require$$2 = /* @__PURE__ */ getAugmentedNamespace(__viteBrowserExternal$1); --let pico = picocolors_browserExports; --let terminalHighlight$1 = require$$2; --let CssSyntaxError$3 = class CssSyntaxError2 extends Error { -- constructor(message, line, column, source, file, plugin22) { -- super(message); -- this.name = "CssSyntaxError"; -- this.reason = message; -- if (file) { -- this.file = file; -- } -- if (source) { -- this.source = source; -- } -- if (plugin22) { -- this.plugin = plugin22; -- } -- if (typeof line !== "undefined" && typeof column !== "undefined") { -- if (typeof line === "number") { -- this.line = line; -- this.column = column; -- } else { -- this.line = line.line; -- this.column = line.column; -- this.endLine = column.line; -- this.endColumn = column.column; -- } -- } -- this.setMessage(); -- if (Error.captureStackTrace) { -- Error.captureStackTrace(this, CssSyntaxError2); -- } -- } -- setMessage() { -- this.message = this.plugin ? this.plugin + ": " : ""; -- this.message += this.file ? this.file : ""; -- if (typeof this.line !== "undefined") { -- this.message += ":" + this.line + ":" + this.column; -- } -- this.message += ": " + this.reason; -- } -- showSourceCode(color) { -- if (!this.source) return ""; -- let css = this.source; -- if (color == null) color = pico.isColorSupported; -- if (terminalHighlight$1) { -- if (color) css = terminalHighlight$1(css); -- } -- let lines = css.split(/\r?\n/); -- let start = Math.max(this.line - 3, 0); -- let end = Math.min(this.line + 2, lines.length); -- let maxWidth = String(end).length; -- let mark, aside; -- if (color) { -- let { bold, gray, red } = pico.createColors(true); -- mark = (text) => bold(red(text)); -- aside = (text) => gray(text); -- } else { -- mark = aside = (str) => str; -- } -- return lines.slice(start, end).map((line, index2) => { -- let number = start + 1 + index2; -- let gutter = " " + (" " + number).slice(-maxWidth) + " | "; -- if (number === this.line) { -- let spacing = aside(gutter.replace(/\d/g, " ")) + line.slice(0, this.column - 1).replace(/[^\t]/g, " "); -- return mark(">") + aside(gutter) + line + "\n " + spacing + mark("^"); -- } -- return " " + aside(gutter) + line; -- }).join("\n"); -- } -- toString() { -- let code = this.showSourceCode(); -- if (code) { -- code = "\n\n" + code + "\n"; -- } -- return this.name + ": " + this.message + code; -- } --}; --var cssSyntaxError = CssSyntaxError$3; --CssSyntaxError$3.default = CssSyntaxError$3; --var symbols = {}; --symbols.isClean = Symbol("isClean"); --symbols.my = Symbol("my"); --const DEFAULT_RAW = { -- after: "\n", -- beforeClose: "\n", -- beforeComment: "\n", -- beforeDecl: "\n", -- beforeOpen: " ", -- beforeRule: "\n", -- colon: ": ", -- commentLeft: " ", -- commentRight: " ", -- emptyBody: "", -- indent: " ", -- semicolon: false --}; --function capitalize(str) { -- return str[0].toUpperCase() + str.slice(1); --} --let Stringifier$2 = class Stringifier2 { -- constructor(builder) { -- this.builder = builder; -- } -- atrule(node2, semicolon) { -- let name = "@" + node2.name; -- let params = node2.params ? this.rawValue(node2, "params") : ""; -- if (typeof node2.raws.afterName !== "undefined") { -- name += node2.raws.afterName; -- } else if (params) { -- name += " "; -- } -- if (node2.nodes) { -- this.block(node2, name + params); -- } else { -- let end = (node2.raws.between || "") + (semicolon ? ";" : ""); -- this.builder(name + params + end, node2); -- } -- } -- beforeAfter(node2, detect) { -- let value; -- if (node2.type === "decl") { -- value = this.raw(node2, null, "beforeDecl"); -- } else if (node2.type === "comment") { -- value = this.raw(node2, null, "beforeComment"); -- } else if (detect === "before") { -- value = this.raw(node2, null, "beforeRule"); -- } else { -- value = this.raw(node2, null, "beforeClose"); -- } -- let buf = node2.parent; -- let depth = 0; -- while (buf && buf.type !== "root") { -- depth += 1; -- buf = buf.parent; -- } -- if (value.includes("\n")) { -- let indent = this.raw(node2, null, "indent"); -- if (indent.length) { -- for (let step = 0; step < depth; step++) value += indent; -- } -- } -- return value; -- } -- block(node2, start) { -- let between = this.raw(node2, "between", "beforeOpen"); -- this.builder(start + between + "{", node2, "start"); -- let after; -- if (node2.nodes && node2.nodes.length) { -- this.body(node2); -- after = this.raw(node2, "after"); -- } else { -- after = this.raw(node2, "after", "emptyBody"); -- } -- if (after) this.builder(after); -- this.builder("}", node2, "end"); -- } -- body(node2) { -- let last = node2.nodes.length - 1; -- while (last > 0) { -- if (node2.nodes[last].type !== "comment") break; -- last -= 1; -- } -- let semicolon = this.raw(node2, "semicolon"); -- for (let i2 = 0; i2 < node2.nodes.length; i2++) { -- let child = node2.nodes[i2]; -- let before = this.raw(child, "before"); -- if (before) this.builder(before); -- this.stringify(child, last !== i2 || semicolon); -- } -- } -- comment(node2) { -- let left = this.raw(node2, "left", "commentLeft"); -- let right = this.raw(node2, "right", "commentRight"); -- this.builder("/*" + left + node2.text + right + "*/", node2); -- } -- decl(node2, semicolon) { -- let between = this.raw(node2, "between", "colon"); -- let string = node2.prop + between + this.rawValue(node2, "value"); -- if (node2.important) { -- string += node2.raws.important || " !important"; -- } -- if (semicolon) string += ";"; -- this.builder(string, node2); -- } -- document(node2) { -- this.body(node2); -- } -- raw(node2, own, detect) { -- let value; -- if (!detect) detect = own; -- if (own) { -- value = node2.raws[own]; -- if (typeof value !== "undefined") return value; -- } -- let parent = node2.parent; -- if (detect === "before") { -- if (!parent || parent.type === "root" && parent.first === node2) { -- return ""; -- } -- if (parent && parent.type === "document") { -- return ""; -- } -- } -- if (!parent) return DEFAULT_RAW[detect]; -- let root2 = node2.root(); -- if (!root2.rawCache) root2.rawCache = {}; -- if (typeof root2.rawCache[detect] !== "undefined") { -- return root2.rawCache[detect]; -- } -- if (detect === "before" || detect === "after") { -- return this.beforeAfter(node2, detect); -- } else { -- let method = "raw" + capitalize(detect); -- if (this[method]) { -- value = this[method](root2, node2); -- } else { -- root2.walk((i2) => { -- value = i2.raws[own]; -- if (typeof value !== "undefined") return false; -- }); -- } -- } -- if (typeof value === "undefined") value = DEFAULT_RAW[detect]; -- root2.rawCache[detect] = value; -- return value; -- } -- rawBeforeClose(root2) { -- let value; -- root2.walk((i2) => { -- if (i2.nodes && i2.nodes.length > 0) { -- if (typeof i2.raws.after !== "undefined") { -- value = i2.raws.after; -- if (value.includes("\n")) { -- value = value.replace(/[^\n]+$/, ""); -- } -- return false; -- } -- } -- }); -- if (value) value = value.replace(/\S/g, ""); -- return value; -- } -- rawBeforeComment(root2, node2) { -- let value; -- root2.walkComments((i2) => { -- if (typeof i2.raws.before !== "undefined") { -- value = i2.raws.before; -- if (value.includes("\n")) { -- value = value.replace(/[^\n]+$/, ""); -- } -- return false; -- } -- }); -- if (typeof value === "undefined") { -- value = this.raw(node2, null, "beforeDecl"); -- } else if (value) { -- value = value.replace(/\S/g, ""); -- } -- return value; -- } -- rawBeforeDecl(root2, node2) { -- let value; -- root2.walkDecls((i2) => { -- if (typeof i2.raws.before !== "undefined") { -- value = i2.raws.before; -- if (value.includes("\n")) { -- value = value.replace(/[^\n]+$/, ""); -- } -- return false; -- } -- }); -- if (typeof value === "undefined") { -- value = this.raw(node2, null, "beforeRule"); -- } else if (value) { -- value = value.replace(/\S/g, ""); -- } -- return value; -- } -- rawBeforeOpen(root2) { -- let value; -- root2.walk((i2) => { -- if (i2.type !== "decl") { -- value = i2.raws.between; -- if (typeof value !== "undefined") return false; -- } -- }); -- return value; -- } -- rawBeforeRule(root2) { -- let value; -- root2.walk((i2) => { -- if (i2.nodes && (i2.parent !== root2 || root2.first !== i2)) { -- if (typeof i2.raws.before !== "undefined") { -- value = i2.raws.before; -- if (value.includes("\n")) { -- value = value.replace(/[^\n]+$/, ""); -- } -- return false; -- } -- } -- }); -- if (value) value = value.replace(/\S/g, ""); -- return value; -- } -- rawColon(root2) { -- let value; -- root2.walkDecls((i2) => { -- if (typeof i2.raws.between !== "undefined") { -- value = i2.raws.between.replace(/[^\s:]/g, ""); -- return false; -- } -- }); -- return value; -- } -- rawEmptyBody(root2) { -- let value; -- root2.walk((i2) => { -- if (i2.nodes && i2.nodes.length === 0) { -- value = i2.raws.after; -- if (typeof value !== "undefined") return false; -- } -- }); -- return value; -- } -- rawIndent(root2) { -- if (root2.raws.indent) return root2.raws.indent; -- let value; -- root2.walk((i2) => { -- let p = i2.parent; -- if (p && p !== root2 && p.parent && p.parent === root2) { -- if (typeof i2.raws.before !== "undefined") { -- let parts = i2.raws.before.split("\n"); -- value = parts[parts.length - 1]; -- value = value.replace(/\S/g, ""); -- return false; -- } -- } -- }); -- return value; -- } -- rawSemicolon(root2) { -- let value; -- root2.walk((i2) => { -- if (i2.nodes && i2.nodes.length && i2.last.type === "decl") { -- value = i2.raws.semicolon; -- if (typeof value !== "undefined") return false; -- } -- }); -- return value; -- } -- rawValue(node2, prop) { -- let value = node2[prop]; -- let raw = node2.raws[prop]; -- if (raw && raw.value === value) { -- return raw.raw; -- } -- return value; -- } -- root(node2) { -- this.body(node2); -- if (node2.raws.after) this.builder(node2.raws.after); -- } -- rule(node2) { -- this.block(node2, this.rawValue(node2, "selector")); -- if (node2.raws.ownSemicolon) { -- this.builder(node2.raws.ownSemicolon, node2, "end"); -- } -- } -- stringify(node2, semicolon) { -- if (!this[node2.type]) { -- throw new Error( -- "Unknown AST node type " + node2.type + ". Maybe you need to change PostCSS stringifier." -- ); -- } -- this[node2.type](node2, semicolon); -- } --}; --var stringifier = Stringifier$2; --Stringifier$2.default = Stringifier$2; --let Stringifier$1 = stringifier; --function stringify$4(node2, builder) { -- let str = new Stringifier$1(builder); -- str.stringify(node2); --} --var stringify_1 = stringify$4; --stringify$4.default = stringify$4; --let { isClean: isClean$2, my: my$2 } = symbols; --let CssSyntaxError$2 = cssSyntaxError; --let Stringifier22 = stringifier; --let stringify$3 = stringify_1; --function cloneNode(obj, parent) { -- let cloned = new obj.constructor(); -- for (let i2 in obj) { -- if (!Object.prototype.hasOwnProperty.call(obj, i2)) { -- continue; -- } -- if (i2 === "proxyCache") continue; -- let value = obj[i2]; -- let type = typeof value; -- if (i2 === "parent" && type === "object") { -- if (parent) cloned[i2] = parent; -- } else if (i2 === "source") { -- cloned[i2] = value; -- } else if (Array.isArray(value)) { -- cloned[i2] = value.map((j) => cloneNode(j, cloned)); -- } else { -- if (type === "object" && value !== null) value = cloneNode(value); -- cloned[i2] = value; -- } -- } -- return cloned; --} --let Node$4 = class Node3 { -- constructor(defaults = {}) { -- this.raws = {}; -- this[isClean$2] = false; -- this[my$2] = true; -- for (let name in defaults) { -- if (name === "nodes") { -- this.nodes = []; -- for (let node2 of defaults[name]) { -- if (typeof node2.clone === "function") { -- this.append(node2.clone()); -- } else { -- this.append(node2); -- } -- } -- } else { -- this[name] = defaults[name]; -- } -- } -- } -- addToError(error) { -- error.postcssNode = this; -- if (error.stack && this.source && /\n\s{4}at /.test(error.stack)) { -- let s2 = this.source; -- error.stack = error.stack.replace( -- /\n\s{4}at /, -- `$&${s2.input.from}:${s2.start.line}:${s2.start.column}$&` -- ); -- } -- return error; -- } -- after(add) { -- this.parent.insertAfter(this, add); -- return this; -- } -- assign(overrides = {}) { -- for (let name in overrides) { -- this[name] = overrides[name]; -- } -- return this; -- } -- before(add) { -- this.parent.insertBefore(this, add); -- return this; -- } -- cleanRaws(keepBetween) { -- delete this.raws.before; -- delete this.raws.after; -- if (!keepBetween) delete this.raws.between; -- } -- clone(overrides = {}) { -- let cloned = cloneNode(this); -- for (let name in overrides) { -- cloned[name] = overrides[name]; -- } -- return cloned; -- } -- cloneAfter(overrides = {}) { -- let cloned = this.clone(overrides); -- this.parent.insertAfter(this, cloned); -- return cloned; -- } -- cloneBefore(overrides = {}) { -- let cloned = this.clone(overrides); -- this.parent.insertBefore(this, cloned); -- return cloned; -- } -- error(message, opts = {}) { -- if (this.source) { -- let { end, start } = this.rangeBy(opts); -- return this.source.input.error( -- message, -- { column: start.column, line: start.line }, -- { column: end.column, line: end.line }, -- opts -- ); -- } -- return new CssSyntaxError$2(message); -- } -- getProxyProcessor() { -- return { -- get(node2, prop) { -- if (prop === "proxyOf") { -- return node2; -- } else if (prop === "root") { -- return () => node2.root().toProxy(); -- } else { -- return node2[prop]; -- } -- }, -- set(node2, prop, value) { -- if (node2[prop] === value) return true; -- node2[prop] = value; -- if (prop === "prop" || prop === "value" || prop === "name" || prop === "params" || prop === "important" || /* c8 ignore next */ -- prop === "text") { -- node2.markDirty(); -- } -- return true; -- } -- }; -- } -- markDirty() { -- if (this[isClean$2]) { -- this[isClean$2] = false; -- let next = this; -- while (next = next.parent) { -- next[isClean$2] = false; -- } -- } -- } -- next() { -- if (!this.parent) return void 0; -- let index2 = this.parent.index(this); -- return this.parent.nodes[index2 + 1]; -- } -- positionBy(opts, stringRepresentation) { -- let pos = this.source.start; -- if (opts.index) { -- pos = this.positionInside(opts.index, stringRepresentation); -- } else if (opts.word) { -- stringRepresentation = this.toString(); -- let index2 = stringRepresentation.indexOf(opts.word); -- if (index2 !== -1) pos = this.positionInside(index2, stringRepresentation); -- } -- return pos; -- } -- positionInside(index2, stringRepresentation) { -- let string = stringRepresentation || this.toString(); -- let column = this.source.start.column; -- let line = this.source.start.line; -- for (let i2 = 0; i2 < index2; i2++) { -- if (string[i2] === "\n") { -- column = 1; -- line += 1; -- } else { -- column += 1; -- } -- } -- return { column, line }; -- } -- prev() { -- if (!this.parent) return void 0; -- let index2 = this.parent.index(this); -- return this.parent.nodes[index2 - 1]; -- } -- rangeBy(opts) { -- let start = { -- column: this.source.start.column, -- line: this.source.start.line -- }; -- let end = this.source.end ? { -- column: this.source.end.column + 1, -- line: this.source.end.line -- } : { -- column: start.column + 1, -- line: start.line -- }; -- if (opts.word) { -- let stringRepresentation = this.toString(); -- let index2 = stringRepresentation.indexOf(opts.word); -- if (index2 !== -1) { -- start = this.positionInside(index2, stringRepresentation); -- end = this.positionInside(index2 + opts.word.length, stringRepresentation); -- } -- } else { -- if (opts.start) { -- start = { -- column: opts.start.column, -- line: opts.start.line -- }; -- } else if (opts.index) { -- start = this.positionInside(opts.index); -- } -- if (opts.end) { -- end = { -- column: opts.end.column, -- line: opts.end.line -- }; -- } else if (typeof opts.endIndex === "number") { -- end = this.positionInside(opts.endIndex); -- } else if (opts.index) { -- end = this.positionInside(opts.index + 1); -- } -- } -- if (end.line < start.line || end.line === start.line && end.column <= start.column) { -- end = { column: start.column + 1, line: start.line }; -- } -- return { end, start }; -- } -- raw(prop, defaultType) { -- let str = new Stringifier22(); -- return str.raw(this, prop, defaultType); -- } -- remove() { -- if (this.parent) { -- this.parent.removeChild(this); -- } -- this.parent = void 0; -- return this; -- } -- replaceWith(...nodes) { -- if (this.parent) { -- let bookmark = this; -- let foundSelf = false; -- for (let node2 of nodes) { -- if (node2 === this) { -- foundSelf = true; -- } else if (foundSelf) { -- this.parent.insertAfter(bookmark, node2); -- bookmark = node2; -- } else { -- this.parent.insertBefore(bookmark, node2); -- } -- } -- if (!foundSelf) { -- this.remove(); -- } -- } -- return this; -- } -- root() { -- let result2 = this; -- while (result2.parent && result2.parent.type !== "document") { -- result2 = result2.parent; -- } -- return result2; -- } -- toJSON(_, inputs) { -- let fixed = {}; -- let emitInputs = inputs == null; -- inputs = inputs || /* @__PURE__ */ new Map(); -- let inputsNextIndex = 0; -- for (let name in this) { -- if (!Object.prototype.hasOwnProperty.call(this, name)) { -- continue; -- } -- if (name === "parent" || name === "proxyCache") continue; -- let value = this[name]; -- if (Array.isArray(value)) { -- fixed[name] = value.map((i2) => { -- if (typeof i2 === "object" && i2.toJSON) { -- return i2.toJSON(null, inputs); -- } else { -- return i2; -- } -- }); -- } else if (typeof value === "object" && value.toJSON) { -- fixed[name] = value.toJSON(null, inputs); -- } else if (name === "source") { -- let inputId = inputs.get(value.input); -- if (inputId == null) { -- inputId = inputsNextIndex; -- inputs.set(value.input, inputsNextIndex); -- inputsNextIndex++; -- } -- fixed[name] = { -- end: value.end, -- inputId, -- start: value.start -- }; -- } else { -- fixed[name] = value; -- } -- } -- if (emitInputs) { -- fixed.inputs = [...inputs.keys()].map((input2) => input2.toJSON()); -- } -- return fixed; -- } -- toProxy() { -- if (!this.proxyCache) { -- this.proxyCache = new Proxy(this, this.getProxyProcessor()); -- } -- return this.proxyCache; -- } -- toString(stringifier2 = stringify$3) { -- if (stringifier2.stringify) stringifier2 = stringifier2.stringify; -- let result2 = ""; -- stringifier2(this, (i2) => { -- result2 += i2; -- }); -- return result2; -- } -- warn(result2, text, opts) { -- let data = { node: this }; -- for (let i2 in opts) data[i2] = opts[i2]; -- return result2.warn(text, data); -- } -- get proxyOf() { -- return this; -- } --}; --var node = Node$4; --Node$4.default = Node$4; --let Node$3 = node; --let Declaration$4 = class Declaration2 extends Node$3 { -- constructor(defaults) { -- if (defaults && typeof defaults.value !== "undefined" && typeof defaults.value !== "string") { -- defaults = { ...defaults, value: String(defaults.value) }; -- } -- super(defaults); -- this.type = "decl"; -- } -- get variable() { -- return this.prop.startsWith("--") || this.prop[0] === "$"; -- } --}; --var declaration = Declaration$4; --Declaration$4.default = Declaration$4; --let urlAlphabet = "useandom-26T198340PX75pxJACKVERYMINDBUSHWOLF_GQZbfghjklqvwyzrict"; --let customAlphabet = (alphabet, defaultSize = 21) => { -- return (size = defaultSize) => { -- let id = ""; -- let i2 = size; -- while (i2--) { -- id += alphabet[Math.random() * alphabet.length | 0]; -- } -- return id; -- }; --}; --let nanoid$1 = (size = 21) => { -- let id = ""; -- let i2 = size; -- while (i2--) { -- id += urlAlphabet[Math.random() * 64 | 0]; -- } -- return id; --}; --var nonSecure = { nanoid: nanoid$1, customAlphabet }; --let { SourceMapConsumer: SourceMapConsumer$2, SourceMapGenerator: SourceMapGenerator$2 } = require$$2; --let { existsSync, readFileSync } = require$$2; --let { dirname: dirname$1, join } = require$$2; --function fromBase64(str) { -- if (Buffer) { -- return Buffer.from(str, "base64").toString(); -- } else { -- return window.atob(str); -- } --} --let PreviousMap$2 = class PreviousMap2 { -- constructor(css, opts) { -- if (opts.map === false) return; -- this.loadAnnotation(css); -- this.inline = this.startWith(this.annotation, "data:"); -- let prev = opts.map ? opts.map.prev : void 0; -- let text = this.loadMap(opts.from, prev); -- if (!this.mapFile && opts.from) { -- this.mapFile = opts.from; -- } -- if (this.mapFile) this.root = dirname$1(this.mapFile); -- if (text) this.text = text; -- } -- consumer() { -- if (!this.consumerCache) { -- this.consumerCache = new SourceMapConsumer$2(this.text); -- } -- return this.consumerCache; -- } -- decodeInline(text) { -- let baseCharsetUri = /^data:application\/json;charset=utf-?8;base64,/; -- let baseUri = /^data:application\/json;base64,/; -- let charsetUri = /^data:application\/json;charset=utf-?8,/; -- let uri = /^data:application\/json,/; -- if (charsetUri.test(text) || uri.test(text)) { -- return decodeURIComponent(text.substr(RegExp.lastMatch.length)); -- } -- if (baseCharsetUri.test(text) || baseUri.test(text)) { -- return fromBase64(text.substr(RegExp.lastMatch.length)); -- } -- let encoding = text.match(/data:application\/json;([^,]+),/)[1]; -- throw new Error("Unsupported source map encoding " + encoding); -- } -- getAnnotationURL(sourceMapString) { -- return sourceMapString.replace(/^\/\*\s*# sourceMappingURL=/, "").trim(); -- } -- isMap(map) { -- if (typeof map !== "object") return false; -- return typeof map.mappings === "string" || typeof map._mappings === "string" || Array.isArray(map.sections); -- } -- loadAnnotation(css) { -- let comments = css.match(/\/\*\s*# sourceMappingURL=/gm); -- if (!comments) return; -- let start = css.lastIndexOf(comments.pop()); -- let end = css.indexOf("*/", start); -- if (start > -1 && end > -1) { -- this.annotation = this.getAnnotationURL(css.substring(start, end)); -- } -- } -- loadFile(path) { -- this.root = dirname$1(path); -- if (existsSync(path)) { -- this.mapFile = path; -- return readFileSync(path, "utf-8").toString().trim(); -- } -- } -- loadMap(file, prev) { -- if (prev === false) return false; -- if (prev) { -- if (typeof prev === "string") { -- return prev; -- } else if (typeof prev === "function") { -- let prevPath = prev(file); -- if (prevPath) { -- let map = this.loadFile(prevPath); -- if (!map) { -- throw new Error( -- "Unable to load previous source map: " + prevPath.toString() -- ); -- } -- return map; -- } -- } else if (prev instanceof SourceMapConsumer$2) { -- return SourceMapGenerator$2.fromSourceMap(prev).toString(); -- } else if (prev instanceof SourceMapGenerator$2) { -- return prev.toString(); -- } else if (this.isMap(prev)) { -- return JSON.stringify(prev); -- } else { -- throw new Error( -- "Unsupported previous source map format: " + prev.toString() -- ); -- } -- } else if (this.inline) { -- return this.decodeInline(this.annotation); -- } else if (this.annotation) { -- let map = this.annotation; -- if (file) map = join(dirname$1(file), map); -- return this.loadFile(map); -- } -- } -- startWith(string, start) { -- if (!string) return false; -- return string.substr(0, start.length) === start; -- } -- withContent() { -- return !!(this.consumer().sourcesContent && this.consumer().sourcesContent.length > 0); -- } --}; --var previousMap = PreviousMap$2; --PreviousMap$2.default = PreviousMap$2; --let { SourceMapConsumer: SourceMapConsumer$1, SourceMapGenerator: SourceMapGenerator$1 } = require$$2; --let { fileURLToPath, pathToFileURL: pathToFileURL$1 } = require$$2; --let { isAbsolute, resolve: resolve$1 } = require$$2; --let { nanoid } = nonSecure; --let terminalHighlight = require$$2; --let CssSyntaxError$1 = cssSyntaxError; --let PreviousMap$1 = previousMap; --let fromOffsetCache = Symbol("fromOffsetCache"); --let sourceMapAvailable$1 = Boolean(SourceMapConsumer$1 && SourceMapGenerator$1); --let pathAvailable$1 = Boolean(resolve$1 && isAbsolute); --let Input$4 = class Input2 { -- constructor(css, opts = {}) { -- if (css === null || typeof css === "undefined" || typeof css === "object" && !css.toString) { -- throw new Error(`PostCSS received ${css} instead of CSS string`); -- } -- this.css = css.toString(); -- if (this.css[0] === "\uFEFF" || this.css[0] === "￾") { -- this.hasBOM = true; -- this.css = this.css.slice(1); -- } else { -- this.hasBOM = false; -- } -- if (opts.from) { -- if (!pathAvailable$1 || /^\w+:\/\//.test(opts.from) || isAbsolute(opts.from)) { -- this.file = opts.from; -- } else { -- this.file = resolve$1(opts.from); -- } -- } -- if (pathAvailable$1 && sourceMapAvailable$1) { -- let map = new PreviousMap$1(this.css, opts); -- if (map.text) { -- this.map = map; -- let file = map.consumer().file; -- if (!this.file && file) this.file = this.mapResolve(file); -- } -- } -- if (!this.file) { -- this.id = ""; -- } -- if (this.map) this.map.file = this.from; -- } -- error(message, line, column, opts = {}) { -- let result2, endLine, endColumn; -- if (line && typeof line === "object") { -- let start = line; -- let end = column; -- if (typeof start.offset === "number") { -- let pos = this.fromOffset(start.offset); -- line = pos.line; -- column = pos.col; -- } else { -- line = start.line; -- column = start.column; -- } -- if (typeof end.offset === "number") { -- let pos = this.fromOffset(end.offset); -- endLine = pos.line; -- endColumn = pos.col; -- } else { -- endLine = end.line; -- endColumn = end.column; -- } -- } else if (!column) { -- let pos = this.fromOffset(line); -- line = pos.line; -- column = pos.col; -- } -- let origin = this.origin(line, column, endLine, endColumn); -- if (origin) { -- result2 = new CssSyntaxError$1( -- message, -- origin.endLine === void 0 ? origin.line : { column: origin.column, line: origin.line }, -- origin.endLine === void 0 ? origin.column : { column: origin.endColumn, line: origin.endLine }, -- origin.source, -- origin.file, -- opts.plugin -- ); -- } else { -- result2 = new CssSyntaxError$1( -- message, -- endLine === void 0 ? line : { column, line }, -- endLine === void 0 ? column : { column: endColumn, line: endLine }, -- this.css, -- this.file, -- opts.plugin -- ); -- } -- result2.input = { column, endColumn, endLine, line, source: this.css }; -- if (this.file) { -- if (pathToFileURL$1) { -- result2.input.url = pathToFileURL$1(this.file).toString(); -- } -- result2.input.file = this.file; -- } -- return result2; -- } -- fromOffset(offset) { -- let lastLine, lineToIndex; -- if (!this[fromOffsetCache]) { -- let lines = this.css.split("\n"); -- lineToIndex = new Array(lines.length); -- let prevIndex = 0; -- for (let i2 = 0, l2 = lines.length; i2 < l2; i2++) { -- lineToIndex[i2] = prevIndex; -- prevIndex += lines[i2].length + 1; -- } -- this[fromOffsetCache] = lineToIndex; -- } else { -- lineToIndex = this[fromOffsetCache]; -- } -- lastLine = lineToIndex[lineToIndex.length - 1]; -- let min = 0; -- if (offset >= lastLine) { -- min = lineToIndex.length - 1; -- } else { -- let max = lineToIndex.length - 2; -- let mid; -- while (min < max) { -- mid = min + (max - min >> 1); -- if (offset < lineToIndex[mid]) { -- max = mid - 1; -- } else if (offset >= lineToIndex[mid + 1]) { -- min = mid + 1; -- } else { -- min = mid; -- break; -- } -- } -- } -- return { -- col: offset - lineToIndex[min] + 1, -- line: min + 1 -- }; -- } -- mapResolve(file) { -- if (/^\w+:\/\//.test(file)) { -- return file; -- } -- return resolve$1(this.map.consumer().sourceRoot || this.map.root || ".", file); -- } -- origin(line, column, endLine, endColumn) { -- if (!this.map) return false; -- let consumer = this.map.consumer(); -- let from = consumer.originalPositionFor({ column, line }); -- if (!from.source) return false; -- let to; -- if (typeof endLine === "number") { -- to = consumer.originalPositionFor({ column: endColumn, line: endLine }); -- } -- let fromUrl; -- if (isAbsolute(from.source)) { -- fromUrl = pathToFileURL$1(from.source); -- } else { -- fromUrl = new URL( -- from.source, -- this.map.consumer().sourceRoot || pathToFileURL$1(this.map.mapFile) -- ); -- } -- let result2 = { -- column: from.column, -- endColumn: to && to.column, -- endLine: to && to.line, -- line: from.line, -- url: fromUrl.toString() -- }; -- if (fromUrl.protocol === "file:") { -- if (fileURLToPath) { -- result2.file = fileURLToPath(fromUrl); -- } else { -- throw new Error(`file: protocol is not available in this PostCSS build`); -- } -- } -- let source = consumer.sourceContentFor(from.source); -- if (source) result2.source = source; -- return result2; -- } -- toJSON() { -- let json = {}; -- for (let name of ["hasBOM", "css", "file", "id"]) { -- if (this[name] != null) { -- json[name] = this[name]; -- } -- } -- if (this.map) { -- json.map = { ...this.map }; -- if (json.map.consumerCache) { -- json.map.consumerCache = void 0; -- } -- } -- return json; -- } -- get from() { -- return this.file || this.id; -- } --}; --var input = Input$4; --Input$4.default = Input$4; --if (terminalHighlight && terminalHighlight.registerInput) { -- terminalHighlight.registerInput(Input$4); --} --let { SourceMapConsumer, SourceMapGenerator } = require$$2; --let { dirname, relative, resolve, sep } = require$$2; --let { pathToFileURL } = require$$2; --let Input$3 = input; --let sourceMapAvailable = Boolean(SourceMapConsumer && SourceMapGenerator); --let pathAvailable = Boolean(dirname && resolve && relative && sep); --let MapGenerator$2 = class MapGenerator2 { -- constructor(stringify2, root2, opts, cssString) { -- this.stringify = stringify2; -- this.mapOpts = opts.map || {}; -- this.root = root2; -- this.opts = opts; -- this.css = cssString; -- this.originalCSS = cssString; -- this.usesFileUrls = !this.mapOpts.from && this.mapOpts.absolute; -- this.memoizedFileURLs = /* @__PURE__ */ new Map(); -- this.memoizedPaths = /* @__PURE__ */ new Map(); -- this.memoizedURLs = /* @__PURE__ */ new Map(); -- } -- addAnnotation() { -- let content; -- if (this.isInline()) { -- content = "data:application/json;base64," + this.toBase64(this.map.toString()); -- } else if (typeof this.mapOpts.annotation === "string") { -- content = this.mapOpts.annotation; -- } else if (typeof this.mapOpts.annotation === "function") { -- content = this.mapOpts.annotation(this.opts.to, this.root); -- } else { -- content = this.outputFile() + ".map"; -- } -- let eol = "\n"; -- if (this.css.includes("\r\n")) eol = "\r\n"; -- this.css += eol + "/*# sourceMappingURL=" + content + " */"; -- } -- applyPrevMaps() { -- for (let prev of this.previous()) { -- let from = this.toUrl(this.path(prev.file)); -- let root2 = prev.root || dirname(prev.file); -- let map; -- if (this.mapOpts.sourcesContent === false) { -- map = new SourceMapConsumer(prev.text); -- if (map.sourcesContent) { -- map.sourcesContent = null; -- } -- } else { -- map = prev.consumer(); -- } -- this.map.applySourceMap(map, from, this.toUrl(this.path(root2))); -- } -- } -- clearAnnotation() { -- if (this.mapOpts.annotation === false) return; -- if (this.root) { -- let node2; -- for (let i2 = this.root.nodes.length - 1; i2 >= 0; i2--) { -- node2 = this.root.nodes[i2]; -- if (node2.type !== "comment") continue; -- if (node2.text.indexOf("# sourceMappingURL=") === 0) { -- this.root.removeChild(i2); -- } -- } -- } else if (this.css) { -- this.css = this.css.replace(/\n*?\/\*#[\S\s]*?\*\/$/gm, ""); -- } -- } -- generate() { -- this.clearAnnotation(); -- if (pathAvailable && sourceMapAvailable && this.isMap()) { -- return this.generateMap(); -- } else { -- let result2 = ""; -- this.stringify(this.root, (i2) => { -- result2 += i2; -- }); -- return [result2]; -- } -- } -- generateMap() { -- if (this.root) { -- this.generateString(); -- } else if (this.previous().length === 1) { -- let prev = this.previous()[0].consumer(); -- prev.file = this.outputFile(); -- this.map = SourceMapGenerator.fromSourceMap(prev, { -- ignoreInvalidMapping: true -- }); -- } else { -- this.map = new SourceMapGenerator({ -- file: this.outputFile(), -- ignoreInvalidMapping: true -- }); -- this.map.addMapping({ -- generated: { column: 0, line: 1 }, -- original: { column: 0, line: 1 }, -- source: this.opts.from ? this.toUrl(this.path(this.opts.from)) : "" -- }); -- } -- if (this.isSourcesContent()) this.setSourcesContent(); -- if (this.root && this.previous().length > 0) this.applyPrevMaps(); -- if (this.isAnnotation()) this.addAnnotation(); -- if (this.isInline()) { -- return [this.css]; -- } else { -- return [this.css, this.map]; -- } -- } -- generateString() { -- this.css = ""; -- this.map = new SourceMapGenerator({ -- file: this.outputFile(), -- ignoreInvalidMapping: true -- }); -- let line = 1; -- let column = 1; -- let noSource = ""; -- let mapping = { -- generated: { column: 0, line: 0 }, -- original: { column: 0, line: 0 }, -- source: "" -- }; -- let lines, last; -- this.stringify(this.root, (str, node2, type) => { -- this.css += str; -- if (node2 && type !== "end") { -- mapping.generated.line = line; -- mapping.generated.column = column - 1; -- if (node2.source && node2.source.start) { -- mapping.source = this.sourcePath(node2); -- mapping.original.line = node2.source.start.line; -- mapping.original.column = node2.source.start.column - 1; -- this.map.addMapping(mapping); -- } else { -- mapping.source = noSource; -- mapping.original.line = 1; -- mapping.original.column = 0; -- this.map.addMapping(mapping); -- } -- } -- lines = str.match(/\n/g); -- if (lines) { -- line += lines.length; -- last = str.lastIndexOf("\n"); -- column = str.length - last; -- } else { -- column += str.length; -- } -- if (node2 && type !== "start") { -- let p = node2.parent || { raws: {} }; -- let childless = node2.type === "decl" || node2.type === "atrule" && !node2.nodes; -- if (!childless || node2 !== p.last || p.raws.semicolon) { -- if (node2.source && node2.source.end) { -- mapping.source = this.sourcePath(node2); -- mapping.original.line = node2.source.end.line; -- mapping.original.column = node2.source.end.column - 1; -- mapping.generated.line = line; -- mapping.generated.column = column - 2; -- this.map.addMapping(mapping); -- } else { -- mapping.source = noSource; -- mapping.original.line = 1; -- mapping.original.column = 0; -- mapping.generated.line = line; -- mapping.generated.column = column - 1; -- this.map.addMapping(mapping); -- } -- } -- } -- }); -- } -- isAnnotation() { -- if (this.isInline()) { -- return true; -- } -- if (typeof this.mapOpts.annotation !== "undefined") { -- return this.mapOpts.annotation; -- } -- if (this.previous().length) { -- return this.previous().some((i2) => i2.annotation); -- } -- return true; -- } -- isInline() { -- if (typeof this.mapOpts.inline !== "undefined") { -- return this.mapOpts.inline; -- } -- let annotation = this.mapOpts.annotation; -- if (typeof annotation !== "undefined" && annotation !== true) { -- return false; -- } -- if (this.previous().length) { -- return this.previous().some((i2) => i2.inline); -- } -- return true; -- } -- isMap() { -- if (typeof this.opts.map !== "undefined") { -- return !!this.opts.map; -- } -- return this.previous().length > 0; -- } -- isSourcesContent() { -- if (typeof this.mapOpts.sourcesContent !== "undefined") { -- return this.mapOpts.sourcesContent; -- } -- if (this.previous().length) { -- return this.previous().some((i2) => i2.withContent()); -- } -- return true; -- } -- outputFile() { -- if (this.opts.to) { -- return this.path(this.opts.to); -- } else if (this.opts.from) { -- return this.path(this.opts.from); -- } else { -- return "to.css"; -- } -- } -- path(file) { -- if (this.mapOpts.absolute) return file; -- if (file.charCodeAt(0) === 60) return file; -- if (/^\w+:\/\//.test(file)) return file; -- let cached = this.memoizedPaths.get(file); -- if (cached) return cached; -- let from = this.opts.to ? dirname(this.opts.to) : "."; -- if (typeof this.mapOpts.annotation === "string") { -- from = dirname(resolve(from, this.mapOpts.annotation)); -- } -- let path = relative(from, file); -- this.memoizedPaths.set(file, path); -- return path; -- } -- previous() { -- if (!this.previousMaps) { -- this.previousMaps = []; -- if (this.root) { -- this.root.walk((node2) => { -- if (node2.source && node2.source.input.map) { -- let map = node2.source.input.map; -- if (!this.previousMaps.includes(map)) { -- this.previousMaps.push(map); -- } -- } -- }); -- } else { -- let input2 = new Input$3(this.originalCSS, this.opts); -- if (input2.map) this.previousMaps.push(input2.map); -- } -- } -- return this.previousMaps; -- } -- setSourcesContent() { -- let already = {}; -- if (this.root) { -- this.root.walk((node2) => { -- if (node2.source) { -- let from = node2.source.input.from; -- if (from && !already[from]) { -- already[from] = true; -- let fromUrl = this.usesFileUrls ? this.toFileUrl(from) : this.toUrl(this.path(from)); -- this.map.setSourceContent(fromUrl, node2.source.input.css); -- } -- } -- }); -- } else if (this.css) { -- let from = this.opts.from ? this.toUrl(this.path(this.opts.from)) : ""; -- this.map.setSourceContent(from, this.css); -- } -- } -- sourcePath(node2) { -- if (this.mapOpts.from) { -- return this.toUrl(this.mapOpts.from); -- } else if (this.usesFileUrls) { -- return this.toFileUrl(node2.source.input.from); -- } else { -- return this.toUrl(this.path(node2.source.input.from)); -- } -- } -- toBase64(str) { -- if (Buffer) { -- return Buffer.from(str).toString("base64"); -- } else { -- return window.btoa(unescape(encodeURIComponent(str))); -- } -- } -- toFileUrl(path) { -- let cached = this.memoizedFileURLs.get(path); -- if (cached) return cached; -- if (pathToFileURL) { -- let fileURL = pathToFileURL(path).toString(); -- this.memoizedFileURLs.set(path, fileURL); -- return fileURL; -- } else { -- throw new Error( -- "`map.absolute` option is not available in this PostCSS build" -- ); -- } -- } -- toUrl(path) { -- let cached = this.memoizedURLs.get(path); -- if (cached) return cached; -- if (sep === "\\") { -- path = path.replace(/\\/g, "/"); -- } -- let url = encodeURI(path).replace(/[#?]/g, encodeURIComponent); -- this.memoizedURLs.set(path, url); -- return url; -- } --}; --var mapGenerator = MapGenerator$2; --let Node$2 = node; --let Comment$4 = class Comment2 extends Node$2 { -- constructor(defaults) { -- super(defaults); -- this.type = "comment"; -- } --}; --var comment = Comment$4; --Comment$4.default = Comment$4; --let { isClean: isClean$1, my: my$1 } = symbols; --let Declaration$3 = declaration; --let Comment$3 = comment; --let Node$1 = node; --let parse$4, Rule$4, AtRule$4, Root$6; --function cleanSource(nodes) { -- return nodes.map((i2) => { -- if (i2.nodes) i2.nodes = cleanSource(i2.nodes); -- delete i2.source; -- return i2; -- }); --} --function markDirtyUp(node2) { -- node2[isClean$1] = false; -- if (node2.proxyOf.nodes) { -- for (let i2 of node2.proxyOf.nodes) { -- markDirtyUp(i2); -- } -- } --} --let Container$7 = class Container2 extends Node$1 { -- append(...children) { -- for (let child of children) { -- let nodes = this.normalize(child, this.last); -- for (let node2 of nodes) this.proxyOf.nodes.push(node2); -- } -- this.markDirty(); -- return this; -- } -- cleanRaws(keepBetween) { -- super.cleanRaws(keepBetween); -- if (this.nodes) { -- for (let node2 of this.nodes) node2.cleanRaws(keepBetween); -- } -- } -- each(callback) { -- if (!this.proxyOf.nodes) return void 0; -- let iterator = this.getIterator(); -- let index2, result2; -- while (this.indexes[iterator] < this.proxyOf.nodes.length) { -- index2 = this.indexes[iterator]; -- result2 = callback(this.proxyOf.nodes[index2], index2); -- if (result2 === false) break; -- this.indexes[iterator] += 1; -- } -- delete this.indexes[iterator]; -- return result2; -- } -- every(condition) { -- return this.nodes.every(condition); -- } -- getIterator() { -- if (!this.lastEach) this.lastEach = 0; -- if (!this.indexes) this.indexes = {}; -- this.lastEach += 1; -- let iterator = this.lastEach; -- this.indexes[iterator] = 0; -- return iterator; -- } -- getProxyProcessor() { -- return { -- get(node2, prop) { -- if (prop === "proxyOf") { -- return node2; -- } else if (!node2[prop]) { -- return node2[prop]; -- } else if (prop === "each" || typeof prop === "string" && prop.startsWith("walk")) { -- return (...args) => { -- return node2[prop]( -- ...args.map((i2) => { -- if (typeof i2 === "function") { -- return (child, index2) => i2(child.toProxy(), index2); -- } else { -- return i2; -- } -- }) -- ); -- }; -- } else if (prop === "every" || prop === "some") { -- return (cb) => { -- return node2[prop]( -- (child, ...other) => cb(child.toProxy(), ...other) -- ); -- }; -- } else if (prop === "root") { -- return () => node2.root().toProxy(); -- } else if (prop === "nodes") { -- return node2.nodes.map((i2) => i2.toProxy()); -- } else if (prop === "first" || prop === "last") { -- return node2[prop].toProxy(); -- } else { -- return node2[prop]; -- } -- }, -- set(node2, prop, value) { -- if (node2[prop] === value) return true; -- node2[prop] = value; -- if (prop === "name" || prop === "params" || prop === "selector") { -- node2.markDirty(); -- } -- return true; -- } -- }; -- } -- index(child) { -- if (typeof child === "number") return child; -- if (child.proxyOf) child = child.proxyOf; -- return this.proxyOf.nodes.indexOf(child); -- } -- insertAfter(exist, add) { -- let existIndex = this.index(exist); -- let nodes = this.normalize(add, this.proxyOf.nodes[existIndex]).reverse(); -- existIndex = this.index(exist); -- for (let node2 of nodes) this.proxyOf.nodes.splice(existIndex + 1, 0, node2); -- let index2; -- for (let id in this.indexes) { -- index2 = this.indexes[id]; -- if (existIndex < index2) { -- this.indexes[id] = index2 + nodes.length; -- } -- } -- this.markDirty(); -- return this; -- } -- insertBefore(exist, add) { -- let existIndex = this.index(exist); -- let type = existIndex === 0 ? "prepend" : false; -- let nodes = this.normalize(add, this.proxyOf.nodes[existIndex], type).reverse(); -- existIndex = this.index(exist); -- for (let node2 of nodes) this.proxyOf.nodes.splice(existIndex, 0, node2); -- let index2; -- for (let id in this.indexes) { -- index2 = this.indexes[id]; -- if (existIndex <= index2) { -- this.indexes[id] = index2 + nodes.length; -- } -- } -- this.markDirty(); -- return this; -- } -- normalize(nodes, sample) { -- if (typeof nodes === "string") { -- nodes = cleanSource(parse$4(nodes).nodes); -- } else if (typeof nodes === "undefined") { -- nodes = []; -- } else if (Array.isArray(nodes)) { -- nodes = nodes.slice(0); -- for (let i2 of nodes) { -- if (i2.parent) i2.parent.removeChild(i2, "ignore"); -- } -- } else if (nodes.type === "root" && this.type !== "document") { -- nodes = nodes.nodes.slice(0); -- for (let i2 of nodes) { -- if (i2.parent) i2.parent.removeChild(i2, "ignore"); -- } -- } else if (nodes.type) { -- nodes = [nodes]; -- } else if (nodes.prop) { -- if (typeof nodes.value === "undefined") { -- throw new Error("Value field is missed in node creation"); -- } else if (typeof nodes.value !== "string") { -- nodes.value = String(nodes.value); -- } -- nodes = [new Declaration$3(nodes)]; -- } else if (nodes.selector) { -- nodes = [new Rule$4(nodes)]; -- } else if (nodes.name) { -- nodes = [new AtRule$4(nodes)]; -- } else if (nodes.text) { -- nodes = [new Comment$3(nodes)]; -- } else { -- throw new Error("Unknown node type in node creation"); -- } -- let processed = nodes.map((i2) => { -- if (!i2[my$1]) Container2.rebuild(i2); -- i2 = i2.proxyOf; -- if (i2.parent) i2.parent.removeChild(i2); -- if (i2[isClean$1]) markDirtyUp(i2); -- if (typeof i2.raws.before === "undefined") { -- if (sample && typeof sample.raws.before !== "undefined") { -- i2.raws.before = sample.raws.before.replace(/\S/g, ""); -- } -- } -- i2.parent = this.proxyOf; -- return i2; -- }); -- return processed; -- } -- prepend(...children) { -- children = children.reverse(); -- for (let child of children) { -- let nodes = this.normalize(child, this.first, "prepend").reverse(); -- for (let node2 of nodes) this.proxyOf.nodes.unshift(node2); -- for (let id in this.indexes) { -- this.indexes[id] = this.indexes[id] + nodes.length; -- } -- } -- this.markDirty(); -- return this; -- } -- push(child) { -- child.parent = this; -- this.proxyOf.nodes.push(child); -- return this; -- } -- removeAll() { -- for (let node2 of this.proxyOf.nodes) node2.parent = void 0; -- this.proxyOf.nodes = []; -- this.markDirty(); -- return this; -- } -- removeChild(child) { -- child = this.index(child); -- this.proxyOf.nodes[child].parent = void 0; -- this.proxyOf.nodes.splice(child, 1); -- let index2; -- for (let id in this.indexes) { -- index2 = this.indexes[id]; -- if (index2 >= child) { -- this.indexes[id] = index2 - 1; -- } -- } -- this.markDirty(); -- return this; -- } -- replaceValues(pattern, opts, callback) { -- if (!callback) { -- callback = opts; -- opts = {}; -- } -- this.walkDecls((decl) => { -- if (opts.props && !opts.props.includes(decl.prop)) return; -- if (opts.fast && !decl.value.includes(opts.fast)) return; -- decl.value = decl.value.replace(pattern, callback); -- }); -- this.markDirty(); -- return this; -- } -- some(condition) { -- return this.nodes.some(condition); -- } -- walk(callback) { -- return this.each((child, i2) => { -- let result2; -- try { -- result2 = callback(child, i2); -- } catch (e2) { -- throw child.addToError(e2); -- } -- if (result2 !== false && child.walk) { -- result2 = child.walk(callback); -- } -- return result2; -- }); -- } -- walkAtRules(name, callback) { -- if (!callback) { -- callback = name; -- return this.walk((child, i2) => { -- if (child.type === "atrule") { -- return callback(child, i2); -- } -- }); -- } -- if (name instanceof RegExp) { -- return this.walk((child, i2) => { -- if (child.type === "atrule" && name.test(child.name)) { -- return callback(child, i2); -- } -- }); -- } -- return this.walk((child, i2) => { -- if (child.type === "atrule" && child.name === name) { -- return callback(child, i2); -- } -- }); -- } -- walkComments(callback) { -- return this.walk((child, i2) => { -- if (child.type === "comment") { -- return callback(child, i2); -- } -- }); -- } -- walkDecls(prop, callback) { -- if (!callback) { -- callback = prop; -- return this.walk((child, i2) => { -- if (child.type === "decl") { -- return callback(child, i2); -- } -- }); -- } -- if (prop instanceof RegExp) { -- return this.walk((child, i2) => { -- if (child.type === "decl" && prop.test(child.prop)) { -- return callback(child, i2); -- } -- }); -- } -- return this.walk((child, i2) => { -- if (child.type === "decl" && child.prop === prop) { -- return callback(child, i2); -- } -- }); -- } -- walkRules(selector, callback) { -- if (!callback) { -- callback = selector; -- return this.walk((child, i2) => { -- if (child.type === "rule") { -- return callback(child, i2); -- } -- }); -- } -- if (selector instanceof RegExp) { -- return this.walk((child, i2) => { -- if (child.type === "rule" && selector.test(child.selector)) { -- return callback(child, i2); -- } -- }); -- } -- return this.walk((child, i2) => { -- if (child.type === "rule" && child.selector === selector) { -- return callback(child, i2); -- } -- }); -- } -- get first() { -- if (!this.proxyOf.nodes) return void 0; -- return this.proxyOf.nodes[0]; -- } -- get last() { -- if (!this.proxyOf.nodes) return void 0; -- return this.proxyOf.nodes[this.proxyOf.nodes.length - 1]; -- } --}; --Container$7.registerParse = (dependant) => { -- parse$4 = dependant; --}; --Container$7.registerRule = (dependant) => { -- Rule$4 = dependant; --}; --Container$7.registerAtRule = (dependant) => { -- AtRule$4 = dependant; --}; --Container$7.registerRoot = (dependant) => { -- Root$6 = dependant; --}; --var container = Container$7; --Container$7.default = Container$7; --Container$7.rebuild = (node2) => { -- if (node2.type === "atrule") { -- Object.setPrototypeOf(node2, AtRule$4.prototype); -- } else if (node2.type === "rule") { -- Object.setPrototypeOf(node2, Rule$4.prototype); -- } else if (node2.type === "decl") { -- Object.setPrototypeOf(node2, Declaration$3.prototype); -- } else if (node2.type === "comment") { -- Object.setPrototypeOf(node2, Comment$3.prototype); -- } else if (node2.type === "root") { -- Object.setPrototypeOf(node2, Root$6.prototype); -- } -- node2[my$1] = true; -- if (node2.nodes) { -- node2.nodes.forEach((child) => { -- Container$7.rebuild(child); -- }); -- } --}; --let Container$6 = container; --let LazyResult$4, Processor$3; --let Document$3 = class Document23 extends Container$6 { -- constructor(defaults) { -- super({ type: "document", ...defaults }); -- if (!this.nodes) { -- this.nodes = []; -- } -- } -- toResult(opts = {}) { -- let lazy = new LazyResult$4(new Processor$3(), this, opts); -- return lazy.stringify(); -- } --}; --Document$3.registerLazyResult = (dependant) => { -- LazyResult$4 = dependant; --}; --Document$3.registerProcessor = (dependant) => { -- Processor$3 = dependant; --}; --var document$1 = Document$3; --Document$3.default = Document$3; --let printed = {}; --var warnOnce$2 = function warnOnce2(message) { -- if (printed[message]) return; -- printed[message] = true; -- if (typeof console !== "undefined" && console.warn) { -- console.warn(message); -- } --}; --let Warning$2 = class Warning2 { -- constructor(text, opts = {}) { -- this.type = "warning"; -- this.text = text; -- if (opts.node && opts.node.source) { -- let range = opts.node.rangeBy(opts); -- this.line = range.start.line; -- this.column = range.start.column; -- this.endLine = range.end.line; -- this.endColumn = range.end.column; -- } -- for (let opt in opts) this[opt] = opts[opt]; -- } -- toString() { -- if (this.node) { -- return this.node.error(this.text, { -- index: this.index, -- plugin: this.plugin, -- word: this.word -- }).message; -- } -- if (this.plugin) { -- return this.plugin + ": " + this.text; -- } -- return this.text; -- } --}; --var warning = Warning$2; --Warning$2.default = Warning$2; --let Warning$1 = warning; --let Result$3 = class Result2 { -- constructor(processor2, root2, opts) { -- this.processor = processor2; -- this.messages = []; -- this.root = root2; -- this.opts = opts; -- this.css = void 0; -- this.map = void 0; -- } -- toString() { -- return this.css; -- } -- warn(text, opts = {}) { -- if (!opts.plugin) { -- if (this.lastPlugin && this.lastPlugin.postcssPlugin) { -- opts.plugin = this.lastPlugin.postcssPlugin; -- } -- } -- let warning2 = new Warning$1(text, opts); -- this.messages.push(warning2); -- return warning2; -- } -- warnings() { -- return this.messages.filter((i2) => i2.type === "warning"); -- } -- get content() { -- return this.css; -- } --}; --var result = Result$3; --Result$3.default = Result$3; --const SINGLE_QUOTE = "'".charCodeAt(0); --const DOUBLE_QUOTE = '"'.charCodeAt(0); --const BACKSLASH = "\\".charCodeAt(0); --const SLASH = "/".charCodeAt(0); --const NEWLINE = "\n".charCodeAt(0); --const SPACE = " ".charCodeAt(0); --const FEED = "\f".charCodeAt(0); --const TAB = " ".charCodeAt(0); --const CR = "\r".charCodeAt(0); --const OPEN_SQUARE = "[".charCodeAt(0); --const CLOSE_SQUARE = "]".charCodeAt(0); --const OPEN_PARENTHESES = "(".charCodeAt(0); --const CLOSE_PARENTHESES = ")".charCodeAt(0); --const OPEN_CURLY = "{".charCodeAt(0); --const CLOSE_CURLY = "}".charCodeAt(0); --const SEMICOLON = ";".charCodeAt(0); --const ASTERISK = "*".charCodeAt(0); --const COLON = ":".charCodeAt(0); --const AT = "@".charCodeAt(0); --const RE_AT_END = /[\t\n\f\r "#'()/;[\\\]{}]/g; --const RE_WORD_END = /[\t\n\f\r !"#'():;@[\\\]{}]|\/(?=\*)/g; --const RE_BAD_BRACKET = /.[\r\n"'(/\\]/; --const RE_HEX_ESCAPE = /[\da-f]/i; --var tokenize = function tokenizer2(input2, options = {}) { -- let css = input2.css.valueOf(); -- let ignore = options.ignoreErrors; -- let code, next, quote, content, escape; -- let escaped, escapePos, prev, n2, currentToken; -- let length = css.length; -- let pos = 0; -- let buffer = []; -- let returned = []; -- function position() { -- return pos; -- } -- function unclosed(what) { -- throw input2.error("Unclosed " + what, pos); -- } -- function endOfFile() { -- return returned.length === 0 && pos >= length; -- } -- function nextToken(opts) { -- if (returned.length) return returned.pop(); -- if (pos >= length) return; -- let ignoreUnclosed = opts ? opts.ignoreUnclosed : false; -- code = css.charCodeAt(pos); -- switch (code) { -- case NEWLINE: -- case SPACE: -- case TAB: -- case CR: -- case FEED: { -- next = pos; -- do { -- next += 1; -- code = css.charCodeAt(next); -- } while (code === SPACE || code === NEWLINE || code === TAB || code === CR || code === FEED); -- currentToken = ["space", css.slice(pos, next)]; -- pos = next - 1; -- break; -- } -- case OPEN_SQUARE: -- case CLOSE_SQUARE: -- case OPEN_CURLY: -- case CLOSE_CURLY: -- case COLON: -- case SEMICOLON: -- case CLOSE_PARENTHESES: { -- let controlChar = String.fromCharCode(code); -- currentToken = [controlChar, controlChar, pos]; -- break; -- } -- case OPEN_PARENTHESES: { -- prev = buffer.length ? buffer.pop()[1] : ""; -- n2 = css.charCodeAt(pos + 1); -- if (prev === "url" && n2 !== SINGLE_QUOTE && n2 !== DOUBLE_QUOTE && n2 !== SPACE && n2 !== NEWLINE && n2 !== TAB && n2 !== FEED && n2 !== CR) { -- next = pos; -- do { -- escaped = false; -- next = css.indexOf(")", next + 1); -- if (next === -1) { -- if (ignore || ignoreUnclosed) { -- next = pos; -- break; -- } else { -- unclosed("bracket"); -- } -- } -- escapePos = next; -- while (css.charCodeAt(escapePos - 1) === BACKSLASH) { -- escapePos -= 1; -- escaped = !escaped; -- } -- } while (escaped); -- currentToken = ["brackets", css.slice(pos, next + 1), pos, next]; -- pos = next; -- } else { -- next = css.indexOf(")", pos + 1); -- content = css.slice(pos, next + 1); -- if (next === -1 || RE_BAD_BRACKET.test(content)) { -- currentToken = ["(", "(", pos]; -- } else { -- currentToken = ["brackets", content, pos, next]; -- pos = next; -- } -- } -- break; -- } -- case SINGLE_QUOTE: -- case DOUBLE_QUOTE: { -- quote = code === SINGLE_QUOTE ? "'" : '"'; -- next = pos; -- do { -- escaped = false; -- next = css.indexOf(quote, next + 1); -- if (next === -1) { -- if (ignore || ignoreUnclosed) { -- next = pos + 1; -- break; -- } else { -- unclosed("string"); -- } -- } -- escapePos = next; -- while (css.charCodeAt(escapePos - 1) === BACKSLASH) { -- escapePos -= 1; -- escaped = !escaped; -- } -- } while (escaped); -- currentToken = ["string", css.slice(pos, next + 1), pos, next]; -- pos = next; -- break; -- } -- case AT: { -- RE_AT_END.lastIndex = pos + 1; -- RE_AT_END.test(css); -- if (RE_AT_END.lastIndex === 0) { -- next = css.length - 1; -- } else { -- next = RE_AT_END.lastIndex - 2; -- } -- currentToken = ["at-word", css.slice(pos, next + 1), pos, next]; -- pos = next; -- break; -- } -- case BACKSLASH: { -- next = pos; -- escape = true; -- while (css.charCodeAt(next + 1) === BACKSLASH) { -- next += 1; -- escape = !escape; -- } -- code = css.charCodeAt(next + 1); -- if (escape && code !== SLASH && code !== SPACE && code !== NEWLINE && code !== TAB && code !== CR && code !== FEED) { -- next += 1; -- if (RE_HEX_ESCAPE.test(css.charAt(next))) { -- while (RE_HEX_ESCAPE.test(css.charAt(next + 1))) { -- next += 1; -- } -- if (css.charCodeAt(next + 1) === SPACE) { -- next += 1; -- } -- } -- } -- currentToken = ["word", css.slice(pos, next + 1), pos, next]; -- pos = next; -- break; -- } -- default: { -- if (code === SLASH && css.charCodeAt(pos + 1) === ASTERISK) { -- next = css.indexOf("*/", pos + 2) + 1; -- if (next === 0) { -- if (ignore || ignoreUnclosed) { -- next = css.length; -- } else { -- unclosed("comment"); -- } -- } -- currentToken = ["comment", css.slice(pos, next + 1), pos, next]; -- pos = next; -- } else { -- RE_WORD_END.lastIndex = pos + 1; -- RE_WORD_END.test(css); -- if (RE_WORD_END.lastIndex === 0) { -- next = css.length - 1; -- } else { -- next = RE_WORD_END.lastIndex - 2; -- } -- currentToken = ["word", css.slice(pos, next + 1), pos, next]; -- buffer.push(currentToken); -- pos = next; -- } -- break; -- } -- } -- pos++; -- return currentToken; -- } -- function back(token) { -- returned.push(token); -- } -- return { -- back, -- endOfFile, -- nextToken, -- position -- }; --}; --let Container$5 = container; --let AtRule$3 = class AtRule2 extends Container$5 { -- constructor(defaults) { -- super(defaults); -- this.type = "atrule"; -- } -- append(...children) { -- if (!this.proxyOf.nodes) this.nodes = []; -- return super.append(...children); -- } -- prepend(...children) { -- if (!this.proxyOf.nodes) this.nodes = []; -- return super.prepend(...children); -- } --}; --var atRule = AtRule$3; --AtRule$3.default = AtRule$3; --Container$5.registerAtRule(AtRule$3); --let Container$4 = container; --let LazyResult$3, Processor$2; --let Root$5 = class Root2 extends Container$4 { -- constructor(defaults) { -- super(defaults); -- this.type = "root"; -- if (!this.nodes) this.nodes = []; -- } -- normalize(child, sample, type) { -- let nodes = super.normalize(child); -- if (sample) { -- if (type === "prepend") { -- if (this.nodes.length > 1) { -- sample.raws.before = this.nodes[1].raws.before; -- } else { -- delete sample.raws.before; -- } -- } else if (this.first !== sample) { -- for (let node2 of nodes) { -- node2.raws.before = sample.raws.before; -- } -- } -- } -- return nodes; -- } -- removeChild(child, ignore) { -- let index2 = this.index(child); -- if (!ignore && index2 === 0 && this.nodes.length > 1) { -- this.nodes[1].raws.before = this.nodes[index2].raws.before; -- } -- return super.removeChild(child); -- } -- toResult(opts = {}) { -- let lazy = new LazyResult$3(new Processor$2(), this, opts); -- return lazy.stringify(); -- } --}; --Root$5.registerLazyResult = (dependant) => { -- LazyResult$3 = dependant; --}; --Root$5.registerProcessor = (dependant) => { -- Processor$2 = dependant; --}; --var root = Root$5; --Root$5.default = Root$5; --Container$4.registerRoot(Root$5); --let list$2 = { -- comma(string) { -- return list$2.split(string, [","], true); -- }, -- space(string) { -- let spaces = [" ", "\n", " "]; -- return list$2.split(string, spaces); -- }, -- split(string, separators, last) { -- let array = []; -- let current = ""; -- let split = false; -- let func = 0; -- let inQuote = false; -- let prevQuote = ""; -- let escape = false; -- for (let letter of string) { -- if (escape) { -- escape = false; -- } else if (letter === "\\") { -- escape = true; -- } else if (inQuote) { -- if (letter === prevQuote) { -- inQuote = false; -- } -- } else if (letter === '"' || letter === "'") { -- inQuote = true; -- prevQuote = letter; -- } else if (letter === "(") { -- func += 1; -- } else if (letter === ")") { -- if (func > 0) func -= 1; -- } else if (func === 0) { -- if (separators.includes(letter)) split = true; -- } -- if (split) { -- if (current !== "") array.push(current.trim()); -- current = ""; -- split = false; -- } else { -- current += letter; -- } -- } -- if (last || current !== "") array.push(current.trim()); -- return array; -- } --}; --var list_1 = list$2; --list$2.default = list$2; --let Container$3 = container; --let list$1 = list_1; --let Rule$3 = class Rule2 extends Container$3 { -- constructor(defaults) { -- super(defaults); -- this.type = "rule"; -- if (!this.nodes) this.nodes = []; -- } -- get selectors() { -- return list$1.comma(this.selector); -- } -- set selectors(values) { -- let match = this.selector ? this.selector.match(/,\s*/) : null; -- let sep2 = match ? match[0] : "," + this.raw("between", "beforeOpen"); -- this.selector = values.join(sep2); -- } --}; --var rule = Rule$3; --Rule$3.default = Rule$3; --Container$3.registerRule(Rule$3); --let Declaration$2 = declaration; --let tokenizer22 = tokenize; --let Comment$2 = comment; --let AtRule$2 = atRule; --let Root$4 = root; --let Rule$2 = rule; --const SAFE_COMMENT_NEIGHBOR = { -- empty: true, -- space: true --}; --function findLastWithPosition(tokens) { -- for (let i2 = tokens.length - 1; i2 >= 0; i2--) { -- let token = tokens[i2]; -- let pos = token[3] || token[2]; -- if (pos) return pos; -- } --} --let Parser$1 = class Parser2 { -- constructor(input2) { -- this.input = input2; -- this.root = new Root$4(); -- this.current = this.root; -- this.spaces = ""; -- this.semicolon = false; -- this.createTokenizer(); -- this.root.source = { input: input2, start: { column: 1, line: 1, offset: 0 } }; -- } -- atrule(token) { -- let node2 = new AtRule$2(); -- node2.name = token[1].slice(1); -- if (node2.name === "") { -- this.unnamedAtrule(node2, token); -- } -- this.init(node2, token[2]); -- let type; -- let prev; -- let shift; -- let last = false; -- let open = false; -- let params = []; -- let brackets = []; -- while (!this.tokenizer.endOfFile()) { -- token = this.tokenizer.nextToken(); -- type = token[0]; -- if (type === "(" || type === "[") { -- brackets.push(type === "(" ? ")" : "]"); -- } else if (type === "{" && brackets.length > 0) { -- brackets.push("}"); -- } else if (type === brackets[brackets.length - 1]) { -- brackets.pop(); -- } -- if (brackets.length === 0) { -- if (type === ";") { -- node2.source.end = this.getPosition(token[2]); -- node2.source.end.offset++; -- this.semicolon = true; -- break; -- } else if (type === "{") { -- open = true; -- break; -- } else if (type === "}") { -- if (params.length > 0) { -- shift = params.length - 1; -- prev = params[shift]; -- while (prev && prev[0] === "space") { -- prev = params[--shift]; -- } -- if (prev) { -- node2.source.end = this.getPosition(prev[3] || prev[2]); -- node2.source.end.offset++; -- } -- } -- this.end(token); -- break; -- } else { -- params.push(token); -- } -- } else { -- params.push(token); -- } -- if (this.tokenizer.endOfFile()) { -- last = true; -- break; -- } -- } -- node2.raws.between = this.spacesAndCommentsFromEnd(params); -- if (params.length) { -- node2.raws.afterName = this.spacesAndCommentsFromStart(params); -- this.raw(node2, "params", params); -- if (last) { -- token = params[params.length - 1]; -- node2.source.end = this.getPosition(token[3] || token[2]); -- node2.source.end.offset++; -- this.spaces = node2.raws.between; -- node2.raws.between = ""; -- } -- } else { -- node2.raws.afterName = ""; -- node2.params = ""; -- } -- if (open) { -- node2.nodes = []; -- this.current = node2; -- } -- } -- checkMissedSemicolon(tokens) { -- let colon = this.colon(tokens); -- if (colon === false) return; -- let founded = 0; -- let token; -- for (let j = colon - 1; j >= 0; j--) { -- token = tokens[j]; -- if (token[0] !== "space") { -- founded += 1; -- if (founded === 2) break; -- } -- } -- throw this.input.error( -- "Missed semicolon", -- token[0] === "word" ? token[3] + 1 : token[2] -- ); -- } -- colon(tokens) { -- let brackets = 0; -- let token, type, prev; -- for (let [i2, element] of tokens.entries()) { -- token = element; -- type = token[0]; -- if (type === "(") { -- brackets += 1; -- } -- if (type === ")") { -- brackets -= 1; -- } -- if (brackets === 0 && type === ":") { -- if (!prev) { -- this.doubleColon(token); -- } else if (prev[0] === "word" && prev[1] === "progid") { -- continue; -- } else { -- return i2; -- } -- } -- prev = token; -- } -- return false; -- } -- comment(token) { -- let node2 = new Comment$2(); -- this.init(node2, token[2]); -- node2.source.end = this.getPosition(token[3] || token[2]); -- node2.source.end.offset++; -- let text = token[1].slice(2, -2); -- if (/^\s*$/.test(text)) { -- node2.text = ""; -- node2.raws.left = text; -- node2.raws.right = ""; -- } else { -- let match = text.match(/^(\s*)([^]*\S)(\s*)$/); -- node2.text = match[2]; -- node2.raws.left = match[1]; -- node2.raws.right = match[3]; -- } -- } -- createTokenizer() { -- this.tokenizer = tokenizer22(this.input); -- } -- decl(tokens, customProperty) { -- let node2 = new Declaration$2(); -- this.init(node2, tokens[0][2]); -- let last = tokens[tokens.length - 1]; -- if (last[0] === ";") { -- this.semicolon = true; -- tokens.pop(); -- } -- node2.source.end = this.getPosition( -- last[3] || last[2] || findLastWithPosition(tokens) -- ); -- node2.source.end.offset++; -- while (tokens[0][0] !== "word") { -- if (tokens.length === 1) this.unknownWord(tokens); -- node2.raws.before += tokens.shift()[1]; -- } -- node2.source.start = this.getPosition(tokens[0][2]); -- node2.prop = ""; -- while (tokens.length) { -- let type = tokens[0][0]; -- if (type === ":" || type === "space" || type === "comment") { -- break; -- } -- node2.prop += tokens.shift()[1]; -- } -- node2.raws.between = ""; -- let token; -- while (tokens.length) { -- token = tokens.shift(); -- if (token[0] === ":") { -- node2.raws.between += token[1]; -- break; -- } else { -- if (token[0] === "word" && /\w/.test(token[1])) { -- this.unknownWord([token]); -- } -- node2.raws.between += token[1]; -- } -- } -- if (node2.prop[0] === "_" || node2.prop[0] === "*") { -- node2.raws.before += node2.prop[0]; -- node2.prop = node2.prop.slice(1); -- } -- let firstSpaces = []; -- let next; -- while (tokens.length) { -- next = tokens[0][0]; -- if (next !== "space" && next !== "comment") break; -- firstSpaces.push(tokens.shift()); -- } -- this.precheckMissedSemicolon(tokens); -- for (let i2 = tokens.length - 1; i2 >= 0; i2--) { -- token = tokens[i2]; -- if (token[1].toLowerCase() === "!important") { -- node2.important = true; -- let string = this.stringFrom(tokens, i2); -- string = this.spacesFromEnd(tokens) + string; -- if (string !== " !important") node2.raws.important = string; -- break; -- } else if (token[1].toLowerCase() === "important") { -- let cache = tokens.slice(0); -- let str = ""; -- for (let j = i2; j > 0; j--) { -- let type = cache[j][0]; -- if (str.trim().indexOf("!") === 0 && type !== "space") { -- break; -- } -- str = cache.pop()[1] + str; -- } -- if (str.trim().indexOf("!") === 0) { -- node2.important = true; -- node2.raws.important = str; -- tokens = cache; -- } -- } -- if (token[0] !== "space" && token[0] !== "comment") { -- break; -- } -- } -- let hasWord = tokens.some((i2) => i2[0] !== "space" && i2[0] !== "comment"); -- if (hasWord) { -- node2.raws.between += firstSpaces.map((i2) => i2[1]).join(""); -- firstSpaces = []; -- } -- this.raw(node2, "value", firstSpaces.concat(tokens), customProperty); -- if (node2.value.includes(":") && !customProperty) { -- this.checkMissedSemicolon(tokens); -- } -- } -- doubleColon(token) { -- throw this.input.error( -- "Double colon", -- { offset: token[2] }, -- { offset: token[2] + token[1].length } -- ); -- } -- emptyRule(token) { -- let node2 = new Rule$2(); -- this.init(node2, token[2]); -- node2.selector = ""; -- node2.raws.between = ""; -- this.current = node2; -- } -- end(token) { -- if (this.current.nodes && this.current.nodes.length) { -- this.current.raws.semicolon = this.semicolon; -- } -- this.semicolon = false; -- this.current.raws.after = (this.current.raws.after || "") + this.spaces; -- this.spaces = ""; -- if (this.current.parent) { -- this.current.source.end = this.getPosition(token[2]); -- this.current.source.end.offset++; -- this.current = this.current.parent; -- } else { -- this.unexpectedClose(token); -- } -- } -- endFile() { -- if (this.current.parent) this.unclosedBlock(); -- if (this.current.nodes && this.current.nodes.length) { -- this.current.raws.semicolon = this.semicolon; -- } -- this.current.raws.after = (this.current.raws.after || "") + this.spaces; -- this.root.source.end = this.getPosition(this.tokenizer.position()); -- } -- freeSemicolon(token) { -- this.spaces += token[1]; -- if (this.current.nodes) { -- let prev = this.current.nodes[this.current.nodes.length - 1]; -- if (prev && prev.type === "rule" && !prev.raws.ownSemicolon) { -- prev.raws.ownSemicolon = this.spaces; -- this.spaces = ""; -- } -- } -- } -- // Helpers -- getPosition(offset) { -- let pos = this.input.fromOffset(offset); -- return { -- column: pos.col, -- line: pos.line, -- offset -- }; -- } -- init(node2, offset) { -- this.current.push(node2); -- node2.source = { -- input: this.input, -- start: this.getPosition(offset) -- }; -- node2.raws.before = this.spaces; -- this.spaces = ""; -- if (node2.type !== "comment") this.semicolon = false; -- } -- other(start) { -- let end = false; -- let type = null; -- let colon = false; -- let bracket = null; -- let brackets = []; -- let customProperty = start[1].startsWith("--"); -- let tokens = []; -- let token = start; -- while (token) { -- type = token[0]; -- tokens.push(token); -- if (type === "(" || type === "[") { -- if (!bracket) bracket = token; -- brackets.push(type === "(" ? ")" : "]"); -- } else if (customProperty && colon && type === "{") { -- if (!bracket) bracket = token; -- brackets.push("}"); -- } else if (brackets.length === 0) { -- if (type === ";") { -- if (colon) { -- this.decl(tokens, customProperty); -- return; -- } else { -- break; -- } -- } else if (type === "{") { -- this.rule(tokens); -- return; -- } else if (type === "}") { -- this.tokenizer.back(tokens.pop()); -- end = true; -- break; -- } else if (type === ":") { -- colon = true; -- } -- } else if (type === brackets[brackets.length - 1]) { -- brackets.pop(); -- if (brackets.length === 0) bracket = null; -- } -- token = this.tokenizer.nextToken(); -- } -- if (this.tokenizer.endOfFile()) end = true; -- if (brackets.length > 0) this.unclosedBracket(bracket); -- if (end && colon) { -- if (!customProperty) { -- while (tokens.length) { -- token = tokens[tokens.length - 1][0]; -- if (token !== "space" && token !== "comment") break; -- this.tokenizer.back(tokens.pop()); -- } -- } -- this.decl(tokens, customProperty); -- } else { -- this.unknownWord(tokens); -- } -- } -- parse() { -- let token; -- while (!this.tokenizer.endOfFile()) { -- token = this.tokenizer.nextToken(); -- switch (token[0]) { -- case "space": -- this.spaces += token[1]; -- break; -- case ";": -- this.freeSemicolon(token); -- break; -- case "}": -- this.end(token); -- break; -- case "comment": -- this.comment(token); -- break; -- case "at-word": -- this.atrule(token); -- break; -- case "{": -- this.emptyRule(token); -- break; -- default: -- this.other(token); -- break; -- } -- } -- this.endFile(); -- } -- precheckMissedSemicolon() { -- } -- raw(node2, prop, tokens, customProperty) { -- let token, type; -- let length = tokens.length; -- let value = ""; -- let clean = true; -- let next, prev; -- for (let i2 = 0; i2 < length; i2 += 1) { -- token = tokens[i2]; -- type = token[0]; -- if (type === "space" && i2 === length - 1 && !customProperty) { -- clean = false; -- } else if (type === "comment") { -- prev = tokens[i2 - 1] ? tokens[i2 - 1][0] : "empty"; -- next = tokens[i2 + 1] ? tokens[i2 + 1][0] : "empty"; -- if (!SAFE_COMMENT_NEIGHBOR[prev] && !SAFE_COMMENT_NEIGHBOR[next]) { -- if (value.slice(-1) === ",") { -- clean = false; -- } else { -- value += token[1]; -- } -- } else { -- clean = false; -- } -- } else { -- value += token[1]; -- } -- } -- if (!clean) { -- let raw = tokens.reduce((all, i2) => all + i2[1], ""); -- node2.raws[prop] = { raw, value }; -- } -- node2[prop] = value; -- } -- rule(tokens) { -- tokens.pop(); -- let node2 = new Rule$2(); -- this.init(node2, tokens[0][2]); -- node2.raws.between = this.spacesAndCommentsFromEnd(tokens); -- this.raw(node2, "selector", tokens); -- this.current = node2; -- } -- spacesAndCommentsFromEnd(tokens) { -- let lastTokenType; -- let spaces = ""; -- while (tokens.length) { -- lastTokenType = tokens[tokens.length - 1][0]; -- if (lastTokenType !== "space" && lastTokenType !== "comment") break; -- spaces = tokens.pop()[1] + spaces; -- } -- return spaces; -- } -- // Errors -- spacesAndCommentsFromStart(tokens) { -- let next; -- let spaces = ""; -- while (tokens.length) { -- next = tokens[0][0]; -- if (next !== "space" && next !== "comment") break; -- spaces += tokens.shift()[1]; -- } -- return spaces; -- } -- spacesFromEnd(tokens) { -- let lastTokenType; -- let spaces = ""; -- while (tokens.length) { -- lastTokenType = tokens[tokens.length - 1][0]; -- if (lastTokenType !== "space") break; -- spaces = tokens.pop()[1] + spaces; -- } -- return spaces; -- } -- stringFrom(tokens, from) { -- let result2 = ""; -- for (let i2 = from; i2 < tokens.length; i2++) { -- result2 += tokens[i2][1]; -- } -- tokens.splice(from, tokens.length - from); -- return result2; -- } -- unclosedBlock() { -- let pos = this.current.source.start; -- throw this.input.error("Unclosed block", pos.line, pos.column); -- } -- unclosedBracket(bracket) { -- throw this.input.error( -- "Unclosed bracket", -- { offset: bracket[2] }, -- { offset: bracket[2] + 1 } -- ); -- } -- unexpectedClose(token) { -- throw this.input.error( -- "Unexpected }", -- { offset: token[2] }, -- { offset: token[2] + 1 } -- ); -- } -- unknownWord(tokens) { -- throw this.input.error( -- "Unknown word", -- { offset: tokens[0][2] }, -- { offset: tokens[0][2] + tokens[0][1].length } -- ); -- } -- unnamedAtrule(node2, token) { -- throw this.input.error( -- "At-rule without name", -- { offset: token[2] }, -- { offset: token[2] + token[1].length } -- ); -- } --}; --var parser = Parser$1; --let Container$2 = container; --let Parser22 = parser; --let Input$2 = input; --function parse$3(css, opts) { -- let input2 = new Input$2(css, opts); -- let parser2 = new Parser22(input2); -- try { -- parser2.parse(); -- } catch (e2) { -- if (process.env.NODE_ENV !== "production") { -- if (e2.name === "CssSyntaxError" && opts && opts.from) { -- if (/\.scss$/i.test(opts.from)) { -- e2.message += "\nYou tried to parse SCSS with the standard CSS parser; try again with the postcss-scss parser"; -- } else if (/\.sass/i.test(opts.from)) { -- e2.message += "\nYou tried to parse Sass with the standard CSS parser; try again with the postcss-sass parser"; -- } else if (/\.less$/i.test(opts.from)) { -- e2.message += "\nYou tried to parse Less with the standard CSS parser; try again with the postcss-less parser"; -- } -- } -- } -- throw e2; -- } -- return parser2.root; --} --var parse_1 = parse$3; --parse$3.default = parse$3; --Container$2.registerParse(parse$3); --let { isClean, my } = symbols; --let MapGenerator$1 = mapGenerator; --let stringify$2 = stringify_1; --let Container$1 = container; --let Document$2 = document$1; --let warnOnce$1 = warnOnce$2; --let Result$2 = result; --let parse$2 = parse_1; --let Root$3 = root; --const TYPE_TO_CLASS_NAME = { -- atrule: "AtRule", -- comment: "Comment", -- decl: "Declaration", -- document: "Document", -- root: "Root", -- rule: "Rule" --}; --const PLUGIN_PROPS = { -- AtRule: true, -- AtRuleExit: true, -- Comment: true, -- CommentExit: true, -- Declaration: true, -- DeclarationExit: true, -- Document: true, -- DocumentExit: true, -- Once: true, -- OnceExit: true, -- postcssPlugin: true, -- prepare: true, -- Root: true, -- RootExit: true, -- Rule: true, -- RuleExit: true --}; --const NOT_VISITORS = { -- Once: true, -- postcssPlugin: true, -- prepare: true --}; --const CHILDREN = 0; --function isPromise(obj) { -- return typeof obj === "object" && typeof obj.then === "function"; --} --function getEvents(node2) { -- let key = false; -- let type = TYPE_TO_CLASS_NAME[node2.type]; -- if (node2.type === "decl") { -- key = node2.prop.toLowerCase(); -- } else if (node2.type === "atrule") { -- key = node2.name.toLowerCase(); -- } -- if (key && node2.append) { -- return [ -- type, -- type + "-" + key, -- CHILDREN, -- type + "Exit", -- type + "Exit-" + key -- ]; -- } else if (key) { -- return [type, type + "-" + key, type + "Exit", type + "Exit-" + key]; -- } else if (node2.append) { -- return [type, CHILDREN, type + "Exit"]; -- } else { -- return [type, type + "Exit"]; -- } --} --function toStack(node2) { -- let events; -- if (node2.type === "document") { -- events = ["Document", CHILDREN, "DocumentExit"]; -- } else if (node2.type === "root") { -- events = ["Root", CHILDREN, "RootExit"]; -- } else { -- events = getEvents(node2); -- } -- return { -- eventIndex: 0, -- events, -- iterator: 0, -- node: node2, -- visitorIndex: 0, -- visitors: [] -- }; --} --function cleanMarks(node2) { -- node2[isClean] = false; -- if (node2.nodes) node2.nodes.forEach((i2) => cleanMarks(i2)); -- return node2; --} --let postcss$2 = {}; --let LazyResult$2 = class LazyResult2 { -- constructor(processor2, css, opts) { -- this.stringified = false; -- this.processed = false; -- let root2; -- if (typeof css === "object" && css !== null && (css.type === "root" || css.type === "document")) { -- root2 = cleanMarks(css); -- } else if (css instanceof LazyResult2 || css instanceof Result$2) { -- root2 = cleanMarks(css.root); -- if (css.map) { -- if (typeof opts.map === "undefined") opts.map = {}; -- if (!opts.map.inline) opts.map.inline = false; -- opts.map.prev = css.map; -- } -- } else { -- let parser2 = parse$2; -- if (opts.syntax) parser2 = opts.syntax.parse; -- if (opts.parser) parser2 = opts.parser; -- if (parser2.parse) parser2 = parser2.parse; -- try { -- root2 = parser2(css, opts); -- } catch (error) { -- this.processed = true; -- this.error = error; -- } -- if (root2 && !root2[my]) { -- Container$1.rebuild(root2); -- } -- } -- this.result = new Result$2(processor2, root2, opts); -- this.helpers = { ...postcss$2, postcss: postcss$2, result: this.result }; -- this.plugins = this.processor.plugins.map((plugin22) => { -- if (typeof plugin22 === "object" && plugin22.prepare) { -- return { ...plugin22, ...plugin22.prepare(this.result) }; -- } else { -- return plugin22; -- } -- }); -- } -- async() { -- if (this.error) return Promise.reject(this.error); -- if (this.processed) return Promise.resolve(this.result); -- if (!this.processing) { -- this.processing = this.runAsync(); -- } -- return this.processing; -- } -- catch(onRejected) { -- return this.async().catch(onRejected); -- } -- finally(onFinally) { -- return this.async().then(onFinally, onFinally); -- } -- getAsyncError() { -- throw new Error("Use process(css).then(cb) to work with async plugins"); -- } -- handleError(error, node2) { -- let plugin22 = this.result.lastPlugin; -- try { -- if (node2) node2.addToError(error); -- this.error = error; -- if (error.name === "CssSyntaxError" && !error.plugin) { -- error.plugin = plugin22.postcssPlugin; -- error.setMessage(); -- } else if (plugin22.postcssVersion) { -- if (process.env.NODE_ENV !== "production") { -- let pluginName = plugin22.postcssPlugin; -- let pluginVer = plugin22.postcssVersion; -- let runtimeVer = this.result.processor.version; -- let a2 = pluginVer.split("."); -- let b = runtimeVer.split("."); -- if (a2[0] !== b[0] || parseInt(a2[1]) > parseInt(b[1])) { -- console.error( -- "Unknown error from PostCSS plugin. Your current PostCSS version is " + runtimeVer + ", but " + pluginName + " uses " + pluginVer + ". Perhaps this is the source of the error below." -- ); -- } -- } -- } -- } catch (err) { -- if (console && console.error) console.error(err); -- } -- return error; -- } -- prepareVisitors() { -- this.listeners = {}; -- let add = (plugin22, type, cb) => { -- if (!this.listeners[type]) this.listeners[type] = []; -- this.listeners[type].push([plugin22, cb]); -- }; -- for (let plugin22 of this.plugins) { -- if (typeof plugin22 === "object") { -- for (let event in plugin22) { -- if (!PLUGIN_PROPS[event] && /^[A-Z]/.test(event)) { -- throw new Error( -- `Unknown event ${event} in ${plugin22.postcssPlugin}. Try to update PostCSS (${this.processor.version} now).` -- ); -- } -- if (!NOT_VISITORS[event]) { -- if (typeof plugin22[event] === "object") { -- for (let filter in plugin22[event]) { -- if (filter === "*") { -- add(plugin22, event, plugin22[event][filter]); -- } else { -- add( -- plugin22, -- event + "-" + filter.toLowerCase(), -- plugin22[event][filter] -- ); -- } -- } -- } else if (typeof plugin22[event] === "function") { -- add(plugin22, event, plugin22[event]); -- } -- } -- } -- } -- } -- this.hasListener = Object.keys(this.listeners).length > 0; -- } -- async runAsync() { -- this.plugin = 0; -- for (let i2 = 0; i2 < this.plugins.length; i2++) { -- let plugin22 = this.plugins[i2]; -- let promise = this.runOnRoot(plugin22); -- if (isPromise(promise)) { -- try { -- await promise; -- } catch (error) { -- throw this.handleError(error); -- } -- } -- } -- this.prepareVisitors(); -- if (this.hasListener) { -- let root2 = this.result.root; -- while (!root2[isClean]) { -- root2[isClean] = true; -- let stack = [toStack(root2)]; -- while (stack.length > 0) { -- let promise = this.visitTick(stack); -- if (isPromise(promise)) { -- try { -- await promise; -- } catch (e2) { -- let node2 = stack[stack.length - 1].node; -- throw this.handleError(e2, node2); -- } -- } -- } -- } -- if (this.listeners.OnceExit) { -- for (let [plugin22, visitor] of this.listeners.OnceExit) { -- this.result.lastPlugin = plugin22; -- try { -- if (root2.type === "document") { -- let roots = root2.nodes.map( -- (subRoot) => visitor(subRoot, this.helpers) -- ); -- await Promise.all(roots); -- } else { -- await visitor(root2, this.helpers); -- } -- } catch (e2) { -- throw this.handleError(e2); -- } -- } -- } -- } -- this.processed = true; -- return this.stringify(); -- } -- runOnRoot(plugin22) { -- this.result.lastPlugin = plugin22; -- try { -- if (typeof plugin22 === "object" && plugin22.Once) { -- if (this.result.root.type === "document") { -- let roots = this.result.root.nodes.map( -- (root2) => plugin22.Once(root2, this.helpers) -- ); -- if (isPromise(roots[0])) { -- return Promise.all(roots); -- } -- return roots; -- } -- return plugin22.Once(this.result.root, this.helpers); -- } else if (typeof plugin22 === "function") { -- return plugin22(this.result.root, this.result); -- } -- } catch (error) { -- throw this.handleError(error); -- } -- } -- stringify() { -- if (this.error) throw this.error; -- if (this.stringified) return this.result; -- this.stringified = true; -- this.sync(); -- let opts = this.result.opts; -- let str = stringify$2; -- if (opts.syntax) str = opts.syntax.stringify; -- if (opts.stringifier) str = opts.stringifier; -- if (str.stringify) str = str.stringify; -- let map = new MapGenerator$1(str, this.result.root, this.result.opts); -- let data = map.generate(); -- this.result.css = data[0]; -- this.result.map = data[1]; -- return this.result; -- } -- sync() { -- if (this.error) throw this.error; -- if (this.processed) return this.result; -- this.processed = true; -- if (this.processing) { -- throw this.getAsyncError(); -- } -- for (let plugin22 of this.plugins) { -- let promise = this.runOnRoot(plugin22); -- if (isPromise(promise)) { -- throw this.getAsyncError(); -- } -- } -- this.prepareVisitors(); -- if (this.hasListener) { -- let root2 = this.result.root; -- while (!root2[isClean]) { -- root2[isClean] = true; -- this.walkSync(root2); -- } -- if (this.listeners.OnceExit) { -- if (root2.type === "document") { -- for (let subRoot of root2.nodes) { -- this.visitSync(this.listeners.OnceExit, subRoot); -- } -- } else { -- this.visitSync(this.listeners.OnceExit, root2); -- } -- } -- } -- return this.result; -- } -- then(onFulfilled, onRejected) { -- if (process.env.NODE_ENV !== "production") { -- if (!("from" in this.opts)) { -- warnOnce$1( -- "Without `from` option PostCSS could generate wrong source map and will not find Browserslist config. Set it to CSS file path or to `undefined` to prevent this warning." -- ); -- } -- } -- return this.async().then(onFulfilled, onRejected); -- } -- toString() { -- return this.css; -- } -- visitSync(visitors, node2) { -- for (let [plugin22, visitor] of visitors) { -- this.result.lastPlugin = plugin22; -- let promise; -- try { -- promise = visitor(node2, this.helpers); -- } catch (e2) { -- throw this.handleError(e2, node2.proxyOf); -- } -- if (node2.type !== "root" && node2.type !== "document" && !node2.parent) { -- return true; -- } -- if (isPromise(promise)) { -- throw this.getAsyncError(); -- } -- } -- } -- visitTick(stack) { -- let visit2 = stack[stack.length - 1]; -- let { node: node2, visitors } = visit2; -- if (node2.type !== "root" && node2.type !== "document" && !node2.parent) { -- stack.pop(); -- return; -- } -- if (visitors.length > 0 && visit2.visitorIndex < visitors.length) { -- let [plugin22, visitor] = visitors[visit2.visitorIndex]; -- visit2.visitorIndex += 1; -- if (visit2.visitorIndex === visitors.length) { -- visit2.visitors = []; -- visit2.visitorIndex = 0; -- } -- this.result.lastPlugin = plugin22; -- try { -- return visitor(node2.toProxy(), this.helpers); -- } catch (e2) { -- throw this.handleError(e2, node2); -- } -- } -- if (visit2.iterator !== 0) { -- let iterator = visit2.iterator; -- let child; -- while (child = node2.nodes[node2.indexes[iterator]]) { -- node2.indexes[iterator] += 1; -- if (!child[isClean]) { -- child[isClean] = true; -- stack.push(toStack(child)); -- return; -- } -- } -- visit2.iterator = 0; -- delete node2.indexes[iterator]; -- } -- let events = visit2.events; -- while (visit2.eventIndex < events.length) { -- let event = events[visit2.eventIndex]; -- visit2.eventIndex += 1; -- if (event === CHILDREN) { -- if (node2.nodes && node2.nodes.length) { -- node2[isClean] = true; -- visit2.iterator = node2.getIterator(); -- } -- return; -- } else if (this.listeners[event]) { -- visit2.visitors = this.listeners[event]; -- return; -- } -- } -- stack.pop(); -- } -- walkSync(node2) { -- node2[isClean] = true; -- let events = getEvents(node2); -- for (let event of events) { -- if (event === CHILDREN) { -- if (node2.nodes) { -- node2.each((child) => { -- if (!child[isClean]) this.walkSync(child); -- }); -- } -- } else { -- let visitors = this.listeners[event]; -- if (visitors) { -- if (this.visitSync(visitors, node2.toProxy())) return; -- } -- } -- } -- } -- warnings() { -- return this.sync().warnings(); -- } -- get content() { -- return this.stringify().content; -- } -- get css() { -- return this.stringify().css; -- } -- get map() { -- return this.stringify().map; -- } -- get messages() { -- return this.sync().messages; -- } -- get opts() { -- return this.result.opts; -- } -- get processor() { -- return this.result.processor; -- } -- get root() { -- return this.sync().root; -- } -- get [Symbol.toStringTag]() { -- return "LazyResult"; -- } --}; --LazyResult$2.registerPostcss = (dependant) => { -- postcss$2 = dependant; --}; --var lazyResult = LazyResult$2; --LazyResult$2.default = LazyResult$2; --Root$3.registerLazyResult(LazyResult$2); --Document$2.registerLazyResult(LazyResult$2); --let MapGenerator22 = mapGenerator; --let stringify$1 = stringify_1; --let warnOnce22 = warnOnce$2; --let parse$1 = parse_1; --const Result$1 = result; --let NoWorkResult$1 = class NoWorkResult2 { -- constructor(processor2, css, opts) { -- css = css.toString(); -- this.stringified = false; -- this._processor = processor2; -- this._css = css; -- this._opts = opts; -- this._map = void 0; -- let root2; -- let str = stringify$1; -- this.result = new Result$1(this._processor, root2, this._opts); -- this.result.css = css; -- let self = this; -- Object.defineProperty(this.result, "root", { -- get() { -- return self.root; -- } -- }); -- let map = new MapGenerator22(str, root2, this._opts, css); -- if (map.isMap()) { -- let [generatedCSS, generatedMap] = map.generate(); -- if (generatedCSS) { -- this.result.css = generatedCSS; -- } -- if (generatedMap) { -- this.result.map = generatedMap; -- } -- } else { -- map.clearAnnotation(); -- this.result.css = map.css; -- } -- } -- async() { -- if (this.error) return Promise.reject(this.error); -- return Promise.resolve(this.result); -- } -- catch(onRejected) { -- return this.async().catch(onRejected); -- } -- finally(onFinally) { -- return this.async().then(onFinally, onFinally); -- } -- sync() { -- if (this.error) throw this.error; -- return this.result; -- } -- then(onFulfilled, onRejected) { -- if (process.env.NODE_ENV !== "production") { -- if (!("from" in this._opts)) { -- warnOnce22( -- "Without `from` option PostCSS could generate wrong source map and will not find Browserslist config. Set it to CSS file path or to `undefined` to prevent this warning." -- ); -- } -- } -- return this.async().then(onFulfilled, onRejected); -- } -- toString() { -- return this._css; -- } -- warnings() { -- return []; -- } -- get content() { -- return this.result.css; -- } -- get css() { -- return this.result.css; -- } -- get map() { -- return this.result.map; -- } -- get messages() { -- return []; -- } -- get opts() { -- return this.result.opts; -- } -- get processor() { -- return this.result.processor; -- } -- get root() { -- if (this._root) { -- return this._root; -- } -- let root2; -- let parser2 = parse$1; -- try { -- root2 = parser2(this._css, this._opts); -- } catch (error) { -- this.error = error; -- } -- if (this.error) { -- throw this.error; -- } else { -- this._root = root2; -- return root2; -- } -- } -- get [Symbol.toStringTag]() { -- return "NoWorkResult"; -- } --}; --var noWorkResult = NoWorkResult$1; --NoWorkResult$1.default = NoWorkResult$1; --let NoWorkResult22 = noWorkResult; --let LazyResult$1 = lazyResult; --let Document$1 = document$1; --let Root$2 = root; --let Processor$1 = class Processor2 { -- constructor(plugins = []) { -- this.version = "8.4.38"; -- this.plugins = this.normalize(plugins); -- } -- normalize(plugins) { -- let normalized = []; -- for (let i2 of plugins) { -- if (i2.postcss === true) { -- i2 = i2(); -- } else if (i2.postcss) { -- i2 = i2.postcss; -- } -- if (typeof i2 === "object" && Array.isArray(i2.plugins)) { -- normalized = normalized.concat(i2.plugins); -- } else if (typeof i2 === "object" && i2.postcssPlugin) { -- normalized.push(i2); -- } else if (typeof i2 === "function") { -- normalized.push(i2); -- } else if (typeof i2 === "object" && (i2.parse || i2.stringify)) { -- if (process.env.NODE_ENV !== "production") { -- throw new Error( -- "PostCSS syntaxes cannot be used as plugins. Instead, please use one of the syntax/parser/stringifier options as outlined in your PostCSS runner documentation." -- ); -- } -- } else { -- throw new Error(i2 + " is not a PostCSS plugin"); -- } -- } -- return normalized; -- } -- process(css, opts = {}) { -- if (!this.plugins.length && !opts.parser && !opts.stringifier && !opts.syntax) { -- return new NoWorkResult22(this, css, opts); -- } else { -- return new LazyResult$1(this, css, opts); -- } -- } -- use(plugin22) { -- this.plugins = this.plugins.concat(this.normalize([plugin22])); -- return this; -- } --}; --var processor = Processor$1; --Processor$1.default = Processor$1; --Root$2.registerProcessor(Processor$1); --Document$1.registerProcessor(Processor$1); --let Declaration$1 = declaration; --let PreviousMap22 = previousMap; --let Comment$1 = comment; --let AtRule$1 = atRule; --let Input$1 = input; --let Root$1 = root; --let Rule$1 = rule; --function fromJSON$1(json, inputs) { -- if (Array.isArray(json)) return json.map((n2) => fromJSON$1(n2)); -- let { inputs: ownInputs, ...defaults } = json; -- if (ownInputs) { -- inputs = []; -- for (let input2 of ownInputs) { -- let inputHydrated = { ...input2, __proto__: Input$1.prototype }; -- if (inputHydrated.map) { -- inputHydrated.map = { -- ...inputHydrated.map, -- __proto__: PreviousMap22.prototype -- }; -- } -- inputs.push(inputHydrated); -- } -- } -- if (defaults.nodes) { -- defaults.nodes = json.nodes.map((n2) => fromJSON$1(n2, inputs)); -- } -- if (defaults.source) { -- let { inputId, ...source } = defaults.source; -- defaults.source = source; -- if (inputId != null) { -- defaults.source.input = inputs[inputId]; -- } -- } -- if (defaults.type === "root") { -- return new Root$1(defaults); -- } else if (defaults.type === "decl") { -- return new Declaration$1(defaults); -- } else if (defaults.type === "rule") { -- return new Rule$1(defaults); -- } else if (defaults.type === "comment") { -- return new Comment$1(defaults); -- } else if (defaults.type === "atrule") { -- return new AtRule$1(defaults); -- } else { -- throw new Error("Unknown node type: " + json.type); -- } --} --var fromJSON_1 = fromJSON$1; --fromJSON$1.default = fromJSON$1; --let CssSyntaxError22 = cssSyntaxError; --let Declaration22 = declaration; --let LazyResult22 = lazyResult; --let Container22 = container; --let Processor22 = processor; --let stringify = stringify_1; --let fromJSON = fromJSON_1; --let Document222 = document$1; --let Warning22 = warning; --let Comment22 = comment; --let AtRule22 = atRule; --let Result22 = result; --let Input22 = input; --let parse = parse_1; --let list = list_1; --let Rule22 = rule; --let Root22 = root; --let Node22 = node; --function postcss(...plugins) { -- if (plugins.length === 1 && Array.isArray(plugins[0])) { -- plugins = plugins[0]; -- } -- return new Processor22(plugins); --} --postcss.plugin = function plugin2(name, initializer) { -- let warningPrinted = false; -- function creator(...args) { -- if (console && console.warn && !warningPrinted) { -- warningPrinted = true; -- console.warn( -- name + ": postcss.plugin was deprecated. Migration guide:\nhttps://evilmartians.com/chronicles/postcss-8-plugin-migration" -- ); -- if (process.env.LANG && process.env.LANG.startsWith("cn")) { -- console.warn( -- name + ": 里面 postcss.plugin 被弃用. 迁移指南:\nhttps://www.w3ctech.com/topic/2226" -- ); -- } -- } -- let transformer = initializer(...args); -- transformer.postcssPlugin = name; -- transformer.postcssVersion = new Processor22().version; -- return transformer; -- } -- let cache; -- Object.defineProperty(creator, "postcss", { -- get() { -- if (!cache) cache = creator(); -- return cache; -- } -- }); -- creator.process = function(css, processOpts, pluginOpts) { -- return postcss([creator(pluginOpts)]).process(css, processOpts); -- }; -- return creator; --}; --postcss.stringify = stringify; --postcss.parse = parse; --postcss.fromJSON = fromJSON; --postcss.list = list; --postcss.comment = (defaults) => new Comment22(defaults); --postcss.atRule = (defaults) => new AtRule22(defaults); --postcss.decl = (defaults) => new Declaration22(defaults); --postcss.rule = (defaults) => new Rule22(defaults); --postcss.root = (defaults) => new Root22(defaults); --postcss.document = (defaults) => new Document222(defaults); --postcss.CssSyntaxError = CssSyntaxError22; --postcss.Declaration = Declaration22; --postcss.Container = Container22; --postcss.Processor = Processor22; --postcss.Document = Document222; --postcss.Comment = Comment22; --postcss.Warning = Warning22; --postcss.AtRule = AtRule22; --postcss.Result = Result22; --postcss.Input = Input22; --postcss.Rule = Rule22; --postcss.Root = Root22; --postcss.Node = Node22; --LazyResult22.registerPostcss(postcss); --var postcss_1 = postcss; --postcss.default = postcss; --const postcss$1 = /* @__PURE__ */ getDefaultExportFromCjs(postcss_1); --postcss$1.stringify; --postcss$1.fromJSON; --postcss$1.plugin; --postcss$1.parse; --postcss$1.list; --postcss$1.document; --postcss$1.comment; --postcss$1.atRule; --postcss$1.rule; --postcss$1.decl; --postcss$1.root; --postcss$1.CssSyntaxError; --postcss$1.Declaration; --postcss$1.Container; --postcss$1.Processor; --postcss$1.Document; --postcss$1.Comment; --postcss$1.Warning; --postcss$1.AtRule; --postcss$1.Result; --postcss$1.Input; --postcss$1.Rule; --postcss$1.Root; --postcss$1.Node; - class BaseRRNode { - // eslint-disable-next-line @typescript-eslint/no-unused-vars, @typescript-eslint/no-explicit-any - constructor(..._args) { diff --git a/patches/rrweb@2.0.0-alpha.17.patch b/patches/rrweb@2.0.0-alpha.17.patch new file mode 100644 index 000000000..7caa5db40 --- /dev/null +++ b/patches/rrweb@2.0.0-alpha.17.patch @@ -0,0 +1,81 @@ +diff --git a/dist/rrweb.js b/dist/rrweb.js +index 12f4ad3c7f897fe8a9ee2f4595dcf37f302d17c5..43f6bd95676c456e187b7bd68ba7af56e7b09f29 100644 +--- a/dist/rrweb.js ++++ b/dist/rrweb.js +@@ -246,6 +246,9 @@ function isCSSImportRule(rule2) { + function isCSSStyleRule(rule2) { + return "selectorText" in rule2; + } ++function findStylesheet(doc, href) { ++ return Array.from(doc.styleSheets).find((s) => s.href === href); ++} + class Mirror { + constructor() { + __publicField$1(this, "idNodeMap", /* @__PURE__ */ new Map()); +@@ -821,9 +824,14 @@ function serializeElementNode(n2, options) { + } + } + if (tagName === "link" && inlineStylesheet) { +- const stylesheet = Array.from(doc.styleSheets).find((s2) => { +- return s2.href === n2.href; +- }); ++ const href = n2.href; ++ let stylesheet = findStylesheet(doc, href); ++ if (!stylesheet && href.includes('.css')) { ++ const rootDomain = window.location.origin; ++ const stylesheetPath = href.replace(window.location.href, ''); ++ const potentialStylesheetHref = rootDomain + '/' + stylesheetPath; ++ stylesheet = findStylesheet(doc, potentialStylesheetHref); ++ } + let cssText = null; + if (stylesheet) { + cssText = stringifyStylesheet(stylesheet); +@@ -13276,11 +13284,19 @@ class CanvasManager { + let rafId; + const getCanvas = () => { + const matchedCanvas = []; +- win.document.querySelectorAll("canvas").forEach((canvas) => { +- if (!isBlocked(canvas, blockClass, blockSelector, true)) { +- matchedCanvas.push(canvas); +- } +- }); ++ const searchCanvas = (root) => { ++ root.querySelectorAll("canvas").forEach((canvas) => { ++ if (!isBlocked(canvas, blockClass, blockSelector, true)) { ++ matchedCanvas.push(canvas); ++ } ++ }); ++ root.querySelectorAll("*").forEach((elem) => { ++ if (elem.shadowRoot) { ++ searchCanvas(elem.shadowRoot); ++ } ++ }); ++ }; ++ searchCanvas(win.document); + return matchedCanvas; + }; + const takeCanvasSnapshots = (timestamp) => { +@@ -13301,13 +13317,20 @@ class CanvasManager { + context.clear(context.COLOR_BUFFER_BIT); + } + } +- const bitmap = await createImageBitmap(canvas); ++ // createImageBitmap throws if resizing to 0 ++ // Fallback to intrinsic size if canvas has not yet rendered ++ const width = canvas.clientWidth || canvas.width; ++ const height = canvas.clientHeight || canvas.height; ++ const bitmap = await createImageBitmap(canvas, { ++ resizeWidth: width, ++ resizeHeight: height ++ }); + worker.postMessage( + { + id, + bitmap, +- width: canvas.width, +- height: canvas.height, ++ width: width, ++ height: height, + dataURLOptions: options.dataURLOptions + }, + [bitmap] diff --git a/playground/segment/server.js b/playground/segment/server.js index 565b09bbf..8c67259a1 100644 --- a/playground/segment/server.js +++ b/playground/segment/server.js @@ -10,7 +10,7 @@ app.get('/segment.html', function (req, res) { }) app.get('/static/recorder.js', function (req, res) { - let filePath = path.join(__dirname, '/../../node_modules/@rrweb/record/dist/record.js') + let filePath = path.join(__dirname, '/../../node_modules/rrweb/dist/rrweb.js') res.sendFile(filePath) }) diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml index ab12253a4..bc8d2dcea 100644 --- a/pnpm-lock.yaml +++ b/pnpm-lock.yaml @@ -5,9 +5,9 @@ settings: excludeLinksFromLockfile: false patchedDependencies: - '@rrweb/record@2.0.0-alpha.17': - hash: or7biymn4kjyhnfwbz74vqezxa - path: patches/@rrweb__record@2.0.0-alpha.17.patch + rrweb@2.0.0-alpha.17: + hash: xlkuvshzdprjlpxe7nzsj3spyi + path: patches/rrweb@2.0.0-alpha.17.patch dependencies: core-js: @@ -66,9 +66,6 @@ devDependencies: '@rollup/plugin-typescript': specifier: ^12.1.1 version: 12.1.1(rollup@4.24.0)(tslib@2.5.0)(typescript@5.5.4) - '@rrweb/record': - specifier: 2.0.0-alpha.17 - version: 2.0.0-alpha.17(patch_hash=or7biymn4kjyhnfwbz74vqezxa) '@rrweb/rrweb-plugin-console-record': specifier: 2.0.0-alpha.17 version: 2.0.0-alpha.17(rrweb@2.0.0-alpha.17) @@ -207,6 +204,12 @@ devDependencies: rollup-plugin-visualizer: specifier: ^5.12.0 version: 5.12.0(rollup@4.24.0) + rrweb: + specifier: 2.0.0-alpha.17 + version: 2.0.0-alpha.17(patch_hash=xlkuvshzdprjlpxe7nzsj3spyi) + rrweb-snapshot: + specifier: 2.0.0-alpha.17 + version: 2.0.0-alpha.17 sinon: specifier: 9.0.2 version: 9.0.2 @@ -2799,20 +2802,12 @@ packages: dev: true optional: true - /@rrweb/record@2.0.0-alpha.17(patch_hash=or7biymn4kjyhnfwbz74vqezxa): - resolution: {integrity: sha512-Je+lzjeWMF8/I0IDoXFzkGPKT8j7AkaBup5YcwUHlkp18VhLVze416MvI6915teE27uUA2ScXMXzG0Yiu5VTIw==} - dependencies: - '@rrweb/types': 2.0.0-alpha.17 - rrweb: 2.0.0-alpha.17 - dev: true - patched: true - /@rrweb/rrweb-plugin-console-record@2.0.0-alpha.17(rrweb@2.0.0-alpha.17): resolution: {integrity: sha512-tjNJ3wWUDMMf275xr4Rb5tVYF2UR+wXvSxnyS9tRKnRa574PQQvx7sGbqM/O9AytYjnbiTrAMqNR7OFysGCMwQ==} peerDependencies: rrweb: ^2.0.0-alpha.17 dependencies: - rrweb: 2.0.0-alpha.17 + rrweb: 2.0.0-alpha.17(patch_hash=xlkuvshzdprjlpxe7nzsj3spyi) dev: true /@rrweb/types@2.0.0-alpha.17: @@ -9417,7 +9412,7 @@ packages: postcss: 8.4.47 dev: true - /rrweb@2.0.0-alpha.17: + /rrweb@2.0.0-alpha.17(patch_hash=xlkuvshzdprjlpxe7nzsj3spyi): resolution: {integrity: sha512-GQxBkCC4r9XL2bwSdv7iIS49M3cEA8OtObVq0rrQ4GUT4+h7omucGQ4x7m5YN5Vq1oalStBaBlYqF7yRnfG3JA==} dependencies: '@rrweb/types': 2.0.0-alpha.17 @@ -9429,6 +9424,7 @@ packages: rrdom: 2.0.0-alpha.17 rrweb-snapshot: 2.0.0-alpha.17 dev: true + patched: true /rsvp@4.8.5: resolution: {integrity: sha512-nfMOlASu9OnRJo1mbEk2cz0D56a1MBNrJ7orjRZQG10XDyuvwksKbuXNp6qa+kbn839HwjwhBzhFmdsaEAfauA==} diff --git a/src/extensions/replay/sessionrecording-utils.ts b/src/extensions/replay/sessionrecording-utils.ts index 42cb7729c..aba786e87 100644 --- a/src/extensions/replay/sessionrecording-utils.ts +++ b/src/extensions/replay/sessionrecording-utils.ts @@ -9,6 +9,7 @@ import type { RecordPlugin, SamplingStrategy, } from '@rrweb/types' +import type { DataURLOptions, MaskInputFn, MaskInputOptions, MaskTextFn, Mirror, SlimDOMOptions } from 'rrweb-snapshot' import { isObject } from '../../utils/type-utils' import { SnapshotBuffer } from './sessionrecording' @@ -53,7 +54,7 @@ export type rrwebRecord = { (options: recordOptions): listenerHandler addCustomEvent: (tag: string, payload: any) => void takeFullSnapshot: () => void - mirror: any + mirror: Mirror } export declare type recordOptions = { @@ -66,16 +67,16 @@ export declare type recordOptions = { maskTextClass?: maskTextClass maskTextSelector?: string maskAllInputs?: boolean - maskInputOptions?: any - maskInputFn?: any - maskTextFn?: any - slimDOMOptions?: any | 'all' | true + maskInputOptions?: MaskInputOptions + maskInputFn?: MaskInputFn + maskTextFn?: MaskTextFn + slimDOMOptions?: SlimDOMOptions | 'all' | true ignoreCSSAttributes?: Set inlineStylesheet?: boolean hooks?: hooksParam // packFn?: PackFn sampling?: SamplingStrategy - dataURLOptions?: any + dataURLOptions?: DataURLOptions recordCanvas?: boolean recordCrossOriginIframes?: boolean recordAfter?: 'DOMContentLoaded' | 'load' diff --git a/src/types.ts b/src/types.ts index d3bf1f353..a652d729f 100644 --- a/src/types.ts +++ b/src/types.ts @@ -1,3 +1,4 @@ +import type { MaskInputOptions, SlimDOMOptions } from 'rrweb-snapshot' import { PostHog } from './posthog-core' import type { SegmentAnalytics } from './extensions/segment-integration' @@ -267,9 +268,9 @@ export interface SessionRecordingOptions { maskTextSelector?: string | null maskTextFn?: ((text: string, element: HTMLElement | null) => string) | null maskAllInputs?: boolean - maskInputOptions?: any + maskInputOptions?: MaskInputOptions maskInputFn?: ((text: string, element?: HTMLElement) => string) | null - slimDOMOptions?: any | 'all' | true + slimDOMOptions?: SlimDOMOptions | 'all' | true collectFonts?: boolean inlineStylesheet?: boolean recordCrossOriginIframes?: boolean From d84179a7ff30a25ac5de4b1b861ccdc8d90c5e12 Mon Sep 17 00:00:00 2001 From: David Newell Date: Wed, 23 Oct 2024 15:27:21 +0100 Subject: [PATCH 13/21] fix import --- src/entrypoints/recorder.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/entrypoints/recorder.ts b/src/entrypoints/recorder.ts index 134b252ff..4f53d4a71 100644 --- a/src/entrypoints/recorder.ts +++ b/src/entrypoints/recorder.ts @@ -1,4 +1,4 @@ -import { record as rrwebRecord } from '@rrweb/record' +import { record as rrwebRecord } from 'rrweb' import { getRecordConsolePlugin } from '@rrweb/rrweb-plugin-console-record' // rrweb/network@1 code starts From 61885faaa267215811e1c39b876850f5d8445b54 Mon Sep 17 00:00:00 2001 From: David Newell Date: Mon, 28 Oct 2024 16:19:49 +0000 Subject: [PATCH 14/21] replace with @rrweb/record --- package.json | 2 +- pnpm-lock.yaml | 13 ++++++++++--- src/entrypoints/recorder.ts | 2 +- 3 files changed, 12 insertions(+), 5 deletions(-) diff --git a/package.json b/package.json index 937359225..6c63a0124 100644 --- a/package.json +++ b/package.json @@ -104,7 +104,7 @@ "rollup": "^4.24.0", "rollup-plugin-dts": "^6.1.1", "rollup-plugin-visualizer": "^5.12.0", - "rrweb": "2.0.0-alpha.17", + "@rrweb/record": "2.0.0-alpha.17", "rrweb-snapshot": "2.0.0-alpha.17", "sinon": "9.0.2", "testcafe": "1.19.0", diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml index bc8d2dcea..f2732c517 100644 --- a/pnpm-lock.yaml +++ b/pnpm-lock.yaml @@ -66,6 +66,9 @@ devDependencies: '@rollup/plugin-typescript': specifier: ^12.1.1 version: 12.1.1(rollup@4.24.0)(tslib@2.5.0)(typescript@5.5.4) + '@rrweb/record': + specifier: 2.0.0-alpha.17 + version: 2.0.0-alpha.17 '@rrweb/rrweb-plugin-console-record': specifier: 2.0.0-alpha.17 version: 2.0.0-alpha.17(rrweb@2.0.0-alpha.17) @@ -204,9 +207,6 @@ devDependencies: rollup-plugin-visualizer: specifier: ^5.12.0 version: 5.12.0(rollup@4.24.0) - rrweb: - specifier: 2.0.0-alpha.17 - version: 2.0.0-alpha.17(patch_hash=xlkuvshzdprjlpxe7nzsj3spyi) rrweb-snapshot: specifier: 2.0.0-alpha.17 version: 2.0.0-alpha.17 @@ -2802,6 +2802,13 @@ packages: dev: true optional: true + /@rrweb/record@2.0.0-alpha.17: + resolution: {integrity: sha512-Je+lzjeWMF8/I0IDoXFzkGPKT8j7AkaBup5YcwUHlkp18VhLVze416MvI6915teE27uUA2ScXMXzG0Yiu5VTIw==} + dependencies: + '@rrweb/types': 2.0.0-alpha.17 + rrweb: 2.0.0-alpha.17(patch_hash=xlkuvshzdprjlpxe7nzsj3spyi) + dev: true + /@rrweb/rrweb-plugin-console-record@2.0.0-alpha.17(rrweb@2.0.0-alpha.17): resolution: {integrity: sha512-tjNJ3wWUDMMf275xr4Rb5tVYF2UR+wXvSxnyS9tRKnRa574PQQvx7sGbqM/O9AytYjnbiTrAMqNR7OFysGCMwQ==} peerDependencies: diff --git a/src/entrypoints/recorder.ts b/src/entrypoints/recorder.ts index 4f53d4a71..134b252ff 100644 --- a/src/entrypoints/recorder.ts +++ b/src/entrypoints/recorder.ts @@ -1,4 +1,4 @@ -import { record as rrwebRecord } from 'rrweb' +import { record as rrwebRecord } from '@rrweb/record' import { getRecordConsolePlugin } from '@rrweb/rrweb-plugin-console-record' // rrweb/network@1 code starts From 57a50f6796147e12ea1676397a2c5065e8926c33 Mon Sep 17 00:00:00 2001 From: David Newell Date: Mon, 28 Oct 2024 16:23:59 +0000 Subject: [PATCH 15/21] remove from both packages --- package.json | 6 +- patches/@rrweb__record@2.0.0-alpha.17.patch | 7085 +++++++++++++++++++ patches/rrweb-snapshot@2.0.0-alpha.17.patch | 3533 +++++++++ pnpm-lock.yaml | 22 +- 4 files changed, 10637 insertions(+), 9 deletions(-) create mode 100644 patches/@rrweb__record@2.0.0-alpha.17.patch create mode 100644 patches/rrweb-snapshot@2.0.0-alpha.17.patch diff --git a/package.json b/package.json index 6c63a0124..26591b4be 100644 --- a/package.json +++ b/package.json @@ -58,6 +58,7 @@ "@rollup/plugin-node-resolve": "^15.3.0", "@rollup/plugin-terser": "^0.4.4", "@rollup/plugin-typescript": "^12.1.1", + "@rrweb/record": "2.0.0-alpha.17", "@rrweb/rrweb-plugin-console-record": "2.0.0-alpha.17", "@rrweb/types": "2.0.0-alpha.17", "@sentry/types": "8.7.0", @@ -104,7 +105,6 @@ "rollup": "^4.24.0", "rollup-plugin-dts": "^6.1.1", "rollup-plugin-visualizer": "^5.12.0", - "@rrweb/record": "2.0.0-alpha.17", "rrweb-snapshot": "2.0.0-alpha.17", "sinon": "9.0.2", "testcafe": "1.19.0", @@ -127,7 +127,9 @@ ], "pnpm": { "patchedDependencies": { - "rrweb@2.0.0-alpha.17": "patches/rrweb@2.0.0-alpha.17.patch" + "rrweb@2.0.0-alpha.17": "patches/rrweb@2.0.0-alpha.17.patch", + "@rrweb/record@2.0.0-alpha.17": "patches/@rrweb__record@2.0.0-alpha.17.patch", + "rrweb-snapshot@2.0.0-alpha.17": "patches/rrweb-snapshot@2.0.0-alpha.17.patch" } } } diff --git a/patches/@rrweb__record@2.0.0-alpha.17.patch b/patches/@rrweb__record@2.0.0-alpha.17.patch new file mode 100644 index 000000000..bc9a5b25b --- /dev/null +++ b/patches/@rrweb__record@2.0.0-alpha.17.patch @@ -0,0 +1,7085 @@ +diff --git a/dist/record.js b/dist/record.js +index 46ec389fefb698243008b39db65470dbdf0a3857..ab4f489bda64cb992c184b727a9175de7a646f2d 100644 +--- a/dist/record.js ++++ b/dist/record.js +@@ -1336,7080 +1336,6 @@ function getAugmentedNamespace$1(n2) { + }); + return a2; + } +-var picocolors_browser$1 = { exports: {} }; +-var x$1 = String; +-var create$1 = function() { +- return { isColorSupported: false, reset: x$1, bold: x$1, dim: x$1, italic: x$1, underline: x$1, inverse: x$1, hidden: x$1, strikethrough: x$1, black: x$1, red: x$1, green: x$1, yellow: x$1, blue: x$1, magenta: x$1, cyan: x$1, white: x$1, gray: x$1, bgBlack: x$1, bgRed: x$1, bgGreen: x$1, bgYellow: x$1, bgBlue: x$1, bgMagenta: x$1, bgCyan: x$1, bgWhite: x$1 }; +-}; +-picocolors_browser$1.exports = create$1(); +-picocolors_browser$1.exports.createColors = create$1; +-var picocolors_browserExports$1 = picocolors_browser$1.exports; +-const __viteBrowserExternal$2 = {}; +-const __viteBrowserExternal$1$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({ +- __proto__: null, +- default: __viteBrowserExternal$2 +-}, Symbol.toStringTag, { value: "Module" })); +-const require$$2$1 = /* @__PURE__ */ getAugmentedNamespace$1(__viteBrowserExternal$1$1); +-let pico$1 = picocolors_browserExports$1; +-let terminalHighlight$1$1 = require$$2$1; +-let CssSyntaxError$3$1 = class CssSyntaxError extends Error { +- constructor(message, line, column, source, file, plugin22) { +- super(message); +- this.name = "CssSyntaxError"; +- this.reason = message; +- if (file) { +- this.file = file; +- } +- if (source) { +- this.source = source; +- } +- if (plugin22) { +- this.plugin = plugin22; +- } +- if (typeof line !== "undefined" && typeof column !== "undefined") { +- if (typeof line === "number") { +- this.line = line; +- this.column = column; +- } else { +- this.line = line.line; +- this.column = line.column; +- this.endLine = column.line; +- this.endColumn = column.column; +- } +- } +- this.setMessage(); +- if (Error.captureStackTrace) { +- Error.captureStackTrace(this, CssSyntaxError); +- } +- } +- setMessage() { +- this.message = this.plugin ? this.plugin + ": " : ""; +- this.message += this.file ? this.file : ""; +- if (typeof this.line !== "undefined") { +- this.message += ":" + this.line + ":" + this.column; +- } +- this.message += ": " + this.reason; +- } +- showSourceCode(color) { +- if (!this.source) return ""; +- let css = this.source; +- if (color == null) color = pico$1.isColorSupported; +- if (terminalHighlight$1$1) { +- if (color) css = terminalHighlight$1$1(css); +- } +- let lines = css.split(/\r?\n/); +- let start = Math.max(this.line - 3, 0); +- let end = Math.min(this.line + 2, lines.length); +- let maxWidth = String(end).length; +- let mark, aside; +- if (color) { +- let { bold, gray, red } = pico$1.createColors(true); +- mark = (text) => bold(red(text)); +- aside = (text) => gray(text); +- } else { +- mark = aside = (str) => str; +- } +- return lines.slice(start, end).map((line, index2) => { +- let number = start + 1 + index2; +- let gutter = " " + (" " + number).slice(-maxWidth) + " | "; +- if (number === this.line) { +- let spacing = aside(gutter.replace(/\d/g, " ")) + line.slice(0, this.column - 1).replace(/[^\t]/g, " "); +- return mark(">") + aside(gutter) + line + "\n " + spacing + mark("^"); +- } +- return " " + aside(gutter) + line; +- }).join("\n"); +- } +- toString() { +- let code = this.showSourceCode(); +- if (code) { +- code = "\n\n" + code + "\n"; +- } +- return this.name + ": " + this.message + code; +- } +-}; +-var cssSyntaxError$1 = CssSyntaxError$3$1; +-CssSyntaxError$3$1.default = CssSyntaxError$3$1; +-var symbols$1 = {}; +-symbols$1.isClean = Symbol("isClean"); +-symbols$1.my = Symbol("my"); +-const DEFAULT_RAW$1 = { +- after: "\n", +- beforeClose: "\n", +- beforeComment: "\n", +- beforeDecl: "\n", +- beforeOpen: " ", +- beforeRule: "\n", +- colon: ": ", +- commentLeft: " ", +- commentRight: " ", +- emptyBody: "", +- indent: " ", +- semicolon: false +-}; +-function capitalize$1(str) { +- return str[0].toUpperCase() + str.slice(1); +-} +-let Stringifier$2$1 = class Stringifier { +- constructor(builder) { +- this.builder = builder; +- } +- atrule(node2, semicolon) { +- let name = "@" + node2.name; +- let params = node2.params ? this.rawValue(node2, "params") : ""; +- if (typeof node2.raws.afterName !== "undefined") { +- name += node2.raws.afterName; +- } else if (params) { +- name += " "; +- } +- if (node2.nodes) { +- this.block(node2, name + params); +- } else { +- let end = (node2.raws.between || "") + (semicolon ? ";" : ""); +- this.builder(name + params + end, node2); +- } +- } +- beforeAfter(node2, detect) { +- let value; +- if (node2.type === "decl") { +- value = this.raw(node2, null, "beforeDecl"); +- } else if (node2.type === "comment") { +- value = this.raw(node2, null, "beforeComment"); +- } else if (detect === "before") { +- value = this.raw(node2, null, "beforeRule"); +- } else { +- value = this.raw(node2, null, "beforeClose"); +- } +- let buf = node2.parent; +- let depth = 0; +- while (buf && buf.type !== "root") { +- depth += 1; +- buf = buf.parent; +- } +- if (value.includes("\n")) { +- let indent = this.raw(node2, null, "indent"); +- if (indent.length) { +- for (let step = 0; step < depth; step++) value += indent; +- } +- } +- return value; +- } +- block(node2, start) { +- let between = this.raw(node2, "between", "beforeOpen"); +- this.builder(start + between + "{", node2, "start"); +- let after; +- if (node2.nodes && node2.nodes.length) { +- this.body(node2); +- after = this.raw(node2, "after"); +- } else { +- after = this.raw(node2, "after", "emptyBody"); +- } +- if (after) this.builder(after); +- this.builder("}", node2, "end"); +- } +- body(node2) { +- let last = node2.nodes.length - 1; +- while (last > 0) { +- if (node2.nodes[last].type !== "comment") break; +- last -= 1; +- } +- let semicolon = this.raw(node2, "semicolon"); +- for (let i2 = 0; i2 < node2.nodes.length; i2++) { +- let child = node2.nodes[i2]; +- let before = this.raw(child, "before"); +- if (before) this.builder(before); +- this.stringify(child, last !== i2 || semicolon); +- } +- } +- comment(node2) { +- let left = this.raw(node2, "left", "commentLeft"); +- let right = this.raw(node2, "right", "commentRight"); +- this.builder("/*" + left + node2.text + right + "*/", node2); +- } +- decl(node2, semicolon) { +- let between = this.raw(node2, "between", "colon"); +- let string = node2.prop + between + this.rawValue(node2, "value"); +- if (node2.important) { +- string += node2.raws.important || " !important"; +- } +- if (semicolon) string += ";"; +- this.builder(string, node2); +- } +- document(node2) { +- this.body(node2); +- } +- raw(node2, own, detect) { +- let value; +- if (!detect) detect = own; +- if (own) { +- value = node2.raws[own]; +- if (typeof value !== "undefined") return value; +- } +- let parent = node2.parent; +- if (detect === "before") { +- if (!parent || parent.type === "root" && parent.first === node2) { +- return ""; +- } +- if (parent && parent.type === "document") { +- return ""; +- } +- } +- if (!parent) return DEFAULT_RAW$1[detect]; +- let root2 = node2.root(); +- if (!root2.rawCache) root2.rawCache = {}; +- if (typeof root2.rawCache[detect] !== "undefined") { +- return root2.rawCache[detect]; +- } +- if (detect === "before" || detect === "after") { +- return this.beforeAfter(node2, detect); +- } else { +- let method = "raw" + capitalize$1(detect); +- if (this[method]) { +- value = this[method](root2, node2); +- } else { +- root2.walk((i2) => { +- value = i2.raws[own]; +- if (typeof value !== "undefined") return false; +- }); +- } +- } +- if (typeof value === "undefined") value = DEFAULT_RAW$1[detect]; +- root2.rawCache[detect] = value; +- return value; +- } +- rawBeforeClose(root2) { +- let value; +- root2.walk((i2) => { +- if (i2.nodes && i2.nodes.length > 0) { +- if (typeof i2.raws.after !== "undefined") { +- value = i2.raws.after; +- if (value.includes("\n")) { +- value = value.replace(/[^\n]+$/, ""); +- } +- return false; +- } +- } +- }); +- if (value) value = value.replace(/\S/g, ""); +- return value; +- } +- rawBeforeComment(root2, node2) { +- let value; +- root2.walkComments((i2) => { +- if (typeof i2.raws.before !== "undefined") { +- value = i2.raws.before; +- if (value.includes("\n")) { +- value = value.replace(/[^\n]+$/, ""); +- } +- return false; +- } +- }); +- if (typeof value === "undefined") { +- value = this.raw(node2, null, "beforeDecl"); +- } else if (value) { +- value = value.replace(/\S/g, ""); +- } +- return value; +- } +- rawBeforeDecl(root2, node2) { +- let value; +- root2.walkDecls((i2) => { +- if (typeof i2.raws.before !== "undefined") { +- value = i2.raws.before; +- if (value.includes("\n")) { +- value = value.replace(/[^\n]+$/, ""); +- } +- return false; +- } +- }); +- if (typeof value === "undefined") { +- value = this.raw(node2, null, "beforeRule"); +- } else if (value) { +- value = value.replace(/\S/g, ""); +- } +- return value; +- } +- rawBeforeOpen(root2) { +- let value; +- root2.walk((i2) => { +- if (i2.type !== "decl") { +- value = i2.raws.between; +- if (typeof value !== "undefined") return false; +- } +- }); +- return value; +- } +- rawBeforeRule(root2) { +- let value; +- root2.walk((i2) => { +- if (i2.nodes && (i2.parent !== root2 || root2.first !== i2)) { +- if (typeof i2.raws.before !== "undefined") { +- value = i2.raws.before; +- if (value.includes("\n")) { +- value = value.replace(/[^\n]+$/, ""); +- } +- return false; +- } +- } +- }); +- if (value) value = value.replace(/\S/g, ""); +- return value; +- } +- rawColon(root2) { +- let value; +- root2.walkDecls((i2) => { +- if (typeof i2.raws.between !== "undefined") { +- value = i2.raws.between.replace(/[^\s:]/g, ""); +- return false; +- } +- }); +- return value; +- } +- rawEmptyBody(root2) { +- let value; +- root2.walk((i2) => { +- if (i2.nodes && i2.nodes.length === 0) { +- value = i2.raws.after; +- if (typeof value !== "undefined") return false; +- } +- }); +- return value; +- } +- rawIndent(root2) { +- if (root2.raws.indent) return root2.raws.indent; +- let value; +- root2.walk((i2) => { +- let p = i2.parent; +- if (p && p !== root2 && p.parent && p.parent === root2) { +- if (typeof i2.raws.before !== "undefined") { +- let parts = i2.raws.before.split("\n"); +- value = parts[parts.length - 1]; +- value = value.replace(/\S/g, ""); +- return false; +- } +- } +- }); +- return value; +- } +- rawSemicolon(root2) { +- let value; +- root2.walk((i2) => { +- if (i2.nodes && i2.nodes.length && i2.last.type === "decl") { +- value = i2.raws.semicolon; +- if (typeof value !== "undefined") return false; +- } +- }); +- return value; +- } +- rawValue(node2, prop) { +- let value = node2[prop]; +- let raw = node2.raws[prop]; +- if (raw && raw.value === value) { +- return raw.raw; +- } +- return value; +- } +- root(node2) { +- this.body(node2); +- if (node2.raws.after) this.builder(node2.raws.after); +- } +- rule(node2) { +- this.block(node2, this.rawValue(node2, "selector")); +- if (node2.raws.ownSemicolon) { +- this.builder(node2.raws.ownSemicolon, node2, "end"); +- } +- } +- stringify(node2, semicolon) { +- if (!this[node2.type]) { +- throw new Error( +- "Unknown AST node type " + node2.type + ". Maybe you need to change PostCSS stringifier." +- ); +- } +- this[node2.type](node2, semicolon); +- } +-}; +-var stringifier$1 = Stringifier$2$1; +-Stringifier$2$1.default = Stringifier$2$1; +-let Stringifier$1$1 = stringifier$1; +-function stringify$4$1(node2, builder) { +- let str = new Stringifier$1$1(builder); +- str.stringify(node2); +-} +-var stringify_1$1 = stringify$4$1; +-stringify$4$1.default = stringify$4$1; +-let { isClean: isClean$2$1, my: my$2$1 } = symbols$1; +-let CssSyntaxError$2$1 = cssSyntaxError$1; +-let Stringifier2$1 = stringifier$1; +-let stringify$3$1 = stringify_1$1; +-function cloneNode$1(obj, parent) { +- let cloned = new obj.constructor(); +- for (let i2 in obj) { +- if (!Object.prototype.hasOwnProperty.call(obj, i2)) { +- continue; +- } +- if (i2 === "proxyCache") continue; +- let value = obj[i2]; +- let type = typeof value; +- if (i2 === "parent" && type === "object") { +- if (parent) cloned[i2] = parent; +- } else if (i2 === "source") { +- cloned[i2] = value; +- } else if (Array.isArray(value)) { +- cloned[i2] = value.map((j) => cloneNode$1(j, cloned)); +- } else { +- if (type === "object" && value !== null) value = cloneNode$1(value); +- cloned[i2] = value; +- } +- } +- return cloned; +-} +-let Node$4$1 = class Node2 { +- constructor(defaults = {}) { +- this.raws = {}; +- this[isClean$2$1] = false; +- this[my$2$1] = true; +- for (let name in defaults) { +- if (name === "nodes") { +- this.nodes = []; +- for (let node2 of defaults[name]) { +- if (typeof node2.clone === "function") { +- this.append(node2.clone()); +- } else { +- this.append(node2); +- } +- } +- } else { +- this[name] = defaults[name]; +- } +- } +- } +- addToError(error) { +- error.postcssNode = this; +- if (error.stack && this.source && /\n\s{4}at /.test(error.stack)) { +- let s2 = this.source; +- error.stack = error.stack.replace( +- /\n\s{4}at /, +- `$&${s2.input.from}:${s2.start.line}:${s2.start.column}$&` +- ); +- } +- return error; +- } +- after(add) { +- this.parent.insertAfter(this, add); +- return this; +- } +- assign(overrides = {}) { +- for (let name in overrides) { +- this[name] = overrides[name]; +- } +- return this; +- } +- before(add) { +- this.parent.insertBefore(this, add); +- return this; +- } +- cleanRaws(keepBetween) { +- delete this.raws.before; +- delete this.raws.after; +- if (!keepBetween) delete this.raws.between; +- } +- clone(overrides = {}) { +- let cloned = cloneNode$1(this); +- for (let name in overrides) { +- cloned[name] = overrides[name]; +- } +- return cloned; +- } +- cloneAfter(overrides = {}) { +- let cloned = this.clone(overrides); +- this.parent.insertAfter(this, cloned); +- return cloned; +- } +- cloneBefore(overrides = {}) { +- let cloned = this.clone(overrides); +- this.parent.insertBefore(this, cloned); +- return cloned; +- } +- error(message, opts = {}) { +- if (this.source) { +- let { end, start } = this.rangeBy(opts); +- return this.source.input.error( +- message, +- { column: start.column, line: start.line }, +- { column: end.column, line: end.line }, +- opts +- ); +- } +- return new CssSyntaxError$2$1(message); +- } +- getProxyProcessor() { +- return { +- get(node2, prop) { +- if (prop === "proxyOf") { +- return node2; +- } else if (prop === "root") { +- return () => node2.root().toProxy(); +- } else { +- return node2[prop]; +- } +- }, +- set(node2, prop, value) { +- if (node2[prop] === value) return true; +- node2[prop] = value; +- if (prop === "prop" || prop === "value" || prop === "name" || prop === "params" || prop === "important" || /* c8 ignore next */ +- prop === "text") { +- node2.markDirty(); +- } +- return true; +- } +- }; +- } +- markDirty() { +- if (this[isClean$2$1]) { +- this[isClean$2$1] = false; +- let next = this; +- while (next = next.parent) { +- next[isClean$2$1] = false; +- } +- } +- } +- next() { +- if (!this.parent) return void 0; +- let index2 = this.parent.index(this); +- return this.parent.nodes[index2 + 1]; +- } +- positionBy(opts, stringRepresentation) { +- let pos = this.source.start; +- if (opts.index) { +- pos = this.positionInside(opts.index, stringRepresentation); +- } else if (opts.word) { +- stringRepresentation = this.toString(); +- let index2 = stringRepresentation.indexOf(opts.word); +- if (index2 !== -1) pos = this.positionInside(index2, stringRepresentation); +- } +- return pos; +- } +- positionInside(index2, stringRepresentation) { +- let string = stringRepresentation || this.toString(); +- let column = this.source.start.column; +- let line = this.source.start.line; +- for (let i2 = 0; i2 < index2; i2++) { +- if (string[i2] === "\n") { +- column = 1; +- line += 1; +- } else { +- column += 1; +- } +- } +- return { column, line }; +- } +- prev() { +- if (!this.parent) return void 0; +- let index2 = this.parent.index(this); +- return this.parent.nodes[index2 - 1]; +- } +- rangeBy(opts) { +- let start = { +- column: this.source.start.column, +- line: this.source.start.line +- }; +- let end = this.source.end ? { +- column: this.source.end.column + 1, +- line: this.source.end.line +- } : { +- column: start.column + 1, +- line: start.line +- }; +- if (opts.word) { +- let stringRepresentation = this.toString(); +- let index2 = stringRepresentation.indexOf(opts.word); +- if (index2 !== -1) { +- start = this.positionInside(index2, stringRepresentation); +- end = this.positionInside(index2 + opts.word.length, stringRepresentation); +- } +- } else { +- if (opts.start) { +- start = { +- column: opts.start.column, +- line: opts.start.line +- }; +- } else if (opts.index) { +- start = this.positionInside(opts.index); +- } +- if (opts.end) { +- end = { +- column: opts.end.column, +- line: opts.end.line +- }; +- } else if (typeof opts.endIndex === "number") { +- end = this.positionInside(opts.endIndex); +- } else if (opts.index) { +- end = this.positionInside(opts.index + 1); +- } +- } +- if (end.line < start.line || end.line === start.line && end.column <= start.column) { +- end = { column: start.column + 1, line: start.line }; +- } +- return { end, start }; +- } +- raw(prop, defaultType) { +- let str = new Stringifier2$1(); +- return str.raw(this, prop, defaultType); +- } +- remove() { +- if (this.parent) { +- this.parent.removeChild(this); +- } +- this.parent = void 0; +- return this; +- } +- replaceWith(...nodes) { +- if (this.parent) { +- let bookmark = this; +- let foundSelf = false; +- for (let node2 of nodes) { +- if (node2 === this) { +- foundSelf = true; +- } else if (foundSelf) { +- this.parent.insertAfter(bookmark, node2); +- bookmark = node2; +- } else { +- this.parent.insertBefore(bookmark, node2); +- } +- } +- if (!foundSelf) { +- this.remove(); +- } +- } +- return this; +- } +- root() { +- let result2 = this; +- while (result2.parent && result2.parent.type !== "document") { +- result2 = result2.parent; +- } +- return result2; +- } +- toJSON(_, inputs) { +- let fixed = {}; +- let emitInputs = inputs == null; +- inputs = inputs || /* @__PURE__ */ new Map(); +- let inputsNextIndex = 0; +- for (let name in this) { +- if (!Object.prototype.hasOwnProperty.call(this, name)) { +- continue; +- } +- if (name === "parent" || name === "proxyCache") continue; +- let value = this[name]; +- if (Array.isArray(value)) { +- fixed[name] = value.map((i2) => { +- if (typeof i2 === "object" && i2.toJSON) { +- return i2.toJSON(null, inputs); +- } else { +- return i2; +- } +- }); +- } else if (typeof value === "object" && value.toJSON) { +- fixed[name] = value.toJSON(null, inputs); +- } else if (name === "source") { +- let inputId = inputs.get(value.input); +- if (inputId == null) { +- inputId = inputsNextIndex; +- inputs.set(value.input, inputsNextIndex); +- inputsNextIndex++; +- } +- fixed[name] = { +- end: value.end, +- inputId, +- start: value.start +- }; +- } else { +- fixed[name] = value; +- } +- } +- if (emitInputs) { +- fixed.inputs = [...inputs.keys()].map((input2) => input2.toJSON()); +- } +- return fixed; +- } +- toProxy() { +- if (!this.proxyCache) { +- this.proxyCache = new Proxy(this, this.getProxyProcessor()); +- } +- return this.proxyCache; +- } +- toString(stringifier2 = stringify$3$1) { +- if (stringifier2.stringify) stringifier2 = stringifier2.stringify; +- let result2 = ""; +- stringifier2(this, (i2) => { +- result2 += i2; +- }); +- return result2; +- } +- warn(result2, text, opts) { +- let data = { node: this }; +- for (let i2 in opts) data[i2] = opts[i2]; +- return result2.warn(text, data); +- } +- get proxyOf() { +- return this; +- } +-}; +-var node$1 = Node$4$1; +-Node$4$1.default = Node$4$1; +-let Node$3$1 = node$1; +-let Declaration$4$1 = class Declaration extends Node$3$1 { +- constructor(defaults) { +- if (defaults && typeof defaults.value !== "undefined" && typeof defaults.value !== "string") { +- defaults = { ...defaults, value: String(defaults.value) }; +- } +- super(defaults); +- this.type = "decl"; +- } +- get variable() { +- return this.prop.startsWith("--") || this.prop[0] === "$"; +- } +-}; +-var declaration$1 = Declaration$4$1; +-Declaration$4$1.default = Declaration$4$1; +-let urlAlphabet$1 = "useandom-26T198340PX75pxJACKVERYMINDBUSHWOLF_GQZbfghjklqvwyzrict"; +-let customAlphabet$1 = (alphabet, defaultSize = 21) => { +- return (size = defaultSize) => { +- let id = ""; +- let i2 = size; +- while (i2--) { +- id += alphabet[Math.random() * alphabet.length | 0]; +- } +- return id; +- }; +-}; +-let nanoid$1$1 = (size = 21) => { +- let id = ""; +- let i2 = size; +- while (i2--) { +- id += urlAlphabet$1[Math.random() * 64 | 0]; +- } +- return id; +-}; +-var nonSecure$1 = { nanoid: nanoid$1$1, customAlphabet: customAlphabet$1 }; +-let { SourceMapConsumer: SourceMapConsumer$2$1, SourceMapGenerator: SourceMapGenerator$2$1 } = require$$2$1; +-let { existsSync: existsSync$1, readFileSync: readFileSync$1 } = require$$2$1; +-let { dirname: dirname$1$1, join: join$1 } = require$$2$1; +-function fromBase64$1(str) { +- if (Buffer) { +- return Buffer.from(str, "base64").toString(); +- } else { +- return window.atob(str); +- } +-} +-let PreviousMap$2$1 = class PreviousMap { +- constructor(css, opts) { +- if (opts.map === false) return; +- this.loadAnnotation(css); +- this.inline = this.startWith(this.annotation, "data:"); +- let prev = opts.map ? opts.map.prev : void 0; +- let text = this.loadMap(opts.from, prev); +- if (!this.mapFile && opts.from) { +- this.mapFile = opts.from; +- } +- if (this.mapFile) this.root = dirname$1$1(this.mapFile); +- if (text) this.text = text; +- } +- consumer() { +- if (!this.consumerCache) { +- this.consumerCache = new SourceMapConsumer$2$1(this.text); +- } +- return this.consumerCache; +- } +- decodeInline(text) { +- let baseCharsetUri = /^data:application\/json;charset=utf-?8;base64,/; +- let baseUri = /^data:application\/json;base64,/; +- let charsetUri = /^data:application\/json;charset=utf-?8,/; +- let uri = /^data:application\/json,/; +- if (charsetUri.test(text) || uri.test(text)) { +- return decodeURIComponent(text.substr(RegExp.lastMatch.length)); +- } +- if (baseCharsetUri.test(text) || baseUri.test(text)) { +- return fromBase64$1(text.substr(RegExp.lastMatch.length)); +- } +- let encoding = text.match(/data:application\/json;([^,]+),/)[1]; +- throw new Error("Unsupported source map encoding " + encoding); +- } +- getAnnotationURL(sourceMapString) { +- return sourceMapString.replace(/^\/\*\s*# sourceMappingURL=/, "").trim(); +- } +- isMap(map) { +- if (typeof map !== "object") return false; +- return typeof map.mappings === "string" || typeof map._mappings === "string" || Array.isArray(map.sections); +- } +- loadAnnotation(css) { +- let comments = css.match(/\/\*\s*# sourceMappingURL=/gm); +- if (!comments) return; +- let start = css.lastIndexOf(comments.pop()); +- let end = css.indexOf("*/", start); +- if (start > -1 && end > -1) { +- this.annotation = this.getAnnotationURL(css.substring(start, end)); +- } +- } +- loadFile(path) { +- this.root = dirname$1$1(path); +- if (existsSync$1(path)) { +- this.mapFile = path; +- return readFileSync$1(path, "utf-8").toString().trim(); +- } +- } +- loadMap(file, prev) { +- if (prev === false) return false; +- if (prev) { +- if (typeof prev === "string") { +- return prev; +- } else if (typeof prev === "function") { +- let prevPath = prev(file); +- if (prevPath) { +- let map = this.loadFile(prevPath); +- if (!map) { +- throw new Error( +- "Unable to load previous source map: " + prevPath.toString() +- ); +- } +- return map; +- } +- } else if (prev instanceof SourceMapConsumer$2$1) { +- return SourceMapGenerator$2$1.fromSourceMap(prev).toString(); +- } else if (prev instanceof SourceMapGenerator$2$1) { +- return prev.toString(); +- } else if (this.isMap(prev)) { +- return JSON.stringify(prev); +- } else { +- throw new Error( +- "Unsupported previous source map format: " + prev.toString() +- ); +- } +- } else if (this.inline) { +- return this.decodeInline(this.annotation); +- } else if (this.annotation) { +- let map = this.annotation; +- if (file) map = join$1(dirname$1$1(file), map); +- return this.loadFile(map); +- } +- } +- startWith(string, start) { +- if (!string) return false; +- return string.substr(0, start.length) === start; +- } +- withContent() { +- return !!(this.consumer().sourcesContent && this.consumer().sourcesContent.length > 0); +- } +-}; +-var previousMap$1 = PreviousMap$2$1; +-PreviousMap$2$1.default = PreviousMap$2$1; +-let { SourceMapConsumer: SourceMapConsumer$1$1, SourceMapGenerator: SourceMapGenerator$1$1 } = require$$2$1; +-let { fileURLToPath: fileURLToPath$1, pathToFileURL: pathToFileURL$1$1 } = require$$2$1; +-let { isAbsolute: isAbsolute$1, resolve: resolve$1$1 } = require$$2$1; +-let { nanoid: nanoid$2 } = nonSecure$1; +-let terminalHighlight$2 = require$$2$1; +-let CssSyntaxError$1$1 = cssSyntaxError$1; +-let PreviousMap$1$1 = previousMap$1; +-let fromOffsetCache$1 = Symbol("fromOffsetCache"); +-let sourceMapAvailable$1$1 = Boolean(SourceMapConsumer$1$1 && SourceMapGenerator$1$1); +-let pathAvailable$1$1 = Boolean(resolve$1$1 && isAbsolute$1); +-let Input$4$1 = class Input { +- constructor(css, opts = {}) { +- if (css === null || typeof css === "undefined" || typeof css === "object" && !css.toString) { +- throw new Error(`PostCSS received ${css} instead of CSS string`); +- } +- this.css = css.toString(); +- if (this.css[0] === "\uFEFF" || this.css[0] === "￾") { +- this.hasBOM = true; +- this.css = this.css.slice(1); +- } else { +- this.hasBOM = false; +- } +- if (opts.from) { +- if (!pathAvailable$1$1 || /^\w+:\/\//.test(opts.from) || isAbsolute$1(opts.from)) { +- this.file = opts.from; +- } else { +- this.file = resolve$1$1(opts.from); +- } +- } +- if (pathAvailable$1$1 && sourceMapAvailable$1$1) { +- let map = new PreviousMap$1$1(this.css, opts); +- if (map.text) { +- this.map = map; +- let file = map.consumer().file; +- if (!this.file && file) this.file = this.mapResolve(file); +- } +- } +- if (!this.file) { +- this.id = ""; +- } +- if (this.map) this.map.file = this.from; +- } +- error(message, line, column, opts = {}) { +- let result2, endLine, endColumn; +- if (line && typeof line === "object") { +- let start = line; +- let end = column; +- if (typeof start.offset === "number") { +- let pos = this.fromOffset(start.offset); +- line = pos.line; +- column = pos.col; +- } else { +- line = start.line; +- column = start.column; +- } +- if (typeof end.offset === "number") { +- let pos = this.fromOffset(end.offset); +- endLine = pos.line; +- endColumn = pos.col; +- } else { +- endLine = end.line; +- endColumn = end.column; +- } +- } else if (!column) { +- let pos = this.fromOffset(line); +- line = pos.line; +- column = pos.col; +- } +- let origin = this.origin(line, column, endLine, endColumn); +- if (origin) { +- result2 = new CssSyntaxError$1$1( +- message, +- origin.endLine === void 0 ? origin.line : { column: origin.column, line: origin.line }, +- origin.endLine === void 0 ? origin.column : { column: origin.endColumn, line: origin.endLine }, +- origin.source, +- origin.file, +- opts.plugin +- ); +- } else { +- result2 = new CssSyntaxError$1$1( +- message, +- endLine === void 0 ? line : { column, line }, +- endLine === void 0 ? column : { column: endColumn, line: endLine }, +- this.css, +- this.file, +- opts.plugin +- ); +- } +- result2.input = { column, endColumn, endLine, line, source: this.css }; +- if (this.file) { +- if (pathToFileURL$1$1) { +- result2.input.url = pathToFileURL$1$1(this.file).toString(); +- } +- result2.input.file = this.file; +- } +- return result2; +- } +- fromOffset(offset) { +- let lastLine, lineToIndex; +- if (!this[fromOffsetCache$1]) { +- let lines = this.css.split("\n"); +- lineToIndex = new Array(lines.length); +- let prevIndex = 0; +- for (let i2 = 0, l2 = lines.length; i2 < l2; i2++) { +- lineToIndex[i2] = prevIndex; +- prevIndex += lines[i2].length + 1; +- } +- this[fromOffsetCache$1] = lineToIndex; +- } else { +- lineToIndex = this[fromOffsetCache$1]; +- } +- lastLine = lineToIndex[lineToIndex.length - 1]; +- let min = 0; +- if (offset >= lastLine) { +- min = lineToIndex.length - 1; +- } else { +- let max = lineToIndex.length - 2; +- let mid; +- while (min < max) { +- mid = min + (max - min >> 1); +- if (offset < lineToIndex[mid]) { +- max = mid - 1; +- } else if (offset >= lineToIndex[mid + 1]) { +- min = mid + 1; +- } else { +- min = mid; +- break; +- } +- } +- } +- return { +- col: offset - lineToIndex[min] + 1, +- line: min + 1 +- }; +- } +- mapResolve(file) { +- if (/^\w+:\/\//.test(file)) { +- return file; +- } +- return resolve$1$1(this.map.consumer().sourceRoot || this.map.root || ".", file); +- } +- origin(line, column, endLine, endColumn) { +- if (!this.map) return false; +- let consumer = this.map.consumer(); +- let from = consumer.originalPositionFor({ column, line }); +- if (!from.source) return false; +- let to; +- if (typeof endLine === "number") { +- to = consumer.originalPositionFor({ column: endColumn, line: endLine }); +- } +- let fromUrl; +- if (isAbsolute$1(from.source)) { +- fromUrl = pathToFileURL$1$1(from.source); +- } else { +- fromUrl = new URL( +- from.source, +- this.map.consumer().sourceRoot || pathToFileURL$1$1(this.map.mapFile) +- ); +- } +- let result2 = { +- column: from.column, +- endColumn: to && to.column, +- endLine: to && to.line, +- line: from.line, +- url: fromUrl.toString() +- }; +- if (fromUrl.protocol === "file:") { +- if (fileURLToPath$1) { +- result2.file = fileURLToPath$1(fromUrl); +- } else { +- throw new Error(`file: protocol is not available in this PostCSS build`); +- } +- } +- let source = consumer.sourceContentFor(from.source); +- if (source) result2.source = source; +- return result2; +- } +- toJSON() { +- let json = {}; +- for (let name of ["hasBOM", "css", "file", "id"]) { +- if (this[name] != null) { +- json[name] = this[name]; +- } +- } +- if (this.map) { +- json.map = { ...this.map }; +- if (json.map.consumerCache) { +- json.map.consumerCache = void 0; +- } +- } +- return json; +- } +- get from() { +- return this.file || this.id; +- } +-}; +-var input$1 = Input$4$1; +-Input$4$1.default = Input$4$1; +-if (terminalHighlight$2 && terminalHighlight$2.registerInput) { +- terminalHighlight$2.registerInput(Input$4$1); +-} +-let { SourceMapConsumer: SourceMapConsumer$3, SourceMapGenerator: SourceMapGenerator$3 } = require$$2$1; +-let { dirname: dirname$2, relative: relative$1, resolve: resolve$2, sep: sep$1 } = require$$2$1; +-let { pathToFileURL: pathToFileURL$2 } = require$$2$1; +-let Input$3$1 = input$1; +-let sourceMapAvailable$2 = Boolean(SourceMapConsumer$3 && SourceMapGenerator$3); +-let pathAvailable$2 = Boolean(dirname$2 && resolve$2 && relative$1 && sep$1); +-let MapGenerator$2$1 = class MapGenerator { +- constructor(stringify2, root2, opts, cssString) { +- this.stringify = stringify2; +- this.mapOpts = opts.map || {}; +- this.root = root2; +- this.opts = opts; +- this.css = cssString; +- this.originalCSS = cssString; +- this.usesFileUrls = !this.mapOpts.from && this.mapOpts.absolute; +- this.memoizedFileURLs = /* @__PURE__ */ new Map(); +- this.memoizedPaths = /* @__PURE__ */ new Map(); +- this.memoizedURLs = /* @__PURE__ */ new Map(); +- } +- addAnnotation() { +- let content; +- if (this.isInline()) { +- content = "data:application/json;base64," + this.toBase64(this.map.toString()); +- } else if (typeof this.mapOpts.annotation === "string") { +- content = this.mapOpts.annotation; +- } else if (typeof this.mapOpts.annotation === "function") { +- content = this.mapOpts.annotation(this.opts.to, this.root); +- } else { +- content = this.outputFile() + ".map"; +- } +- let eol = "\n"; +- if (this.css.includes("\r\n")) eol = "\r\n"; +- this.css += eol + "/*# sourceMappingURL=" + content + " */"; +- } +- applyPrevMaps() { +- for (let prev of this.previous()) { +- let from = this.toUrl(this.path(prev.file)); +- let root2 = prev.root || dirname$2(prev.file); +- let map; +- if (this.mapOpts.sourcesContent === false) { +- map = new SourceMapConsumer$3(prev.text); +- if (map.sourcesContent) { +- map.sourcesContent = null; +- } +- } else { +- map = prev.consumer(); +- } +- this.map.applySourceMap(map, from, this.toUrl(this.path(root2))); +- } +- } +- clearAnnotation() { +- if (this.mapOpts.annotation === false) return; +- if (this.root) { +- let node2; +- for (let i2 = this.root.nodes.length - 1; i2 >= 0; i2--) { +- node2 = this.root.nodes[i2]; +- if (node2.type !== "comment") continue; +- if (node2.text.indexOf("# sourceMappingURL=") === 0) { +- this.root.removeChild(i2); +- } +- } +- } else if (this.css) { +- this.css = this.css.replace(/\n*?\/\*#[\S\s]*?\*\/$/gm, ""); +- } +- } +- generate() { +- this.clearAnnotation(); +- if (pathAvailable$2 && sourceMapAvailable$2 && this.isMap()) { +- return this.generateMap(); +- } else { +- let result2 = ""; +- this.stringify(this.root, (i2) => { +- result2 += i2; +- }); +- return [result2]; +- } +- } +- generateMap() { +- if (this.root) { +- this.generateString(); +- } else if (this.previous().length === 1) { +- let prev = this.previous()[0].consumer(); +- prev.file = this.outputFile(); +- this.map = SourceMapGenerator$3.fromSourceMap(prev, { +- ignoreInvalidMapping: true +- }); +- } else { +- this.map = new SourceMapGenerator$3({ +- file: this.outputFile(), +- ignoreInvalidMapping: true +- }); +- this.map.addMapping({ +- generated: { column: 0, line: 1 }, +- original: { column: 0, line: 1 }, +- source: this.opts.from ? this.toUrl(this.path(this.opts.from)) : "" +- }); +- } +- if (this.isSourcesContent()) this.setSourcesContent(); +- if (this.root && this.previous().length > 0) this.applyPrevMaps(); +- if (this.isAnnotation()) this.addAnnotation(); +- if (this.isInline()) { +- return [this.css]; +- } else { +- return [this.css, this.map]; +- } +- } +- generateString() { +- this.css = ""; +- this.map = new SourceMapGenerator$3({ +- file: this.outputFile(), +- ignoreInvalidMapping: true +- }); +- let line = 1; +- let column = 1; +- let noSource = ""; +- let mapping = { +- generated: { column: 0, line: 0 }, +- original: { column: 0, line: 0 }, +- source: "" +- }; +- let lines, last; +- this.stringify(this.root, (str, node2, type) => { +- this.css += str; +- if (node2 && type !== "end") { +- mapping.generated.line = line; +- mapping.generated.column = column - 1; +- if (node2.source && node2.source.start) { +- mapping.source = this.sourcePath(node2); +- mapping.original.line = node2.source.start.line; +- mapping.original.column = node2.source.start.column - 1; +- this.map.addMapping(mapping); +- } else { +- mapping.source = noSource; +- mapping.original.line = 1; +- mapping.original.column = 0; +- this.map.addMapping(mapping); +- } +- } +- lines = str.match(/\n/g); +- if (lines) { +- line += lines.length; +- last = str.lastIndexOf("\n"); +- column = str.length - last; +- } else { +- column += str.length; +- } +- if (node2 && type !== "start") { +- let p = node2.parent || { raws: {} }; +- let childless = node2.type === "decl" || node2.type === "atrule" && !node2.nodes; +- if (!childless || node2 !== p.last || p.raws.semicolon) { +- if (node2.source && node2.source.end) { +- mapping.source = this.sourcePath(node2); +- mapping.original.line = node2.source.end.line; +- mapping.original.column = node2.source.end.column - 1; +- mapping.generated.line = line; +- mapping.generated.column = column - 2; +- this.map.addMapping(mapping); +- } else { +- mapping.source = noSource; +- mapping.original.line = 1; +- mapping.original.column = 0; +- mapping.generated.line = line; +- mapping.generated.column = column - 1; +- this.map.addMapping(mapping); +- } +- } +- } +- }); +- } +- isAnnotation() { +- if (this.isInline()) { +- return true; +- } +- if (typeof this.mapOpts.annotation !== "undefined") { +- return this.mapOpts.annotation; +- } +- if (this.previous().length) { +- return this.previous().some((i2) => i2.annotation); +- } +- return true; +- } +- isInline() { +- if (typeof this.mapOpts.inline !== "undefined") { +- return this.mapOpts.inline; +- } +- let annotation = this.mapOpts.annotation; +- if (typeof annotation !== "undefined" && annotation !== true) { +- return false; +- } +- if (this.previous().length) { +- return this.previous().some((i2) => i2.inline); +- } +- return true; +- } +- isMap() { +- if (typeof this.opts.map !== "undefined") { +- return !!this.opts.map; +- } +- return this.previous().length > 0; +- } +- isSourcesContent() { +- if (typeof this.mapOpts.sourcesContent !== "undefined") { +- return this.mapOpts.sourcesContent; +- } +- if (this.previous().length) { +- return this.previous().some((i2) => i2.withContent()); +- } +- return true; +- } +- outputFile() { +- if (this.opts.to) { +- return this.path(this.opts.to); +- } else if (this.opts.from) { +- return this.path(this.opts.from); +- } else { +- return "to.css"; +- } +- } +- path(file) { +- if (this.mapOpts.absolute) return file; +- if (file.charCodeAt(0) === 60) return file; +- if (/^\w+:\/\//.test(file)) return file; +- let cached = this.memoizedPaths.get(file); +- if (cached) return cached; +- let from = this.opts.to ? dirname$2(this.opts.to) : "."; +- if (typeof this.mapOpts.annotation === "string") { +- from = dirname$2(resolve$2(from, this.mapOpts.annotation)); +- } +- let path = relative$1(from, file); +- this.memoizedPaths.set(file, path); +- return path; +- } +- previous() { +- if (!this.previousMaps) { +- this.previousMaps = []; +- if (this.root) { +- this.root.walk((node2) => { +- if (node2.source && node2.source.input.map) { +- let map = node2.source.input.map; +- if (!this.previousMaps.includes(map)) { +- this.previousMaps.push(map); +- } +- } +- }); +- } else { +- let input2 = new Input$3$1(this.originalCSS, this.opts); +- if (input2.map) this.previousMaps.push(input2.map); +- } +- } +- return this.previousMaps; +- } +- setSourcesContent() { +- let already = {}; +- if (this.root) { +- this.root.walk((node2) => { +- if (node2.source) { +- let from = node2.source.input.from; +- if (from && !already[from]) { +- already[from] = true; +- let fromUrl = this.usesFileUrls ? this.toFileUrl(from) : this.toUrl(this.path(from)); +- this.map.setSourceContent(fromUrl, node2.source.input.css); +- } +- } +- }); +- } else if (this.css) { +- let from = this.opts.from ? this.toUrl(this.path(this.opts.from)) : ""; +- this.map.setSourceContent(from, this.css); +- } +- } +- sourcePath(node2) { +- if (this.mapOpts.from) { +- return this.toUrl(this.mapOpts.from); +- } else if (this.usesFileUrls) { +- return this.toFileUrl(node2.source.input.from); +- } else { +- return this.toUrl(this.path(node2.source.input.from)); +- } +- } +- toBase64(str) { +- if (Buffer) { +- return Buffer.from(str).toString("base64"); +- } else { +- return window.btoa(unescape(encodeURIComponent(str))); +- } +- } +- toFileUrl(path) { +- let cached = this.memoizedFileURLs.get(path); +- if (cached) return cached; +- if (pathToFileURL$2) { +- let fileURL = pathToFileURL$2(path).toString(); +- this.memoizedFileURLs.set(path, fileURL); +- return fileURL; +- } else { +- throw new Error( +- "`map.absolute` option is not available in this PostCSS build" +- ); +- } +- } +- toUrl(path) { +- let cached = this.memoizedURLs.get(path); +- if (cached) return cached; +- if (sep$1 === "\\") { +- path = path.replace(/\\/g, "/"); +- } +- let url = encodeURI(path).replace(/[#?]/g, encodeURIComponent); +- this.memoizedURLs.set(path, url); +- return url; +- } +-}; +-var mapGenerator$1 = MapGenerator$2$1; +-let Node$2$1 = node$1; +-let Comment$4$1 = class Comment extends Node$2$1 { +- constructor(defaults) { +- super(defaults); +- this.type = "comment"; +- } +-}; +-var comment$1 = Comment$4$1; +-Comment$4$1.default = Comment$4$1; +-let { isClean: isClean$1$1, my: my$1$1 } = symbols$1; +-let Declaration$3$1 = declaration$1; +-let Comment$3$1 = comment$1; +-let Node$1$1 = node$1; +-let parse$4$1, Rule$4$1, AtRule$4$1, Root$6$1; +-function cleanSource$1(nodes) { +- return nodes.map((i2) => { +- if (i2.nodes) i2.nodes = cleanSource$1(i2.nodes); +- delete i2.source; +- return i2; +- }); +-} +-function markDirtyUp$1(node2) { +- node2[isClean$1$1] = false; +- if (node2.proxyOf.nodes) { +- for (let i2 of node2.proxyOf.nodes) { +- markDirtyUp$1(i2); +- } +- } +-} +-let Container$7$1 = class Container extends Node$1$1 { +- append(...children) { +- for (let child of children) { +- let nodes = this.normalize(child, this.last); +- for (let node2 of nodes) this.proxyOf.nodes.push(node2); +- } +- this.markDirty(); +- return this; +- } +- cleanRaws(keepBetween) { +- super.cleanRaws(keepBetween); +- if (this.nodes) { +- for (let node2 of this.nodes) node2.cleanRaws(keepBetween); +- } +- } +- each(callback) { +- if (!this.proxyOf.nodes) return void 0; +- let iterator = this.getIterator(); +- let index2, result2; +- while (this.indexes[iterator] < this.proxyOf.nodes.length) { +- index2 = this.indexes[iterator]; +- result2 = callback(this.proxyOf.nodes[index2], index2); +- if (result2 === false) break; +- this.indexes[iterator] += 1; +- } +- delete this.indexes[iterator]; +- return result2; +- } +- every(condition) { +- return this.nodes.every(condition); +- } +- getIterator() { +- if (!this.lastEach) this.lastEach = 0; +- if (!this.indexes) this.indexes = {}; +- this.lastEach += 1; +- let iterator = this.lastEach; +- this.indexes[iterator] = 0; +- return iterator; +- } +- getProxyProcessor() { +- return { +- get(node2, prop) { +- if (prop === "proxyOf") { +- return node2; +- } else if (!node2[prop]) { +- return node2[prop]; +- } else if (prop === "each" || typeof prop === "string" && prop.startsWith("walk")) { +- return (...args) => { +- return node2[prop]( +- ...args.map((i2) => { +- if (typeof i2 === "function") { +- return (child, index2) => i2(child.toProxy(), index2); +- } else { +- return i2; +- } +- }) +- ); +- }; +- } else if (prop === "every" || prop === "some") { +- return (cb) => { +- return node2[prop]( +- (child, ...other) => cb(child.toProxy(), ...other) +- ); +- }; +- } else if (prop === "root") { +- return () => node2.root().toProxy(); +- } else if (prop === "nodes") { +- return node2.nodes.map((i2) => i2.toProxy()); +- } else if (prop === "first" || prop === "last") { +- return node2[prop].toProxy(); +- } else { +- return node2[prop]; +- } +- }, +- set(node2, prop, value) { +- if (node2[prop] === value) return true; +- node2[prop] = value; +- if (prop === "name" || prop === "params" || prop === "selector") { +- node2.markDirty(); +- } +- return true; +- } +- }; +- } +- index(child) { +- if (typeof child === "number") return child; +- if (child.proxyOf) child = child.proxyOf; +- return this.proxyOf.nodes.indexOf(child); +- } +- insertAfter(exist, add) { +- let existIndex = this.index(exist); +- let nodes = this.normalize(add, this.proxyOf.nodes[existIndex]).reverse(); +- existIndex = this.index(exist); +- for (let node2 of nodes) this.proxyOf.nodes.splice(existIndex + 1, 0, node2); +- let index2; +- for (let id in this.indexes) { +- index2 = this.indexes[id]; +- if (existIndex < index2) { +- this.indexes[id] = index2 + nodes.length; +- } +- } +- this.markDirty(); +- return this; +- } +- insertBefore(exist, add) { +- let existIndex = this.index(exist); +- let type = existIndex === 0 ? "prepend" : false; +- let nodes = this.normalize(add, this.proxyOf.nodes[existIndex], type).reverse(); +- existIndex = this.index(exist); +- for (let node2 of nodes) this.proxyOf.nodes.splice(existIndex, 0, node2); +- let index2; +- for (let id in this.indexes) { +- index2 = this.indexes[id]; +- if (existIndex <= index2) { +- this.indexes[id] = index2 + nodes.length; +- } +- } +- this.markDirty(); +- return this; +- } +- normalize(nodes, sample) { +- if (typeof nodes === "string") { +- nodes = cleanSource$1(parse$4$1(nodes).nodes); +- } else if (typeof nodes === "undefined") { +- nodes = []; +- } else if (Array.isArray(nodes)) { +- nodes = nodes.slice(0); +- for (let i2 of nodes) { +- if (i2.parent) i2.parent.removeChild(i2, "ignore"); +- } +- } else if (nodes.type === "root" && this.type !== "document") { +- nodes = nodes.nodes.slice(0); +- for (let i2 of nodes) { +- if (i2.parent) i2.parent.removeChild(i2, "ignore"); +- } +- } else if (nodes.type) { +- nodes = [nodes]; +- } else if (nodes.prop) { +- if (typeof nodes.value === "undefined") { +- throw new Error("Value field is missed in node creation"); +- } else if (typeof nodes.value !== "string") { +- nodes.value = String(nodes.value); +- } +- nodes = [new Declaration$3$1(nodes)]; +- } else if (nodes.selector) { +- nodes = [new Rule$4$1(nodes)]; +- } else if (nodes.name) { +- nodes = [new AtRule$4$1(nodes)]; +- } else if (nodes.text) { +- nodes = [new Comment$3$1(nodes)]; +- } else { +- throw new Error("Unknown node type in node creation"); +- } +- let processed = nodes.map((i2) => { +- if (!i2[my$1$1]) Container.rebuild(i2); +- i2 = i2.proxyOf; +- if (i2.parent) i2.parent.removeChild(i2); +- if (i2[isClean$1$1]) markDirtyUp$1(i2); +- if (typeof i2.raws.before === "undefined") { +- if (sample && typeof sample.raws.before !== "undefined") { +- i2.raws.before = sample.raws.before.replace(/\S/g, ""); +- } +- } +- i2.parent = this.proxyOf; +- return i2; +- }); +- return processed; +- } +- prepend(...children) { +- children = children.reverse(); +- for (let child of children) { +- let nodes = this.normalize(child, this.first, "prepend").reverse(); +- for (let node2 of nodes) this.proxyOf.nodes.unshift(node2); +- for (let id in this.indexes) { +- this.indexes[id] = this.indexes[id] + nodes.length; +- } +- } +- this.markDirty(); +- return this; +- } +- push(child) { +- child.parent = this; +- this.proxyOf.nodes.push(child); +- return this; +- } +- removeAll() { +- for (let node2 of this.proxyOf.nodes) node2.parent = void 0; +- this.proxyOf.nodes = []; +- this.markDirty(); +- return this; +- } +- removeChild(child) { +- child = this.index(child); +- this.proxyOf.nodes[child].parent = void 0; +- this.proxyOf.nodes.splice(child, 1); +- let index2; +- for (let id in this.indexes) { +- index2 = this.indexes[id]; +- if (index2 >= child) { +- this.indexes[id] = index2 - 1; +- } +- } +- this.markDirty(); +- return this; +- } +- replaceValues(pattern, opts, callback) { +- if (!callback) { +- callback = opts; +- opts = {}; +- } +- this.walkDecls((decl) => { +- if (opts.props && !opts.props.includes(decl.prop)) return; +- if (opts.fast && !decl.value.includes(opts.fast)) return; +- decl.value = decl.value.replace(pattern, callback); +- }); +- this.markDirty(); +- return this; +- } +- some(condition) { +- return this.nodes.some(condition); +- } +- walk(callback) { +- return this.each((child, i2) => { +- let result2; +- try { +- result2 = callback(child, i2); +- } catch (e2) { +- throw child.addToError(e2); +- } +- if (result2 !== false && child.walk) { +- result2 = child.walk(callback); +- } +- return result2; +- }); +- } +- walkAtRules(name, callback) { +- if (!callback) { +- callback = name; +- return this.walk((child, i2) => { +- if (child.type === "atrule") { +- return callback(child, i2); +- } +- }); +- } +- if (name instanceof RegExp) { +- return this.walk((child, i2) => { +- if (child.type === "atrule" && name.test(child.name)) { +- return callback(child, i2); +- } +- }); +- } +- return this.walk((child, i2) => { +- if (child.type === "atrule" && child.name === name) { +- return callback(child, i2); +- } +- }); +- } +- walkComments(callback) { +- return this.walk((child, i2) => { +- if (child.type === "comment") { +- return callback(child, i2); +- } +- }); +- } +- walkDecls(prop, callback) { +- if (!callback) { +- callback = prop; +- return this.walk((child, i2) => { +- if (child.type === "decl") { +- return callback(child, i2); +- } +- }); +- } +- if (prop instanceof RegExp) { +- return this.walk((child, i2) => { +- if (child.type === "decl" && prop.test(child.prop)) { +- return callback(child, i2); +- } +- }); +- } +- return this.walk((child, i2) => { +- if (child.type === "decl" && child.prop === prop) { +- return callback(child, i2); +- } +- }); +- } +- walkRules(selector, callback) { +- if (!callback) { +- callback = selector; +- return this.walk((child, i2) => { +- if (child.type === "rule") { +- return callback(child, i2); +- } +- }); +- } +- if (selector instanceof RegExp) { +- return this.walk((child, i2) => { +- if (child.type === "rule" && selector.test(child.selector)) { +- return callback(child, i2); +- } +- }); +- } +- return this.walk((child, i2) => { +- if (child.type === "rule" && child.selector === selector) { +- return callback(child, i2); +- } +- }); +- } +- get first() { +- if (!this.proxyOf.nodes) return void 0; +- return this.proxyOf.nodes[0]; +- } +- get last() { +- if (!this.proxyOf.nodes) return void 0; +- return this.proxyOf.nodes[this.proxyOf.nodes.length - 1]; +- } +-}; +-Container$7$1.registerParse = (dependant) => { +- parse$4$1 = dependant; +-}; +-Container$7$1.registerRule = (dependant) => { +- Rule$4$1 = dependant; +-}; +-Container$7$1.registerAtRule = (dependant) => { +- AtRule$4$1 = dependant; +-}; +-Container$7$1.registerRoot = (dependant) => { +- Root$6$1 = dependant; +-}; +-var container$1 = Container$7$1; +-Container$7$1.default = Container$7$1; +-Container$7$1.rebuild = (node2) => { +- if (node2.type === "atrule") { +- Object.setPrototypeOf(node2, AtRule$4$1.prototype); +- } else if (node2.type === "rule") { +- Object.setPrototypeOf(node2, Rule$4$1.prototype); +- } else if (node2.type === "decl") { +- Object.setPrototypeOf(node2, Declaration$3$1.prototype); +- } else if (node2.type === "comment") { +- Object.setPrototypeOf(node2, Comment$3$1.prototype); +- } else if (node2.type === "root") { +- Object.setPrototypeOf(node2, Root$6$1.prototype); +- } +- node2[my$1$1] = true; +- if (node2.nodes) { +- node2.nodes.forEach((child) => { +- Container$7$1.rebuild(child); +- }); +- } +-}; +-let Container$6$1 = container$1; +-let LazyResult$4$1, Processor$3$1; +-let Document$3$1 = class Document2 extends Container$6$1 { +- constructor(defaults) { +- super({ type: "document", ...defaults }); +- if (!this.nodes) { +- this.nodes = []; +- } +- } +- toResult(opts = {}) { +- let lazy = new LazyResult$4$1(new Processor$3$1(), this, opts); +- return lazy.stringify(); +- } +-}; +-Document$3$1.registerLazyResult = (dependant) => { +- LazyResult$4$1 = dependant; +-}; +-Document$3$1.registerProcessor = (dependant) => { +- Processor$3$1 = dependant; +-}; +-var document$1$1 = Document$3$1; +-Document$3$1.default = Document$3$1; +-let printed$1 = {}; +-var warnOnce$2$1 = function warnOnce(message) { +- if (printed$1[message]) return; +- printed$1[message] = true; +- if (typeof console !== "undefined" && console.warn) { +- console.warn(message); +- } +-}; +-let Warning$2$1 = class Warning { +- constructor(text, opts = {}) { +- this.type = "warning"; +- this.text = text; +- if (opts.node && opts.node.source) { +- let range = opts.node.rangeBy(opts); +- this.line = range.start.line; +- this.column = range.start.column; +- this.endLine = range.end.line; +- this.endColumn = range.end.column; +- } +- for (let opt in opts) this[opt] = opts[opt]; +- } +- toString() { +- if (this.node) { +- return this.node.error(this.text, { +- index: this.index, +- plugin: this.plugin, +- word: this.word +- }).message; +- } +- if (this.plugin) { +- return this.plugin + ": " + this.text; +- } +- return this.text; +- } +-}; +-var warning$1 = Warning$2$1; +-Warning$2$1.default = Warning$2$1; +-let Warning$1$1 = warning$1; +-let Result$3$1 = class Result { +- constructor(processor2, root2, opts) { +- this.processor = processor2; +- this.messages = []; +- this.root = root2; +- this.opts = opts; +- this.css = void 0; +- this.map = void 0; +- } +- toString() { +- return this.css; +- } +- warn(text, opts = {}) { +- if (!opts.plugin) { +- if (this.lastPlugin && this.lastPlugin.postcssPlugin) { +- opts.plugin = this.lastPlugin.postcssPlugin; +- } +- } +- let warning2 = new Warning$1$1(text, opts); +- this.messages.push(warning2); +- return warning2; +- } +- warnings() { +- return this.messages.filter((i2) => i2.type === "warning"); +- } +- get content() { +- return this.css; +- } +-}; +-var result$1 = Result$3$1; +-Result$3$1.default = Result$3$1; +-const SINGLE_QUOTE$1 = "'".charCodeAt(0); +-const DOUBLE_QUOTE$1 = '"'.charCodeAt(0); +-const BACKSLASH$1 = "\\".charCodeAt(0); +-const SLASH$1 = "/".charCodeAt(0); +-const NEWLINE$1 = "\n".charCodeAt(0); +-const SPACE$1 = " ".charCodeAt(0); +-const FEED$1 = "\f".charCodeAt(0); +-const TAB$1 = " ".charCodeAt(0); +-const CR$1 = "\r".charCodeAt(0); +-const OPEN_SQUARE$1 = "[".charCodeAt(0); +-const CLOSE_SQUARE$1 = "]".charCodeAt(0); +-const OPEN_PARENTHESES$1 = "(".charCodeAt(0); +-const CLOSE_PARENTHESES$1 = ")".charCodeAt(0); +-const OPEN_CURLY$1 = "{".charCodeAt(0); +-const CLOSE_CURLY$1 = "}".charCodeAt(0); +-const SEMICOLON$1 = ";".charCodeAt(0); +-const ASTERISK$1 = "*".charCodeAt(0); +-const COLON$1 = ":".charCodeAt(0); +-const AT$1 = "@".charCodeAt(0); +-const RE_AT_END$1 = /[\t\n\f\r "#'()/;[\\\]{}]/g; +-const RE_WORD_END$1 = /[\t\n\f\r !"#'():;@[\\\]{}]|\/(?=\*)/g; +-const RE_BAD_BRACKET$1 = /.[\r\n"'(/\\]/; +-const RE_HEX_ESCAPE$1 = /[\da-f]/i; +-var tokenize$1 = function tokenizer(input2, options = {}) { +- let css = input2.css.valueOf(); +- let ignore = options.ignoreErrors; +- let code, next, quote, content, escape; +- let escaped, escapePos, prev, n2, currentToken; +- let length = css.length; +- let pos = 0; +- let buffer = []; +- let returned = []; +- function position() { +- return pos; +- } +- function unclosed(what) { +- throw input2.error("Unclosed " + what, pos); +- } +- function endOfFile() { +- return returned.length === 0 && pos >= length; +- } +- function nextToken(opts) { +- if (returned.length) return returned.pop(); +- if (pos >= length) return; +- let ignoreUnclosed = opts ? opts.ignoreUnclosed : false; +- code = css.charCodeAt(pos); +- switch (code) { +- case NEWLINE$1: +- case SPACE$1: +- case TAB$1: +- case CR$1: +- case FEED$1: { +- next = pos; +- do { +- next += 1; +- code = css.charCodeAt(next); +- } while (code === SPACE$1 || code === NEWLINE$1 || code === TAB$1 || code === CR$1 || code === FEED$1); +- currentToken = ["space", css.slice(pos, next)]; +- pos = next - 1; +- break; +- } +- case OPEN_SQUARE$1: +- case CLOSE_SQUARE$1: +- case OPEN_CURLY$1: +- case CLOSE_CURLY$1: +- case COLON$1: +- case SEMICOLON$1: +- case CLOSE_PARENTHESES$1: { +- let controlChar = String.fromCharCode(code); +- currentToken = [controlChar, controlChar, pos]; +- break; +- } +- case OPEN_PARENTHESES$1: { +- prev = buffer.length ? buffer.pop()[1] : ""; +- n2 = css.charCodeAt(pos + 1); +- if (prev === "url" && n2 !== SINGLE_QUOTE$1 && n2 !== DOUBLE_QUOTE$1 && n2 !== SPACE$1 && n2 !== NEWLINE$1 && n2 !== TAB$1 && n2 !== FEED$1 && n2 !== CR$1) { +- next = pos; +- do { +- escaped = false; +- next = css.indexOf(")", next + 1); +- if (next === -1) { +- if (ignore || ignoreUnclosed) { +- next = pos; +- break; +- } else { +- unclosed("bracket"); +- } +- } +- escapePos = next; +- while (css.charCodeAt(escapePos - 1) === BACKSLASH$1) { +- escapePos -= 1; +- escaped = !escaped; +- } +- } while (escaped); +- currentToken = ["brackets", css.slice(pos, next + 1), pos, next]; +- pos = next; +- } else { +- next = css.indexOf(")", pos + 1); +- content = css.slice(pos, next + 1); +- if (next === -1 || RE_BAD_BRACKET$1.test(content)) { +- currentToken = ["(", "(", pos]; +- } else { +- currentToken = ["brackets", content, pos, next]; +- pos = next; +- } +- } +- break; +- } +- case SINGLE_QUOTE$1: +- case DOUBLE_QUOTE$1: { +- quote = code === SINGLE_QUOTE$1 ? "'" : '"'; +- next = pos; +- do { +- escaped = false; +- next = css.indexOf(quote, next + 1); +- if (next === -1) { +- if (ignore || ignoreUnclosed) { +- next = pos + 1; +- break; +- } else { +- unclosed("string"); +- } +- } +- escapePos = next; +- while (css.charCodeAt(escapePos - 1) === BACKSLASH$1) { +- escapePos -= 1; +- escaped = !escaped; +- } +- } while (escaped); +- currentToken = ["string", css.slice(pos, next + 1), pos, next]; +- pos = next; +- break; +- } +- case AT$1: { +- RE_AT_END$1.lastIndex = pos + 1; +- RE_AT_END$1.test(css); +- if (RE_AT_END$1.lastIndex === 0) { +- next = css.length - 1; +- } else { +- next = RE_AT_END$1.lastIndex - 2; +- } +- currentToken = ["at-word", css.slice(pos, next + 1), pos, next]; +- pos = next; +- break; +- } +- case BACKSLASH$1: { +- next = pos; +- escape = true; +- while (css.charCodeAt(next + 1) === BACKSLASH$1) { +- next += 1; +- escape = !escape; +- } +- code = css.charCodeAt(next + 1); +- if (escape && code !== SLASH$1 && code !== SPACE$1 && code !== NEWLINE$1 && code !== TAB$1 && code !== CR$1 && code !== FEED$1) { +- next += 1; +- if (RE_HEX_ESCAPE$1.test(css.charAt(next))) { +- while (RE_HEX_ESCAPE$1.test(css.charAt(next + 1))) { +- next += 1; +- } +- if (css.charCodeAt(next + 1) === SPACE$1) { +- next += 1; +- } +- } +- } +- currentToken = ["word", css.slice(pos, next + 1), pos, next]; +- pos = next; +- break; +- } +- default: { +- if (code === SLASH$1 && css.charCodeAt(pos + 1) === ASTERISK$1) { +- next = css.indexOf("*/", pos + 2) + 1; +- if (next === 0) { +- if (ignore || ignoreUnclosed) { +- next = css.length; +- } else { +- unclosed("comment"); +- } +- } +- currentToken = ["comment", css.slice(pos, next + 1), pos, next]; +- pos = next; +- } else { +- RE_WORD_END$1.lastIndex = pos + 1; +- RE_WORD_END$1.test(css); +- if (RE_WORD_END$1.lastIndex === 0) { +- next = css.length - 1; +- } else { +- next = RE_WORD_END$1.lastIndex - 2; +- } +- currentToken = ["word", css.slice(pos, next + 1), pos, next]; +- buffer.push(currentToken); +- pos = next; +- } +- break; +- } +- } +- pos++; +- return currentToken; +- } +- function back(token) { +- returned.push(token); +- } +- return { +- back, +- endOfFile, +- nextToken, +- position +- }; +-}; +-let Container$5$1 = container$1; +-let AtRule$3$1 = class AtRule extends Container$5$1 { +- constructor(defaults) { +- super(defaults); +- this.type = "atrule"; +- } +- append(...children) { +- if (!this.proxyOf.nodes) this.nodes = []; +- return super.append(...children); +- } +- prepend(...children) { +- if (!this.proxyOf.nodes) this.nodes = []; +- return super.prepend(...children); +- } +-}; +-var atRule$1 = AtRule$3$1; +-AtRule$3$1.default = AtRule$3$1; +-Container$5$1.registerAtRule(AtRule$3$1); +-let Container$4$1 = container$1; +-let LazyResult$3$1, Processor$2$1; +-let Root$5$1 = class Root extends Container$4$1 { +- constructor(defaults) { +- super(defaults); +- this.type = "root"; +- if (!this.nodes) this.nodes = []; +- } +- normalize(child, sample, type) { +- let nodes = super.normalize(child); +- if (sample) { +- if (type === "prepend") { +- if (this.nodes.length > 1) { +- sample.raws.before = this.nodes[1].raws.before; +- } else { +- delete sample.raws.before; +- } +- } else if (this.first !== sample) { +- for (let node2 of nodes) { +- node2.raws.before = sample.raws.before; +- } +- } +- } +- return nodes; +- } +- removeChild(child, ignore) { +- let index2 = this.index(child); +- if (!ignore && index2 === 0 && this.nodes.length > 1) { +- this.nodes[1].raws.before = this.nodes[index2].raws.before; +- } +- return super.removeChild(child); +- } +- toResult(opts = {}) { +- let lazy = new LazyResult$3$1(new Processor$2$1(), this, opts); +- return lazy.stringify(); +- } +-}; +-Root$5$1.registerLazyResult = (dependant) => { +- LazyResult$3$1 = dependant; +-}; +-Root$5$1.registerProcessor = (dependant) => { +- Processor$2$1 = dependant; +-}; +-var root$1 = Root$5$1; +-Root$5$1.default = Root$5$1; +-Container$4$1.registerRoot(Root$5$1); +-let list$2$1 = { +- comma(string) { +- return list$2$1.split(string, [","], true); +- }, +- space(string) { +- let spaces = [" ", "\n", " "]; +- return list$2$1.split(string, spaces); +- }, +- split(string, separators, last) { +- let array = []; +- let current = ""; +- let split = false; +- let func = 0; +- let inQuote = false; +- let prevQuote = ""; +- let escape = false; +- for (let letter of string) { +- if (escape) { +- escape = false; +- } else if (letter === "\\") { +- escape = true; +- } else if (inQuote) { +- if (letter === prevQuote) { +- inQuote = false; +- } +- } else if (letter === '"' || letter === "'") { +- inQuote = true; +- prevQuote = letter; +- } else if (letter === "(") { +- func += 1; +- } else if (letter === ")") { +- if (func > 0) func -= 1; +- } else if (func === 0) { +- if (separators.includes(letter)) split = true; +- } +- if (split) { +- if (current !== "") array.push(current.trim()); +- current = ""; +- split = false; +- } else { +- current += letter; +- } +- } +- if (last || current !== "") array.push(current.trim()); +- return array; +- } +-}; +-var list_1$1 = list$2$1; +-list$2$1.default = list$2$1; +-let Container$3$1 = container$1; +-let list$1$1 = list_1$1; +-let Rule$3$1 = class Rule extends Container$3$1 { +- constructor(defaults) { +- super(defaults); +- this.type = "rule"; +- if (!this.nodes) this.nodes = []; +- } +- get selectors() { +- return list$1$1.comma(this.selector); +- } +- set selectors(values) { +- let match = this.selector ? this.selector.match(/,\s*/) : null; +- let sep2 = match ? match[0] : "," + this.raw("between", "beforeOpen"); +- this.selector = values.join(sep2); +- } +-}; +-var rule$1 = Rule$3$1; +-Rule$3$1.default = Rule$3$1; +-Container$3$1.registerRule(Rule$3$1); +-let Declaration$2$1 = declaration$1; +-let tokenizer2$1 = tokenize$1; +-let Comment$2$1 = comment$1; +-let AtRule$2$1 = atRule$1; +-let Root$4$1 = root$1; +-let Rule$2$1 = rule$1; +-const SAFE_COMMENT_NEIGHBOR$1 = { +- empty: true, +- space: true +-}; +-function findLastWithPosition$1(tokens) { +- for (let i2 = tokens.length - 1; i2 >= 0; i2--) { +- let token = tokens[i2]; +- let pos = token[3] || token[2]; +- if (pos) return pos; +- } +-} +-let Parser$1$1 = class Parser { +- constructor(input2) { +- this.input = input2; +- this.root = new Root$4$1(); +- this.current = this.root; +- this.spaces = ""; +- this.semicolon = false; +- this.createTokenizer(); +- this.root.source = { input: input2, start: { column: 1, line: 1, offset: 0 } }; +- } +- atrule(token) { +- let node2 = new AtRule$2$1(); +- node2.name = token[1].slice(1); +- if (node2.name === "") { +- this.unnamedAtrule(node2, token); +- } +- this.init(node2, token[2]); +- let type; +- let prev; +- let shift; +- let last = false; +- let open = false; +- let params = []; +- let brackets = []; +- while (!this.tokenizer.endOfFile()) { +- token = this.tokenizer.nextToken(); +- type = token[0]; +- if (type === "(" || type === "[") { +- brackets.push(type === "(" ? ")" : "]"); +- } else if (type === "{" && brackets.length > 0) { +- brackets.push("}"); +- } else if (type === brackets[brackets.length - 1]) { +- brackets.pop(); +- } +- if (brackets.length === 0) { +- if (type === ";") { +- node2.source.end = this.getPosition(token[2]); +- node2.source.end.offset++; +- this.semicolon = true; +- break; +- } else if (type === "{") { +- open = true; +- break; +- } else if (type === "}") { +- if (params.length > 0) { +- shift = params.length - 1; +- prev = params[shift]; +- while (prev && prev[0] === "space") { +- prev = params[--shift]; +- } +- if (prev) { +- node2.source.end = this.getPosition(prev[3] || prev[2]); +- node2.source.end.offset++; +- } +- } +- this.end(token); +- break; +- } else { +- params.push(token); +- } +- } else { +- params.push(token); +- } +- if (this.tokenizer.endOfFile()) { +- last = true; +- break; +- } +- } +- node2.raws.between = this.spacesAndCommentsFromEnd(params); +- if (params.length) { +- node2.raws.afterName = this.spacesAndCommentsFromStart(params); +- this.raw(node2, "params", params); +- if (last) { +- token = params[params.length - 1]; +- node2.source.end = this.getPosition(token[3] || token[2]); +- node2.source.end.offset++; +- this.spaces = node2.raws.between; +- node2.raws.between = ""; +- } +- } else { +- node2.raws.afterName = ""; +- node2.params = ""; +- } +- if (open) { +- node2.nodes = []; +- this.current = node2; +- } +- } +- checkMissedSemicolon(tokens) { +- let colon = this.colon(tokens); +- if (colon === false) return; +- let founded = 0; +- let token; +- for (let j = colon - 1; j >= 0; j--) { +- token = tokens[j]; +- if (token[0] !== "space") { +- founded += 1; +- if (founded === 2) break; +- } +- } +- throw this.input.error( +- "Missed semicolon", +- token[0] === "word" ? token[3] + 1 : token[2] +- ); +- } +- colon(tokens) { +- let brackets = 0; +- let token, type, prev; +- for (let [i2, element] of tokens.entries()) { +- token = element; +- type = token[0]; +- if (type === "(") { +- brackets += 1; +- } +- if (type === ")") { +- brackets -= 1; +- } +- if (brackets === 0 && type === ":") { +- if (!prev) { +- this.doubleColon(token); +- } else if (prev[0] === "word" && prev[1] === "progid") { +- continue; +- } else { +- return i2; +- } +- } +- prev = token; +- } +- return false; +- } +- comment(token) { +- let node2 = new Comment$2$1(); +- this.init(node2, token[2]); +- node2.source.end = this.getPosition(token[3] || token[2]); +- node2.source.end.offset++; +- let text = token[1].slice(2, -2); +- if (/^\s*$/.test(text)) { +- node2.text = ""; +- node2.raws.left = text; +- node2.raws.right = ""; +- } else { +- let match = text.match(/^(\s*)([^]*\S)(\s*)$/); +- node2.text = match[2]; +- node2.raws.left = match[1]; +- node2.raws.right = match[3]; +- } +- } +- createTokenizer() { +- this.tokenizer = tokenizer2$1(this.input); +- } +- decl(tokens, customProperty) { +- let node2 = new Declaration$2$1(); +- this.init(node2, tokens[0][2]); +- let last = tokens[tokens.length - 1]; +- if (last[0] === ";") { +- this.semicolon = true; +- tokens.pop(); +- } +- node2.source.end = this.getPosition( +- last[3] || last[2] || findLastWithPosition$1(tokens) +- ); +- node2.source.end.offset++; +- while (tokens[0][0] !== "word") { +- if (tokens.length === 1) this.unknownWord(tokens); +- node2.raws.before += tokens.shift()[1]; +- } +- node2.source.start = this.getPosition(tokens[0][2]); +- node2.prop = ""; +- while (tokens.length) { +- let type = tokens[0][0]; +- if (type === ":" || type === "space" || type === "comment") { +- break; +- } +- node2.prop += tokens.shift()[1]; +- } +- node2.raws.between = ""; +- let token; +- while (tokens.length) { +- token = tokens.shift(); +- if (token[0] === ":") { +- node2.raws.between += token[1]; +- break; +- } else { +- if (token[0] === "word" && /\w/.test(token[1])) { +- this.unknownWord([token]); +- } +- node2.raws.between += token[1]; +- } +- } +- if (node2.prop[0] === "_" || node2.prop[0] === "*") { +- node2.raws.before += node2.prop[0]; +- node2.prop = node2.prop.slice(1); +- } +- let firstSpaces = []; +- let next; +- while (tokens.length) { +- next = tokens[0][0]; +- if (next !== "space" && next !== "comment") break; +- firstSpaces.push(tokens.shift()); +- } +- this.precheckMissedSemicolon(tokens); +- for (let i2 = tokens.length - 1; i2 >= 0; i2--) { +- token = tokens[i2]; +- if (token[1].toLowerCase() === "!important") { +- node2.important = true; +- let string = this.stringFrom(tokens, i2); +- string = this.spacesFromEnd(tokens) + string; +- if (string !== " !important") node2.raws.important = string; +- break; +- } else if (token[1].toLowerCase() === "important") { +- let cache = tokens.slice(0); +- let str = ""; +- for (let j = i2; j > 0; j--) { +- let type = cache[j][0]; +- if (str.trim().indexOf("!") === 0 && type !== "space") { +- break; +- } +- str = cache.pop()[1] + str; +- } +- if (str.trim().indexOf("!") === 0) { +- node2.important = true; +- node2.raws.important = str; +- tokens = cache; +- } +- } +- if (token[0] !== "space" && token[0] !== "comment") { +- break; +- } +- } +- let hasWord = tokens.some((i2) => i2[0] !== "space" && i2[0] !== "comment"); +- if (hasWord) { +- node2.raws.between += firstSpaces.map((i2) => i2[1]).join(""); +- firstSpaces = []; +- } +- this.raw(node2, "value", firstSpaces.concat(tokens), customProperty); +- if (node2.value.includes(":") && !customProperty) { +- this.checkMissedSemicolon(tokens); +- } +- } +- doubleColon(token) { +- throw this.input.error( +- "Double colon", +- { offset: token[2] }, +- { offset: token[2] + token[1].length } +- ); +- } +- emptyRule(token) { +- let node2 = new Rule$2$1(); +- this.init(node2, token[2]); +- node2.selector = ""; +- node2.raws.between = ""; +- this.current = node2; +- } +- end(token) { +- if (this.current.nodes && this.current.nodes.length) { +- this.current.raws.semicolon = this.semicolon; +- } +- this.semicolon = false; +- this.current.raws.after = (this.current.raws.after || "") + this.spaces; +- this.spaces = ""; +- if (this.current.parent) { +- this.current.source.end = this.getPosition(token[2]); +- this.current.source.end.offset++; +- this.current = this.current.parent; +- } else { +- this.unexpectedClose(token); +- } +- } +- endFile() { +- if (this.current.parent) this.unclosedBlock(); +- if (this.current.nodes && this.current.nodes.length) { +- this.current.raws.semicolon = this.semicolon; +- } +- this.current.raws.after = (this.current.raws.after || "") + this.spaces; +- this.root.source.end = this.getPosition(this.tokenizer.position()); +- } +- freeSemicolon(token) { +- this.spaces += token[1]; +- if (this.current.nodes) { +- let prev = this.current.nodes[this.current.nodes.length - 1]; +- if (prev && prev.type === "rule" && !prev.raws.ownSemicolon) { +- prev.raws.ownSemicolon = this.spaces; +- this.spaces = ""; +- } +- } +- } +- // Helpers +- getPosition(offset) { +- let pos = this.input.fromOffset(offset); +- return { +- column: pos.col, +- line: pos.line, +- offset +- }; +- } +- init(node2, offset) { +- this.current.push(node2); +- node2.source = { +- input: this.input, +- start: this.getPosition(offset) +- }; +- node2.raws.before = this.spaces; +- this.spaces = ""; +- if (node2.type !== "comment") this.semicolon = false; +- } +- other(start) { +- let end = false; +- let type = null; +- let colon = false; +- let bracket = null; +- let brackets = []; +- let customProperty = start[1].startsWith("--"); +- let tokens = []; +- let token = start; +- while (token) { +- type = token[0]; +- tokens.push(token); +- if (type === "(" || type === "[") { +- if (!bracket) bracket = token; +- brackets.push(type === "(" ? ")" : "]"); +- } else if (customProperty && colon && type === "{") { +- if (!bracket) bracket = token; +- brackets.push("}"); +- } else if (brackets.length === 0) { +- if (type === ";") { +- if (colon) { +- this.decl(tokens, customProperty); +- return; +- } else { +- break; +- } +- } else if (type === "{") { +- this.rule(tokens); +- return; +- } else if (type === "}") { +- this.tokenizer.back(tokens.pop()); +- end = true; +- break; +- } else if (type === ":") { +- colon = true; +- } +- } else if (type === brackets[brackets.length - 1]) { +- brackets.pop(); +- if (brackets.length === 0) bracket = null; +- } +- token = this.tokenizer.nextToken(); +- } +- if (this.tokenizer.endOfFile()) end = true; +- if (brackets.length > 0) this.unclosedBracket(bracket); +- if (end && colon) { +- if (!customProperty) { +- while (tokens.length) { +- token = tokens[tokens.length - 1][0]; +- if (token !== "space" && token !== "comment") break; +- this.tokenizer.back(tokens.pop()); +- } +- } +- this.decl(tokens, customProperty); +- } else { +- this.unknownWord(tokens); +- } +- } +- parse() { +- let token; +- while (!this.tokenizer.endOfFile()) { +- token = this.tokenizer.nextToken(); +- switch (token[0]) { +- case "space": +- this.spaces += token[1]; +- break; +- case ";": +- this.freeSemicolon(token); +- break; +- case "}": +- this.end(token); +- break; +- case "comment": +- this.comment(token); +- break; +- case "at-word": +- this.atrule(token); +- break; +- case "{": +- this.emptyRule(token); +- break; +- default: +- this.other(token); +- break; +- } +- } +- this.endFile(); +- } +- precheckMissedSemicolon() { +- } +- raw(node2, prop, tokens, customProperty) { +- let token, type; +- let length = tokens.length; +- let value = ""; +- let clean = true; +- let next, prev; +- for (let i2 = 0; i2 < length; i2 += 1) { +- token = tokens[i2]; +- type = token[0]; +- if (type === "space" && i2 === length - 1 && !customProperty) { +- clean = false; +- } else if (type === "comment") { +- prev = tokens[i2 - 1] ? tokens[i2 - 1][0] : "empty"; +- next = tokens[i2 + 1] ? tokens[i2 + 1][0] : "empty"; +- if (!SAFE_COMMENT_NEIGHBOR$1[prev] && !SAFE_COMMENT_NEIGHBOR$1[next]) { +- if (value.slice(-1) === ",") { +- clean = false; +- } else { +- value += token[1]; +- } +- } else { +- clean = false; +- } +- } else { +- value += token[1]; +- } +- } +- if (!clean) { +- let raw = tokens.reduce((all, i2) => all + i2[1], ""); +- node2.raws[prop] = { raw, value }; +- } +- node2[prop] = value; +- } +- rule(tokens) { +- tokens.pop(); +- let node2 = new Rule$2$1(); +- this.init(node2, tokens[0][2]); +- node2.raws.between = this.spacesAndCommentsFromEnd(tokens); +- this.raw(node2, "selector", tokens); +- this.current = node2; +- } +- spacesAndCommentsFromEnd(tokens) { +- let lastTokenType; +- let spaces = ""; +- while (tokens.length) { +- lastTokenType = tokens[tokens.length - 1][0]; +- if (lastTokenType !== "space" && lastTokenType !== "comment") break; +- spaces = tokens.pop()[1] + spaces; +- } +- return spaces; +- } +- // Errors +- spacesAndCommentsFromStart(tokens) { +- let next; +- let spaces = ""; +- while (tokens.length) { +- next = tokens[0][0]; +- if (next !== "space" && next !== "comment") break; +- spaces += tokens.shift()[1]; +- } +- return spaces; +- } +- spacesFromEnd(tokens) { +- let lastTokenType; +- let spaces = ""; +- while (tokens.length) { +- lastTokenType = tokens[tokens.length - 1][0]; +- if (lastTokenType !== "space") break; +- spaces = tokens.pop()[1] + spaces; +- } +- return spaces; +- } +- stringFrom(tokens, from) { +- let result2 = ""; +- for (let i2 = from; i2 < tokens.length; i2++) { +- result2 += tokens[i2][1]; +- } +- tokens.splice(from, tokens.length - from); +- return result2; +- } +- unclosedBlock() { +- let pos = this.current.source.start; +- throw this.input.error("Unclosed block", pos.line, pos.column); +- } +- unclosedBracket(bracket) { +- throw this.input.error( +- "Unclosed bracket", +- { offset: bracket[2] }, +- { offset: bracket[2] + 1 } +- ); +- } +- unexpectedClose(token) { +- throw this.input.error( +- "Unexpected }", +- { offset: token[2] }, +- { offset: token[2] + 1 } +- ); +- } +- unknownWord(tokens) { +- throw this.input.error( +- "Unknown word", +- { offset: tokens[0][2] }, +- { offset: tokens[0][2] + tokens[0][1].length } +- ); +- } +- unnamedAtrule(node2, token) { +- throw this.input.error( +- "At-rule without name", +- { offset: token[2] }, +- { offset: token[2] + token[1].length } +- ); +- } +-}; +-var parser$1 = Parser$1$1; +-let Container$2$1 = container$1; +-let Parser2$1 = parser$1; +-let Input$2$1 = input$1; +-function parse$3$1(css, opts) { +- let input2 = new Input$2$1(css, opts); +- let parser2 = new Parser2$1(input2); +- try { +- parser2.parse(); +- } catch (e2) { +- if (process.env.NODE_ENV !== "production") { +- if (e2.name === "CssSyntaxError" && opts && opts.from) { +- if (/\.scss$/i.test(opts.from)) { +- e2.message += "\nYou tried to parse SCSS with the standard CSS parser; try again with the postcss-scss parser"; +- } else if (/\.sass/i.test(opts.from)) { +- e2.message += "\nYou tried to parse Sass with the standard CSS parser; try again with the postcss-sass parser"; +- } else if (/\.less$/i.test(opts.from)) { +- e2.message += "\nYou tried to parse Less with the standard CSS parser; try again with the postcss-less parser"; +- } +- } +- } +- throw e2; +- } +- return parser2.root; +-} +-var parse_1$1 = parse$3$1; +-parse$3$1.default = parse$3$1; +-Container$2$1.registerParse(parse$3$1); +-let { isClean: isClean$3, my: my$3 } = symbols$1; +-let MapGenerator$1$1 = mapGenerator$1; +-let stringify$2$1 = stringify_1$1; +-let Container$1$1 = container$1; +-let Document$2$1 = document$1$1; +-let warnOnce$1$1 = warnOnce$2$1; +-let Result$2$1 = result$1; +-let parse$2$1 = parse_1$1; +-let Root$3$1 = root$1; +-const TYPE_TO_CLASS_NAME$1 = { +- atrule: "AtRule", +- comment: "Comment", +- decl: "Declaration", +- document: "Document", +- root: "Root", +- rule: "Rule" +-}; +-const PLUGIN_PROPS$1 = { +- AtRule: true, +- AtRuleExit: true, +- Comment: true, +- CommentExit: true, +- Declaration: true, +- DeclarationExit: true, +- Document: true, +- DocumentExit: true, +- Once: true, +- OnceExit: true, +- postcssPlugin: true, +- prepare: true, +- Root: true, +- RootExit: true, +- Rule: true, +- RuleExit: true +-}; +-const NOT_VISITORS$1 = { +- Once: true, +- postcssPlugin: true, +- prepare: true +-}; +-const CHILDREN$1 = 0; +-function isPromise$1(obj) { +- return typeof obj === "object" && typeof obj.then === "function"; +-} +-function getEvents$1(node2) { +- let key = false; +- let type = TYPE_TO_CLASS_NAME$1[node2.type]; +- if (node2.type === "decl") { +- key = node2.prop.toLowerCase(); +- } else if (node2.type === "atrule") { +- key = node2.name.toLowerCase(); +- } +- if (key && node2.append) { +- return [ +- type, +- type + "-" + key, +- CHILDREN$1, +- type + "Exit", +- type + "Exit-" + key +- ]; +- } else if (key) { +- return [type, type + "-" + key, type + "Exit", type + "Exit-" + key]; +- } else if (node2.append) { +- return [type, CHILDREN$1, type + "Exit"]; +- } else { +- return [type, type + "Exit"]; +- } +-} +-function toStack$1(node2) { +- let events; +- if (node2.type === "document") { +- events = ["Document", CHILDREN$1, "DocumentExit"]; +- } else if (node2.type === "root") { +- events = ["Root", CHILDREN$1, "RootExit"]; +- } else { +- events = getEvents$1(node2); +- } +- return { +- eventIndex: 0, +- events, +- iterator: 0, +- node: node2, +- visitorIndex: 0, +- visitors: [] +- }; +-} +-function cleanMarks$1(node2) { +- node2[isClean$3] = false; +- if (node2.nodes) node2.nodes.forEach((i2) => cleanMarks$1(i2)); +- return node2; +-} +-let postcss$2$1 = {}; +-let LazyResult$2$1 = class LazyResult { +- constructor(processor2, css, opts) { +- this.stringified = false; +- this.processed = false; +- let root2; +- if (typeof css === "object" && css !== null && (css.type === "root" || css.type === "document")) { +- root2 = cleanMarks$1(css); +- } else if (css instanceof LazyResult || css instanceof Result$2$1) { +- root2 = cleanMarks$1(css.root); +- if (css.map) { +- if (typeof opts.map === "undefined") opts.map = {}; +- if (!opts.map.inline) opts.map.inline = false; +- opts.map.prev = css.map; +- } +- } else { +- let parser2 = parse$2$1; +- if (opts.syntax) parser2 = opts.syntax.parse; +- if (opts.parser) parser2 = opts.parser; +- if (parser2.parse) parser2 = parser2.parse; +- try { +- root2 = parser2(css, opts); +- } catch (error) { +- this.processed = true; +- this.error = error; +- } +- if (root2 && !root2[my$3]) { +- Container$1$1.rebuild(root2); +- } +- } +- this.result = new Result$2$1(processor2, root2, opts); +- this.helpers = { ...postcss$2$1, postcss: postcss$2$1, result: this.result }; +- this.plugins = this.processor.plugins.map((plugin22) => { +- if (typeof plugin22 === "object" && plugin22.prepare) { +- return { ...plugin22, ...plugin22.prepare(this.result) }; +- } else { +- return plugin22; +- } +- }); +- } +- async() { +- if (this.error) return Promise.reject(this.error); +- if (this.processed) return Promise.resolve(this.result); +- if (!this.processing) { +- this.processing = this.runAsync(); +- } +- return this.processing; +- } +- catch(onRejected) { +- return this.async().catch(onRejected); +- } +- finally(onFinally) { +- return this.async().then(onFinally, onFinally); +- } +- getAsyncError() { +- throw new Error("Use process(css).then(cb) to work with async plugins"); +- } +- handleError(error, node2) { +- let plugin22 = this.result.lastPlugin; +- try { +- if (node2) node2.addToError(error); +- this.error = error; +- if (error.name === "CssSyntaxError" && !error.plugin) { +- error.plugin = plugin22.postcssPlugin; +- error.setMessage(); +- } else if (plugin22.postcssVersion) { +- if (process.env.NODE_ENV !== "production") { +- let pluginName = plugin22.postcssPlugin; +- let pluginVer = plugin22.postcssVersion; +- let runtimeVer = this.result.processor.version; +- let a2 = pluginVer.split("."); +- let b = runtimeVer.split("."); +- if (a2[0] !== b[0] || parseInt(a2[1]) > parseInt(b[1])) { +- console.error( +- "Unknown error from PostCSS plugin. Your current PostCSS version is " + runtimeVer + ", but " + pluginName + " uses " + pluginVer + ". Perhaps this is the source of the error below." +- ); +- } +- } +- } +- } catch (err) { +- if (console && console.error) console.error(err); +- } +- return error; +- } +- prepareVisitors() { +- this.listeners = {}; +- let add = (plugin22, type, cb) => { +- if (!this.listeners[type]) this.listeners[type] = []; +- this.listeners[type].push([plugin22, cb]); +- }; +- for (let plugin22 of this.plugins) { +- if (typeof plugin22 === "object") { +- for (let event in plugin22) { +- if (!PLUGIN_PROPS$1[event] && /^[A-Z]/.test(event)) { +- throw new Error( +- `Unknown event ${event} in ${plugin22.postcssPlugin}. Try to update PostCSS (${this.processor.version} now).` +- ); +- } +- if (!NOT_VISITORS$1[event]) { +- if (typeof plugin22[event] === "object") { +- for (let filter in plugin22[event]) { +- if (filter === "*") { +- add(plugin22, event, plugin22[event][filter]); +- } else { +- add( +- plugin22, +- event + "-" + filter.toLowerCase(), +- plugin22[event][filter] +- ); +- } +- } +- } else if (typeof plugin22[event] === "function") { +- add(plugin22, event, plugin22[event]); +- } +- } +- } +- } +- } +- this.hasListener = Object.keys(this.listeners).length > 0; +- } +- async runAsync() { +- this.plugin = 0; +- for (let i2 = 0; i2 < this.plugins.length; i2++) { +- let plugin22 = this.plugins[i2]; +- let promise = this.runOnRoot(plugin22); +- if (isPromise$1(promise)) { +- try { +- await promise; +- } catch (error) { +- throw this.handleError(error); +- } +- } +- } +- this.prepareVisitors(); +- if (this.hasListener) { +- let root2 = this.result.root; +- while (!root2[isClean$3]) { +- root2[isClean$3] = true; +- let stack = [toStack$1(root2)]; +- while (stack.length > 0) { +- let promise = this.visitTick(stack); +- if (isPromise$1(promise)) { +- try { +- await promise; +- } catch (e2) { +- let node2 = stack[stack.length - 1].node; +- throw this.handleError(e2, node2); +- } +- } +- } +- } +- if (this.listeners.OnceExit) { +- for (let [plugin22, visitor] of this.listeners.OnceExit) { +- this.result.lastPlugin = plugin22; +- try { +- if (root2.type === "document") { +- let roots = root2.nodes.map( +- (subRoot) => visitor(subRoot, this.helpers) +- ); +- await Promise.all(roots); +- } else { +- await visitor(root2, this.helpers); +- } +- } catch (e2) { +- throw this.handleError(e2); +- } +- } +- } +- } +- this.processed = true; +- return this.stringify(); +- } +- runOnRoot(plugin22) { +- this.result.lastPlugin = plugin22; +- try { +- if (typeof plugin22 === "object" && plugin22.Once) { +- if (this.result.root.type === "document") { +- let roots = this.result.root.nodes.map( +- (root2) => plugin22.Once(root2, this.helpers) +- ); +- if (isPromise$1(roots[0])) { +- return Promise.all(roots); +- } +- return roots; +- } +- return plugin22.Once(this.result.root, this.helpers); +- } else if (typeof plugin22 === "function") { +- return plugin22(this.result.root, this.result); +- } +- } catch (error) { +- throw this.handleError(error); +- } +- } +- stringify() { +- if (this.error) throw this.error; +- if (this.stringified) return this.result; +- this.stringified = true; +- this.sync(); +- let opts = this.result.opts; +- let str = stringify$2$1; +- if (opts.syntax) str = opts.syntax.stringify; +- if (opts.stringifier) str = opts.stringifier; +- if (str.stringify) str = str.stringify; +- let map = new MapGenerator$1$1(str, this.result.root, this.result.opts); +- let data = map.generate(); +- this.result.css = data[0]; +- this.result.map = data[1]; +- return this.result; +- } +- sync() { +- if (this.error) throw this.error; +- if (this.processed) return this.result; +- this.processed = true; +- if (this.processing) { +- throw this.getAsyncError(); +- } +- for (let plugin22 of this.plugins) { +- let promise = this.runOnRoot(plugin22); +- if (isPromise$1(promise)) { +- throw this.getAsyncError(); +- } +- } +- this.prepareVisitors(); +- if (this.hasListener) { +- let root2 = this.result.root; +- while (!root2[isClean$3]) { +- root2[isClean$3] = true; +- this.walkSync(root2); +- } +- if (this.listeners.OnceExit) { +- if (root2.type === "document") { +- for (let subRoot of root2.nodes) { +- this.visitSync(this.listeners.OnceExit, subRoot); +- } +- } else { +- this.visitSync(this.listeners.OnceExit, root2); +- } +- } +- } +- return this.result; +- } +- then(onFulfilled, onRejected) { +- if (process.env.NODE_ENV !== "production") { +- if (!("from" in this.opts)) { +- warnOnce$1$1( +- "Without `from` option PostCSS could generate wrong source map and will not find Browserslist config. Set it to CSS file path or to `undefined` to prevent this warning." +- ); +- } +- } +- return this.async().then(onFulfilled, onRejected); +- } +- toString() { +- return this.css; +- } +- visitSync(visitors, node2) { +- for (let [plugin22, visitor] of visitors) { +- this.result.lastPlugin = plugin22; +- let promise; +- try { +- promise = visitor(node2, this.helpers); +- } catch (e2) { +- throw this.handleError(e2, node2.proxyOf); +- } +- if (node2.type !== "root" && node2.type !== "document" && !node2.parent) { +- return true; +- } +- if (isPromise$1(promise)) { +- throw this.getAsyncError(); +- } +- } +- } +- visitTick(stack) { +- let visit2 = stack[stack.length - 1]; +- let { node: node2, visitors } = visit2; +- if (node2.type !== "root" && node2.type !== "document" && !node2.parent) { +- stack.pop(); +- return; +- } +- if (visitors.length > 0 && visit2.visitorIndex < visitors.length) { +- let [plugin22, visitor] = visitors[visit2.visitorIndex]; +- visit2.visitorIndex += 1; +- if (visit2.visitorIndex === visitors.length) { +- visit2.visitors = []; +- visit2.visitorIndex = 0; +- } +- this.result.lastPlugin = plugin22; +- try { +- return visitor(node2.toProxy(), this.helpers); +- } catch (e2) { +- throw this.handleError(e2, node2); +- } +- } +- if (visit2.iterator !== 0) { +- let iterator = visit2.iterator; +- let child; +- while (child = node2.nodes[node2.indexes[iterator]]) { +- node2.indexes[iterator] += 1; +- if (!child[isClean$3]) { +- child[isClean$3] = true; +- stack.push(toStack$1(child)); +- return; +- } +- } +- visit2.iterator = 0; +- delete node2.indexes[iterator]; +- } +- let events = visit2.events; +- while (visit2.eventIndex < events.length) { +- let event = events[visit2.eventIndex]; +- visit2.eventIndex += 1; +- if (event === CHILDREN$1) { +- if (node2.nodes && node2.nodes.length) { +- node2[isClean$3] = true; +- visit2.iterator = node2.getIterator(); +- } +- return; +- } else if (this.listeners[event]) { +- visit2.visitors = this.listeners[event]; +- return; +- } +- } +- stack.pop(); +- } +- walkSync(node2) { +- node2[isClean$3] = true; +- let events = getEvents$1(node2); +- for (let event of events) { +- if (event === CHILDREN$1) { +- if (node2.nodes) { +- node2.each((child) => { +- if (!child[isClean$3]) this.walkSync(child); +- }); +- } +- } else { +- let visitors = this.listeners[event]; +- if (visitors) { +- if (this.visitSync(visitors, node2.toProxy())) return; +- } +- } +- } +- } +- warnings() { +- return this.sync().warnings(); +- } +- get content() { +- return this.stringify().content; +- } +- get css() { +- return this.stringify().css; +- } +- get map() { +- return this.stringify().map; +- } +- get messages() { +- return this.sync().messages; +- } +- get opts() { +- return this.result.opts; +- } +- get processor() { +- return this.result.processor; +- } +- get root() { +- return this.sync().root; +- } +- get [Symbol.toStringTag]() { +- return "LazyResult"; +- } +-}; +-LazyResult$2$1.registerPostcss = (dependant) => { +- postcss$2$1 = dependant; +-}; +-var lazyResult$1 = LazyResult$2$1; +-LazyResult$2$1.default = LazyResult$2$1; +-Root$3$1.registerLazyResult(LazyResult$2$1); +-Document$2$1.registerLazyResult(LazyResult$2$1); +-let MapGenerator2$1 = mapGenerator$1; +-let stringify$1$1 = stringify_1$1; +-let warnOnce2$1 = warnOnce$2$1; +-let parse$1$1 = parse_1$1; +-const Result$1$1 = result$1; +-let NoWorkResult$1$1 = class NoWorkResult { +- constructor(processor2, css, opts) { +- css = css.toString(); +- this.stringified = false; +- this._processor = processor2; +- this._css = css; +- this._opts = opts; +- this._map = void 0; +- let root2; +- let str = stringify$1$1; +- this.result = new Result$1$1(this._processor, root2, this._opts); +- this.result.css = css; +- let self = this; +- Object.defineProperty(this.result, "root", { +- get() { +- return self.root; +- } +- }); +- let map = new MapGenerator2$1(str, root2, this._opts, css); +- if (map.isMap()) { +- let [generatedCSS, generatedMap] = map.generate(); +- if (generatedCSS) { +- this.result.css = generatedCSS; +- } +- if (generatedMap) { +- this.result.map = generatedMap; +- } +- } else { +- map.clearAnnotation(); +- this.result.css = map.css; +- } +- } +- async() { +- if (this.error) return Promise.reject(this.error); +- return Promise.resolve(this.result); +- } +- catch(onRejected) { +- return this.async().catch(onRejected); +- } +- finally(onFinally) { +- return this.async().then(onFinally, onFinally); +- } +- sync() { +- if (this.error) throw this.error; +- return this.result; +- } +- then(onFulfilled, onRejected) { +- if (process.env.NODE_ENV !== "production") { +- if (!("from" in this._opts)) { +- warnOnce2$1( +- "Without `from` option PostCSS could generate wrong source map and will not find Browserslist config. Set it to CSS file path or to `undefined` to prevent this warning." +- ); +- } +- } +- return this.async().then(onFulfilled, onRejected); +- } +- toString() { +- return this._css; +- } +- warnings() { +- return []; +- } +- get content() { +- return this.result.css; +- } +- get css() { +- return this.result.css; +- } +- get map() { +- return this.result.map; +- } +- get messages() { +- return []; +- } +- get opts() { +- return this.result.opts; +- } +- get processor() { +- return this.result.processor; +- } +- get root() { +- if (this._root) { +- return this._root; +- } +- let root2; +- let parser2 = parse$1$1; +- try { +- root2 = parser2(this._css, this._opts); +- } catch (error) { +- this.error = error; +- } +- if (this.error) { +- throw this.error; +- } else { +- this._root = root2; +- return root2; +- } +- } +- get [Symbol.toStringTag]() { +- return "NoWorkResult"; +- } +-}; +-var noWorkResult$1 = NoWorkResult$1$1; +-NoWorkResult$1$1.default = NoWorkResult$1$1; +-let NoWorkResult2$1 = noWorkResult$1; +-let LazyResult$1$1 = lazyResult$1; +-let Document$1$1 = document$1$1; +-let Root$2$1 = root$1; +-let Processor$1$1 = class Processor { +- constructor(plugins = []) { +- this.version = "8.4.38"; +- this.plugins = this.normalize(plugins); +- } +- normalize(plugins) { +- let normalized = []; +- for (let i2 of plugins) { +- if (i2.postcss === true) { +- i2 = i2(); +- } else if (i2.postcss) { +- i2 = i2.postcss; +- } +- if (typeof i2 === "object" && Array.isArray(i2.plugins)) { +- normalized = normalized.concat(i2.plugins); +- } else if (typeof i2 === "object" && i2.postcssPlugin) { +- normalized.push(i2); +- } else if (typeof i2 === "function") { +- normalized.push(i2); +- } else if (typeof i2 === "object" && (i2.parse || i2.stringify)) { +- if (process.env.NODE_ENV !== "production") { +- throw new Error( +- "PostCSS syntaxes cannot be used as plugins. Instead, please use one of the syntax/parser/stringifier options as outlined in your PostCSS runner documentation." +- ); +- } +- } else { +- throw new Error(i2 + " is not a PostCSS plugin"); +- } +- } +- return normalized; +- } +- process(css, opts = {}) { +- if (!this.plugins.length && !opts.parser && !opts.stringifier && !opts.syntax) { +- return new NoWorkResult2$1(this, css, opts); +- } else { +- return new LazyResult$1$1(this, css, opts); +- } +- } +- use(plugin22) { +- this.plugins = this.plugins.concat(this.normalize([plugin22])); +- return this; +- } +-}; +-var processor$1 = Processor$1$1; +-Processor$1$1.default = Processor$1$1; +-Root$2$1.registerProcessor(Processor$1$1); +-Document$1$1.registerProcessor(Processor$1$1); +-let Declaration$1$1 = declaration$1; +-let PreviousMap2$1 = previousMap$1; +-let Comment$1$1 = comment$1; +-let AtRule$1$1 = atRule$1; +-let Input$1$1 = input$1; +-let Root$1$1 = root$1; +-let Rule$1$1 = rule$1; +-function fromJSON$1$1(json, inputs) { +- if (Array.isArray(json)) return json.map((n2) => fromJSON$1$1(n2)); +- let { inputs: ownInputs, ...defaults } = json; +- if (ownInputs) { +- inputs = []; +- for (let input2 of ownInputs) { +- let inputHydrated = { ...input2, __proto__: Input$1$1.prototype }; +- if (inputHydrated.map) { +- inputHydrated.map = { +- ...inputHydrated.map, +- __proto__: PreviousMap2$1.prototype +- }; +- } +- inputs.push(inputHydrated); +- } +- } +- if (defaults.nodes) { +- defaults.nodes = json.nodes.map((n2) => fromJSON$1$1(n2, inputs)); +- } +- if (defaults.source) { +- let { inputId, ...source } = defaults.source; +- defaults.source = source; +- if (inputId != null) { +- defaults.source.input = inputs[inputId]; +- } +- } +- if (defaults.type === "root") { +- return new Root$1$1(defaults); +- } else if (defaults.type === "decl") { +- return new Declaration$1$1(defaults); +- } else if (defaults.type === "rule") { +- return new Rule$1$1(defaults); +- } else if (defaults.type === "comment") { +- return new Comment$1$1(defaults); +- } else if (defaults.type === "atrule") { +- return new AtRule$1$1(defaults); +- } else { +- throw new Error("Unknown node type: " + json.type); +- } +-} +-var fromJSON_1$1 = fromJSON$1$1; +-fromJSON$1$1.default = fromJSON$1$1; +-let CssSyntaxError2$1 = cssSyntaxError$1; +-let Declaration2$1 = declaration$1; +-let LazyResult2$1 = lazyResult$1; +-let Container2$1 = container$1; +-let Processor2$1 = processor$1; +-let stringify$5 = stringify_1$1; +-let fromJSON$2 = fromJSON_1$1; +-let Document22 = document$1$1; +-let Warning2$1 = warning$1; +-let Comment2$1 = comment$1; +-let AtRule2$1 = atRule$1; +-let Result2$1 = result$1; +-let Input2$1 = input$1; +-let parse$5 = parse_1$1; +-let list$3 = list_1$1; +-let Rule2$1 = rule$1; +-let Root2$1 = root$1; +-let Node2$1 = node$1; +-function postcss$3(...plugins) { +- if (plugins.length === 1 && Array.isArray(plugins[0])) { +- plugins = plugins[0]; +- } +- return new Processor2$1(plugins); +-} +-postcss$3.plugin = function plugin(name, initializer) { +- let warningPrinted = false; +- function creator(...args) { +- if (console && console.warn && !warningPrinted) { +- warningPrinted = true; +- console.warn( +- name + ": postcss.plugin was deprecated. Migration guide:\nhttps://evilmartians.com/chronicles/postcss-8-plugin-migration" +- ); +- if (process.env.LANG && process.env.LANG.startsWith("cn")) { +- console.warn( +- name + ": 里面 postcss.plugin 被弃用. 迁移指南:\nhttps://www.w3ctech.com/topic/2226" +- ); +- } +- } +- let transformer = initializer(...args); +- transformer.postcssPlugin = name; +- transformer.postcssVersion = new Processor2$1().version; +- return transformer; +- } +- let cache; +- Object.defineProperty(creator, "postcss", { +- get() { +- if (!cache) cache = creator(); +- return cache; +- } +- }); +- creator.process = function(css, processOpts, pluginOpts) { +- return postcss$3([creator(pluginOpts)]).process(css, processOpts); +- }; +- return creator; +-}; +-postcss$3.stringify = stringify$5; +-postcss$3.parse = parse$5; +-postcss$3.fromJSON = fromJSON$2; +-postcss$3.list = list$3; +-postcss$3.comment = (defaults) => new Comment2$1(defaults); +-postcss$3.atRule = (defaults) => new AtRule2$1(defaults); +-postcss$3.decl = (defaults) => new Declaration2$1(defaults); +-postcss$3.rule = (defaults) => new Rule2$1(defaults); +-postcss$3.root = (defaults) => new Root2$1(defaults); +-postcss$3.document = (defaults) => new Document22(defaults); +-postcss$3.CssSyntaxError = CssSyntaxError2$1; +-postcss$3.Declaration = Declaration2$1; +-postcss$3.Container = Container2$1; +-postcss$3.Processor = Processor2$1; +-postcss$3.Document = Document22; +-postcss$3.Comment = Comment2$1; +-postcss$3.Warning = Warning2$1; +-postcss$3.AtRule = AtRule2$1; +-postcss$3.Result = Result2$1; +-postcss$3.Input = Input2$1; +-postcss$3.Rule = Rule2$1; +-postcss$3.Root = Root2$1; +-postcss$3.Node = Node2$1; +-LazyResult2$1.registerPostcss(postcss$3); +-var postcss_1$1 = postcss$3; +-postcss$3.default = postcss$3; +-const postcss$1$1 = /* @__PURE__ */ getDefaultExportFromCjs$1(postcss_1$1); +-postcss$1$1.stringify; +-postcss$1$1.fromJSON; +-postcss$1$1.plugin; +-postcss$1$1.parse; +-postcss$1$1.list; +-postcss$1$1.document; +-postcss$1$1.comment; +-postcss$1$1.atRule; +-postcss$1$1.rule; +-postcss$1$1.decl; +-postcss$1$1.root; +-postcss$1$1.CssSyntaxError; +-postcss$1$1.Declaration; +-postcss$1$1.Container; +-postcss$1$1.Processor; +-postcss$1$1.Document; +-postcss$1$1.Comment; +-postcss$1$1.Warning; +-postcss$1$1.AtRule; +-postcss$1$1.Result; +-postcss$1$1.Input; +-postcss$1$1.Rule; +-postcss$1$1.Root; +-postcss$1$1.Node; +-var __defProp2 = Object.defineProperty; +-var __defNormalProp2 = (obj, key, value) => key in obj ? __defProp2(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value; +-var __publicField2 = (obj, key, value) => __defNormalProp2(obj, typeof key !== "symbol" ? key + "" : key, value); +-function getDefaultExportFromCjs(x2) { +- return x2 && x2.__esModule && Object.prototype.hasOwnProperty.call(x2, "default") ? x2["default"] : x2; +-} +-function getAugmentedNamespace(n2) { +- if (n2.__esModule) return n2; +- var f2 = n2.default; +- if (typeof f2 == "function") { +- var a2 = function a22() { +- if (this instanceof a22) { +- return Reflect.construct(f2, arguments, this.constructor); +- } +- return f2.apply(this, arguments); +- }; +- a2.prototype = f2.prototype; +- } else a2 = {}; +- Object.defineProperty(a2, "__esModule", { value: true }); +- Object.keys(n2).forEach(function(k) { +- var d = Object.getOwnPropertyDescriptor(n2, k); +- Object.defineProperty(a2, k, d.get ? d : { +- enumerable: true, +- get: function() { +- return n2[k]; +- } +- }); +- }); +- return a2; +-} +-var picocolors_browser = { exports: {} }; +-var x = String; +-var create = function() { +- return { isColorSupported: false, reset: x, bold: x, dim: x, italic: x, underline: x, inverse: x, hidden: x, strikethrough: x, black: x, red: x, green: x, yellow: x, blue: x, magenta: x, cyan: x, white: x, gray: x, bgBlack: x, bgRed: x, bgGreen: x, bgYellow: x, bgBlue: x, bgMagenta: x, bgCyan: x, bgWhite: x }; +-}; +-picocolors_browser.exports = create(); +-picocolors_browser.exports.createColors = create; +-var picocolors_browserExports = picocolors_browser.exports; +-const __viteBrowserExternal = {}; +-const __viteBrowserExternal$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({ +- __proto__: null, +- default: __viteBrowserExternal +-}, Symbol.toStringTag, { value: "Module" })); +-const require$$2 = /* @__PURE__ */ getAugmentedNamespace(__viteBrowserExternal$1); +-let pico = picocolors_browserExports; +-let terminalHighlight$1 = require$$2; +-let CssSyntaxError$3 = class CssSyntaxError2 extends Error { +- constructor(message, line, column, source, file, plugin22) { +- super(message); +- this.name = "CssSyntaxError"; +- this.reason = message; +- if (file) { +- this.file = file; +- } +- if (source) { +- this.source = source; +- } +- if (plugin22) { +- this.plugin = plugin22; +- } +- if (typeof line !== "undefined" && typeof column !== "undefined") { +- if (typeof line === "number") { +- this.line = line; +- this.column = column; +- } else { +- this.line = line.line; +- this.column = line.column; +- this.endLine = column.line; +- this.endColumn = column.column; +- } +- } +- this.setMessage(); +- if (Error.captureStackTrace) { +- Error.captureStackTrace(this, CssSyntaxError2); +- } +- } +- setMessage() { +- this.message = this.plugin ? this.plugin + ": " : ""; +- this.message += this.file ? this.file : ""; +- if (typeof this.line !== "undefined") { +- this.message += ":" + this.line + ":" + this.column; +- } +- this.message += ": " + this.reason; +- } +- showSourceCode(color) { +- if (!this.source) return ""; +- let css = this.source; +- if (color == null) color = pico.isColorSupported; +- if (terminalHighlight$1) { +- if (color) css = terminalHighlight$1(css); +- } +- let lines = css.split(/\r?\n/); +- let start = Math.max(this.line - 3, 0); +- let end = Math.min(this.line + 2, lines.length); +- let maxWidth = String(end).length; +- let mark, aside; +- if (color) { +- let { bold, gray, red } = pico.createColors(true); +- mark = (text) => bold(red(text)); +- aside = (text) => gray(text); +- } else { +- mark = aside = (str) => str; +- } +- return lines.slice(start, end).map((line, index2) => { +- let number = start + 1 + index2; +- let gutter = " " + (" " + number).slice(-maxWidth) + " | "; +- if (number === this.line) { +- let spacing = aside(gutter.replace(/\d/g, " ")) + line.slice(0, this.column - 1).replace(/[^\t]/g, " "); +- return mark(">") + aside(gutter) + line + "\n " + spacing + mark("^"); +- } +- return " " + aside(gutter) + line; +- }).join("\n"); +- } +- toString() { +- let code = this.showSourceCode(); +- if (code) { +- code = "\n\n" + code + "\n"; +- } +- return this.name + ": " + this.message + code; +- } +-}; +-var cssSyntaxError = CssSyntaxError$3; +-CssSyntaxError$3.default = CssSyntaxError$3; +-var symbols = {}; +-symbols.isClean = Symbol("isClean"); +-symbols.my = Symbol("my"); +-const DEFAULT_RAW = { +- after: "\n", +- beforeClose: "\n", +- beforeComment: "\n", +- beforeDecl: "\n", +- beforeOpen: " ", +- beforeRule: "\n", +- colon: ": ", +- commentLeft: " ", +- commentRight: " ", +- emptyBody: "", +- indent: " ", +- semicolon: false +-}; +-function capitalize(str) { +- return str[0].toUpperCase() + str.slice(1); +-} +-let Stringifier$2 = class Stringifier2 { +- constructor(builder) { +- this.builder = builder; +- } +- atrule(node2, semicolon) { +- let name = "@" + node2.name; +- let params = node2.params ? this.rawValue(node2, "params") : ""; +- if (typeof node2.raws.afterName !== "undefined") { +- name += node2.raws.afterName; +- } else if (params) { +- name += " "; +- } +- if (node2.nodes) { +- this.block(node2, name + params); +- } else { +- let end = (node2.raws.between || "") + (semicolon ? ";" : ""); +- this.builder(name + params + end, node2); +- } +- } +- beforeAfter(node2, detect) { +- let value; +- if (node2.type === "decl") { +- value = this.raw(node2, null, "beforeDecl"); +- } else if (node2.type === "comment") { +- value = this.raw(node2, null, "beforeComment"); +- } else if (detect === "before") { +- value = this.raw(node2, null, "beforeRule"); +- } else { +- value = this.raw(node2, null, "beforeClose"); +- } +- let buf = node2.parent; +- let depth = 0; +- while (buf && buf.type !== "root") { +- depth += 1; +- buf = buf.parent; +- } +- if (value.includes("\n")) { +- let indent = this.raw(node2, null, "indent"); +- if (indent.length) { +- for (let step = 0; step < depth; step++) value += indent; +- } +- } +- return value; +- } +- block(node2, start) { +- let between = this.raw(node2, "between", "beforeOpen"); +- this.builder(start + between + "{", node2, "start"); +- let after; +- if (node2.nodes && node2.nodes.length) { +- this.body(node2); +- after = this.raw(node2, "after"); +- } else { +- after = this.raw(node2, "after", "emptyBody"); +- } +- if (after) this.builder(after); +- this.builder("}", node2, "end"); +- } +- body(node2) { +- let last = node2.nodes.length - 1; +- while (last > 0) { +- if (node2.nodes[last].type !== "comment") break; +- last -= 1; +- } +- let semicolon = this.raw(node2, "semicolon"); +- for (let i2 = 0; i2 < node2.nodes.length; i2++) { +- let child = node2.nodes[i2]; +- let before = this.raw(child, "before"); +- if (before) this.builder(before); +- this.stringify(child, last !== i2 || semicolon); +- } +- } +- comment(node2) { +- let left = this.raw(node2, "left", "commentLeft"); +- let right = this.raw(node2, "right", "commentRight"); +- this.builder("/*" + left + node2.text + right + "*/", node2); +- } +- decl(node2, semicolon) { +- let between = this.raw(node2, "between", "colon"); +- let string = node2.prop + between + this.rawValue(node2, "value"); +- if (node2.important) { +- string += node2.raws.important || " !important"; +- } +- if (semicolon) string += ";"; +- this.builder(string, node2); +- } +- document(node2) { +- this.body(node2); +- } +- raw(node2, own, detect) { +- let value; +- if (!detect) detect = own; +- if (own) { +- value = node2.raws[own]; +- if (typeof value !== "undefined") return value; +- } +- let parent = node2.parent; +- if (detect === "before") { +- if (!parent || parent.type === "root" && parent.first === node2) { +- return ""; +- } +- if (parent && parent.type === "document") { +- return ""; +- } +- } +- if (!parent) return DEFAULT_RAW[detect]; +- let root2 = node2.root(); +- if (!root2.rawCache) root2.rawCache = {}; +- if (typeof root2.rawCache[detect] !== "undefined") { +- return root2.rawCache[detect]; +- } +- if (detect === "before" || detect === "after") { +- return this.beforeAfter(node2, detect); +- } else { +- let method = "raw" + capitalize(detect); +- if (this[method]) { +- value = this[method](root2, node2); +- } else { +- root2.walk((i2) => { +- value = i2.raws[own]; +- if (typeof value !== "undefined") return false; +- }); +- } +- } +- if (typeof value === "undefined") value = DEFAULT_RAW[detect]; +- root2.rawCache[detect] = value; +- return value; +- } +- rawBeforeClose(root2) { +- let value; +- root2.walk((i2) => { +- if (i2.nodes && i2.nodes.length > 0) { +- if (typeof i2.raws.after !== "undefined") { +- value = i2.raws.after; +- if (value.includes("\n")) { +- value = value.replace(/[^\n]+$/, ""); +- } +- return false; +- } +- } +- }); +- if (value) value = value.replace(/\S/g, ""); +- return value; +- } +- rawBeforeComment(root2, node2) { +- let value; +- root2.walkComments((i2) => { +- if (typeof i2.raws.before !== "undefined") { +- value = i2.raws.before; +- if (value.includes("\n")) { +- value = value.replace(/[^\n]+$/, ""); +- } +- return false; +- } +- }); +- if (typeof value === "undefined") { +- value = this.raw(node2, null, "beforeDecl"); +- } else if (value) { +- value = value.replace(/\S/g, ""); +- } +- return value; +- } +- rawBeforeDecl(root2, node2) { +- let value; +- root2.walkDecls((i2) => { +- if (typeof i2.raws.before !== "undefined") { +- value = i2.raws.before; +- if (value.includes("\n")) { +- value = value.replace(/[^\n]+$/, ""); +- } +- return false; +- } +- }); +- if (typeof value === "undefined") { +- value = this.raw(node2, null, "beforeRule"); +- } else if (value) { +- value = value.replace(/\S/g, ""); +- } +- return value; +- } +- rawBeforeOpen(root2) { +- let value; +- root2.walk((i2) => { +- if (i2.type !== "decl") { +- value = i2.raws.between; +- if (typeof value !== "undefined") return false; +- } +- }); +- return value; +- } +- rawBeforeRule(root2) { +- let value; +- root2.walk((i2) => { +- if (i2.nodes && (i2.parent !== root2 || root2.first !== i2)) { +- if (typeof i2.raws.before !== "undefined") { +- value = i2.raws.before; +- if (value.includes("\n")) { +- value = value.replace(/[^\n]+$/, ""); +- } +- return false; +- } +- } +- }); +- if (value) value = value.replace(/\S/g, ""); +- return value; +- } +- rawColon(root2) { +- let value; +- root2.walkDecls((i2) => { +- if (typeof i2.raws.between !== "undefined") { +- value = i2.raws.between.replace(/[^\s:]/g, ""); +- return false; +- } +- }); +- return value; +- } +- rawEmptyBody(root2) { +- let value; +- root2.walk((i2) => { +- if (i2.nodes && i2.nodes.length === 0) { +- value = i2.raws.after; +- if (typeof value !== "undefined") return false; +- } +- }); +- return value; +- } +- rawIndent(root2) { +- if (root2.raws.indent) return root2.raws.indent; +- let value; +- root2.walk((i2) => { +- let p = i2.parent; +- if (p && p !== root2 && p.parent && p.parent === root2) { +- if (typeof i2.raws.before !== "undefined") { +- let parts = i2.raws.before.split("\n"); +- value = parts[parts.length - 1]; +- value = value.replace(/\S/g, ""); +- return false; +- } +- } +- }); +- return value; +- } +- rawSemicolon(root2) { +- let value; +- root2.walk((i2) => { +- if (i2.nodes && i2.nodes.length && i2.last.type === "decl") { +- value = i2.raws.semicolon; +- if (typeof value !== "undefined") return false; +- } +- }); +- return value; +- } +- rawValue(node2, prop) { +- let value = node2[prop]; +- let raw = node2.raws[prop]; +- if (raw && raw.value === value) { +- return raw.raw; +- } +- return value; +- } +- root(node2) { +- this.body(node2); +- if (node2.raws.after) this.builder(node2.raws.after); +- } +- rule(node2) { +- this.block(node2, this.rawValue(node2, "selector")); +- if (node2.raws.ownSemicolon) { +- this.builder(node2.raws.ownSemicolon, node2, "end"); +- } +- } +- stringify(node2, semicolon) { +- if (!this[node2.type]) { +- throw new Error( +- "Unknown AST node type " + node2.type + ". Maybe you need to change PostCSS stringifier." +- ); +- } +- this[node2.type](node2, semicolon); +- } +-}; +-var stringifier = Stringifier$2; +-Stringifier$2.default = Stringifier$2; +-let Stringifier$1 = stringifier; +-function stringify$4(node2, builder) { +- let str = new Stringifier$1(builder); +- str.stringify(node2); +-} +-var stringify_1 = stringify$4; +-stringify$4.default = stringify$4; +-let { isClean: isClean$2, my: my$2 } = symbols; +-let CssSyntaxError$2 = cssSyntaxError; +-let Stringifier22 = stringifier; +-let stringify$3 = stringify_1; +-function cloneNode(obj, parent) { +- let cloned = new obj.constructor(); +- for (let i2 in obj) { +- if (!Object.prototype.hasOwnProperty.call(obj, i2)) { +- continue; +- } +- if (i2 === "proxyCache") continue; +- let value = obj[i2]; +- let type = typeof value; +- if (i2 === "parent" && type === "object") { +- if (parent) cloned[i2] = parent; +- } else if (i2 === "source") { +- cloned[i2] = value; +- } else if (Array.isArray(value)) { +- cloned[i2] = value.map((j) => cloneNode(j, cloned)); +- } else { +- if (type === "object" && value !== null) value = cloneNode(value); +- cloned[i2] = value; +- } +- } +- return cloned; +-} +-let Node$4 = class Node3 { +- constructor(defaults = {}) { +- this.raws = {}; +- this[isClean$2] = false; +- this[my$2] = true; +- for (let name in defaults) { +- if (name === "nodes") { +- this.nodes = []; +- for (let node2 of defaults[name]) { +- if (typeof node2.clone === "function") { +- this.append(node2.clone()); +- } else { +- this.append(node2); +- } +- } +- } else { +- this[name] = defaults[name]; +- } +- } +- } +- addToError(error) { +- error.postcssNode = this; +- if (error.stack && this.source && /\n\s{4}at /.test(error.stack)) { +- let s2 = this.source; +- error.stack = error.stack.replace( +- /\n\s{4}at /, +- `$&${s2.input.from}:${s2.start.line}:${s2.start.column}$&` +- ); +- } +- return error; +- } +- after(add) { +- this.parent.insertAfter(this, add); +- return this; +- } +- assign(overrides = {}) { +- for (let name in overrides) { +- this[name] = overrides[name]; +- } +- return this; +- } +- before(add) { +- this.parent.insertBefore(this, add); +- return this; +- } +- cleanRaws(keepBetween) { +- delete this.raws.before; +- delete this.raws.after; +- if (!keepBetween) delete this.raws.between; +- } +- clone(overrides = {}) { +- let cloned = cloneNode(this); +- for (let name in overrides) { +- cloned[name] = overrides[name]; +- } +- return cloned; +- } +- cloneAfter(overrides = {}) { +- let cloned = this.clone(overrides); +- this.parent.insertAfter(this, cloned); +- return cloned; +- } +- cloneBefore(overrides = {}) { +- let cloned = this.clone(overrides); +- this.parent.insertBefore(this, cloned); +- return cloned; +- } +- error(message, opts = {}) { +- if (this.source) { +- let { end, start } = this.rangeBy(opts); +- return this.source.input.error( +- message, +- { column: start.column, line: start.line }, +- { column: end.column, line: end.line }, +- opts +- ); +- } +- return new CssSyntaxError$2(message); +- } +- getProxyProcessor() { +- return { +- get(node2, prop) { +- if (prop === "proxyOf") { +- return node2; +- } else if (prop === "root") { +- return () => node2.root().toProxy(); +- } else { +- return node2[prop]; +- } +- }, +- set(node2, prop, value) { +- if (node2[prop] === value) return true; +- node2[prop] = value; +- if (prop === "prop" || prop === "value" || prop === "name" || prop === "params" || prop === "important" || /* c8 ignore next */ +- prop === "text") { +- node2.markDirty(); +- } +- return true; +- } +- }; +- } +- markDirty() { +- if (this[isClean$2]) { +- this[isClean$2] = false; +- let next = this; +- while (next = next.parent) { +- next[isClean$2] = false; +- } +- } +- } +- next() { +- if (!this.parent) return void 0; +- let index2 = this.parent.index(this); +- return this.parent.nodes[index2 + 1]; +- } +- positionBy(opts, stringRepresentation) { +- let pos = this.source.start; +- if (opts.index) { +- pos = this.positionInside(opts.index, stringRepresentation); +- } else if (opts.word) { +- stringRepresentation = this.toString(); +- let index2 = stringRepresentation.indexOf(opts.word); +- if (index2 !== -1) pos = this.positionInside(index2, stringRepresentation); +- } +- return pos; +- } +- positionInside(index2, stringRepresentation) { +- let string = stringRepresentation || this.toString(); +- let column = this.source.start.column; +- let line = this.source.start.line; +- for (let i2 = 0; i2 < index2; i2++) { +- if (string[i2] === "\n") { +- column = 1; +- line += 1; +- } else { +- column += 1; +- } +- } +- return { column, line }; +- } +- prev() { +- if (!this.parent) return void 0; +- let index2 = this.parent.index(this); +- return this.parent.nodes[index2 - 1]; +- } +- rangeBy(opts) { +- let start = { +- column: this.source.start.column, +- line: this.source.start.line +- }; +- let end = this.source.end ? { +- column: this.source.end.column + 1, +- line: this.source.end.line +- } : { +- column: start.column + 1, +- line: start.line +- }; +- if (opts.word) { +- let stringRepresentation = this.toString(); +- let index2 = stringRepresentation.indexOf(opts.word); +- if (index2 !== -1) { +- start = this.positionInside(index2, stringRepresentation); +- end = this.positionInside(index2 + opts.word.length, stringRepresentation); +- } +- } else { +- if (opts.start) { +- start = { +- column: opts.start.column, +- line: opts.start.line +- }; +- } else if (opts.index) { +- start = this.positionInside(opts.index); +- } +- if (opts.end) { +- end = { +- column: opts.end.column, +- line: opts.end.line +- }; +- } else if (typeof opts.endIndex === "number") { +- end = this.positionInside(opts.endIndex); +- } else if (opts.index) { +- end = this.positionInside(opts.index + 1); +- } +- } +- if (end.line < start.line || end.line === start.line && end.column <= start.column) { +- end = { column: start.column + 1, line: start.line }; +- } +- return { end, start }; +- } +- raw(prop, defaultType) { +- let str = new Stringifier22(); +- return str.raw(this, prop, defaultType); +- } +- remove() { +- if (this.parent) { +- this.parent.removeChild(this); +- } +- this.parent = void 0; +- return this; +- } +- replaceWith(...nodes) { +- if (this.parent) { +- let bookmark = this; +- let foundSelf = false; +- for (let node2 of nodes) { +- if (node2 === this) { +- foundSelf = true; +- } else if (foundSelf) { +- this.parent.insertAfter(bookmark, node2); +- bookmark = node2; +- } else { +- this.parent.insertBefore(bookmark, node2); +- } +- } +- if (!foundSelf) { +- this.remove(); +- } +- } +- return this; +- } +- root() { +- let result2 = this; +- while (result2.parent && result2.parent.type !== "document") { +- result2 = result2.parent; +- } +- return result2; +- } +- toJSON(_, inputs) { +- let fixed = {}; +- let emitInputs = inputs == null; +- inputs = inputs || /* @__PURE__ */ new Map(); +- let inputsNextIndex = 0; +- for (let name in this) { +- if (!Object.prototype.hasOwnProperty.call(this, name)) { +- continue; +- } +- if (name === "parent" || name === "proxyCache") continue; +- let value = this[name]; +- if (Array.isArray(value)) { +- fixed[name] = value.map((i2) => { +- if (typeof i2 === "object" && i2.toJSON) { +- return i2.toJSON(null, inputs); +- } else { +- return i2; +- } +- }); +- } else if (typeof value === "object" && value.toJSON) { +- fixed[name] = value.toJSON(null, inputs); +- } else if (name === "source") { +- let inputId = inputs.get(value.input); +- if (inputId == null) { +- inputId = inputsNextIndex; +- inputs.set(value.input, inputsNextIndex); +- inputsNextIndex++; +- } +- fixed[name] = { +- end: value.end, +- inputId, +- start: value.start +- }; +- } else { +- fixed[name] = value; +- } +- } +- if (emitInputs) { +- fixed.inputs = [...inputs.keys()].map((input2) => input2.toJSON()); +- } +- return fixed; +- } +- toProxy() { +- if (!this.proxyCache) { +- this.proxyCache = new Proxy(this, this.getProxyProcessor()); +- } +- return this.proxyCache; +- } +- toString(stringifier2 = stringify$3) { +- if (stringifier2.stringify) stringifier2 = stringifier2.stringify; +- let result2 = ""; +- stringifier2(this, (i2) => { +- result2 += i2; +- }); +- return result2; +- } +- warn(result2, text, opts) { +- let data = { node: this }; +- for (let i2 in opts) data[i2] = opts[i2]; +- return result2.warn(text, data); +- } +- get proxyOf() { +- return this; +- } +-}; +-var node = Node$4; +-Node$4.default = Node$4; +-let Node$3 = node; +-let Declaration$4 = class Declaration2 extends Node$3 { +- constructor(defaults) { +- if (defaults && typeof defaults.value !== "undefined" && typeof defaults.value !== "string") { +- defaults = { ...defaults, value: String(defaults.value) }; +- } +- super(defaults); +- this.type = "decl"; +- } +- get variable() { +- return this.prop.startsWith("--") || this.prop[0] === "$"; +- } +-}; +-var declaration = Declaration$4; +-Declaration$4.default = Declaration$4; +-let urlAlphabet = "useandom-26T198340PX75pxJACKVERYMINDBUSHWOLF_GQZbfghjklqvwyzrict"; +-let customAlphabet = (alphabet, defaultSize = 21) => { +- return (size = defaultSize) => { +- let id = ""; +- let i2 = size; +- while (i2--) { +- id += alphabet[Math.random() * alphabet.length | 0]; +- } +- return id; +- }; +-}; +-let nanoid$1 = (size = 21) => { +- let id = ""; +- let i2 = size; +- while (i2--) { +- id += urlAlphabet[Math.random() * 64 | 0]; +- } +- return id; +-}; +-var nonSecure = { nanoid: nanoid$1, customAlphabet }; +-let { SourceMapConsumer: SourceMapConsumer$2, SourceMapGenerator: SourceMapGenerator$2 } = require$$2; +-let { existsSync, readFileSync } = require$$2; +-let { dirname: dirname$1, join } = require$$2; +-function fromBase64(str) { +- if (Buffer) { +- return Buffer.from(str, "base64").toString(); +- } else { +- return window.atob(str); +- } +-} +-let PreviousMap$2 = class PreviousMap2 { +- constructor(css, opts) { +- if (opts.map === false) return; +- this.loadAnnotation(css); +- this.inline = this.startWith(this.annotation, "data:"); +- let prev = opts.map ? opts.map.prev : void 0; +- let text = this.loadMap(opts.from, prev); +- if (!this.mapFile && opts.from) { +- this.mapFile = opts.from; +- } +- if (this.mapFile) this.root = dirname$1(this.mapFile); +- if (text) this.text = text; +- } +- consumer() { +- if (!this.consumerCache) { +- this.consumerCache = new SourceMapConsumer$2(this.text); +- } +- return this.consumerCache; +- } +- decodeInline(text) { +- let baseCharsetUri = /^data:application\/json;charset=utf-?8;base64,/; +- let baseUri = /^data:application\/json;base64,/; +- let charsetUri = /^data:application\/json;charset=utf-?8,/; +- let uri = /^data:application\/json,/; +- if (charsetUri.test(text) || uri.test(text)) { +- return decodeURIComponent(text.substr(RegExp.lastMatch.length)); +- } +- if (baseCharsetUri.test(text) || baseUri.test(text)) { +- return fromBase64(text.substr(RegExp.lastMatch.length)); +- } +- let encoding = text.match(/data:application\/json;([^,]+),/)[1]; +- throw new Error("Unsupported source map encoding " + encoding); +- } +- getAnnotationURL(sourceMapString) { +- return sourceMapString.replace(/^\/\*\s*# sourceMappingURL=/, "").trim(); +- } +- isMap(map) { +- if (typeof map !== "object") return false; +- return typeof map.mappings === "string" || typeof map._mappings === "string" || Array.isArray(map.sections); +- } +- loadAnnotation(css) { +- let comments = css.match(/\/\*\s*# sourceMappingURL=/gm); +- if (!comments) return; +- let start = css.lastIndexOf(comments.pop()); +- let end = css.indexOf("*/", start); +- if (start > -1 && end > -1) { +- this.annotation = this.getAnnotationURL(css.substring(start, end)); +- } +- } +- loadFile(path) { +- this.root = dirname$1(path); +- if (existsSync(path)) { +- this.mapFile = path; +- return readFileSync(path, "utf-8").toString().trim(); +- } +- } +- loadMap(file, prev) { +- if (prev === false) return false; +- if (prev) { +- if (typeof prev === "string") { +- return prev; +- } else if (typeof prev === "function") { +- let prevPath = prev(file); +- if (prevPath) { +- let map = this.loadFile(prevPath); +- if (!map) { +- throw new Error( +- "Unable to load previous source map: " + prevPath.toString() +- ); +- } +- return map; +- } +- } else if (prev instanceof SourceMapConsumer$2) { +- return SourceMapGenerator$2.fromSourceMap(prev).toString(); +- } else if (prev instanceof SourceMapGenerator$2) { +- return prev.toString(); +- } else if (this.isMap(prev)) { +- return JSON.stringify(prev); +- } else { +- throw new Error( +- "Unsupported previous source map format: " + prev.toString() +- ); +- } +- } else if (this.inline) { +- return this.decodeInline(this.annotation); +- } else if (this.annotation) { +- let map = this.annotation; +- if (file) map = join(dirname$1(file), map); +- return this.loadFile(map); +- } +- } +- startWith(string, start) { +- if (!string) return false; +- return string.substr(0, start.length) === start; +- } +- withContent() { +- return !!(this.consumer().sourcesContent && this.consumer().sourcesContent.length > 0); +- } +-}; +-var previousMap = PreviousMap$2; +-PreviousMap$2.default = PreviousMap$2; +-let { SourceMapConsumer: SourceMapConsumer$1, SourceMapGenerator: SourceMapGenerator$1 } = require$$2; +-let { fileURLToPath, pathToFileURL: pathToFileURL$1 } = require$$2; +-let { isAbsolute, resolve: resolve$1 } = require$$2; +-let { nanoid } = nonSecure; +-let terminalHighlight = require$$2; +-let CssSyntaxError$1 = cssSyntaxError; +-let PreviousMap$1 = previousMap; +-let fromOffsetCache = Symbol("fromOffsetCache"); +-let sourceMapAvailable$1 = Boolean(SourceMapConsumer$1 && SourceMapGenerator$1); +-let pathAvailable$1 = Boolean(resolve$1 && isAbsolute); +-let Input$4 = class Input2 { +- constructor(css, opts = {}) { +- if (css === null || typeof css === "undefined" || typeof css === "object" && !css.toString) { +- throw new Error(`PostCSS received ${css} instead of CSS string`); +- } +- this.css = css.toString(); +- if (this.css[0] === "\uFEFF" || this.css[0] === "￾") { +- this.hasBOM = true; +- this.css = this.css.slice(1); +- } else { +- this.hasBOM = false; +- } +- if (opts.from) { +- if (!pathAvailable$1 || /^\w+:\/\//.test(opts.from) || isAbsolute(opts.from)) { +- this.file = opts.from; +- } else { +- this.file = resolve$1(opts.from); +- } +- } +- if (pathAvailable$1 && sourceMapAvailable$1) { +- let map = new PreviousMap$1(this.css, opts); +- if (map.text) { +- this.map = map; +- let file = map.consumer().file; +- if (!this.file && file) this.file = this.mapResolve(file); +- } +- } +- if (!this.file) { +- this.id = ""; +- } +- if (this.map) this.map.file = this.from; +- } +- error(message, line, column, opts = {}) { +- let result2, endLine, endColumn; +- if (line && typeof line === "object") { +- let start = line; +- let end = column; +- if (typeof start.offset === "number") { +- let pos = this.fromOffset(start.offset); +- line = pos.line; +- column = pos.col; +- } else { +- line = start.line; +- column = start.column; +- } +- if (typeof end.offset === "number") { +- let pos = this.fromOffset(end.offset); +- endLine = pos.line; +- endColumn = pos.col; +- } else { +- endLine = end.line; +- endColumn = end.column; +- } +- } else if (!column) { +- let pos = this.fromOffset(line); +- line = pos.line; +- column = pos.col; +- } +- let origin = this.origin(line, column, endLine, endColumn); +- if (origin) { +- result2 = new CssSyntaxError$1( +- message, +- origin.endLine === void 0 ? origin.line : { column: origin.column, line: origin.line }, +- origin.endLine === void 0 ? origin.column : { column: origin.endColumn, line: origin.endLine }, +- origin.source, +- origin.file, +- opts.plugin +- ); +- } else { +- result2 = new CssSyntaxError$1( +- message, +- endLine === void 0 ? line : { column, line }, +- endLine === void 0 ? column : { column: endColumn, line: endLine }, +- this.css, +- this.file, +- opts.plugin +- ); +- } +- result2.input = { column, endColumn, endLine, line, source: this.css }; +- if (this.file) { +- if (pathToFileURL$1) { +- result2.input.url = pathToFileURL$1(this.file).toString(); +- } +- result2.input.file = this.file; +- } +- return result2; +- } +- fromOffset(offset) { +- let lastLine, lineToIndex; +- if (!this[fromOffsetCache]) { +- let lines = this.css.split("\n"); +- lineToIndex = new Array(lines.length); +- let prevIndex = 0; +- for (let i2 = 0, l2 = lines.length; i2 < l2; i2++) { +- lineToIndex[i2] = prevIndex; +- prevIndex += lines[i2].length + 1; +- } +- this[fromOffsetCache] = lineToIndex; +- } else { +- lineToIndex = this[fromOffsetCache]; +- } +- lastLine = lineToIndex[lineToIndex.length - 1]; +- let min = 0; +- if (offset >= lastLine) { +- min = lineToIndex.length - 1; +- } else { +- let max = lineToIndex.length - 2; +- let mid; +- while (min < max) { +- mid = min + (max - min >> 1); +- if (offset < lineToIndex[mid]) { +- max = mid - 1; +- } else if (offset >= lineToIndex[mid + 1]) { +- min = mid + 1; +- } else { +- min = mid; +- break; +- } +- } +- } +- return { +- col: offset - lineToIndex[min] + 1, +- line: min + 1 +- }; +- } +- mapResolve(file) { +- if (/^\w+:\/\//.test(file)) { +- return file; +- } +- return resolve$1(this.map.consumer().sourceRoot || this.map.root || ".", file); +- } +- origin(line, column, endLine, endColumn) { +- if (!this.map) return false; +- let consumer = this.map.consumer(); +- let from = consumer.originalPositionFor({ column, line }); +- if (!from.source) return false; +- let to; +- if (typeof endLine === "number") { +- to = consumer.originalPositionFor({ column: endColumn, line: endLine }); +- } +- let fromUrl; +- if (isAbsolute(from.source)) { +- fromUrl = pathToFileURL$1(from.source); +- } else { +- fromUrl = new URL( +- from.source, +- this.map.consumer().sourceRoot || pathToFileURL$1(this.map.mapFile) +- ); +- } +- let result2 = { +- column: from.column, +- endColumn: to && to.column, +- endLine: to && to.line, +- line: from.line, +- url: fromUrl.toString() +- }; +- if (fromUrl.protocol === "file:") { +- if (fileURLToPath) { +- result2.file = fileURLToPath(fromUrl); +- } else { +- throw new Error(`file: protocol is not available in this PostCSS build`); +- } +- } +- let source = consumer.sourceContentFor(from.source); +- if (source) result2.source = source; +- return result2; +- } +- toJSON() { +- let json = {}; +- for (let name of ["hasBOM", "css", "file", "id"]) { +- if (this[name] != null) { +- json[name] = this[name]; +- } +- } +- if (this.map) { +- json.map = { ...this.map }; +- if (json.map.consumerCache) { +- json.map.consumerCache = void 0; +- } +- } +- return json; +- } +- get from() { +- return this.file || this.id; +- } +-}; +-var input = Input$4; +-Input$4.default = Input$4; +-if (terminalHighlight && terminalHighlight.registerInput) { +- terminalHighlight.registerInput(Input$4); +-} +-let { SourceMapConsumer, SourceMapGenerator } = require$$2; +-let { dirname, relative, resolve, sep } = require$$2; +-let { pathToFileURL } = require$$2; +-let Input$3 = input; +-let sourceMapAvailable = Boolean(SourceMapConsumer && SourceMapGenerator); +-let pathAvailable = Boolean(dirname && resolve && relative && sep); +-let MapGenerator$2 = class MapGenerator2 { +- constructor(stringify2, root2, opts, cssString) { +- this.stringify = stringify2; +- this.mapOpts = opts.map || {}; +- this.root = root2; +- this.opts = opts; +- this.css = cssString; +- this.originalCSS = cssString; +- this.usesFileUrls = !this.mapOpts.from && this.mapOpts.absolute; +- this.memoizedFileURLs = /* @__PURE__ */ new Map(); +- this.memoizedPaths = /* @__PURE__ */ new Map(); +- this.memoizedURLs = /* @__PURE__ */ new Map(); +- } +- addAnnotation() { +- let content; +- if (this.isInline()) { +- content = "data:application/json;base64," + this.toBase64(this.map.toString()); +- } else if (typeof this.mapOpts.annotation === "string") { +- content = this.mapOpts.annotation; +- } else if (typeof this.mapOpts.annotation === "function") { +- content = this.mapOpts.annotation(this.opts.to, this.root); +- } else { +- content = this.outputFile() + ".map"; +- } +- let eol = "\n"; +- if (this.css.includes("\r\n")) eol = "\r\n"; +- this.css += eol + "/*# sourceMappingURL=" + content + " */"; +- } +- applyPrevMaps() { +- for (let prev of this.previous()) { +- let from = this.toUrl(this.path(prev.file)); +- let root2 = prev.root || dirname(prev.file); +- let map; +- if (this.mapOpts.sourcesContent === false) { +- map = new SourceMapConsumer(prev.text); +- if (map.sourcesContent) { +- map.sourcesContent = null; +- } +- } else { +- map = prev.consumer(); +- } +- this.map.applySourceMap(map, from, this.toUrl(this.path(root2))); +- } +- } +- clearAnnotation() { +- if (this.mapOpts.annotation === false) return; +- if (this.root) { +- let node2; +- for (let i2 = this.root.nodes.length - 1; i2 >= 0; i2--) { +- node2 = this.root.nodes[i2]; +- if (node2.type !== "comment") continue; +- if (node2.text.indexOf("# sourceMappingURL=") === 0) { +- this.root.removeChild(i2); +- } +- } +- } else if (this.css) { +- this.css = this.css.replace(/\n*?\/\*#[\S\s]*?\*\/$/gm, ""); +- } +- } +- generate() { +- this.clearAnnotation(); +- if (pathAvailable && sourceMapAvailable && this.isMap()) { +- return this.generateMap(); +- } else { +- let result2 = ""; +- this.stringify(this.root, (i2) => { +- result2 += i2; +- }); +- return [result2]; +- } +- } +- generateMap() { +- if (this.root) { +- this.generateString(); +- } else if (this.previous().length === 1) { +- let prev = this.previous()[0].consumer(); +- prev.file = this.outputFile(); +- this.map = SourceMapGenerator.fromSourceMap(prev, { +- ignoreInvalidMapping: true +- }); +- } else { +- this.map = new SourceMapGenerator({ +- file: this.outputFile(), +- ignoreInvalidMapping: true +- }); +- this.map.addMapping({ +- generated: { column: 0, line: 1 }, +- original: { column: 0, line: 1 }, +- source: this.opts.from ? this.toUrl(this.path(this.opts.from)) : "" +- }); +- } +- if (this.isSourcesContent()) this.setSourcesContent(); +- if (this.root && this.previous().length > 0) this.applyPrevMaps(); +- if (this.isAnnotation()) this.addAnnotation(); +- if (this.isInline()) { +- return [this.css]; +- } else { +- return [this.css, this.map]; +- } +- } +- generateString() { +- this.css = ""; +- this.map = new SourceMapGenerator({ +- file: this.outputFile(), +- ignoreInvalidMapping: true +- }); +- let line = 1; +- let column = 1; +- let noSource = ""; +- let mapping = { +- generated: { column: 0, line: 0 }, +- original: { column: 0, line: 0 }, +- source: "" +- }; +- let lines, last; +- this.stringify(this.root, (str, node2, type) => { +- this.css += str; +- if (node2 && type !== "end") { +- mapping.generated.line = line; +- mapping.generated.column = column - 1; +- if (node2.source && node2.source.start) { +- mapping.source = this.sourcePath(node2); +- mapping.original.line = node2.source.start.line; +- mapping.original.column = node2.source.start.column - 1; +- this.map.addMapping(mapping); +- } else { +- mapping.source = noSource; +- mapping.original.line = 1; +- mapping.original.column = 0; +- this.map.addMapping(mapping); +- } +- } +- lines = str.match(/\n/g); +- if (lines) { +- line += lines.length; +- last = str.lastIndexOf("\n"); +- column = str.length - last; +- } else { +- column += str.length; +- } +- if (node2 && type !== "start") { +- let p = node2.parent || { raws: {} }; +- let childless = node2.type === "decl" || node2.type === "atrule" && !node2.nodes; +- if (!childless || node2 !== p.last || p.raws.semicolon) { +- if (node2.source && node2.source.end) { +- mapping.source = this.sourcePath(node2); +- mapping.original.line = node2.source.end.line; +- mapping.original.column = node2.source.end.column - 1; +- mapping.generated.line = line; +- mapping.generated.column = column - 2; +- this.map.addMapping(mapping); +- } else { +- mapping.source = noSource; +- mapping.original.line = 1; +- mapping.original.column = 0; +- mapping.generated.line = line; +- mapping.generated.column = column - 1; +- this.map.addMapping(mapping); +- } +- } +- } +- }); +- } +- isAnnotation() { +- if (this.isInline()) { +- return true; +- } +- if (typeof this.mapOpts.annotation !== "undefined") { +- return this.mapOpts.annotation; +- } +- if (this.previous().length) { +- return this.previous().some((i2) => i2.annotation); +- } +- return true; +- } +- isInline() { +- if (typeof this.mapOpts.inline !== "undefined") { +- return this.mapOpts.inline; +- } +- let annotation = this.mapOpts.annotation; +- if (typeof annotation !== "undefined" && annotation !== true) { +- return false; +- } +- if (this.previous().length) { +- return this.previous().some((i2) => i2.inline); +- } +- return true; +- } +- isMap() { +- if (typeof this.opts.map !== "undefined") { +- return !!this.opts.map; +- } +- return this.previous().length > 0; +- } +- isSourcesContent() { +- if (typeof this.mapOpts.sourcesContent !== "undefined") { +- return this.mapOpts.sourcesContent; +- } +- if (this.previous().length) { +- return this.previous().some((i2) => i2.withContent()); +- } +- return true; +- } +- outputFile() { +- if (this.opts.to) { +- return this.path(this.opts.to); +- } else if (this.opts.from) { +- return this.path(this.opts.from); +- } else { +- return "to.css"; +- } +- } +- path(file) { +- if (this.mapOpts.absolute) return file; +- if (file.charCodeAt(0) === 60) return file; +- if (/^\w+:\/\//.test(file)) return file; +- let cached = this.memoizedPaths.get(file); +- if (cached) return cached; +- let from = this.opts.to ? dirname(this.opts.to) : "."; +- if (typeof this.mapOpts.annotation === "string") { +- from = dirname(resolve(from, this.mapOpts.annotation)); +- } +- let path = relative(from, file); +- this.memoizedPaths.set(file, path); +- return path; +- } +- previous() { +- if (!this.previousMaps) { +- this.previousMaps = []; +- if (this.root) { +- this.root.walk((node2) => { +- if (node2.source && node2.source.input.map) { +- let map = node2.source.input.map; +- if (!this.previousMaps.includes(map)) { +- this.previousMaps.push(map); +- } +- } +- }); +- } else { +- let input2 = new Input$3(this.originalCSS, this.opts); +- if (input2.map) this.previousMaps.push(input2.map); +- } +- } +- return this.previousMaps; +- } +- setSourcesContent() { +- let already = {}; +- if (this.root) { +- this.root.walk((node2) => { +- if (node2.source) { +- let from = node2.source.input.from; +- if (from && !already[from]) { +- already[from] = true; +- let fromUrl = this.usesFileUrls ? this.toFileUrl(from) : this.toUrl(this.path(from)); +- this.map.setSourceContent(fromUrl, node2.source.input.css); +- } +- } +- }); +- } else if (this.css) { +- let from = this.opts.from ? this.toUrl(this.path(this.opts.from)) : ""; +- this.map.setSourceContent(from, this.css); +- } +- } +- sourcePath(node2) { +- if (this.mapOpts.from) { +- return this.toUrl(this.mapOpts.from); +- } else if (this.usesFileUrls) { +- return this.toFileUrl(node2.source.input.from); +- } else { +- return this.toUrl(this.path(node2.source.input.from)); +- } +- } +- toBase64(str) { +- if (Buffer) { +- return Buffer.from(str).toString("base64"); +- } else { +- return window.btoa(unescape(encodeURIComponent(str))); +- } +- } +- toFileUrl(path) { +- let cached = this.memoizedFileURLs.get(path); +- if (cached) return cached; +- if (pathToFileURL) { +- let fileURL = pathToFileURL(path).toString(); +- this.memoizedFileURLs.set(path, fileURL); +- return fileURL; +- } else { +- throw new Error( +- "`map.absolute` option is not available in this PostCSS build" +- ); +- } +- } +- toUrl(path) { +- let cached = this.memoizedURLs.get(path); +- if (cached) return cached; +- if (sep === "\\") { +- path = path.replace(/\\/g, "/"); +- } +- let url = encodeURI(path).replace(/[#?]/g, encodeURIComponent); +- this.memoizedURLs.set(path, url); +- return url; +- } +-}; +-var mapGenerator = MapGenerator$2; +-let Node$2 = node; +-let Comment$4 = class Comment2 extends Node$2 { +- constructor(defaults) { +- super(defaults); +- this.type = "comment"; +- } +-}; +-var comment = Comment$4; +-Comment$4.default = Comment$4; +-let { isClean: isClean$1, my: my$1 } = symbols; +-let Declaration$3 = declaration; +-let Comment$3 = comment; +-let Node$1 = node; +-let parse$4, Rule$4, AtRule$4, Root$6; +-function cleanSource(nodes) { +- return nodes.map((i2) => { +- if (i2.nodes) i2.nodes = cleanSource(i2.nodes); +- delete i2.source; +- return i2; +- }); +-} +-function markDirtyUp(node2) { +- node2[isClean$1] = false; +- if (node2.proxyOf.nodes) { +- for (let i2 of node2.proxyOf.nodes) { +- markDirtyUp(i2); +- } +- } +-} +-let Container$7 = class Container2 extends Node$1 { +- append(...children) { +- for (let child of children) { +- let nodes = this.normalize(child, this.last); +- for (let node2 of nodes) this.proxyOf.nodes.push(node2); +- } +- this.markDirty(); +- return this; +- } +- cleanRaws(keepBetween) { +- super.cleanRaws(keepBetween); +- if (this.nodes) { +- for (let node2 of this.nodes) node2.cleanRaws(keepBetween); +- } +- } +- each(callback) { +- if (!this.proxyOf.nodes) return void 0; +- let iterator = this.getIterator(); +- let index2, result2; +- while (this.indexes[iterator] < this.proxyOf.nodes.length) { +- index2 = this.indexes[iterator]; +- result2 = callback(this.proxyOf.nodes[index2], index2); +- if (result2 === false) break; +- this.indexes[iterator] += 1; +- } +- delete this.indexes[iterator]; +- return result2; +- } +- every(condition) { +- return this.nodes.every(condition); +- } +- getIterator() { +- if (!this.lastEach) this.lastEach = 0; +- if (!this.indexes) this.indexes = {}; +- this.lastEach += 1; +- let iterator = this.lastEach; +- this.indexes[iterator] = 0; +- return iterator; +- } +- getProxyProcessor() { +- return { +- get(node2, prop) { +- if (prop === "proxyOf") { +- return node2; +- } else if (!node2[prop]) { +- return node2[prop]; +- } else if (prop === "each" || typeof prop === "string" && prop.startsWith("walk")) { +- return (...args) => { +- return node2[prop]( +- ...args.map((i2) => { +- if (typeof i2 === "function") { +- return (child, index2) => i2(child.toProxy(), index2); +- } else { +- return i2; +- } +- }) +- ); +- }; +- } else if (prop === "every" || prop === "some") { +- return (cb) => { +- return node2[prop]( +- (child, ...other) => cb(child.toProxy(), ...other) +- ); +- }; +- } else if (prop === "root") { +- return () => node2.root().toProxy(); +- } else if (prop === "nodes") { +- return node2.nodes.map((i2) => i2.toProxy()); +- } else if (prop === "first" || prop === "last") { +- return node2[prop].toProxy(); +- } else { +- return node2[prop]; +- } +- }, +- set(node2, prop, value) { +- if (node2[prop] === value) return true; +- node2[prop] = value; +- if (prop === "name" || prop === "params" || prop === "selector") { +- node2.markDirty(); +- } +- return true; +- } +- }; +- } +- index(child) { +- if (typeof child === "number") return child; +- if (child.proxyOf) child = child.proxyOf; +- return this.proxyOf.nodes.indexOf(child); +- } +- insertAfter(exist, add) { +- let existIndex = this.index(exist); +- let nodes = this.normalize(add, this.proxyOf.nodes[existIndex]).reverse(); +- existIndex = this.index(exist); +- for (let node2 of nodes) this.proxyOf.nodes.splice(existIndex + 1, 0, node2); +- let index2; +- for (let id in this.indexes) { +- index2 = this.indexes[id]; +- if (existIndex < index2) { +- this.indexes[id] = index2 + nodes.length; +- } +- } +- this.markDirty(); +- return this; +- } +- insertBefore(exist, add) { +- let existIndex = this.index(exist); +- let type = existIndex === 0 ? "prepend" : false; +- let nodes = this.normalize(add, this.proxyOf.nodes[existIndex], type).reverse(); +- existIndex = this.index(exist); +- for (let node2 of nodes) this.proxyOf.nodes.splice(existIndex, 0, node2); +- let index2; +- for (let id in this.indexes) { +- index2 = this.indexes[id]; +- if (existIndex <= index2) { +- this.indexes[id] = index2 + nodes.length; +- } +- } +- this.markDirty(); +- return this; +- } +- normalize(nodes, sample) { +- if (typeof nodes === "string") { +- nodes = cleanSource(parse$4(nodes).nodes); +- } else if (typeof nodes === "undefined") { +- nodes = []; +- } else if (Array.isArray(nodes)) { +- nodes = nodes.slice(0); +- for (let i2 of nodes) { +- if (i2.parent) i2.parent.removeChild(i2, "ignore"); +- } +- } else if (nodes.type === "root" && this.type !== "document") { +- nodes = nodes.nodes.slice(0); +- for (let i2 of nodes) { +- if (i2.parent) i2.parent.removeChild(i2, "ignore"); +- } +- } else if (nodes.type) { +- nodes = [nodes]; +- } else if (nodes.prop) { +- if (typeof nodes.value === "undefined") { +- throw new Error("Value field is missed in node creation"); +- } else if (typeof nodes.value !== "string") { +- nodes.value = String(nodes.value); +- } +- nodes = [new Declaration$3(nodes)]; +- } else if (nodes.selector) { +- nodes = [new Rule$4(nodes)]; +- } else if (nodes.name) { +- nodes = [new AtRule$4(nodes)]; +- } else if (nodes.text) { +- nodes = [new Comment$3(nodes)]; +- } else { +- throw new Error("Unknown node type in node creation"); +- } +- let processed = nodes.map((i2) => { +- if (!i2[my$1]) Container2.rebuild(i2); +- i2 = i2.proxyOf; +- if (i2.parent) i2.parent.removeChild(i2); +- if (i2[isClean$1]) markDirtyUp(i2); +- if (typeof i2.raws.before === "undefined") { +- if (sample && typeof sample.raws.before !== "undefined") { +- i2.raws.before = sample.raws.before.replace(/\S/g, ""); +- } +- } +- i2.parent = this.proxyOf; +- return i2; +- }); +- return processed; +- } +- prepend(...children) { +- children = children.reverse(); +- for (let child of children) { +- let nodes = this.normalize(child, this.first, "prepend").reverse(); +- for (let node2 of nodes) this.proxyOf.nodes.unshift(node2); +- for (let id in this.indexes) { +- this.indexes[id] = this.indexes[id] + nodes.length; +- } +- } +- this.markDirty(); +- return this; +- } +- push(child) { +- child.parent = this; +- this.proxyOf.nodes.push(child); +- return this; +- } +- removeAll() { +- for (let node2 of this.proxyOf.nodes) node2.parent = void 0; +- this.proxyOf.nodes = []; +- this.markDirty(); +- return this; +- } +- removeChild(child) { +- child = this.index(child); +- this.proxyOf.nodes[child].parent = void 0; +- this.proxyOf.nodes.splice(child, 1); +- let index2; +- for (let id in this.indexes) { +- index2 = this.indexes[id]; +- if (index2 >= child) { +- this.indexes[id] = index2 - 1; +- } +- } +- this.markDirty(); +- return this; +- } +- replaceValues(pattern, opts, callback) { +- if (!callback) { +- callback = opts; +- opts = {}; +- } +- this.walkDecls((decl) => { +- if (opts.props && !opts.props.includes(decl.prop)) return; +- if (opts.fast && !decl.value.includes(opts.fast)) return; +- decl.value = decl.value.replace(pattern, callback); +- }); +- this.markDirty(); +- return this; +- } +- some(condition) { +- return this.nodes.some(condition); +- } +- walk(callback) { +- return this.each((child, i2) => { +- let result2; +- try { +- result2 = callback(child, i2); +- } catch (e2) { +- throw child.addToError(e2); +- } +- if (result2 !== false && child.walk) { +- result2 = child.walk(callback); +- } +- return result2; +- }); +- } +- walkAtRules(name, callback) { +- if (!callback) { +- callback = name; +- return this.walk((child, i2) => { +- if (child.type === "atrule") { +- return callback(child, i2); +- } +- }); +- } +- if (name instanceof RegExp) { +- return this.walk((child, i2) => { +- if (child.type === "atrule" && name.test(child.name)) { +- return callback(child, i2); +- } +- }); +- } +- return this.walk((child, i2) => { +- if (child.type === "atrule" && child.name === name) { +- return callback(child, i2); +- } +- }); +- } +- walkComments(callback) { +- return this.walk((child, i2) => { +- if (child.type === "comment") { +- return callback(child, i2); +- } +- }); +- } +- walkDecls(prop, callback) { +- if (!callback) { +- callback = prop; +- return this.walk((child, i2) => { +- if (child.type === "decl") { +- return callback(child, i2); +- } +- }); +- } +- if (prop instanceof RegExp) { +- return this.walk((child, i2) => { +- if (child.type === "decl" && prop.test(child.prop)) { +- return callback(child, i2); +- } +- }); +- } +- return this.walk((child, i2) => { +- if (child.type === "decl" && child.prop === prop) { +- return callback(child, i2); +- } +- }); +- } +- walkRules(selector, callback) { +- if (!callback) { +- callback = selector; +- return this.walk((child, i2) => { +- if (child.type === "rule") { +- return callback(child, i2); +- } +- }); +- } +- if (selector instanceof RegExp) { +- return this.walk((child, i2) => { +- if (child.type === "rule" && selector.test(child.selector)) { +- return callback(child, i2); +- } +- }); +- } +- return this.walk((child, i2) => { +- if (child.type === "rule" && child.selector === selector) { +- return callback(child, i2); +- } +- }); +- } +- get first() { +- if (!this.proxyOf.nodes) return void 0; +- return this.proxyOf.nodes[0]; +- } +- get last() { +- if (!this.proxyOf.nodes) return void 0; +- return this.proxyOf.nodes[this.proxyOf.nodes.length - 1]; +- } +-}; +-Container$7.registerParse = (dependant) => { +- parse$4 = dependant; +-}; +-Container$7.registerRule = (dependant) => { +- Rule$4 = dependant; +-}; +-Container$7.registerAtRule = (dependant) => { +- AtRule$4 = dependant; +-}; +-Container$7.registerRoot = (dependant) => { +- Root$6 = dependant; +-}; +-var container = Container$7; +-Container$7.default = Container$7; +-Container$7.rebuild = (node2) => { +- if (node2.type === "atrule") { +- Object.setPrototypeOf(node2, AtRule$4.prototype); +- } else if (node2.type === "rule") { +- Object.setPrototypeOf(node2, Rule$4.prototype); +- } else if (node2.type === "decl") { +- Object.setPrototypeOf(node2, Declaration$3.prototype); +- } else if (node2.type === "comment") { +- Object.setPrototypeOf(node2, Comment$3.prototype); +- } else if (node2.type === "root") { +- Object.setPrototypeOf(node2, Root$6.prototype); +- } +- node2[my$1] = true; +- if (node2.nodes) { +- node2.nodes.forEach((child) => { +- Container$7.rebuild(child); +- }); +- } +-}; +-let Container$6 = container; +-let LazyResult$4, Processor$3; +-let Document$3 = class Document23 extends Container$6 { +- constructor(defaults) { +- super({ type: "document", ...defaults }); +- if (!this.nodes) { +- this.nodes = []; +- } +- } +- toResult(opts = {}) { +- let lazy = new LazyResult$4(new Processor$3(), this, opts); +- return lazy.stringify(); +- } +-}; +-Document$3.registerLazyResult = (dependant) => { +- LazyResult$4 = dependant; +-}; +-Document$3.registerProcessor = (dependant) => { +- Processor$3 = dependant; +-}; +-var document$1 = Document$3; +-Document$3.default = Document$3; +-let printed = {}; +-var warnOnce$2 = function warnOnce2(message) { +- if (printed[message]) return; +- printed[message] = true; +- if (typeof console !== "undefined" && console.warn) { +- console.warn(message); +- } +-}; +-let Warning$2 = class Warning2 { +- constructor(text, opts = {}) { +- this.type = "warning"; +- this.text = text; +- if (opts.node && opts.node.source) { +- let range = opts.node.rangeBy(opts); +- this.line = range.start.line; +- this.column = range.start.column; +- this.endLine = range.end.line; +- this.endColumn = range.end.column; +- } +- for (let opt in opts) this[opt] = opts[opt]; +- } +- toString() { +- if (this.node) { +- return this.node.error(this.text, { +- index: this.index, +- plugin: this.plugin, +- word: this.word +- }).message; +- } +- if (this.plugin) { +- return this.plugin + ": " + this.text; +- } +- return this.text; +- } +-}; +-var warning = Warning$2; +-Warning$2.default = Warning$2; +-let Warning$1 = warning; +-let Result$3 = class Result2 { +- constructor(processor2, root2, opts) { +- this.processor = processor2; +- this.messages = []; +- this.root = root2; +- this.opts = opts; +- this.css = void 0; +- this.map = void 0; +- } +- toString() { +- return this.css; +- } +- warn(text, opts = {}) { +- if (!opts.plugin) { +- if (this.lastPlugin && this.lastPlugin.postcssPlugin) { +- opts.plugin = this.lastPlugin.postcssPlugin; +- } +- } +- let warning2 = new Warning$1(text, opts); +- this.messages.push(warning2); +- return warning2; +- } +- warnings() { +- return this.messages.filter((i2) => i2.type === "warning"); +- } +- get content() { +- return this.css; +- } +-}; +-var result = Result$3; +-Result$3.default = Result$3; +-const SINGLE_QUOTE = "'".charCodeAt(0); +-const DOUBLE_QUOTE = '"'.charCodeAt(0); +-const BACKSLASH = "\\".charCodeAt(0); +-const SLASH = "/".charCodeAt(0); +-const NEWLINE = "\n".charCodeAt(0); +-const SPACE = " ".charCodeAt(0); +-const FEED = "\f".charCodeAt(0); +-const TAB = " ".charCodeAt(0); +-const CR = "\r".charCodeAt(0); +-const OPEN_SQUARE = "[".charCodeAt(0); +-const CLOSE_SQUARE = "]".charCodeAt(0); +-const OPEN_PARENTHESES = "(".charCodeAt(0); +-const CLOSE_PARENTHESES = ")".charCodeAt(0); +-const OPEN_CURLY = "{".charCodeAt(0); +-const CLOSE_CURLY = "}".charCodeAt(0); +-const SEMICOLON = ";".charCodeAt(0); +-const ASTERISK = "*".charCodeAt(0); +-const COLON = ":".charCodeAt(0); +-const AT = "@".charCodeAt(0); +-const RE_AT_END = /[\t\n\f\r "#'()/;[\\\]{}]/g; +-const RE_WORD_END = /[\t\n\f\r !"#'():;@[\\\]{}]|\/(?=\*)/g; +-const RE_BAD_BRACKET = /.[\r\n"'(/\\]/; +-const RE_HEX_ESCAPE = /[\da-f]/i; +-var tokenize = function tokenizer2(input2, options = {}) { +- let css = input2.css.valueOf(); +- let ignore = options.ignoreErrors; +- let code, next, quote, content, escape; +- let escaped, escapePos, prev, n2, currentToken; +- let length = css.length; +- let pos = 0; +- let buffer = []; +- let returned = []; +- function position() { +- return pos; +- } +- function unclosed(what) { +- throw input2.error("Unclosed " + what, pos); +- } +- function endOfFile() { +- return returned.length === 0 && pos >= length; +- } +- function nextToken(opts) { +- if (returned.length) return returned.pop(); +- if (pos >= length) return; +- let ignoreUnclosed = opts ? opts.ignoreUnclosed : false; +- code = css.charCodeAt(pos); +- switch (code) { +- case NEWLINE: +- case SPACE: +- case TAB: +- case CR: +- case FEED: { +- next = pos; +- do { +- next += 1; +- code = css.charCodeAt(next); +- } while (code === SPACE || code === NEWLINE || code === TAB || code === CR || code === FEED); +- currentToken = ["space", css.slice(pos, next)]; +- pos = next - 1; +- break; +- } +- case OPEN_SQUARE: +- case CLOSE_SQUARE: +- case OPEN_CURLY: +- case CLOSE_CURLY: +- case COLON: +- case SEMICOLON: +- case CLOSE_PARENTHESES: { +- let controlChar = String.fromCharCode(code); +- currentToken = [controlChar, controlChar, pos]; +- break; +- } +- case OPEN_PARENTHESES: { +- prev = buffer.length ? buffer.pop()[1] : ""; +- n2 = css.charCodeAt(pos + 1); +- if (prev === "url" && n2 !== SINGLE_QUOTE && n2 !== DOUBLE_QUOTE && n2 !== SPACE && n2 !== NEWLINE && n2 !== TAB && n2 !== FEED && n2 !== CR) { +- next = pos; +- do { +- escaped = false; +- next = css.indexOf(")", next + 1); +- if (next === -1) { +- if (ignore || ignoreUnclosed) { +- next = pos; +- break; +- } else { +- unclosed("bracket"); +- } +- } +- escapePos = next; +- while (css.charCodeAt(escapePos - 1) === BACKSLASH) { +- escapePos -= 1; +- escaped = !escaped; +- } +- } while (escaped); +- currentToken = ["brackets", css.slice(pos, next + 1), pos, next]; +- pos = next; +- } else { +- next = css.indexOf(")", pos + 1); +- content = css.slice(pos, next + 1); +- if (next === -1 || RE_BAD_BRACKET.test(content)) { +- currentToken = ["(", "(", pos]; +- } else { +- currentToken = ["brackets", content, pos, next]; +- pos = next; +- } +- } +- break; +- } +- case SINGLE_QUOTE: +- case DOUBLE_QUOTE: { +- quote = code === SINGLE_QUOTE ? "'" : '"'; +- next = pos; +- do { +- escaped = false; +- next = css.indexOf(quote, next + 1); +- if (next === -1) { +- if (ignore || ignoreUnclosed) { +- next = pos + 1; +- break; +- } else { +- unclosed("string"); +- } +- } +- escapePos = next; +- while (css.charCodeAt(escapePos - 1) === BACKSLASH) { +- escapePos -= 1; +- escaped = !escaped; +- } +- } while (escaped); +- currentToken = ["string", css.slice(pos, next + 1), pos, next]; +- pos = next; +- break; +- } +- case AT: { +- RE_AT_END.lastIndex = pos + 1; +- RE_AT_END.test(css); +- if (RE_AT_END.lastIndex === 0) { +- next = css.length - 1; +- } else { +- next = RE_AT_END.lastIndex - 2; +- } +- currentToken = ["at-word", css.slice(pos, next + 1), pos, next]; +- pos = next; +- break; +- } +- case BACKSLASH: { +- next = pos; +- escape = true; +- while (css.charCodeAt(next + 1) === BACKSLASH) { +- next += 1; +- escape = !escape; +- } +- code = css.charCodeAt(next + 1); +- if (escape && code !== SLASH && code !== SPACE && code !== NEWLINE && code !== TAB && code !== CR && code !== FEED) { +- next += 1; +- if (RE_HEX_ESCAPE.test(css.charAt(next))) { +- while (RE_HEX_ESCAPE.test(css.charAt(next + 1))) { +- next += 1; +- } +- if (css.charCodeAt(next + 1) === SPACE) { +- next += 1; +- } +- } +- } +- currentToken = ["word", css.slice(pos, next + 1), pos, next]; +- pos = next; +- break; +- } +- default: { +- if (code === SLASH && css.charCodeAt(pos + 1) === ASTERISK) { +- next = css.indexOf("*/", pos + 2) + 1; +- if (next === 0) { +- if (ignore || ignoreUnclosed) { +- next = css.length; +- } else { +- unclosed("comment"); +- } +- } +- currentToken = ["comment", css.slice(pos, next + 1), pos, next]; +- pos = next; +- } else { +- RE_WORD_END.lastIndex = pos + 1; +- RE_WORD_END.test(css); +- if (RE_WORD_END.lastIndex === 0) { +- next = css.length - 1; +- } else { +- next = RE_WORD_END.lastIndex - 2; +- } +- currentToken = ["word", css.slice(pos, next + 1), pos, next]; +- buffer.push(currentToken); +- pos = next; +- } +- break; +- } +- } +- pos++; +- return currentToken; +- } +- function back(token) { +- returned.push(token); +- } +- return { +- back, +- endOfFile, +- nextToken, +- position +- }; +-}; +-let Container$5 = container; +-let AtRule$3 = class AtRule2 extends Container$5 { +- constructor(defaults) { +- super(defaults); +- this.type = "atrule"; +- } +- append(...children) { +- if (!this.proxyOf.nodes) this.nodes = []; +- return super.append(...children); +- } +- prepend(...children) { +- if (!this.proxyOf.nodes) this.nodes = []; +- return super.prepend(...children); +- } +-}; +-var atRule = AtRule$3; +-AtRule$3.default = AtRule$3; +-Container$5.registerAtRule(AtRule$3); +-let Container$4 = container; +-let LazyResult$3, Processor$2; +-let Root$5 = class Root2 extends Container$4 { +- constructor(defaults) { +- super(defaults); +- this.type = "root"; +- if (!this.nodes) this.nodes = []; +- } +- normalize(child, sample, type) { +- let nodes = super.normalize(child); +- if (sample) { +- if (type === "prepend") { +- if (this.nodes.length > 1) { +- sample.raws.before = this.nodes[1].raws.before; +- } else { +- delete sample.raws.before; +- } +- } else if (this.first !== sample) { +- for (let node2 of nodes) { +- node2.raws.before = sample.raws.before; +- } +- } +- } +- return nodes; +- } +- removeChild(child, ignore) { +- let index2 = this.index(child); +- if (!ignore && index2 === 0 && this.nodes.length > 1) { +- this.nodes[1].raws.before = this.nodes[index2].raws.before; +- } +- return super.removeChild(child); +- } +- toResult(opts = {}) { +- let lazy = new LazyResult$3(new Processor$2(), this, opts); +- return lazy.stringify(); +- } +-}; +-Root$5.registerLazyResult = (dependant) => { +- LazyResult$3 = dependant; +-}; +-Root$5.registerProcessor = (dependant) => { +- Processor$2 = dependant; +-}; +-var root = Root$5; +-Root$5.default = Root$5; +-Container$4.registerRoot(Root$5); +-let list$2 = { +- comma(string) { +- return list$2.split(string, [","], true); +- }, +- space(string) { +- let spaces = [" ", "\n", " "]; +- return list$2.split(string, spaces); +- }, +- split(string, separators, last) { +- let array = []; +- let current = ""; +- let split = false; +- let func = 0; +- let inQuote = false; +- let prevQuote = ""; +- let escape = false; +- for (let letter of string) { +- if (escape) { +- escape = false; +- } else if (letter === "\\") { +- escape = true; +- } else if (inQuote) { +- if (letter === prevQuote) { +- inQuote = false; +- } +- } else if (letter === '"' || letter === "'") { +- inQuote = true; +- prevQuote = letter; +- } else if (letter === "(") { +- func += 1; +- } else if (letter === ")") { +- if (func > 0) func -= 1; +- } else if (func === 0) { +- if (separators.includes(letter)) split = true; +- } +- if (split) { +- if (current !== "") array.push(current.trim()); +- current = ""; +- split = false; +- } else { +- current += letter; +- } +- } +- if (last || current !== "") array.push(current.trim()); +- return array; +- } +-}; +-var list_1 = list$2; +-list$2.default = list$2; +-let Container$3 = container; +-let list$1 = list_1; +-let Rule$3 = class Rule2 extends Container$3 { +- constructor(defaults) { +- super(defaults); +- this.type = "rule"; +- if (!this.nodes) this.nodes = []; +- } +- get selectors() { +- return list$1.comma(this.selector); +- } +- set selectors(values) { +- let match = this.selector ? this.selector.match(/,\s*/) : null; +- let sep2 = match ? match[0] : "," + this.raw("between", "beforeOpen"); +- this.selector = values.join(sep2); +- } +-}; +-var rule = Rule$3; +-Rule$3.default = Rule$3; +-Container$3.registerRule(Rule$3); +-let Declaration$2 = declaration; +-let tokenizer22 = tokenize; +-let Comment$2 = comment; +-let AtRule$2 = atRule; +-let Root$4 = root; +-let Rule$2 = rule; +-const SAFE_COMMENT_NEIGHBOR = { +- empty: true, +- space: true +-}; +-function findLastWithPosition(tokens) { +- for (let i2 = tokens.length - 1; i2 >= 0; i2--) { +- let token = tokens[i2]; +- let pos = token[3] || token[2]; +- if (pos) return pos; +- } +-} +-let Parser$1 = class Parser2 { +- constructor(input2) { +- this.input = input2; +- this.root = new Root$4(); +- this.current = this.root; +- this.spaces = ""; +- this.semicolon = false; +- this.createTokenizer(); +- this.root.source = { input: input2, start: { column: 1, line: 1, offset: 0 } }; +- } +- atrule(token) { +- let node2 = new AtRule$2(); +- node2.name = token[1].slice(1); +- if (node2.name === "") { +- this.unnamedAtrule(node2, token); +- } +- this.init(node2, token[2]); +- let type; +- let prev; +- let shift; +- let last = false; +- let open = false; +- let params = []; +- let brackets = []; +- while (!this.tokenizer.endOfFile()) { +- token = this.tokenizer.nextToken(); +- type = token[0]; +- if (type === "(" || type === "[") { +- brackets.push(type === "(" ? ")" : "]"); +- } else if (type === "{" && brackets.length > 0) { +- brackets.push("}"); +- } else if (type === brackets[brackets.length - 1]) { +- brackets.pop(); +- } +- if (brackets.length === 0) { +- if (type === ";") { +- node2.source.end = this.getPosition(token[2]); +- node2.source.end.offset++; +- this.semicolon = true; +- break; +- } else if (type === "{") { +- open = true; +- break; +- } else if (type === "}") { +- if (params.length > 0) { +- shift = params.length - 1; +- prev = params[shift]; +- while (prev && prev[0] === "space") { +- prev = params[--shift]; +- } +- if (prev) { +- node2.source.end = this.getPosition(prev[3] || prev[2]); +- node2.source.end.offset++; +- } +- } +- this.end(token); +- break; +- } else { +- params.push(token); +- } +- } else { +- params.push(token); +- } +- if (this.tokenizer.endOfFile()) { +- last = true; +- break; +- } +- } +- node2.raws.between = this.spacesAndCommentsFromEnd(params); +- if (params.length) { +- node2.raws.afterName = this.spacesAndCommentsFromStart(params); +- this.raw(node2, "params", params); +- if (last) { +- token = params[params.length - 1]; +- node2.source.end = this.getPosition(token[3] || token[2]); +- node2.source.end.offset++; +- this.spaces = node2.raws.between; +- node2.raws.between = ""; +- } +- } else { +- node2.raws.afterName = ""; +- node2.params = ""; +- } +- if (open) { +- node2.nodes = []; +- this.current = node2; +- } +- } +- checkMissedSemicolon(tokens) { +- let colon = this.colon(tokens); +- if (colon === false) return; +- let founded = 0; +- let token; +- for (let j = colon - 1; j >= 0; j--) { +- token = tokens[j]; +- if (token[0] !== "space") { +- founded += 1; +- if (founded === 2) break; +- } +- } +- throw this.input.error( +- "Missed semicolon", +- token[0] === "word" ? token[3] + 1 : token[2] +- ); +- } +- colon(tokens) { +- let brackets = 0; +- let token, type, prev; +- for (let [i2, element] of tokens.entries()) { +- token = element; +- type = token[0]; +- if (type === "(") { +- brackets += 1; +- } +- if (type === ")") { +- brackets -= 1; +- } +- if (brackets === 0 && type === ":") { +- if (!prev) { +- this.doubleColon(token); +- } else if (prev[0] === "word" && prev[1] === "progid") { +- continue; +- } else { +- return i2; +- } +- } +- prev = token; +- } +- return false; +- } +- comment(token) { +- let node2 = new Comment$2(); +- this.init(node2, token[2]); +- node2.source.end = this.getPosition(token[3] || token[2]); +- node2.source.end.offset++; +- let text = token[1].slice(2, -2); +- if (/^\s*$/.test(text)) { +- node2.text = ""; +- node2.raws.left = text; +- node2.raws.right = ""; +- } else { +- let match = text.match(/^(\s*)([^]*\S)(\s*)$/); +- node2.text = match[2]; +- node2.raws.left = match[1]; +- node2.raws.right = match[3]; +- } +- } +- createTokenizer() { +- this.tokenizer = tokenizer22(this.input); +- } +- decl(tokens, customProperty) { +- let node2 = new Declaration$2(); +- this.init(node2, tokens[0][2]); +- let last = tokens[tokens.length - 1]; +- if (last[0] === ";") { +- this.semicolon = true; +- tokens.pop(); +- } +- node2.source.end = this.getPosition( +- last[3] || last[2] || findLastWithPosition(tokens) +- ); +- node2.source.end.offset++; +- while (tokens[0][0] !== "word") { +- if (tokens.length === 1) this.unknownWord(tokens); +- node2.raws.before += tokens.shift()[1]; +- } +- node2.source.start = this.getPosition(tokens[0][2]); +- node2.prop = ""; +- while (tokens.length) { +- let type = tokens[0][0]; +- if (type === ":" || type === "space" || type === "comment") { +- break; +- } +- node2.prop += tokens.shift()[1]; +- } +- node2.raws.between = ""; +- let token; +- while (tokens.length) { +- token = tokens.shift(); +- if (token[0] === ":") { +- node2.raws.between += token[1]; +- break; +- } else { +- if (token[0] === "word" && /\w/.test(token[1])) { +- this.unknownWord([token]); +- } +- node2.raws.between += token[1]; +- } +- } +- if (node2.prop[0] === "_" || node2.prop[0] === "*") { +- node2.raws.before += node2.prop[0]; +- node2.prop = node2.prop.slice(1); +- } +- let firstSpaces = []; +- let next; +- while (tokens.length) { +- next = tokens[0][0]; +- if (next !== "space" && next !== "comment") break; +- firstSpaces.push(tokens.shift()); +- } +- this.precheckMissedSemicolon(tokens); +- for (let i2 = tokens.length - 1; i2 >= 0; i2--) { +- token = tokens[i2]; +- if (token[1].toLowerCase() === "!important") { +- node2.important = true; +- let string = this.stringFrom(tokens, i2); +- string = this.spacesFromEnd(tokens) + string; +- if (string !== " !important") node2.raws.important = string; +- break; +- } else if (token[1].toLowerCase() === "important") { +- let cache = tokens.slice(0); +- let str = ""; +- for (let j = i2; j > 0; j--) { +- let type = cache[j][0]; +- if (str.trim().indexOf("!") === 0 && type !== "space") { +- break; +- } +- str = cache.pop()[1] + str; +- } +- if (str.trim().indexOf("!") === 0) { +- node2.important = true; +- node2.raws.important = str; +- tokens = cache; +- } +- } +- if (token[0] !== "space" && token[0] !== "comment") { +- break; +- } +- } +- let hasWord = tokens.some((i2) => i2[0] !== "space" && i2[0] !== "comment"); +- if (hasWord) { +- node2.raws.between += firstSpaces.map((i2) => i2[1]).join(""); +- firstSpaces = []; +- } +- this.raw(node2, "value", firstSpaces.concat(tokens), customProperty); +- if (node2.value.includes(":") && !customProperty) { +- this.checkMissedSemicolon(tokens); +- } +- } +- doubleColon(token) { +- throw this.input.error( +- "Double colon", +- { offset: token[2] }, +- { offset: token[2] + token[1].length } +- ); +- } +- emptyRule(token) { +- let node2 = new Rule$2(); +- this.init(node2, token[2]); +- node2.selector = ""; +- node2.raws.between = ""; +- this.current = node2; +- } +- end(token) { +- if (this.current.nodes && this.current.nodes.length) { +- this.current.raws.semicolon = this.semicolon; +- } +- this.semicolon = false; +- this.current.raws.after = (this.current.raws.after || "") + this.spaces; +- this.spaces = ""; +- if (this.current.parent) { +- this.current.source.end = this.getPosition(token[2]); +- this.current.source.end.offset++; +- this.current = this.current.parent; +- } else { +- this.unexpectedClose(token); +- } +- } +- endFile() { +- if (this.current.parent) this.unclosedBlock(); +- if (this.current.nodes && this.current.nodes.length) { +- this.current.raws.semicolon = this.semicolon; +- } +- this.current.raws.after = (this.current.raws.after || "") + this.spaces; +- this.root.source.end = this.getPosition(this.tokenizer.position()); +- } +- freeSemicolon(token) { +- this.spaces += token[1]; +- if (this.current.nodes) { +- let prev = this.current.nodes[this.current.nodes.length - 1]; +- if (prev && prev.type === "rule" && !prev.raws.ownSemicolon) { +- prev.raws.ownSemicolon = this.spaces; +- this.spaces = ""; +- } +- } +- } +- // Helpers +- getPosition(offset) { +- let pos = this.input.fromOffset(offset); +- return { +- column: pos.col, +- line: pos.line, +- offset +- }; +- } +- init(node2, offset) { +- this.current.push(node2); +- node2.source = { +- input: this.input, +- start: this.getPosition(offset) +- }; +- node2.raws.before = this.spaces; +- this.spaces = ""; +- if (node2.type !== "comment") this.semicolon = false; +- } +- other(start) { +- let end = false; +- let type = null; +- let colon = false; +- let bracket = null; +- let brackets = []; +- let customProperty = start[1].startsWith("--"); +- let tokens = []; +- let token = start; +- while (token) { +- type = token[0]; +- tokens.push(token); +- if (type === "(" || type === "[") { +- if (!bracket) bracket = token; +- brackets.push(type === "(" ? ")" : "]"); +- } else if (customProperty && colon && type === "{") { +- if (!bracket) bracket = token; +- brackets.push("}"); +- } else if (brackets.length === 0) { +- if (type === ";") { +- if (colon) { +- this.decl(tokens, customProperty); +- return; +- } else { +- break; +- } +- } else if (type === "{") { +- this.rule(tokens); +- return; +- } else if (type === "}") { +- this.tokenizer.back(tokens.pop()); +- end = true; +- break; +- } else if (type === ":") { +- colon = true; +- } +- } else if (type === brackets[brackets.length - 1]) { +- brackets.pop(); +- if (brackets.length === 0) bracket = null; +- } +- token = this.tokenizer.nextToken(); +- } +- if (this.tokenizer.endOfFile()) end = true; +- if (brackets.length > 0) this.unclosedBracket(bracket); +- if (end && colon) { +- if (!customProperty) { +- while (tokens.length) { +- token = tokens[tokens.length - 1][0]; +- if (token !== "space" && token !== "comment") break; +- this.tokenizer.back(tokens.pop()); +- } +- } +- this.decl(tokens, customProperty); +- } else { +- this.unknownWord(tokens); +- } +- } +- parse() { +- let token; +- while (!this.tokenizer.endOfFile()) { +- token = this.tokenizer.nextToken(); +- switch (token[0]) { +- case "space": +- this.spaces += token[1]; +- break; +- case ";": +- this.freeSemicolon(token); +- break; +- case "}": +- this.end(token); +- break; +- case "comment": +- this.comment(token); +- break; +- case "at-word": +- this.atrule(token); +- break; +- case "{": +- this.emptyRule(token); +- break; +- default: +- this.other(token); +- break; +- } +- } +- this.endFile(); +- } +- precheckMissedSemicolon() { +- } +- raw(node2, prop, tokens, customProperty) { +- let token, type; +- let length = tokens.length; +- let value = ""; +- let clean = true; +- let next, prev; +- for (let i2 = 0; i2 < length; i2 += 1) { +- token = tokens[i2]; +- type = token[0]; +- if (type === "space" && i2 === length - 1 && !customProperty) { +- clean = false; +- } else if (type === "comment") { +- prev = tokens[i2 - 1] ? tokens[i2 - 1][0] : "empty"; +- next = tokens[i2 + 1] ? tokens[i2 + 1][0] : "empty"; +- if (!SAFE_COMMENT_NEIGHBOR[prev] && !SAFE_COMMENT_NEIGHBOR[next]) { +- if (value.slice(-1) === ",") { +- clean = false; +- } else { +- value += token[1]; +- } +- } else { +- clean = false; +- } +- } else { +- value += token[1]; +- } +- } +- if (!clean) { +- let raw = tokens.reduce((all, i2) => all + i2[1], ""); +- node2.raws[prop] = { raw, value }; +- } +- node2[prop] = value; +- } +- rule(tokens) { +- tokens.pop(); +- let node2 = new Rule$2(); +- this.init(node2, tokens[0][2]); +- node2.raws.between = this.spacesAndCommentsFromEnd(tokens); +- this.raw(node2, "selector", tokens); +- this.current = node2; +- } +- spacesAndCommentsFromEnd(tokens) { +- let lastTokenType; +- let spaces = ""; +- while (tokens.length) { +- lastTokenType = tokens[tokens.length - 1][0]; +- if (lastTokenType !== "space" && lastTokenType !== "comment") break; +- spaces = tokens.pop()[1] + spaces; +- } +- return spaces; +- } +- // Errors +- spacesAndCommentsFromStart(tokens) { +- let next; +- let spaces = ""; +- while (tokens.length) { +- next = tokens[0][0]; +- if (next !== "space" && next !== "comment") break; +- spaces += tokens.shift()[1]; +- } +- return spaces; +- } +- spacesFromEnd(tokens) { +- let lastTokenType; +- let spaces = ""; +- while (tokens.length) { +- lastTokenType = tokens[tokens.length - 1][0]; +- if (lastTokenType !== "space") break; +- spaces = tokens.pop()[1] + spaces; +- } +- return spaces; +- } +- stringFrom(tokens, from) { +- let result2 = ""; +- for (let i2 = from; i2 < tokens.length; i2++) { +- result2 += tokens[i2][1]; +- } +- tokens.splice(from, tokens.length - from); +- return result2; +- } +- unclosedBlock() { +- let pos = this.current.source.start; +- throw this.input.error("Unclosed block", pos.line, pos.column); +- } +- unclosedBracket(bracket) { +- throw this.input.error( +- "Unclosed bracket", +- { offset: bracket[2] }, +- { offset: bracket[2] + 1 } +- ); +- } +- unexpectedClose(token) { +- throw this.input.error( +- "Unexpected }", +- { offset: token[2] }, +- { offset: token[2] + 1 } +- ); +- } +- unknownWord(tokens) { +- throw this.input.error( +- "Unknown word", +- { offset: tokens[0][2] }, +- { offset: tokens[0][2] + tokens[0][1].length } +- ); +- } +- unnamedAtrule(node2, token) { +- throw this.input.error( +- "At-rule without name", +- { offset: token[2] }, +- { offset: token[2] + token[1].length } +- ); +- } +-}; +-var parser = Parser$1; +-let Container$2 = container; +-let Parser22 = parser; +-let Input$2 = input; +-function parse$3(css, opts) { +- let input2 = new Input$2(css, opts); +- let parser2 = new Parser22(input2); +- try { +- parser2.parse(); +- } catch (e2) { +- if (process.env.NODE_ENV !== "production") { +- if (e2.name === "CssSyntaxError" && opts && opts.from) { +- if (/\.scss$/i.test(opts.from)) { +- e2.message += "\nYou tried to parse SCSS with the standard CSS parser; try again with the postcss-scss parser"; +- } else if (/\.sass/i.test(opts.from)) { +- e2.message += "\nYou tried to parse Sass with the standard CSS parser; try again with the postcss-sass parser"; +- } else if (/\.less$/i.test(opts.from)) { +- e2.message += "\nYou tried to parse Less with the standard CSS parser; try again with the postcss-less parser"; +- } +- } +- } +- throw e2; +- } +- return parser2.root; +-} +-var parse_1 = parse$3; +-parse$3.default = parse$3; +-Container$2.registerParse(parse$3); +-let { isClean, my } = symbols; +-let MapGenerator$1 = mapGenerator; +-let stringify$2 = stringify_1; +-let Container$1 = container; +-let Document$2 = document$1; +-let warnOnce$1 = warnOnce$2; +-let Result$2 = result; +-let parse$2 = parse_1; +-let Root$3 = root; +-const TYPE_TO_CLASS_NAME = { +- atrule: "AtRule", +- comment: "Comment", +- decl: "Declaration", +- document: "Document", +- root: "Root", +- rule: "Rule" +-}; +-const PLUGIN_PROPS = { +- AtRule: true, +- AtRuleExit: true, +- Comment: true, +- CommentExit: true, +- Declaration: true, +- DeclarationExit: true, +- Document: true, +- DocumentExit: true, +- Once: true, +- OnceExit: true, +- postcssPlugin: true, +- prepare: true, +- Root: true, +- RootExit: true, +- Rule: true, +- RuleExit: true +-}; +-const NOT_VISITORS = { +- Once: true, +- postcssPlugin: true, +- prepare: true +-}; +-const CHILDREN = 0; +-function isPromise(obj) { +- return typeof obj === "object" && typeof obj.then === "function"; +-} +-function getEvents(node2) { +- let key = false; +- let type = TYPE_TO_CLASS_NAME[node2.type]; +- if (node2.type === "decl") { +- key = node2.prop.toLowerCase(); +- } else if (node2.type === "atrule") { +- key = node2.name.toLowerCase(); +- } +- if (key && node2.append) { +- return [ +- type, +- type + "-" + key, +- CHILDREN, +- type + "Exit", +- type + "Exit-" + key +- ]; +- } else if (key) { +- return [type, type + "-" + key, type + "Exit", type + "Exit-" + key]; +- } else if (node2.append) { +- return [type, CHILDREN, type + "Exit"]; +- } else { +- return [type, type + "Exit"]; +- } +-} +-function toStack(node2) { +- let events; +- if (node2.type === "document") { +- events = ["Document", CHILDREN, "DocumentExit"]; +- } else if (node2.type === "root") { +- events = ["Root", CHILDREN, "RootExit"]; +- } else { +- events = getEvents(node2); +- } +- return { +- eventIndex: 0, +- events, +- iterator: 0, +- node: node2, +- visitorIndex: 0, +- visitors: [] +- }; +-} +-function cleanMarks(node2) { +- node2[isClean] = false; +- if (node2.nodes) node2.nodes.forEach((i2) => cleanMarks(i2)); +- return node2; +-} +-let postcss$2 = {}; +-let LazyResult$2 = class LazyResult2 { +- constructor(processor2, css, opts) { +- this.stringified = false; +- this.processed = false; +- let root2; +- if (typeof css === "object" && css !== null && (css.type === "root" || css.type === "document")) { +- root2 = cleanMarks(css); +- } else if (css instanceof LazyResult2 || css instanceof Result$2) { +- root2 = cleanMarks(css.root); +- if (css.map) { +- if (typeof opts.map === "undefined") opts.map = {}; +- if (!opts.map.inline) opts.map.inline = false; +- opts.map.prev = css.map; +- } +- } else { +- let parser2 = parse$2; +- if (opts.syntax) parser2 = opts.syntax.parse; +- if (opts.parser) parser2 = opts.parser; +- if (parser2.parse) parser2 = parser2.parse; +- try { +- root2 = parser2(css, opts); +- } catch (error) { +- this.processed = true; +- this.error = error; +- } +- if (root2 && !root2[my]) { +- Container$1.rebuild(root2); +- } +- } +- this.result = new Result$2(processor2, root2, opts); +- this.helpers = { ...postcss$2, postcss: postcss$2, result: this.result }; +- this.plugins = this.processor.plugins.map((plugin22) => { +- if (typeof plugin22 === "object" && plugin22.prepare) { +- return { ...plugin22, ...plugin22.prepare(this.result) }; +- } else { +- return plugin22; +- } +- }); +- } +- async() { +- if (this.error) return Promise.reject(this.error); +- if (this.processed) return Promise.resolve(this.result); +- if (!this.processing) { +- this.processing = this.runAsync(); +- } +- return this.processing; +- } +- catch(onRejected) { +- return this.async().catch(onRejected); +- } +- finally(onFinally) { +- return this.async().then(onFinally, onFinally); +- } +- getAsyncError() { +- throw new Error("Use process(css).then(cb) to work with async plugins"); +- } +- handleError(error, node2) { +- let plugin22 = this.result.lastPlugin; +- try { +- if (node2) node2.addToError(error); +- this.error = error; +- if (error.name === "CssSyntaxError" && !error.plugin) { +- error.plugin = plugin22.postcssPlugin; +- error.setMessage(); +- } else if (plugin22.postcssVersion) { +- if (process.env.NODE_ENV !== "production") { +- let pluginName = plugin22.postcssPlugin; +- let pluginVer = plugin22.postcssVersion; +- let runtimeVer = this.result.processor.version; +- let a2 = pluginVer.split("."); +- let b = runtimeVer.split("."); +- if (a2[0] !== b[0] || parseInt(a2[1]) > parseInt(b[1])) { +- console.error( +- "Unknown error from PostCSS plugin. Your current PostCSS version is " + runtimeVer + ", but " + pluginName + " uses " + pluginVer + ". Perhaps this is the source of the error below." +- ); +- } +- } +- } +- } catch (err) { +- if (console && console.error) console.error(err); +- } +- return error; +- } +- prepareVisitors() { +- this.listeners = {}; +- let add = (plugin22, type, cb) => { +- if (!this.listeners[type]) this.listeners[type] = []; +- this.listeners[type].push([plugin22, cb]); +- }; +- for (let plugin22 of this.plugins) { +- if (typeof plugin22 === "object") { +- for (let event in plugin22) { +- if (!PLUGIN_PROPS[event] && /^[A-Z]/.test(event)) { +- throw new Error( +- `Unknown event ${event} in ${plugin22.postcssPlugin}. Try to update PostCSS (${this.processor.version} now).` +- ); +- } +- if (!NOT_VISITORS[event]) { +- if (typeof plugin22[event] === "object") { +- for (let filter in plugin22[event]) { +- if (filter === "*") { +- add(plugin22, event, plugin22[event][filter]); +- } else { +- add( +- plugin22, +- event + "-" + filter.toLowerCase(), +- plugin22[event][filter] +- ); +- } +- } +- } else if (typeof plugin22[event] === "function") { +- add(plugin22, event, plugin22[event]); +- } +- } +- } +- } +- } +- this.hasListener = Object.keys(this.listeners).length > 0; +- } +- async runAsync() { +- this.plugin = 0; +- for (let i2 = 0; i2 < this.plugins.length; i2++) { +- let plugin22 = this.plugins[i2]; +- let promise = this.runOnRoot(plugin22); +- if (isPromise(promise)) { +- try { +- await promise; +- } catch (error) { +- throw this.handleError(error); +- } +- } +- } +- this.prepareVisitors(); +- if (this.hasListener) { +- let root2 = this.result.root; +- while (!root2[isClean]) { +- root2[isClean] = true; +- let stack = [toStack(root2)]; +- while (stack.length > 0) { +- let promise = this.visitTick(stack); +- if (isPromise(promise)) { +- try { +- await promise; +- } catch (e2) { +- let node2 = stack[stack.length - 1].node; +- throw this.handleError(e2, node2); +- } +- } +- } +- } +- if (this.listeners.OnceExit) { +- for (let [plugin22, visitor] of this.listeners.OnceExit) { +- this.result.lastPlugin = plugin22; +- try { +- if (root2.type === "document") { +- let roots = root2.nodes.map( +- (subRoot) => visitor(subRoot, this.helpers) +- ); +- await Promise.all(roots); +- } else { +- await visitor(root2, this.helpers); +- } +- } catch (e2) { +- throw this.handleError(e2); +- } +- } +- } +- } +- this.processed = true; +- return this.stringify(); +- } +- runOnRoot(plugin22) { +- this.result.lastPlugin = plugin22; +- try { +- if (typeof plugin22 === "object" && plugin22.Once) { +- if (this.result.root.type === "document") { +- let roots = this.result.root.nodes.map( +- (root2) => plugin22.Once(root2, this.helpers) +- ); +- if (isPromise(roots[0])) { +- return Promise.all(roots); +- } +- return roots; +- } +- return plugin22.Once(this.result.root, this.helpers); +- } else if (typeof plugin22 === "function") { +- return plugin22(this.result.root, this.result); +- } +- } catch (error) { +- throw this.handleError(error); +- } +- } +- stringify() { +- if (this.error) throw this.error; +- if (this.stringified) return this.result; +- this.stringified = true; +- this.sync(); +- let opts = this.result.opts; +- let str = stringify$2; +- if (opts.syntax) str = opts.syntax.stringify; +- if (opts.stringifier) str = opts.stringifier; +- if (str.stringify) str = str.stringify; +- let map = new MapGenerator$1(str, this.result.root, this.result.opts); +- let data = map.generate(); +- this.result.css = data[0]; +- this.result.map = data[1]; +- return this.result; +- } +- sync() { +- if (this.error) throw this.error; +- if (this.processed) return this.result; +- this.processed = true; +- if (this.processing) { +- throw this.getAsyncError(); +- } +- for (let plugin22 of this.plugins) { +- let promise = this.runOnRoot(plugin22); +- if (isPromise(promise)) { +- throw this.getAsyncError(); +- } +- } +- this.prepareVisitors(); +- if (this.hasListener) { +- let root2 = this.result.root; +- while (!root2[isClean]) { +- root2[isClean] = true; +- this.walkSync(root2); +- } +- if (this.listeners.OnceExit) { +- if (root2.type === "document") { +- for (let subRoot of root2.nodes) { +- this.visitSync(this.listeners.OnceExit, subRoot); +- } +- } else { +- this.visitSync(this.listeners.OnceExit, root2); +- } +- } +- } +- return this.result; +- } +- then(onFulfilled, onRejected) { +- if (process.env.NODE_ENV !== "production") { +- if (!("from" in this.opts)) { +- warnOnce$1( +- "Without `from` option PostCSS could generate wrong source map and will not find Browserslist config. Set it to CSS file path or to `undefined` to prevent this warning." +- ); +- } +- } +- return this.async().then(onFulfilled, onRejected); +- } +- toString() { +- return this.css; +- } +- visitSync(visitors, node2) { +- for (let [plugin22, visitor] of visitors) { +- this.result.lastPlugin = plugin22; +- let promise; +- try { +- promise = visitor(node2, this.helpers); +- } catch (e2) { +- throw this.handleError(e2, node2.proxyOf); +- } +- if (node2.type !== "root" && node2.type !== "document" && !node2.parent) { +- return true; +- } +- if (isPromise(promise)) { +- throw this.getAsyncError(); +- } +- } +- } +- visitTick(stack) { +- let visit2 = stack[stack.length - 1]; +- let { node: node2, visitors } = visit2; +- if (node2.type !== "root" && node2.type !== "document" && !node2.parent) { +- stack.pop(); +- return; +- } +- if (visitors.length > 0 && visit2.visitorIndex < visitors.length) { +- let [plugin22, visitor] = visitors[visit2.visitorIndex]; +- visit2.visitorIndex += 1; +- if (visit2.visitorIndex === visitors.length) { +- visit2.visitors = []; +- visit2.visitorIndex = 0; +- } +- this.result.lastPlugin = plugin22; +- try { +- return visitor(node2.toProxy(), this.helpers); +- } catch (e2) { +- throw this.handleError(e2, node2); +- } +- } +- if (visit2.iterator !== 0) { +- let iterator = visit2.iterator; +- let child; +- while (child = node2.nodes[node2.indexes[iterator]]) { +- node2.indexes[iterator] += 1; +- if (!child[isClean]) { +- child[isClean] = true; +- stack.push(toStack(child)); +- return; +- } +- } +- visit2.iterator = 0; +- delete node2.indexes[iterator]; +- } +- let events = visit2.events; +- while (visit2.eventIndex < events.length) { +- let event = events[visit2.eventIndex]; +- visit2.eventIndex += 1; +- if (event === CHILDREN) { +- if (node2.nodes && node2.nodes.length) { +- node2[isClean] = true; +- visit2.iterator = node2.getIterator(); +- } +- return; +- } else if (this.listeners[event]) { +- visit2.visitors = this.listeners[event]; +- return; +- } +- } +- stack.pop(); +- } +- walkSync(node2) { +- node2[isClean] = true; +- let events = getEvents(node2); +- for (let event of events) { +- if (event === CHILDREN) { +- if (node2.nodes) { +- node2.each((child) => { +- if (!child[isClean]) this.walkSync(child); +- }); +- } +- } else { +- let visitors = this.listeners[event]; +- if (visitors) { +- if (this.visitSync(visitors, node2.toProxy())) return; +- } +- } +- } +- } +- warnings() { +- return this.sync().warnings(); +- } +- get content() { +- return this.stringify().content; +- } +- get css() { +- return this.stringify().css; +- } +- get map() { +- return this.stringify().map; +- } +- get messages() { +- return this.sync().messages; +- } +- get opts() { +- return this.result.opts; +- } +- get processor() { +- return this.result.processor; +- } +- get root() { +- return this.sync().root; +- } +- get [Symbol.toStringTag]() { +- return "LazyResult"; +- } +-}; +-LazyResult$2.registerPostcss = (dependant) => { +- postcss$2 = dependant; +-}; +-var lazyResult = LazyResult$2; +-LazyResult$2.default = LazyResult$2; +-Root$3.registerLazyResult(LazyResult$2); +-Document$2.registerLazyResult(LazyResult$2); +-let MapGenerator22 = mapGenerator; +-let stringify$1 = stringify_1; +-let warnOnce22 = warnOnce$2; +-let parse$1 = parse_1; +-const Result$1 = result; +-let NoWorkResult$1 = class NoWorkResult2 { +- constructor(processor2, css, opts) { +- css = css.toString(); +- this.stringified = false; +- this._processor = processor2; +- this._css = css; +- this._opts = opts; +- this._map = void 0; +- let root2; +- let str = stringify$1; +- this.result = new Result$1(this._processor, root2, this._opts); +- this.result.css = css; +- let self = this; +- Object.defineProperty(this.result, "root", { +- get() { +- return self.root; +- } +- }); +- let map = new MapGenerator22(str, root2, this._opts, css); +- if (map.isMap()) { +- let [generatedCSS, generatedMap] = map.generate(); +- if (generatedCSS) { +- this.result.css = generatedCSS; +- } +- if (generatedMap) { +- this.result.map = generatedMap; +- } +- } else { +- map.clearAnnotation(); +- this.result.css = map.css; +- } +- } +- async() { +- if (this.error) return Promise.reject(this.error); +- return Promise.resolve(this.result); +- } +- catch(onRejected) { +- return this.async().catch(onRejected); +- } +- finally(onFinally) { +- return this.async().then(onFinally, onFinally); +- } +- sync() { +- if (this.error) throw this.error; +- return this.result; +- } +- then(onFulfilled, onRejected) { +- if (process.env.NODE_ENV !== "production") { +- if (!("from" in this._opts)) { +- warnOnce22( +- "Without `from` option PostCSS could generate wrong source map and will not find Browserslist config. Set it to CSS file path or to `undefined` to prevent this warning." +- ); +- } +- } +- return this.async().then(onFulfilled, onRejected); +- } +- toString() { +- return this._css; +- } +- warnings() { +- return []; +- } +- get content() { +- return this.result.css; +- } +- get css() { +- return this.result.css; +- } +- get map() { +- return this.result.map; +- } +- get messages() { +- return []; +- } +- get opts() { +- return this.result.opts; +- } +- get processor() { +- return this.result.processor; +- } +- get root() { +- if (this._root) { +- return this._root; +- } +- let root2; +- let parser2 = parse$1; +- try { +- root2 = parser2(this._css, this._opts); +- } catch (error) { +- this.error = error; +- } +- if (this.error) { +- throw this.error; +- } else { +- this._root = root2; +- return root2; +- } +- } +- get [Symbol.toStringTag]() { +- return "NoWorkResult"; +- } +-}; +-var noWorkResult = NoWorkResult$1; +-NoWorkResult$1.default = NoWorkResult$1; +-let NoWorkResult22 = noWorkResult; +-let LazyResult$1 = lazyResult; +-let Document$1 = document$1; +-let Root$2 = root; +-let Processor$1 = class Processor2 { +- constructor(plugins = []) { +- this.version = "8.4.38"; +- this.plugins = this.normalize(plugins); +- } +- normalize(plugins) { +- let normalized = []; +- for (let i2 of plugins) { +- if (i2.postcss === true) { +- i2 = i2(); +- } else if (i2.postcss) { +- i2 = i2.postcss; +- } +- if (typeof i2 === "object" && Array.isArray(i2.plugins)) { +- normalized = normalized.concat(i2.plugins); +- } else if (typeof i2 === "object" && i2.postcssPlugin) { +- normalized.push(i2); +- } else if (typeof i2 === "function") { +- normalized.push(i2); +- } else if (typeof i2 === "object" && (i2.parse || i2.stringify)) { +- if (process.env.NODE_ENV !== "production") { +- throw new Error( +- "PostCSS syntaxes cannot be used as plugins. Instead, please use one of the syntax/parser/stringifier options as outlined in your PostCSS runner documentation." +- ); +- } +- } else { +- throw new Error(i2 + " is not a PostCSS plugin"); +- } +- } +- return normalized; +- } +- process(css, opts = {}) { +- if (!this.plugins.length && !opts.parser && !opts.stringifier && !opts.syntax) { +- return new NoWorkResult22(this, css, opts); +- } else { +- return new LazyResult$1(this, css, opts); +- } +- } +- use(plugin22) { +- this.plugins = this.plugins.concat(this.normalize([plugin22])); +- return this; +- } +-}; +-var processor = Processor$1; +-Processor$1.default = Processor$1; +-Root$2.registerProcessor(Processor$1); +-Document$1.registerProcessor(Processor$1); +-let Declaration$1 = declaration; +-let PreviousMap22 = previousMap; +-let Comment$1 = comment; +-let AtRule$1 = atRule; +-let Input$1 = input; +-let Root$1 = root; +-let Rule$1 = rule; +-function fromJSON$1(json, inputs) { +- if (Array.isArray(json)) return json.map((n2) => fromJSON$1(n2)); +- let { inputs: ownInputs, ...defaults } = json; +- if (ownInputs) { +- inputs = []; +- for (let input2 of ownInputs) { +- let inputHydrated = { ...input2, __proto__: Input$1.prototype }; +- if (inputHydrated.map) { +- inputHydrated.map = { +- ...inputHydrated.map, +- __proto__: PreviousMap22.prototype +- }; +- } +- inputs.push(inputHydrated); +- } +- } +- if (defaults.nodes) { +- defaults.nodes = json.nodes.map((n2) => fromJSON$1(n2, inputs)); +- } +- if (defaults.source) { +- let { inputId, ...source } = defaults.source; +- defaults.source = source; +- if (inputId != null) { +- defaults.source.input = inputs[inputId]; +- } +- } +- if (defaults.type === "root") { +- return new Root$1(defaults); +- } else if (defaults.type === "decl") { +- return new Declaration$1(defaults); +- } else if (defaults.type === "rule") { +- return new Rule$1(defaults); +- } else if (defaults.type === "comment") { +- return new Comment$1(defaults); +- } else if (defaults.type === "atrule") { +- return new AtRule$1(defaults); +- } else { +- throw new Error("Unknown node type: " + json.type); +- } +-} +-var fromJSON_1 = fromJSON$1; +-fromJSON$1.default = fromJSON$1; +-let CssSyntaxError22 = cssSyntaxError; +-let Declaration22 = declaration; +-let LazyResult22 = lazyResult; +-let Container22 = container; +-let Processor22 = processor; +-let stringify = stringify_1; +-let fromJSON = fromJSON_1; +-let Document222 = document$1; +-let Warning22 = warning; +-let Comment22 = comment; +-let AtRule22 = atRule; +-let Result22 = result; +-let Input22 = input; +-let parse = parse_1; +-let list = list_1; +-let Rule22 = rule; +-let Root22 = root; +-let Node22 = node; +-function postcss(...plugins) { +- if (plugins.length === 1 && Array.isArray(plugins[0])) { +- plugins = plugins[0]; +- } +- return new Processor22(plugins); +-} +-postcss.plugin = function plugin2(name, initializer) { +- let warningPrinted = false; +- function creator(...args) { +- if (console && console.warn && !warningPrinted) { +- warningPrinted = true; +- console.warn( +- name + ": postcss.plugin was deprecated. Migration guide:\nhttps://evilmartians.com/chronicles/postcss-8-plugin-migration" +- ); +- if (process.env.LANG && process.env.LANG.startsWith("cn")) { +- console.warn( +- name + ": 里面 postcss.plugin 被弃用. 迁移指南:\nhttps://www.w3ctech.com/topic/2226" +- ); +- } +- } +- let transformer = initializer(...args); +- transformer.postcssPlugin = name; +- transformer.postcssVersion = new Processor22().version; +- return transformer; +- } +- let cache; +- Object.defineProperty(creator, "postcss", { +- get() { +- if (!cache) cache = creator(); +- return cache; +- } +- }); +- creator.process = function(css, processOpts, pluginOpts) { +- return postcss([creator(pluginOpts)]).process(css, processOpts); +- }; +- return creator; +-}; +-postcss.stringify = stringify; +-postcss.parse = parse; +-postcss.fromJSON = fromJSON; +-postcss.list = list; +-postcss.comment = (defaults) => new Comment22(defaults); +-postcss.atRule = (defaults) => new AtRule22(defaults); +-postcss.decl = (defaults) => new Declaration22(defaults); +-postcss.rule = (defaults) => new Rule22(defaults); +-postcss.root = (defaults) => new Root22(defaults); +-postcss.document = (defaults) => new Document222(defaults); +-postcss.CssSyntaxError = CssSyntaxError22; +-postcss.Declaration = Declaration22; +-postcss.Container = Container22; +-postcss.Processor = Processor22; +-postcss.Document = Document222; +-postcss.Comment = Comment22; +-postcss.Warning = Warning22; +-postcss.AtRule = AtRule22; +-postcss.Result = Result22; +-postcss.Input = Input22; +-postcss.Rule = Rule22; +-postcss.Root = Root22; +-postcss.Node = Node22; +-LazyResult22.registerPostcss(postcss); +-var postcss_1 = postcss; +-postcss.default = postcss; +-const postcss$1 = /* @__PURE__ */ getDefaultExportFromCjs(postcss_1); +-postcss$1.stringify; +-postcss$1.fromJSON; +-postcss$1.plugin; +-postcss$1.parse; +-postcss$1.list; +-postcss$1.document; +-postcss$1.comment; +-postcss$1.atRule; +-postcss$1.rule; +-postcss$1.decl; +-postcss$1.root; +-postcss$1.CssSyntaxError; +-postcss$1.Declaration; +-postcss$1.Container; +-postcss$1.Processor; +-postcss$1.Document; +-postcss$1.Comment; +-postcss$1.Warning; +-postcss$1.AtRule; +-postcss$1.Result; +-postcss$1.Input; +-postcss$1.Rule; +-postcss$1.Root; +-postcss$1.Node; + class BaseRRNode { + // eslint-disable-next-line @typescript-eslint/no-unused-vars, @typescript-eslint/no-explicit-any + constructor(..._args) { diff --git a/patches/rrweb-snapshot@2.0.0-alpha.17.patch b/patches/rrweb-snapshot@2.0.0-alpha.17.patch new file mode 100644 index 000000000..ac805f159 --- /dev/null +++ b/patches/rrweb-snapshot@2.0.0-alpha.17.patch @@ -0,0 +1,3533 @@ +diff --git a/dist/rrweb-snapshot.js b/dist/rrweb-snapshot.js +index c3a1e22f28b6d23821809dc4730b31acc39c87e9..9a8bed21e4920dc081d642fd68b4b2a2820e228a 100644 +--- a/dist/rrweb-snapshot.js ++++ b/dist/rrweb-snapshot.js +@@ -1423,3528 +1423,6 @@ function getAugmentedNamespace(n) { + }); + return a; + } +-var picocolors_browser = { exports: {} }; +-var x = String; +-var create = function() { +- return { isColorSupported: false, reset: x, bold: x, dim: x, italic: x, underline: x, inverse: x, hidden: x, strikethrough: x, black: x, red: x, green: x, yellow: x, blue: x, magenta: x, cyan: x, white: x, gray: x, bgBlack: x, bgRed: x, bgGreen: x, bgYellow: x, bgBlue: x, bgMagenta: x, bgCyan: x, bgWhite: x }; +-}; +-picocolors_browser.exports = create(); +-picocolors_browser.exports.createColors = create; +-var picocolors_browserExports = picocolors_browser.exports; +-const __viteBrowserExternal = {}; +-const __viteBrowserExternal$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({ +- __proto__: null, +- default: __viteBrowserExternal +-}, Symbol.toStringTag, { value: "Module" })); +-const require$$2 = /* @__PURE__ */ getAugmentedNamespace(__viteBrowserExternal$1); +-let pico = picocolors_browserExports; +-let terminalHighlight$1 = require$$2; +-let CssSyntaxError$3 = class CssSyntaxError extends Error { +- constructor(message, line, column, source, file, plugin2) { +- super(message); +- this.name = "CssSyntaxError"; +- this.reason = message; +- if (file) { +- this.file = file; +- } +- if (source) { +- this.source = source; +- } +- if (plugin2) { +- this.plugin = plugin2; +- } +- if (typeof line !== "undefined" && typeof column !== "undefined") { +- if (typeof line === "number") { +- this.line = line; +- this.column = column; +- } else { +- this.line = line.line; +- this.column = line.column; +- this.endLine = column.line; +- this.endColumn = column.column; +- } +- } +- this.setMessage(); +- if (Error.captureStackTrace) { +- Error.captureStackTrace(this, CssSyntaxError); +- } +- } +- setMessage() { +- this.message = this.plugin ? this.plugin + ": " : ""; +- this.message += this.file ? this.file : ""; +- if (typeof this.line !== "undefined") { +- this.message += ":" + this.line + ":" + this.column; +- } +- this.message += ": " + this.reason; +- } +- showSourceCode(color) { +- if (!this.source) return ""; +- let css = this.source; +- if (color == null) color = pico.isColorSupported; +- if (terminalHighlight$1) { +- if (color) css = terminalHighlight$1(css); +- } +- let lines = css.split(/\r?\n/); +- let start = Math.max(this.line - 3, 0); +- let end = Math.min(this.line + 2, lines.length); +- let maxWidth = String(end).length; +- let mark, aside; +- if (color) { +- let { bold, gray, red } = pico.createColors(true); +- mark = (text) => bold(red(text)); +- aside = (text) => gray(text); +- } else { +- mark = aside = (str) => str; +- } +- return lines.slice(start, end).map((line, index2) => { +- let number = start + 1 + index2; +- let gutter = " " + (" " + number).slice(-maxWidth) + " | "; +- if (number === this.line) { +- let spacing = aside(gutter.replace(/\d/g, " ")) + line.slice(0, this.column - 1).replace(/[^\t]/g, " "); +- return mark(">") + aside(gutter) + line + "\n " + spacing + mark("^"); +- } +- return " " + aside(gutter) + line; +- }).join("\n"); +- } +- toString() { +- let code = this.showSourceCode(); +- if (code) { +- code = "\n\n" + code + "\n"; +- } +- return this.name + ": " + this.message + code; +- } +-}; +-var cssSyntaxError = CssSyntaxError$3; +-CssSyntaxError$3.default = CssSyntaxError$3; +-var symbols = {}; +-symbols.isClean = Symbol("isClean"); +-symbols.my = Symbol("my"); +-const DEFAULT_RAW = { +- after: "\n", +- beforeClose: "\n", +- beforeComment: "\n", +- beforeDecl: "\n", +- beforeOpen: " ", +- beforeRule: "\n", +- colon: ": ", +- commentLeft: " ", +- commentRight: " ", +- emptyBody: "", +- indent: " ", +- semicolon: false +-}; +-function capitalize(str) { +- return str[0].toUpperCase() + str.slice(1); +-} +-let Stringifier$2 = class Stringifier { +- constructor(builder) { +- this.builder = builder; +- } +- atrule(node2, semicolon) { +- let name = "@" + node2.name; +- let params = node2.params ? this.rawValue(node2, "params") : ""; +- if (typeof node2.raws.afterName !== "undefined") { +- name += node2.raws.afterName; +- } else if (params) { +- name += " "; +- } +- if (node2.nodes) { +- this.block(node2, name + params); +- } else { +- let end = (node2.raws.between || "") + (semicolon ? ";" : ""); +- this.builder(name + params + end, node2); +- } +- } +- beforeAfter(node2, detect) { +- let value; +- if (node2.type === "decl") { +- value = this.raw(node2, null, "beforeDecl"); +- } else if (node2.type === "comment") { +- value = this.raw(node2, null, "beforeComment"); +- } else if (detect === "before") { +- value = this.raw(node2, null, "beforeRule"); +- } else { +- value = this.raw(node2, null, "beforeClose"); +- } +- let buf = node2.parent; +- let depth = 0; +- while (buf && buf.type !== "root") { +- depth += 1; +- buf = buf.parent; +- } +- if (value.includes("\n")) { +- let indent = this.raw(node2, null, "indent"); +- if (indent.length) { +- for (let step = 0; step < depth; step++) value += indent; +- } +- } +- return value; +- } +- block(node2, start) { +- let between = this.raw(node2, "between", "beforeOpen"); +- this.builder(start + between + "{", node2, "start"); +- let after; +- if (node2.nodes && node2.nodes.length) { +- this.body(node2); +- after = this.raw(node2, "after"); +- } else { +- after = this.raw(node2, "after", "emptyBody"); +- } +- if (after) this.builder(after); +- this.builder("}", node2, "end"); +- } +- body(node2) { +- let last = node2.nodes.length - 1; +- while (last > 0) { +- if (node2.nodes[last].type !== "comment") break; +- last -= 1; +- } +- let semicolon = this.raw(node2, "semicolon"); +- for (let i = 0; i < node2.nodes.length; i++) { +- let child = node2.nodes[i]; +- let before = this.raw(child, "before"); +- if (before) this.builder(before); +- this.stringify(child, last !== i || semicolon); +- } +- } +- comment(node2) { +- let left = this.raw(node2, "left", "commentLeft"); +- let right = this.raw(node2, "right", "commentRight"); +- this.builder("/*" + left + node2.text + right + "*/", node2); +- } +- decl(node2, semicolon) { +- let between = this.raw(node2, "between", "colon"); +- let string = node2.prop + between + this.rawValue(node2, "value"); +- if (node2.important) { +- string += node2.raws.important || " !important"; +- } +- if (semicolon) string += ";"; +- this.builder(string, node2); +- } +- document(node2) { +- this.body(node2); +- } +- raw(node2, own, detect) { +- let value; +- if (!detect) detect = own; +- if (own) { +- value = node2.raws[own]; +- if (typeof value !== "undefined") return value; +- } +- let parent = node2.parent; +- if (detect === "before") { +- if (!parent || parent.type === "root" && parent.first === node2) { +- return ""; +- } +- if (parent && parent.type === "document") { +- return ""; +- } +- } +- if (!parent) return DEFAULT_RAW[detect]; +- let root2 = node2.root(); +- if (!root2.rawCache) root2.rawCache = {}; +- if (typeof root2.rawCache[detect] !== "undefined") { +- return root2.rawCache[detect]; +- } +- if (detect === "before" || detect === "after") { +- return this.beforeAfter(node2, detect); +- } else { +- let method = "raw" + capitalize(detect); +- if (this[method]) { +- value = this[method](root2, node2); +- } else { +- root2.walk((i) => { +- value = i.raws[own]; +- if (typeof value !== "undefined") return false; +- }); +- } +- } +- if (typeof value === "undefined") value = DEFAULT_RAW[detect]; +- root2.rawCache[detect] = value; +- return value; +- } +- rawBeforeClose(root2) { +- let value; +- root2.walk((i) => { +- if (i.nodes && i.nodes.length > 0) { +- if (typeof i.raws.after !== "undefined") { +- value = i.raws.after; +- if (value.includes("\n")) { +- value = value.replace(/[^\n]+$/, ""); +- } +- return false; +- } +- } +- }); +- if (value) value = value.replace(/\S/g, ""); +- return value; +- } +- rawBeforeComment(root2, node2) { +- let value; +- root2.walkComments((i) => { +- if (typeof i.raws.before !== "undefined") { +- value = i.raws.before; +- if (value.includes("\n")) { +- value = value.replace(/[^\n]+$/, ""); +- } +- return false; +- } +- }); +- if (typeof value === "undefined") { +- value = this.raw(node2, null, "beforeDecl"); +- } else if (value) { +- value = value.replace(/\S/g, ""); +- } +- return value; +- } +- rawBeforeDecl(root2, node2) { +- let value; +- root2.walkDecls((i) => { +- if (typeof i.raws.before !== "undefined") { +- value = i.raws.before; +- if (value.includes("\n")) { +- value = value.replace(/[^\n]+$/, ""); +- } +- return false; +- } +- }); +- if (typeof value === "undefined") { +- value = this.raw(node2, null, "beforeRule"); +- } else if (value) { +- value = value.replace(/\S/g, ""); +- } +- return value; +- } +- rawBeforeOpen(root2) { +- let value; +- root2.walk((i) => { +- if (i.type !== "decl") { +- value = i.raws.between; +- if (typeof value !== "undefined") return false; +- } +- }); +- return value; +- } +- rawBeforeRule(root2) { +- let value; +- root2.walk((i) => { +- if (i.nodes && (i.parent !== root2 || root2.first !== i)) { +- if (typeof i.raws.before !== "undefined") { +- value = i.raws.before; +- if (value.includes("\n")) { +- value = value.replace(/[^\n]+$/, ""); +- } +- return false; +- } +- } +- }); +- if (value) value = value.replace(/\S/g, ""); +- return value; +- } +- rawColon(root2) { +- let value; +- root2.walkDecls((i) => { +- if (typeof i.raws.between !== "undefined") { +- value = i.raws.between.replace(/[^\s:]/g, ""); +- return false; +- } +- }); +- return value; +- } +- rawEmptyBody(root2) { +- let value; +- root2.walk((i) => { +- if (i.nodes && i.nodes.length === 0) { +- value = i.raws.after; +- if (typeof value !== "undefined") return false; +- } +- }); +- return value; +- } +- rawIndent(root2) { +- if (root2.raws.indent) return root2.raws.indent; +- let value; +- root2.walk((i) => { +- let p = i.parent; +- if (p && p !== root2 && p.parent && p.parent === root2) { +- if (typeof i.raws.before !== "undefined") { +- let parts = i.raws.before.split("\n"); +- value = parts[parts.length - 1]; +- value = value.replace(/\S/g, ""); +- return false; +- } +- } +- }); +- return value; +- } +- rawSemicolon(root2) { +- let value; +- root2.walk((i) => { +- if (i.nodes && i.nodes.length && i.last.type === "decl") { +- value = i.raws.semicolon; +- if (typeof value !== "undefined") return false; +- } +- }); +- return value; +- } +- rawValue(node2, prop) { +- let value = node2[prop]; +- let raw = node2.raws[prop]; +- if (raw && raw.value === value) { +- return raw.raw; +- } +- return value; +- } +- root(node2) { +- this.body(node2); +- if (node2.raws.after) this.builder(node2.raws.after); +- } +- rule(node2) { +- this.block(node2, this.rawValue(node2, "selector")); +- if (node2.raws.ownSemicolon) { +- this.builder(node2.raws.ownSemicolon, node2, "end"); +- } +- } +- stringify(node2, semicolon) { +- if (!this[node2.type]) { +- throw new Error( +- "Unknown AST node type " + node2.type + ". Maybe you need to change PostCSS stringifier." +- ); +- } +- this[node2.type](node2, semicolon); +- } +-}; +-var stringifier = Stringifier$2; +-Stringifier$2.default = Stringifier$2; +-let Stringifier$1 = stringifier; +-function stringify$4(node2, builder) { +- let str = new Stringifier$1(builder); +- str.stringify(node2); +-} +-var stringify_1 = stringify$4; +-stringify$4.default = stringify$4; +-let { isClean: isClean$2, my: my$2 } = symbols; +-let CssSyntaxError$2 = cssSyntaxError; +-let Stringifier2 = stringifier; +-let stringify$3 = stringify_1; +-function cloneNode(obj, parent) { +- let cloned = new obj.constructor(); +- for (let i in obj) { +- if (!Object.prototype.hasOwnProperty.call(obj, i)) { +- continue; +- } +- if (i === "proxyCache") continue; +- let value = obj[i]; +- let type = typeof value; +- if (i === "parent" && type === "object") { +- if (parent) cloned[i] = parent; +- } else if (i === "source") { +- cloned[i] = value; +- } else if (Array.isArray(value)) { +- cloned[i] = value.map((j) => cloneNode(j, cloned)); +- } else { +- if (type === "object" && value !== null) value = cloneNode(value); +- cloned[i] = value; +- } +- } +- return cloned; +-} +-let Node$4 = class Node { +- constructor(defaults = {}) { +- this.raws = {}; +- this[isClean$2] = false; +- this[my$2] = true; +- for (let name in defaults) { +- if (name === "nodes") { +- this.nodes = []; +- for (let node2 of defaults[name]) { +- if (typeof node2.clone === "function") { +- this.append(node2.clone()); +- } else { +- this.append(node2); +- } +- } +- } else { +- this[name] = defaults[name]; +- } +- } +- } +- addToError(error) { +- error.postcssNode = this; +- if (error.stack && this.source && /\n\s{4}at /.test(error.stack)) { +- let s = this.source; +- error.stack = error.stack.replace( +- /\n\s{4}at /, +- `$&${s.input.from}:${s.start.line}:${s.start.column}$&` +- ); +- } +- return error; +- } +- after(add) { +- this.parent.insertAfter(this, add); +- return this; +- } +- assign(overrides = {}) { +- for (let name in overrides) { +- this[name] = overrides[name]; +- } +- return this; +- } +- before(add) { +- this.parent.insertBefore(this, add); +- return this; +- } +- cleanRaws(keepBetween) { +- delete this.raws.before; +- delete this.raws.after; +- if (!keepBetween) delete this.raws.between; +- } +- clone(overrides = {}) { +- let cloned = cloneNode(this); +- for (let name in overrides) { +- cloned[name] = overrides[name]; +- } +- return cloned; +- } +- cloneAfter(overrides = {}) { +- let cloned = this.clone(overrides); +- this.parent.insertAfter(this, cloned); +- return cloned; +- } +- cloneBefore(overrides = {}) { +- let cloned = this.clone(overrides); +- this.parent.insertBefore(this, cloned); +- return cloned; +- } +- error(message, opts = {}) { +- if (this.source) { +- let { end, start } = this.rangeBy(opts); +- return this.source.input.error( +- message, +- { column: start.column, line: start.line }, +- { column: end.column, line: end.line }, +- opts +- ); +- } +- return new CssSyntaxError$2(message); +- } +- getProxyProcessor() { +- return { +- get(node2, prop) { +- if (prop === "proxyOf") { +- return node2; +- } else if (prop === "root") { +- return () => node2.root().toProxy(); +- } else { +- return node2[prop]; +- } +- }, +- set(node2, prop, value) { +- if (node2[prop] === value) return true; +- node2[prop] = value; +- if (prop === "prop" || prop === "value" || prop === "name" || prop === "params" || prop === "important" || /* c8 ignore next */ +- prop === "text") { +- node2.markDirty(); +- } +- return true; +- } +- }; +- } +- markDirty() { +- if (this[isClean$2]) { +- this[isClean$2] = false; +- let next = this; +- while (next = next.parent) { +- next[isClean$2] = false; +- } +- } +- } +- next() { +- if (!this.parent) return void 0; +- let index2 = this.parent.index(this); +- return this.parent.nodes[index2 + 1]; +- } +- positionBy(opts, stringRepresentation) { +- let pos = this.source.start; +- if (opts.index) { +- pos = this.positionInside(opts.index, stringRepresentation); +- } else if (opts.word) { +- stringRepresentation = this.toString(); +- let index2 = stringRepresentation.indexOf(opts.word); +- if (index2 !== -1) pos = this.positionInside(index2, stringRepresentation); +- } +- return pos; +- } +- positionInside(index2, stringRepresentation) { +- let string = stringRepresentation || this.toString(); +- let column = this.source.start.column; +- let line = this.source.start.line; +- for (let i = 0; i < index2; i++) { +- if (string[i] === "\n") { +- column = 1; +- line += 1; +- } else { +- column += 1; +- } +- } +- return { column, line }; +- } +- prev() { +- if (!this.parent) return void 0; +- let index2 = this.parent.index(this); +- return this.parent.nodes[index2 - 1]; +- } +- rangeBy(opts) { +- let start = { +- column: this.source.start.column, +- line: this.source.start.line +- }; +- let end = this.source.end ? { +- column: this.source.end.column + 1, +- line: this.source.end.line +- } : { +- column: start.column + 1, +- line: start.line +- }; +- if (opts.word) { +- let stringRepresentation = this.toString(); +- let index2 = stringRepresentation.indexOf(opts.word); +- if (index2 !== -1) { +- start = this.positionInside(index2, stringRepresentation); +- end = this.positionInside(index2 + opts.word.length, stringRepresentation); +- } +- } else { +- if (opts.start) { +- start = { +- column: opts.start.column, +- line: opts.start.line +- }; +- } else if (opts.index) { +- start = this.positionInside(opts.index); +- } +- if (opts.end) { +- end = { +- column: opts.end.column, +- line: opts.end.line +- }; +- } else if (typeof opts.endIndex === "number") { +- end = this.positionInside(opts.endIndex); +- } else if (opts.index) { +- end = this.positionInside(opts.index + 1); +- } +- } +- if (end.line < start.line || end.line === start.line && end.column <= start.column) { +- end = { column: start.column + 1, line: start.line }; +- } +- return { end, start }; +- } +- raw(prop, defaultType) { +- let str = new Stringifier2(); +- return str.raw(this, prop, defaultType); +- } +- remove() { +- if (this.parent) { +- this.parent.removeChild(this); +- } +- this.parent = void 0; +- return this; +- } +- replaceWith(...nodes) { +- if (this.parent) { +- let bookmark = this; +- let foundSelf = false; +- for (let node2 of nodes) { +- if (node2 === this) { +- foundSelf = true; +- } else if (foundSelf) { +- this.parent.insertAfter(bookmark, node2); +- bookmark = node2; +- } else { +- this.parent.insertBefore(bookmark, node2); +- } +- } +- if (!foundSelf) { +- this.remove(); +- } +- } +- return this; +- } +- root() { +- let result2 = this; +- while (result2.parent && result2.parent.type !== "document") { +- result2 = result2.parent; +- } +- return result2; +- } +- toJSON(_, inputs) { +- let fixed = {}; +- let emitInputs = inputs == null; +- inputs = inputs || /* @__PURE__ */ new Map(); +- let inputsNextIndex = 0; +- for (let name in this) { +- if (!Object.prototype.hasOwnProperty.call(this, name)) { +- continue; +- } +- if (name === "parent" || name === "proxyCache") continue; +- let value = this[name]; +- if (Array.isArray(value)) { +- fixed[name] = value.map((i) => { +- if (typeof i === "object" && i.toJSON) { +- return i.toJSON(null, inputs); +- } else { +- return i; +- } +- }); +- } else if (typeof value === "object" && value.toJSON) { +- fixed[name] = value.toJSON(null, inputs); +- } else if (name === "source") { +- let inputId = inputs.get(value.input); +- if (inputId == null) { +- inputId = inputsNextIndex; +- inputs.set(value.input, inputsNextIndex); +- inputsNextIndex++; +- } +- fixed[name] = { +- end: value.end, +- inputId, +- start: value.start +- }; +- } else { +- fixed[name] = value; +- } +- } +- if (emitInputs) { +- fixed.inputs = [...inputs.keys()].map((input2) => input2.toJSON()); +- } +- return fixed; +- } +- toProxy() { +- if (!this.proxyCache) { +- this.proxyCache = new Proxy(this, this.getProxyProcessor()); +- } +- return this.proxyCache; +- } +- toString(stringifier2 = stringify$3) { +- if (stringifier2.stringify) stringifier2 = stringifier2.stringify; +- let result2 = ""; +- stringifier2(this, (i) => { +- result2 += i; +- }); +- return result2; +- } +- warn(result2, text, opts) { +- let data = { node: this }; +- for (let i in opts) data[i] = opts[i]; +- return result2.warn(text, data); +- } +- get proxyOf() { +- return this; +- } +-}; +-var node = Node$4; +-Node$4.default = Node$4; +-let Node$3 = node; +-let Declaration$4 = class Declaration extends Node$3 { +- constructor(defaults) { +- if (defaults && typeof defaults.value !== "undefined" && typeof defaults.value !== "string") { +- defaults = { ...defaults, value: String(defaults.value) }; +- } +- super(defaults); +- this.type = "decl"; +- } +- get variable() { +- return this.prop.startsWith("--") || this.prop[0] === "$"; +- } +-}; +-var declaration = Declaration$4; +-Declaration$4.default = Declaration$4; +-let urlAlphabet = "useandom-26T198340PX75pxJACKVERYMINDBUSHWOLF_GQZbfghjklqvwyzrict"; +-let customAlphabet = (alphabet, defaultSize = 21) => { +- return (size = defaultSize) => { +- let id = ""; +- let i = size; +- while (i--) { +- id += alphabet[Math.random() * alphabet.length | 0]; +- } +- return id; +- }; +-}; +-let nanoid$1 = (size = 21) => { +- let id = ""; +- let i = size; +- while (i--) { +- id += urlAlphabet[Math.random() * 64 | 0]; +- } +- return id; +-}; +-var nonSecure = { nanoid: nanoid$1, customAlphabet }; +-let { SourceMapConsumer: SourceMapConsumer$2, SourceMapGenerator: SourceMapGenerator$2 } = require$$2; +-let { existsSync, readFileSync } = require$$2; +-let { dirname: dirname$1, join } = require$$2; +-function fromBase64(str) { +- if (Buffer) { +- return Buffer.from(str, "base64").toString(); +- } else { +- return window.atob(str); +- } +-} +-let PreviousMap$2 = class PreviousMap { +- constructor(css, opts) { +- if (opts.map === false) return; +- this.loadAnnotation(css); +- this.inline = this.startWith(this.annotation, "data:"); +- let prev = opts.map ? opts.map.prev : void 0; +- let text = this.loadMap(opts.from, prev); +- if (!this.mapFile && opts.from) { +- this.mapFile = opts.from; +- } +- if (this.mapFile) this.root = dirname$1(this.mapFile); +- if (text) this.text = text; +- } +- consumer() { +- if (!this.consumerCache) { +- this.consumerCache = new SourceMapConsumer$2(this.text); +- } +- return this.consumerCache; +- } +- decodeInline(text) { +- let baseCharsetUri = /^data:application\/json;charset=utf-?8;base64,/; +- let baseUri = /^data:application\/json;base64,/; +- let charsetUri = /^data:application\/json;charset=utf-?8,/; +- let uri = /^data:application\/json,/; +- if (charsetUri.test(text) || uri.test(text)) { +- return decodeURIComponent(text.substr(RegExp.lastMatch.length)); +- } +- if (baseCharsetUri.test(text) || baseUri.test(text)) { +- return fromBase64(text.substr(RegExp.lastMatch.length)); +- } +- let encoding = text.match(/data:application\/json;([^,]+),/)[1]; +- throw new Error("Unsupported source map encoding " + encoding); +- } +- getAnnotationURL(sourceMapString) { +- return sourceMapString.replace(/^\/\*\s*# sourceMappingURL=/, "").trim(); +- } +- isMap(map) { +- if (typeof map !== "object") return false; +- return typeof map.mappings === "string" || typeof map._mappings === "string" || Array.isArray(map.sections); +- } +- loadAnnotation(css) { +- let comments = css.match(/\/\*\s*# sourceMappingURL=/gm); +- if (!comments) return; +- let start = css.lastIndexOf(comments.pop()); +- let end = css.indexOf("*/", start); +- if (start > -1 && end > -1) { +- this.annotation = this.getAnnotationURL(css.substring(start, end)); +- } +- } +- loadFile(path) { +- this.root = dirname$1(path); +- if (existsSync(path)) { +- this.mapFile = path; +- return readFileSync(path, "utf-8").toString().trim(); +- } +- } +- loadMap(file, prev) { +- if (prev === false) return false; +- if (prev) { +- if (typeof prev === "string") { +- return prev; +- } else if (typeof prev === "function") { +- let prevPath = prev(file); +- if (prevPath) { +- let map = this.loadFile(prevPath); +- if (!map) { +- throw new Error( +- "Unable to load previous source map: " + prevPath.toString() +- ); +- } +- return map; +- } +- } else if (prev instanceof SourceMapConsumer$2) { +- return SourceMapGenerator$2.fromSourceMap(prev).toString(); +- } else if (prev instanceof SourceMapGenerator$2) { +- return prev.toString(); +- } else if (this.isMap(prev)) { +- return JSON.stringify(prev); +- } else { +- throw new Error( +- "Unsupported previous source map format: " + prev.toString() +- ); +- } +- } else if (this.inline) { +- return this.decodeInline(this.annotation); +- } else if (this.annotation) { +- let map = this.annotation; +- if (file) map = join(dirname$1(file), map); +- return this.loadFile(map); +- } +- } +- startWith(string, start) { +- if (!string) return false; +- return string.substr(0, start.length) === start; +- } +- withContent() { +- return !!(this.consumer().sourcesContent && this.consumer().sourcesContent.length > 0); +- } +-}; +-var previousMap = PreviousMap$2; +-PreviousMap$2.default = PreviousMap$2; +-let { SourceMapConsumer: SourceMapConsumer$1, SourceMapGenerator: SourceMapGenerator$1 } = require$$2; +-let { fileURLToPath, pathToFileURL: pathToFileURL$1 } = require$$2; +-let { isAbsolute, resolve: resolve$1 } = require$$2; +-let { nanoid } = nonSecure; +-let terminalHighlight = require$$2; +-let CssSyntaxError$1 = cssSyntaxError; +-let PreviousMap$1 = previousMap; +-let fromOffsetCache = Symbol("fromOffsetCache"); +-let sourceMapAvailable$1 = Boolean(SourceMapConsumer$1 && SourceMapGenerator$1); +-let pathAvailable$1 = Boolean(resolve$1 && isAbsolute); +-let Input$4 = class Input { +- constructor(css, opts = {}) { +- if (css === null || typeof css === "undefined" || typeof css === "object" && !css.toString) { +- throw new Error(`PostCSS received ${css} instead of CSS string`); +- } +- this.css = css.toString(); +- if (this.css[0] === "\uFEFF" || this.css[0] === "￾") { +- this.hasBOM = true; +- this.css = this.css.slice(1); +- } else { +- this.hasBOM = false; +- } +- if (opts.from) { +- if (!pathAvailable$1 || /^\w+:\/\//.test(opts.from) || isAbsolute(opts.from)) { +- this.file = opts.from; +- } else { +- this.file = resolve$1(opts.from); +- } +- } +- if (pathAvailable$1 && sourceMapAvailable$1) { +- let map = new PreviousMap$1(this.css, opts); +- if (map.text) { +- this.map = map; +- let file = map.consumer().file; +- if (!this.file && file) this.file = this.mapResolve(file); +- } +- } +- if (!this.file) { +- this.id = ""; +- } +- if (this.map) this.map.file = this.from; +- } +- error(message, line, column, opts = {}) { +- let result2, endLine, endColumn; +- if (line && typeof line === "object") { +- let start = line; +- let end = column; +- if (typeof start.offset === "number") { +- let pos = this.fromOffset(start.offset); +- line = pos.line; +- column = pos.col; +- } else { +- line = start.line; +- column = start.column; +- } +- if (typeof end.offset === "number") { +- let pos = this.fromOffset(end.offset); +- endLine = pos.line; +- endColumn = pos.col; +- } else { +- endLine = end.line; +- endColumn = end.column; +- } +- } else if (!column) { +- let pos = this.fromOffset(line); +- line = pos.line; +- column = pos.col; +- } +- let origin = this.origin(line, column, endLine, endColumn); +- if (origin) { +- result2 = new CssSyntaxError$1( +- message, +- origin.endLine === void 0 ? origin.line : { column: origin.column, line: origin.line }, +- origin.endLine === void 0 ? origin.column : { column: origin.endColumn, line: origin.endLine }, +- origin.source, +- origin.file, +- opts.plugin +- ); +- } else { +- result2 = new CssSyntaxError$1( +- message, +- endLine === void 0 ? line : { column, line }, +- endLine === void 0 ? column : { column: endColumn, line: endLine }, +- this.css, +- this.file, +- opts.plugin +- ); +- } +- result2.input = { column, endColumn, endLine, line, source: this.css }; +- if (this.file) { +- if (pathToFileURL$1) { +- result2.input.url = pathToFileURL$1(this.file).toString(); +- } +- result2.input.file = this.file; +- } +- return result2; +- } +- fromOffset(offset) { +- let lastLine, lineToIndex; +- if (!this[fromOffsetCache]) { +- let lines = this.css.split("\n"); +- lineToIndex = new Array(lines.length); +- let prevIndex = 0; +- for (let i = 0, l = lines.length; i < l; i++) { +- lineToIndex[i] = prevIndex; +- prevIndex += lines[i].length + 1; +- } +- this[fromOffsetCache] = lineToIndex; +- } else { +- lineToIndex = this[fromOffsetCache]; +- } +- lastLine = lineToIndex[lineToIndex.length - 1]; +- let min = 0; +- if (offset >= lastLine) { +- min = lineToIndex.length - 1; +- } else { +- let max = lineToIndex.length - 2; +- let mid; +- while (min < max) { +- mid = min + (max - min >> 1); +- if (offset < lineToIndex[mid]) { +- max = mid - 1; +- } else if (offset >= lineToIndex[mid + 1]) { +- min = mid + 1; +- } else { +- min = mid; +- break; +- } +- } +- } +- return { +- col: offset - lineToIndex[min] + 1, +- line: min + 1 +- }; +- } +- mapResolve(file) { +- if (/^\w+:\/\//.test(file)) { +- return file; +- } +- return resolve$1(this.map.consumer().sourceRoot || this.map.root || ".", file); +- } +- origin(line, column, endLine, endColumn) { +- if (!this.map) return false; +- let consumer = this.map.consumer(); +- let from = consumer.originalPositionFor({ column, line }); +- if (!from.source) return false; +- let to; +- if (typeof endLine === "number") { +- to = consumer.originalPositionFor({ column: endColumn, line: endLine }); +- } +- let fromUrl; +- if (isAbsolute(from.source)) { +- fromUrl = pathToFileURL$1(from.source); +- } else { +- fromUrl = new URL( +- from.source, +- this.map.consumer().sourceRoot || pathToFileURL$1(this.map.mapFile) +- ); +- } +- let result2 = { +- column: from.column, +- endColumn: to && to.column, +- endLine: to && to.line, +- line: from.line, +- url: fromUrl.toString() +- }; +- if (fromUrl.protocol === "file:") { +- if (fileURLToPath) { +- result2.file = fileURLToPath(fromUrl); +- } else { +- throw new Error(`file: protocol is not available in this PostCSS build`); +- } +- } +- let source = consumer.sourceContentFor(from.source); +- if (source) result2.source = source; +- return result2; +- } +- toJSON() { +- let json = {}; +- for (let name of ["hasBOM", "css", "file", "id"]) { +- if (this[name] != null) { +- json[name] = this[name]; +- } +- } +- if (this.map) { +- json.map = { ...this.map }; +- if (json.map.consumerCache) { +- json.map.consumerCache = void 0; +- } +- } +- return json; +- } +- get from() { +- return this.file || this.id; +- } +-}; +-var input = Input$4; +-Input$4.default = Input$4; +-if (terminalHighlight && terminalHighlight.registerInput) { +- terminalHighlight.registerInput(Input$4); +-} +-let { SourceMapConsumer, SourceMapGenerator } = require$$2; +-let { dirname, relative, resolve, sep } = require$$2; +-let { pathToFileURL } = require$$2; +-let Input$3 = input; +-let sourceMapAvailable = Boolean(SourceMapConsumer && SourceMapGenerator); +-let pathAvailable = Boolean(dirname && resolve && relative && sep); +-let MapGenerator$2 = class MapGenerator { +- constructor(stringify2, root2, opts, cssString) { +- this.stringify = stringify2; +- this.mapOpts = opts.map || {}; +- this.root = root2; +- this.opts = opts; +- this.css = cssString; +- this.originalCSS = cssString; +- this.usesFileUrls = !this.mapOpts.from && this.mapOpts.absolute; +- this.memoizedFileURLs = /* @__PURE__ */ new Map(); +- this.memoizedPaths = /* @__PURE__ */ new Map(); +- this.memoizedURLs = /* @__PURE__ */ new Map(); +- } +- addAnnotation() { +- let content; +- if (this.isInline()) { +- content = "data:application/json;base64," + this.toBase64(this.map.toString()); +- } else if (typeof this.mapOpts.annotation === "string") { +- content = this.mapOpts.annotation; +- } else if (typeof this.mapOpts.annotation === "function") { +- content = this.mapOpts.annotation(this.opts.to, this.root); +- } else { +- content = this.outputFile() + ".map"; +- } +- let eol = "\n"; +- if (this.css.includes("\r\n")) eol = "\r\n"; +- this.css += eol + "/*# sourceMappingURL=" + content + " */"; +- } +- applyPrevMaps() { +- for (let prev of this.previous()) { +- let from = this.toUrl(this.path(prev.file)); +- let root2 = prev.root || dirname(prev.file); +- let map; +- if (this.mapOpts.sourcesContent === false) { +- map = new SourceMapConsumer(prev.text); +- if (map.sourcesContent) { +- map.sourcesContent = null; +- } +- } else { +- map = prev.consumer(); +- } +- this.map.applySourceMap(map, from, this.toUrl(this.path(root2))); +- } +- } +- clearAnnotation() { +- if (this.mapOpts.annotation === false) return; +- if (this.root) { +- let node2; +- for (let i = this.root.nodes.length - 1; i >= 0; i--) { +- node2 = this.root.nodes[i]; +- if (node2.type !== "comment") continue; +- if (node2.text.indexOf("# sourceMappingURL=") === 0) { +- this.root.removeChild(i); +- } +- } +- } else if (this.css) { +- this.css = this.css.replace(/\n*?\/\*#[\S\s]*?\*\/$/gm, ""); +- } +- } +- generate() { +- this.clearAnnotation(); +- if (pathAvailable && sourceMapAvailable && this.isMap()) { +- return this.generateMap(); +- } else { +- let result2 = ""; +- this.stringify(this.root, (i) => { +- result2 += i; +- }); +- return [result2]; +- } +- } +- generateMap() { +- if (this.root) { +- this.generateString(); +- } else if (this.previous().length === 1) { +- let prev = this.previous()[0].consumer(); +- prev.file = this.outputFile(); +- this.map = SourceMapGenerator.fromSourceMap(prev, { +- ignoreInvalidMapping: true +- }); +- } else { +- this.map = new SourceMapGenerator({ +- file: this.outputFile(), +- ignoreInvalidMapping: true +- }); +- this.map.addMapping({ +- generated: { column: 0, line: 1 }, +- original: { column: 0, line: 1 }, +- source: this.opts.from ? this.toUrl(this.path(this.opts.from)) : "" +- }); +- } +- if (this.isSourcesContent()) this.setSourcesContent(); +- if (this.root && this.previous().length > 0) this.applyPrevMaps(); +- if (this.isAnnotation()) this.addAnnotation(); +- if (this.isInline()) { +- return [this.css]; +- } else { +- return [this.css, this.map]; +- } +- } +- generateString() { +- this.css = ""; +- this.map = new SourceMapGenerator({ +- file: this.outputFile(), +- ignoreInvalidMapping: true +- }); +- let line = 1; +- let column = 1; +- let noSource = ""; +- let mapping = { +- generated: { column: 0, line: 0 }, +- original: { column: 0, line: 0 }, +- source: "" +- }; +- let lines, last; +- this.stringify(this.root, (str, node2, type) => { +- this.css += str; +- if (node2 && type !== "end") { +- mapping.generated.line = line; +- mapping.generated.column = column - 1; +- if (node2.source && node2.source.start) { +- mapping.source = this.sourcePath(node2); +- mapping.original.line = node2.source.start.line; +- mapping.original.column = node2.source.start.column - 1; +- this.map.addMapping(mapping); +- } else { +- mapping.source = noSource; +- mapping.original.line = 1; +- mapping.original.column = 0; +- this.map.addMapping(mapping); +- } +- } +- lines = str.match(/\n/g); +- if (lines) { +- line += lines.length; +- last = str.lastIndexOf("\n"); +- column = str.length - last; +- } else { +- column += str.length; +- } +- if (node2 && type !== "start") { +- let p = node2.parent || { raws: {} }; +- let childless = node2.type === "decl" || node2.type === "atrule" && !node2.nodes; +- if (!childless || node2 !== p.last || p.raws.semicolon) { +- if (node2.source && node2.source.end) { +- mapping.source = this.sourcePath(node2); +- mapping.original.line = node2.source.end.line; +- mapping.original.column = node2.source.end.column - 1; +- mapping.generated.line = line; +- mapping.generated.column = column - 2; +- this.map.addMapping(mapping); +- } else { +- mapping.source = noSource; +- mapping.original.line = 1; +- mapping.original.column = 0; +- mapping.generated.line = line; +- mapping.generated.column = column - 1; +- this.map.addMapping(mapping); +- } +- } +- } +- }); +- } +- isAnnotation() { +- if (this.isInline()) { +- return true; +- } +- if (typeof this.mapOpts.annotation !== "undefined") { +- return this.mapOpts.annotation; +- } +- if (this.previous().length) { +- return this.previous().some((i) => i.annotation); +- } +- return true; +- } +- isInline() { +- if (typeof this.mapOpts.inline !== "undefined") { +- return this.mapOpts.inline; +- } +- let annotation = this.mapOpts.annotation; +- if (typeof annotation !== "undefined" && annotation !== true) { +- return false; +- } +- if (this.previous().length) { +- return this.previous().some((i) => i.inline); +- } +- return true; +- } +- isMap() { +- if (typeof this.opts.map !== "undefined") { +- return !!this.opts.map; +- } +- return this.previous().length > 0; +- } +- isSourcesContent() { +- if (typeof this.mapOpts.sourcesContent !== "undefined") { +- return this.mapOpts.sourcesContent; +- } +- if (this.previous().length) { +- return this.previous().some((i) => i.withContent()); +- } +- return true; +- } +- outputFile() { +- if (this.opts.to) { +- return this.path(this.opts.to); +- } else if (this.opts.from) { +- return this.path(this.opts.from); +- } else { +- return "to.css"; +- } +- } +- path(file) { +- if (this.mapOpts.absolute) return file; +- if (file.charCodeAt(0) === 60) return file; +- if (/^\w+:\/\//.test(file)) return file; +- let cached = this.memoizedPaths.get(file); +- if (cached) return cached; +- let from = this.opts.to ? dirname(this.opts.to) : "."; +- if (typeof this.mapOpts.annotation === "string") { +- from = dirname(resolve(from, this.mapOpts.annotation)); +- } +- let path = relative(from, file); +- this.memoizedPaths.set(file, path); +- return path; +- } +- previous() { +- if (!this.previousMaps) { +- this.previousMaps = []; +- if (this.root) { +- this.root.walk((node2) => { +- if (node2.source && node2.source.input.map) { +- let map = node2.source.input.map; +- if (!this.previousMaps.includes(map)) { +- this.previousMaps.push(map); +- } +- } +- }); +- } else { +- let input2 = new Input$3(this.originalCSS, this.opts); +- if (input2.map) this.previousMaps.push(input2.map); +- } +- } +- return this.previousMaps; +- } +- setSourcesContent() { +- let already = {}; +- if (this.root) { +- this.root.walk((node2) => { +- if (node2.source) { +- let from = node2.source.input.from; +- if (from && !already[from]) { +- already[from] = true; +- let fromUrl = this.usesFileUrls ? this.toFileUrl(from) : this.toUrl(this.path(from)); +- this.map.setSourceContent(fromUrl, node2.source.input.css); +- } +- } +- }); +- } else if (this.css) { +- let from = this.opts.from ? this.toUrl(this.path(this.opts.from)) : ""; +- this.map.setSourceContent(from, this.css); +- } +- } +- sourcePath(node2) { +- if (this.mapOpts.from) { +- return this.toUrl(this.mapOpts.from); +- } else if (this.usesFileUrls) { +- return this.toFileUrl(node2.source.input.from); +- } else { +- return this.toUrl(this.path(node2.source.input.from)); +- } +- } +- toBase64(str) { +- if (Buffer) { +- return Buffer.from(str).toString("base64"); +- } else { +- return window.btoa(unescape(encodeURIComponent(str))); +- } +- } +- toFileUrl(path) { +- let cached = this.memoizedFileURLs.get(path); +- if (cached) return cached; +- if (pathToFileURL) { +- let fileURL = pathToFileURL(path).toString(); +- this.memoizedFileURLs.set(path, fileURL); +- return fileURL; +- } else { +- throw new Error( +- "`map.absolute` option is not available in this PostCSS build" +- ); +- } +- } +- toUrl(path) { +- let cached = this.memoizedURLs.get(path); +- if (cached) return cached; +- if (sep === "\\") { +- path = path.replace(/\\/g, "/"); +- } +- let url = encodeURI(path).replace(/[#?]/g, encodeURIComponent); +- this.memoizedURLs.set(path, url); +- return url; +- } +-}; +-var mapGenerator = MapGenerator$2; +-let Node$2 = node; +-let Comment$4 = class Comment extends Node$2 { +- constructor(defaults) { +- super(defaults); +- this.type = "comment"; +- } +-}; +-var comment = Comment$4; +-Comment$4.default = Comment$4; +-let { isClean: isClean$1, my: my$1 } = symbols; +-let Declaration$3 = declaration; +-let Comment$3 = comment; +-let Node$1 = node; +-let parse$4, Rule$4, AtRule$4, Root$6; +-function cleanSource(nodes) { +- return nodes.map((i) => { +- if (i.nodes) i.nodes = cleanSource(i.nodes); +- delete i.source; +- return i; +- }); +-} +-function markDirtyUp(node2) { +- node2[isClean$1] = false; +- if (node2.proxyOf.nodes) { +- for (let i of node2.proxyOf.nodes) { +- markDirtyUp(i); +- } +- } +-} +-let Container$7 = class Container extends Node$1 { +- append(...children) { +- for (let child of children) { +- let nodes = this.normalize(child, this.last); +- for (let node2 of nodes) this.proxyOf.nodes.push(node2); +- } +- this.markDirty(); +- return this; +- } +- cleanRaws(keepBetween) { +- super.cleanRaws(keepBetween); +- if (this.nodes) { +- for (let node2 of this.nodes) node2.cleanRaws(keepBetween); +- } +- } +- each(callback) { +- if (!this.proxyOf.nodes) return void 0; +- let iterator = this.getIterator(); +- let index2, result2; +- while (this.indexes[iterator] < this.proxyOf.nodes.length) { +- index2 = this.indexes[iterator]; +- result2 = callback(this.proxyOf.nodes[index2], index2); +- if (result2 === false) break; +- this.indexes[iterator] += 1; +- } +- delete this.indexes[iterator]; +- return result2; +- } +- every(condition) { +- return this.nodes.every(condition); +- } +- getIterator() { +- if (!this.lastEach) this.lastEach = 0; +- if (!this.indexes) this.indexes = {}; +- this.lastEach += 1; +- let iterator = this.lastEach; +- this.indexes[iterator] = 0; +- return iterator; +- } +- getProxyProcessor() { +- return { +- get(node2, prop) { +- if (prop === "proxyOf") { +- return node2; +- } else if (!node2[prop]) { +- return node2[prop]; +- } else if (prop === "each" || typeof prop === "string" && prop.startsWith("walk")) { +- return (...args) => { +- return node2[prop]( +- ...args.map((i) => { +- if (typeof i === "function") { +- return (child, index2) => i(child.toProxy(), index2); +- } else { +- return i; +- } +- }) +- ); +- }; +- } else if (prop === "every" || prop === "some") { +- return (cb) => { +- return node2[prop]( +- (child, ...other) => cb(child.toProxy(), ...other) +- ); +- }; +- } else if (prop === "root") { +- return () => node2.root().toProxy(); +- } else if (prop === "nodes") { +- return node2.nodes.map((i) => i.toProxy()); +- } else if (prop === "first" || prop === "last") { +- return node2[prop].toProxy(); +- } else { +- return node2[prop]; +- } +- }, +- set(node2, prop, value) { +- if (node2[prop] === value) return true; +- node2[prop] = value; +- if (prop === "name" || prop === "params" || prop === "selector") { +- node2.markDirty(); +- } +- return true; +- } +- }; +- } +- index(child) { +- if (typeof child === "number") return child; +- if (child.proxyOf) child = child.proxyOf; +- return this.proxyOf.nodes.indexOf(child); +- } +- insertAfter(exist, add) { +- let existIndex = this.index(exist); +- let nodes = this.normalize(add, this.proxyOf.nodes[existIndex]).reverse(); +- existIndex = this.index(exist); +- for (let node2 of nodes) this.proxyOf.nodes.splice(existIndex + 1, 0, node2); +- let index2; +- for (let id in this.indexes) { +- index2 = this.indexes[id]; +- if (existIndex < index2) { +- this.indexes[id] = index2 + nodes.length; +- } +- } +- this.markDirty(); +- return this; +- } +- insertBefore(exist, add) { +- let existIndex = this.index(exist); +- let type = existIndex === 0 ? "prepend" : false; +- let nodes = this.normalize(add, this.proxyOf.nodes[existIndex], type).reverse(); +- existIndex = this.index(exist); +- for (let node2 of nodes) this.proxyOf.nodes.splice(existIndex, 0, node2); +- let index2; +- for (let id in this.indexes) { +- index2 = this.indexes[id]; +- if (existIndex <= index2) { +- this.indexes[id] = index2 + nodes.length; +- } +- } +- this.markDirty(); +- return this; +- } +- normalize(nodes, sample) { +- if (typeof nodes === "string") { +- nodes = cleanSource(parse$4(nodes).nodes); +- } else if (typeof nodes === "undefined") { +- nodes = []; +- } else if (Array.isArray(nodes)) { +- nodes = nodes.slice(0); +- for (let i of nodes) { +- if (i.parent) i.parent.removeChild(i, "ignore"); +- } +- } else if (nodes.type === "root" && this.type !== "document") { +- nodes = nodes.nodes.slice(0); +- for (let i of nodes) { +- if (i.parent) i.parent.removeChild(i, "ignore"); +- } +- } else if (nodes.type) { +- nodes = [nodes]; +- } else if (nodes.prop) { +- if (typeof nodes.value === "undefined") { +- throw new Error("Value field is missed in node creation"); +- } else if (typeof nodes.value !== "string") { +- nodes.value = String(nodes.value); +- } +- nodes = [new Declaration$3(nodes)]; +- } else if (nodes.selector) { +- nodes = [new Rule$4(nodes)]; +- } else if (nodes.name) { +- nodes = [new AtRule$4(nodes)]; +- } else if (nodes.text) { +- nodes = [new Comment$3(nodes)]; +- } else { +- throw new Error("Unknown node type in node creation"); +- } +- let processed = nodes.map((i) => { +- if (!i[my$1]) Container.rebuild(i); +- i = i.proxyOf; +- if (i.parent) i.parent.removeChild(i); +- if (i[isClean$1]) markDirtyUp(i); +- if (typeof i.raws.before === "undefined") { +- if (sample && typeof sample.raws.before !== "undefined") { +- i.raws.before = sample.raws.before.replace(/\S/g, ""); +- } +- } +- i.parent = this.proxyOf; +- return i; +- }); +- return processed; +- } +- prepend(...children) { +- children = children.reverse(); +- for (let child of children) { +- let nodes = this.normalize(child, this.first, "prepend").reverse(); +- for (let node2 of nodes) this.proxyOf.nodes.unshift(node2); +- for (let id in this.indexes) { +- this.indexes[id] = this.indexes[id] + nodes.length; +- } +- } +- this.markDirty(); +- return this; +- } +- push(child) { +- child.parent = this; +- this.proxyOf.nodes.push(child); +- return this; +- } +- removeAll() { +- for (let node2 of this.proxyOf.nodes) node2.parent = void 0; +- this.proxyOf.nodes = []; +- this.markDirty(); +- return this; +- } +- removeChild(child) { +- child = this.index(child); +- this.proxyOf.nodes[child].parent = void 0; +- this.proxyOf.nodes.splice(child, 1); +- let index2; +- for (let id in this.indexes) { +- index2 = this.indexes[id]; +- if (index2 >= child) { +- this.indexes[id] = index2 - 1; +- } +- } +- this.markDirty(); +- return this; +- } +- replaceValues(pattern, opts, callback) { +- if (!callback) { +- callback = opts; +- opts = {}; +- } +- this.walkDecls((decl) => { +- if (opts.props && !opts.props.includes(decl.prop)) return; +- if (opts.fast && !decl.value.includes(opts.fast)) return; +- decl.value = decl.value.replace(pattern, callback); +- }); +- this.markDirty(); +- return this; +- } +- some(condition) { +- return this.nodes.some(condition); +- } +- walk(callback) { +- return this.each((child, i) => { +- let result2; +- try { +- result2 = callback(child, i); +- } catch (e) { +- throw child.addToError(e); +- } +- if (result2 !== false && child.walk) { +- result2 = child.walk(callback); +- } +- return result2; +- }); +- } +- walkAtRules(name, callback) { +- if (!callback) { +- callback = name; +- return this.walk((child, i) => { +- if (child.type === "atrule") { +- return callback(child, i); +- } +- }); +- } +- if (name instanceof RegExp) { +- return this.walk((child, i) => { +- if (child.type === "atrule" && name.test(child.name)) { +- return callback(child, i); +- } +- }); +- } +- return this.walk((child, i) => { +- if (child.type === "atrule" && child.name === name) { +- return callback(child, i); +- } +- }); +- } +- walkComments(callback) { +- return this.walk((child, i) => { +- if (child.type === "comment") { +- return callback(child, i); +- } +- }); +- } +- walkDecls(prop, callback) { +- if (!callback) { +- callback = prop; +- return this.walk((child, i) => { +- if (child.type === "decl") { +- return callback(child, i); +- } +- }); +- } +- if (prop instanceof RegExp) { +- return this.walk((child, i) => { +- if (child.type === "decl" && prop.test(child.prop)) { +- return callback(child, i); +- } +- }); +- } +- return this.walk((child, i) => { +- if (child.type === "decl" && child.prop === prop) { +- return callback(child, i); +- } +- }); +- } +- walkRules(selector, callback) { +- if (!callback) { +- callback = selector; +- return this.walk((child, i) => { +- if (child.type === "rule") { +- return callback(child, i); +- } +- }); +- } +- if (selector instanceof RegExp) { +- return this.walk((child, i) => { +- if (child.type === "rule" && selector.test(child.selector)) { +- return callback(child, i); +- } +- }); +- } +- return this.walk((child, i) => { +- if (child.type === "rule" && child.selector === selector) { +- return callback(child, i); +- } +- }); +- } +- get first() { +- if (!this.proxyOf.nodes) return void 0; +- return this.proxyOf.nodes[0]; +- } +- get last() { +- if (!this.proxyOf.nodes) return void 0; +- return this.proxyOf.nodes[this.proxyOf.nodes.length - 1]; +- } +-}; +-Container$7.registerParse = (dependant) => { +- parse$4 = dependant; +-}; +-Container$7.registerRule = (dependant) => { +- Rule$4 = dependant; +-}; +-Container$7.registerAtRule = (dependant) => { +- AtRule$4 = dependant; +-}; +-Container$7.registerRoot = (dependant) => { +- Root$6 = dependant; +-}; +-var container = Container$7; +-Container$7.default = Container$7; +-Container$7.rebuild = (node2) => { +- if (node2.type === "atrule") { +- Object.setPrototypeOf(node2, AtRule$4.prototype); +- } else if (node2.type === "rule") { +- Object.setPrototypeOf(node2, Rule$4.prototype); +- } else if (node2.type === "decl") { +- Object.setPrototypeOf(node2, Declaration$3.prototype); +- } else if (node2.type === "comment") { +- Object.setPrototypeOf(node2, Comment$3.prototype); +- } else if (node2.type === "root") { +- Object.setPrototypeOf(node2, Root$6.prototype); +- } +- node2[my$1] = true; +- if (node2.nodes) { +- node2.nodes.forEach((child) => { +- Container$7.rebuild(child); +- }); +- } +-}; +-let Container$6 = container; +-let LazyResult$4, Processor$3; +-let Document$3 = class Document extends Container$6 { +- constructor(defaults) { +- super({ type: "document", ...defaults }); +- if (!this.nodes) { +- this.nodes = []; +- } +- } +- toResult(opts = {}) { +- let lazy = new LazyResult$4(new Processor$3(), this, opts); +- return lazy.stringify(); +- } +-}; +-Document$3.registerLazyResult = (dependant) => { +- LazyResult$4 = dependant; +-}; +-Document$3.registerProcessor = (dependant) => { +- Processor$3 = dependant; +-}; +-var document$1 = Document$3; +-Document$3.default = Document$3; +-let printed = {}; +-var warnOnce$2 = function warnOnce(message) { +- if (printed[message]) return; +- printed[message] = true; +- if (typeof console !== "undefined" && console.warn) { +- console.warn(message); +- } +-}; +-let Warning$2 = class Warning { +- constructor(text, opts = {}) { +- this.type = "warning"; +- this.text = text; +- if (opts.node && opts.node.source) { +- let range = opts.node.rangeBy(opts); +- this.line = range.start.line; +- this.column = range.start.column; +- this.endLine = range.end.line; +- this.endColumn = range.end.column; +- } +- for (let opt in opts) this[opt] = opts[opt]; +- } +- toString() { +- if (this.node) { +- return this.node.error(this.text, { +- index: this.index, +- plugin: this.plugin, +- word: this.word +- }).message; +- } +- if (this.plugin) { +- return this.plugin + ": " + this.text; +- } +- return this.text; +- } +-}; +-var warning = Warning$2; +-Warning$2.default = Warning$2; +-let Warning$1 = warning; +-let Result$3 = class Result { +- constructor(processor2, root2, opts) { +- this.processor = processor2; +- this.messages = []; +- this.root = root2; +- this.opts = opts; +- this.css = void 0; +- this.map = void 0; +- } +- toString() { +- return this.css; +- } +- warn(text, opts = {}) { +- if (!opts.plugin) { +- if (this.lastPlugin && this.lastPlugin.postcssPlugin) { +- opts.plugin = this.lastPlugin.postcssPlugin; +- } +- } +- let warning2 = new Warning$1(text, opts); +- this.messages.push(warning2); +- return warning2; +- } +- warnings() { +- return this.messages.filter((i) => i.type === "warning"); +- } +- get content() { +- return this.css; +- } +-}; +-var result = Result$3; +-Result$3.default = Result$3; +-const SINGLE_QUOTE = "'".charCodeAt(0); +-const DOUBLE_QUOTE = '"'.charCodeAt(0); +-const BACKSLASH = "\\".charCodeAt(0); +-const SLASH = "/".charCodeAt(0); +-const NEWLINE = "\n".charCodeAt(0); +-const SPACE = " ".charCodeAt(0); +-const FEED = "\f".charCodeAt(0); +-const TAB = " ".charCodeAt(0); +-const CR = "\r".charCodeAt(0); +-const OPEN_SQUARE = "[".charCodeAt(0); +-const CLOSE_SQUARE = "]".charCodeAt(0); +-const OPEN_PARENTHESES = "(".charCodeAt(0); +-const CLOSE_PARENTHESES = ")".charCodeAt(0); +-const OPEN_CURLY = "{".charCodeAt(0); +-const CLOSE_CURLY = "}".charCodeAt(0); +-const SEMICOLON = ";".charCodeAt(0); +-const ASTERISK = "*".charCodeAt(0); +-const COLON = ":".charCodeAt(0); +-const AT = "@".charCodeAt(0); +-const RE_AT_END = /[\t\n\f\r "#'()/;[\\\]{}]/g; +-const RE_WORD_END = /[\t\n\f\r !"#'():;@[\\\]{}]|\/(?=\*)/g; +-const RE_BAD_BRACKET = /.[\r\n"'(/\\]/; +-const RE_HEX_ESCAPE = /[\da-f]/i; +-var tokenize = function tokenizer(input2, options = {}) { +- let css = input2.css.valueOf(); +- let ignore = options.ignoreErrors; +- let code, next, quote, content, escape; +- let escaped, escapePos, prev, n, currentToken; +- let length = css.length; +- let pos = 0; +- let buffer = []; +- let returned = []; +- function position() { +- return pos; +- } +- function unclosed(what) { +- throw input2.error("Unclosed " + what, pos); +- } +- function endOfFile() { +- return returned.length === 0 && pos >= length; +- } +- function nextToken(opts) { +- if (returned.length) return returned.pop(); +- if (pos >= length) return; +- let ignoreUnclosed = opts ? opts.ignoreUnclosed : false; +- code = css.charCodeAt(pos); +- switch (code) { +- case NEWLINE: +- case SPACE: +- case TAB: +- case CR: +- case FEED: { +- next = pos; +- do { +- next += 1; +- code = css.charCodeAt(next); +- } while (code === SPACE || code === NEWLINE || code === TAB || code === CR || code === FEED); +- currentToken = ["space", css.slice(pos, next)]; +- pos = next - 1; +- break; +- } +- case OPEN_SQUARE: +- case CLOSE_SQUARE: +- case OPEN_CURLY: +- case CLOSE_CURLY: +- case COLON: +- case SEMICOLON: +- case CLOSE_PARENTHESES: { +- let controlChar = String.fromCharCode(code); +- currentToken = [controlChar, controlChar, pos]; +- break; +- } +- case OPEN_PARENTHESES: { +- prev = buffer.length ? buffer.pop()[1] : ""; +- n = css.charCodeAt(pos + 1); +- if (prev === "url" && n !== SINGLE_QUOTE && n !== DOUBLE_QUOTE && n !== SPACE && n !== NEWLINE && n !== TAB && n !== FEED && n !== CR) { +- next = pos; +- do { +- escaped = false; +- next = css.indexOf(")", next + 1); +- if (next === -1) { +- if (ignore || ignoreUnclosed) { +- next = pos; +- break; +- } else { +- unclosed("bracket"); +- } +- } +- escapePos = next; +- while (css.charCodeAt(escapePos - 1) === BACKSLASH) { +- escapePos -= 1; +- escaped = !escaped; +- } +- } while (escaped); +- currentToken = ["brackets", css.slice(pos, next + 1), pos, next]; +- pos = next; +- } else { +- next = css.indexOf(")", pos + 1); +- content = css.slice(pos, next + 1); +- if (next === -1 || RE_BAD_BRACKET.test(content)) { +- currentToken = ["(", "(", pos]; +- } else { +- currentToken = ["brackets", content, pos, next]; +- pos = next; +- } +- } +- break; +- } +- case SINGLE_QUOTE: +- case DOUBLE_QUOTE: { +- quote = code === SINGLE_QUOTE ? "'" : '"'; +- next = pos; +- do { +- escaped = false; +- next = css.indexOf(quote, next + 1); +- if (next === -1) { +- if (ignore || ignoreUnclosed) { +- next = pos + 1; +- break; +- } else { +- unclosed("string"); +- } +- } +- escapePos = next; +- while (css.charCodeAt(escapePos - 1) === BACKSLASH) { +- escapePos -= 1; +- escaped = !escaped; +- } +- } while (escaped); +- currentToken = ["string", css.slice(pos, next + 1), pos, next]; +- pos = next; +- break; +- } +- case AT: { +- RE_AT_END.lastIndex = pos + 1; +- RE_AT_END.test(css); +- if (RE_AT_END.lastIndex === 0) { +- next = css.length - 1; +- } else { +- next = RE_AT_END.lastIndex - 2; +- } +- currentToken = ["at-word", css.slice(pos, next + 1), pos, next]; +- pos = next; +- break; +- } +- case BACKSLASH: { +- next = pos; +- escape = true; +- while (css.charCodeAt(next + 1) === BACKSLASH) { +- next += 1; +- escape = !escape; +- } +- code = css.charCodeAt(next + 1); +- if (escape && code !== SLASH && code !== SPACE && code !== NEWLINE && code !== TAB && code !== CR && code !== FEED) { +- next += 1; +- if (RE_HEX_ESCAPE.test(css.charAt(next))) { +- while (RE_HEX_ESCAPE.test(css.charAt(next + 1))) { +- next += 1; +- } +- if (css.charCodeAt(next + 1) === SPACE) { +- next += 1; +- } +- } +- } +- currentToken = ["word", css.slice(pos, next + 1), pos, next]; +- pos = next; +- break; +- } +- default: { +- if (code === SLASH && css.charCodeAt(pos + 1) === ASTERISK) { +- next = css.indexOf("*/", pos + 2) + 1; +- if (next === 0) { +- if (ignore || ignoreUnclosed) { +- next = css.length; +- } else { +- unclosed("comment"); +- } +- } +- currentToken = ["comment", css.slice(pos, next + 1), pos, next]; +- pos = next; +- } else { +- RE_WORD_END.lastIndex = pos + 1; +- RE_WORD_END.test(css); +- if (RE_WORD_END.lastIndex === 0) { +- next = css.length - 1; +- } else { +- next = RE_WORD_END.lastIndex - 2; +- } +- currentToken = ["word", css.slice(pos, next + 1), pos, next]; +- buffer.push(currentToken); +- pos = next; +- } +- break; +- } +- } +- pos++; +- return currentToken; +- } +- function back(token) { +- returned.push(token); +- } +- return { +- back, +- endOfFile, +- nextToken, +- position +- }; +-}; +-let Container$5 = container; +-let AtRule$3 = class AtRule extends Container$5 { +- constructor(defaults) { +- super(defaults); +- this.type = "atrule"; +- } +- append(...children) { +- if (!this.proxyOf.nodes) this.nodes = []; +- return super.append(...children); +- } +- prepend(...children) { +- if (!this.proxyOf.nodes) this.nodes = []; +- return super.prepend(...children); +- } +-}; +-var atRule = AtRule$3; +-AtRule$3.default = AtRule$3; +-Container$5.registerAtRule(AtRule$3); +-let Container$4 = container; +-let LazyResult$3, Processor$2; +-let Root$5 = class Root extends Container$4 { +- constructor(defaults) { +- super(defaults); +- this.type = "root"; +- if (!this.nodes) this.nodes = []; +- } +- normalize(child, sample, type) { +- let nodes = super.normalize(child); +- if (sample) { +- if (type === "prepend") { +- if (this.nodes.length > 1) { +- sample.raws.before = this.nodes[1].raws.before; +- } else { +- delete sample.raws.before; +- } +- } else if (this.first !== sample) { +- for (let node2 of nodes) { +- node2.raws.before = sample.raws.before; +- } +- } +- } +- return nodes; +- } +- removeChild(child, ignore) { +- let index2 = this.index(child); +- if (!ignore && index2 === 0 && this.nodes.length > 1) { +- this.nodes[1].raws.before = this.nodes[index2].raws.before; +- } +- return super.removeChild(child); +- } +- toResult(opts = {}) { +- let lazy = new LazyResult$3(new Processor$2(), this, opts); +- return lazy.stringify(); +- } +-}; +-Root$5.registerLazyResult = (dependant) => { +- LazyResult$3 = dependant; +-}; +-Root$5.registerProcessor = (dependant) => { +- Processor$2 = dependant; +-}; +-var root = Root$5; +-Root$5.default = Root$5; +-Container$4.registerRoot(Root$5); +-let list$2 = { +- comma(string) { +- return list$2.split(string, [","], true); +- }, +- space(string) { +- let spaces = [" ", "\n", " "]; +- return list$2.split(string, spaces); +- }, +- split(string, separators, last) { +- let array = []; +- let current = ""; +- let split = false; +- let func = 0; +- let inQuote = false; +- let prevQuote = ""; +- let escape = false; +- for (let letter of string) { +- if (escape) { +- escape = false; +- } else if (letter === "\\") { +- escape = true; +- } else if (inQuote) { +- if (letter === prevQuote) { +- inQuote = false; +- } +- } else if (letter === '"' || letter === "'") { +- inQuote = true; +- prevQuote = letter; +- } else if (letter === "(") { +- func += 1; +- } else if (letter === ")") { +- if (func > 0) func -= 1; +- } else if (func === 0) { +- if (separators.includes(letter)) split = true; +- } +- if (split) { +- if (current !== "") array.push(current.trim()); +- current = ""; +- split = false; +- } else { +- current += letter; +- } +- } +- if (last || current !== "") array.push(current.trim()); +- return array; +- } +-}; +-var list_1 = list$2; +-list$2.default = list$2; +-let Container$3 = container; +-let list$1 = list_1; +-let Rule$3 = class Rule extends Container$3 { +- constructor(defaults) { +- super(defaults); +- this.type = "rule"; +- if (!this.nodes) this.nodes = []; +- } +- get selectors() { +- return list$1.comma(this.selector); +- } +- set selectors(values) { +- let match = this.selector ? this.selector.match(/,\s*/) : null; +- let sep2 = match ? match[0] : "," + this.raw("between", "beforeOpen"); +- this.selector = values.join(sep2); +- } +-}; +-var rule = Rule$3; +-Rule$3.default = Rule$3; +-Container$3.registerRule(Rule$3); +-let Declaration$2 = declaration; +-let tokenizer2 = tokenize; +-let Comment$2 = comment; +-let AtRule$2 = atRule; +-let Root$4 = root; +-let Rule$2 = rule; +-const SAFE_COMMENT_NEIGHBOR = { +- empty: true, +- space: true +-}; +-function findLastWithPosition(tokens) { +- for (let i = tokens.length - 1; i >= 0; i--) { +- let token = tokens[i]; +- let pos = token[3] || token[2]; +- if (pos) return pos; +- } +-} +-let Parser$1 = class Parser { +- constructor(input2) { +- this.input = input2; +- this.root = new Root$4(); +- this.current = this.root; +- this.spaces = ""; +- this.semicolon = false; +- this.createTokenizer(); +- this.root.source = { input: input2, start: { column: 1, line: 1, offset: 0 } }; +- } +- atrule(token) { +- let node2 = new AtRule$2(); +- node2.name = token[1].slice(1); +- if (node2.name === "") { +- this.unnamedAtrule(node2, token); +- } +- this.init(node2, token[2]); +- let type; +- let prev; +- let shift; +- let last = false; +- let open = false; +- let params = []; +- let brackets = []; +- while (!this.tokenizer.endOfFile()) { +- token = this.tokenizer.nextToken(); +- type = token[0]; +- if (type === "(" || type === "[") { +- brackets.push(type === "(" ? ")" : "]"); +- } else if (type === "{" && brackets.length > 0) { +- brackets.push("}"); +- } else if (type === brackets[brackets.length - 1]) { +- brackets.pop(); +- } +- if (brackets.length === 0) { +- if (type === ";") { +- node2.source.end = this.getPosition(token[2]); +- node2.source.end.offset++; +- this.semicolon = true; +- break; +- } else if (type === "{") { +- open = true; +- break; +- } else if (type === "}") { +- if (params.length > 0) { +- shift = params.length - 1; +- prev = params[shift]; +- while (prev && prev[0] === "space") { +- prev = params[--shift]; +- } +- if (prev) { +- node2.source.end = this.getPosition(prev[3] || prev[2]); +- node2.source.end.offset++; +- } +- } +- this.end(token); +- break; +- } else { +- params.push(token); +- } +- } else { +- params.push(token); +- } +- if (this.tokenizer.endOfFile()) { +- last = true; +- break; +- } +- } +- node2.raws.between = this.spacesAndCommentsFromEnd(params); +- if (params.length) { +- node2.raws.afterName = this.spacesAndCommentsFromStart(params); +- this.raw(node2, "params", params); +- if (last) { +- token = params[params.length - 1]; +- node2.source.end = this.getPosition(token[3] || token[2]); +- node2.source.end.offset++; +- this.spaces = node2.raws.between; +- node2.raws.between = ""; +- } +- } else { +- node2.raws.afterName = ""; +- node2.params = ""; +- } +- if (open) { +- node2.nodes = []; +- this.current = node2; +- } +- } +- checkMissedSemicolon(tokens) { +- let colon = this.colon(tokens); +- if (colon === false) return; +- let founded = 0; +- let token; +- for (let j = colon - 1; j >= 0; j--) { +- token = tokens[j]; +- if (token[0] !== "space") { +- founded += 1; +- if (founded === 2) break; +- } +- } +- throw this.input.error( +- "Missed semicolon", +- token[0] === "word" ? token[3] + 1 : token[2] +- ); +- } +- colon(tokens) { +- let brackets = 0; +- let token, type, prev; +- for (let [i, element] of tokens.entries()) { +- token = element; +- type = token[0]; +- if (type === "(") { +- brackets += 1; +- } +- if (type === ")") { +- brackets -= 1; +- } +- if (brackets === 0 && type === ":") { +- if (!prev) { +- this.doubleColon(token); +- } else if (prev[0] === "word" && prev[1] === "progid") { +- continue; +- } else { +- return i; +- } +- } +- prev = token; +- } +- return false; +- } +- comment(token) { +- let node2 = new Comment$2(); +- this.init(node2, token[2]); +- node2.source.end = this.getPosition(token[3] || token[2]); +- node2.source.end.offset++; +- let text = token[1].slice(2, -2); +- if (/^\s*$/.test(text)) { +- node2.text = ""; +- node2.raws.left = text; +- node2.raws.right = ""; +- } else { +- let match = text.match(/^(\s*)([^]*\S)(\s*)$/); +- node2.text = match[2]; +- node2.raws.left = match[1]; +- node2.raws.right = match[3]; +- } +- } +- createTokenizer() { +- this.tokenizer = tokenizer2(this.input); +- } +- decl(tokens, customProperty) { +- let node2 = new Declaration$2(); +- this.init(node2, tokens[0][2]); +- let last = tokens[tokens.length - 1]; +- if (last[0] === ";") { +- this.semicolon = true; +- tokens.pop(); +- } +- node2.source.end = this.getPosition( +- last[3] || last[2] || findLastWithPosition(tokens) +- ); +- node2.source.end.offset++; +- while (tokens[0][0] !== "word") { +- if (tokens.length === 1) this.unknownWord(tokens); +- node2.raws.before += tokens.shift()[1]; +- } +- node2.source.start = this.getPosition(tokens[0][2]); +- node2.prop = ""; +- while (tokens.length) { +- let type = tokens[0][0]; +- if (type === ":" || type === "space" || type === "comment") { +- break; +- } +- node2.prop += tokens.shift()[1]; +- } +- node2.raws.between = ""; +- let token; +- while (tokens.length) { +- token = tokens.shift(); +- if (token[0] === ":") { +- node2.raws.between += token[1]; +- break; +- } else { +- if (token[0] === "word" && /\w/.test(token[1])) { +- this.unknownWord([token]); +- } +- node2.raws.between += token[1]; +- } +- } +- if (node2.prop[0] === "_" || node2.prop[0] === "*") { +- node2.raws.before += node2.prop[0]; +- node2.prop = node2.prop.slice(1); +- } +- let firstSpaces = []; +- let next; +- while (tokens.length) { +- next = tokens[0][0]; +- if (next !== "space" && next !== "comment") break; +- firstSpaces.push(tokens.shift()); +- } +- this.precheckMissedSemicolon(tokens); +- for (let i = tokens.length - 1; i >= 0; i--) { +- token = tokens[i]; +- if (token[1].toLowerCase() === "!important") { +- node2.important = true; +- let string = this.stringFrom(tokens, i); +- string = this.spacesFromEnd(tokens) + string; +- if (string !== " !important") node2.raws.important = string; +- break; +- } else if (token[1].toLowerCase() === "important") { +- let cache = tokens.slice(0); +- let str = ""; +- for (let j = i; j > 0; j--) { +- let type = cache[j][0]; +- if (str.trim().indexOf("!") === 0 && type !== "space") { +- break; +- } +- str = cache.pop()[1] + str; +- } +- if (str.trim().indexOf("!") === 0) { +- node2.important = true; +- node2.raws.important = str; +- tokens = cache; +- } +- } +- if (token[0] !== "space" && token[0] !== "comment") { +- break; +- } +- } +- let hasWord = tokens.some((i) => i[0] !== "space" && i[0] !== "comment"); +- if (hasWord) { +- node2.raws.between += firstSpaces.map((i) => i[1]).join(""); +- firstSpaces = []; +- } +- this.raw(node2, "value", firstSpaces.concat(tokens), customProperty); +- if (node2.value.includes(":") && !customProperty) { +- this.checkMissedSemicolon(tokens); +- } +- } +- doubleColon(token) { +- throw this.input.error( +- "Double colon", +- { offset: token[2] }, +- { offset: token[2] + token[1].length } +- ); +- } +- emptyRule(token) { +- let node2 = new Rule$2(); +- this.init(node2, token[2]); +- node2.selector = ""; +- node2.raws.between = ""; +- this.current = node2; +- } +- end(token) { +- if (this.current.nodes && this.current.nodes.length) { +- this.current.raws.semicolon = this.semicolon; +- } +- this.semicolon = false; +- this.current.raws.after = (this.current.raws.after || "") + this.spaces; +- this.spaces = ""; +- if (this.current.parent) { +- this.current.source.end = this.getPosition(token[2]); +- this.current.source.end.offset++; +- this.current = this.current.parent; +- } else { +- this.unexpectedClose(token); +- } +- } +- endFile() { +- if (this.current.parent) this.unclosedBlock(); +- if (this.current.nodes && this.current.nodes.length) { +- this.current.raws.semicolon = this.semicolon; +- } +- this.current.raws.after = (this.current.raws.after || "") + this.spaces; +- this.root.source.end = this.getPosition(this.tokenizer.position()); +- } +- freeSemicolon(token) { +- this.spaces += token[1]; +- if (this.current.nodes) { +- let prev = this.current.nodes[this.current.nodes.length - 1]; +- if (prev && prev.type === "rule" && !prev.raws.ownSemicolon) { +- prev.raws.ownSemicolon = this.spaces; +- this.spaces = ""; +- } +- } +- } +- // Helpers +- getPosition(offset) { +- let pos = this.input.fromOffset(offset); +- return { +- column: pos.col, +- line: pos.line, +- offset +- }; +- } +- init(node2, offset) { +- this.current.push(node2); +- node2.source = { +- input: this.input, +- start: this.getPosition(offset) +- }; +- node2.raws.before = this.spaces; +- this.spaces = ""; +- if (node2.type !== "comment") this.semicolon = false; +- } +- other(start) { +- let end = false; +- let type = null; +- let colon = false; +- let bracket = null; +- let brackets = []; +- let customProperty = start[1].startsWith("--"); +- let tokens = []; +- let token = start; +- while (token) { +- type = token[0]; +- tokens.push(token); +- if (type === "(" || type === "[") { +- if (!bracket) bracket = token; +- brackets.push(type === "(" ? ")" : "]"); +- } else if (customProperty && colon && type === "{") { +- if (!bracket) bracket = token; +- brackets.push("}"); +- } else if (brackets.length === 0) { +- if (type === ";") { +- if (colon) { +- this.decl(tokens, customProperty); +- return; +- } else { +- break; +- } +- } else if (type === "{") { +- this.rule(tokens); +- return; +- } else if (type === "}") { +- this.tokenizer.back(tokens.pop()); +- end = true; +- break; +- } else if (type === ":") { +- colon = true; +- } +- } else if (type === brackets[brackets.length - 1]) { +- brackets.pop(); +- if (brackets.length === 0) bracket = null; +- } +- token = this.tokenizer.nextToken(); +- } +- if (this.tokenizer.endOfFile()) end = true; +- if (brackets.length > 0) this.unclosedBracket(bracket); +- if (end && colon) { +- if (!customProperty) { +- while (tokens.length) { +- token = tokens[tokens.length - 1][0]; +- if (token !== "space" && token !== "comment") break; +- this.tokenizer.back(tokens.pop()); +- } +- } +- this.decl(tokens, customProperty); +- } else { +- this.unknownWord(tokens); +- } +- } +- parse() { +- let token; +- while (!this.tokenizer.endOfFile()) { +- token = this.tokenizer.nextToken(); +- switch (token[0]) { +- case "space": +- this.spaces += token[1]; +- break; +- case ";": +- this.freeSemicolon(token); +- break; +- case "}": +- this.end(token); +- break; +- case "comment": +- this.comment(token); +- break; +- case "at-word": +- this.atrule(token); +- break; +- case "{": +- this.emptyRule(token); +- break; +- default: +- this.other(token); +- break; +- } +- } +- this.endFile(); +- } +- precheckMissedSemicolon() { +- } +- raw(node2, prop, tokens, customProperty) { +- let token, type; +- let length = tokens.length; +- let value = ""; +- let clean = true; +- let next, prev; +- for (let i = 0; i < length; i += 1) { +- token = tokens[i]; +- type = token[0]; +- if (type === "space" && i === length - 1 && !customProperty) { +- clean = false; +- } else if (type === "comment") { +- prev = tokens[i - 1] ? tokens[i - 1][0] : "empty"; +- next = tokens[i + 1] ? tokens[i + 1][0] : "empty"; +- if (!SAFE_COMMENT_NEIGHBOR[prev] && !SAFE_COMMENT_NEIGHBOR[next]) { +- if (value.slice(-1) === ",") { +- clean = false; +- } else { +- value += token[1]; +- } +- } else { +- clean = false; +- } +- } else { +- value += token[1]; +- } +- } +- if (!clean) { +- let raw = tokens.reduce((all, i) => all + i[1], ""); +- node2.raws[prop] = { raw, value }; +- } +- node2[prop] = value; +- } +- rule(tokens) { +- tokens.pop(); +- let node2 = new Rule$2(); +- this.init(node2, tokens[0][2]); +- node2.raws.between = this.spacesAndCommentsFromEnd(tokens); +- this.raw(node2, "selector", tokens); +- this.current = node2; +- } +- spacesAndCommentsFromEnd(tokens) { +- let lastTokenType; +- let spaces = ""; +- while (tokens.length) { +- lastTokenType = tokens[tokens.length - 1][0]; +- if (lastTokenType !== "space" && lastTokenType !== "comment") break; +- spaces = tokens.pop()[1] + spaces; +- } +- return spaces; +- } +- // Errors +- spacesAndCommentsFromStart(tokens) { +- let next; +- let spaces = ""; +- while (tokens.length) { +- next = tokens[0][0]; +- if (next !== "space" && next !== "comment") break; +- spaces += tokens.shift()[1]; +- } +- return spaces; +- } +- spacesFromEnd(tokens) { +- let lastTokenType; +- let spaces = ""; +- while (tokens.length) { +- lastTokenType = tokens[tokens.length - 1][0]; +- if (lastTokenType !== "space") break; +- spaces = tokens.pop()[1] + spaces; +- } +- return spaces; +- } +- stringFrom(tokens, from) { +- let result2 = ""; +- for (let i = from; i < tokens.length; i++) { +- result2 += tokens[i][1]; +- } +- tokens.splice(from, tokens.length - from); +- return result2; +- } +- unclosedBlock() { +- let pos = this.current.source.start; +- throw this.input.error("Unclosed block", pos.line, pos.column); +- } +- unclosedBracket(bracket) { +- throw this.input.error( +- "Unclosed bracket", +- { offset: bracket[2] }, +- { offset: bracket[2] + 1 } +- ); +- } +- unexpectedClose(token) { +- throw this.input.error( +- "Unexpected }", +- { offset: token[2] }, +- { offset: token[2] + 1 } +- ); +- } +- unknownWord(tokens) { +- throw this.input.error( +- "Unknown word", +- { offset: tokens[0][2] }, +- { offset: tokens[0][2] + tokens[0][1].length } +- ); +- } +- unnamedAtrule(node2, token) { +- throw this.input.error( +- "At-rule without name", +- { offset: token[2] }, +- { offset: token[2] + token[1].length } +- ); +- } +-}; +-var parser = Parser$1; +-let Container$2 = container; +-let Parser2 = parser; +-let Input$2 = input; +-function parse$3(css, opts) { +- let input2 = new Input$2(css, opts); +- let parser2 = new Parser2(input2); +- try { +- parser2.parse(); +- } catch (e) { +- if (process.env.NODE_ENV !== "production") { +- if (e.name === "CssSyntaxError" && opts && opts.from) { +- if (/\.scss$/i.test(opts.from)) { +- e.message += "\nYou tried to parse SCSS with the standard CSS parser; try again with the postcss-scss parser"; +- } else if (/\.sass/i.test(opts.from)) { +- e.message += "\nYou tried to parse Sass with the standard CSS parser; try again with the postcss-sass parser"; +- } else if (/\.less$/i.test(opts.from)) { +- e.message += "\nYou tried to parse Less with the standard CSS parser; try again with the postcss-less parser"; +- } +- } +- } +- throw e; +- } +- return parser2.root; +-} +-var parse_1 = parse$3; +-parse$3.default = parse$3; +-Container$2.registerParse(parse$3); +-let { isClean, my } = symbols; +-let MapGenerator$1 = mapGenerator; +-let stringify$2 = stringify_1; +-let Container$1 = container; +-let Document$2 = document$1; +-let warnOnce$1 = warnOnce$2; +-let Result$2 = result; +-let parse$2 = parse_1; +-let Root$3 = root; +-const TYPE_TO_CLASS_NAME = { +- atrule: "AtRule", +- comment: "Comment", +- decl: "Declaration", +- document: "Document", +- root: "Root", +- rule: "Rule" +-}; +-const PLUGIN_PROPS = { +- AtRule: true, +- AtRuleExit: true, +- Comment: true, +- CommentExit: true, +- Declaration: true, +- DeclarationExit: true, +- Document: true, +- DocumentExit: true, +- Once: true, +- OnceExit: true, +- postcssPlugin: true, +- prepare: true, +- Root: true, +- RootExit: true, +- Rule: true, +- RuleExit: true +-}; +-const NOT_VISITORS = { +- Once: true, +- postcssPlugin: true, +- prepare: true +-}; +-const CHILDREN = 0; +-function isPromise(obj) { +- return typeof obj === "object" && typeof obj.then === "function"; +-} +-function getEvents(node2) { +- let key = false; +- let type = TYPE_TO_CLASS_NAME[node2.type]; +- if (node2.type === "decl") { +- key = node2.prop.toLowerCase(); +- } else if (node2.type === "atrule") { +- key = node2.name.toLowerCase(); +- } +- if (key && node2.append) { +- return [ +- type, +- type + "-" + key, +- CHILDREN, +- type + "Exit", +- type + "Exit-" + key +- ]; +- } else if (key) { +- return [type, type + "-" + key, type + "Exit", type + "Exit-" + key]; +- } else if (node2.append) { +- return [type, CHILDREN, type + "Exit"]; +- } else { +- return [type, type + "Exit"]; +- } +-} +-function toStack(node2) { +- let events; +- if (node2.type === "document") { +- events = ["Document", CHILDREN, "DocumentExit"]; +- } else if (node2.type === "root") { +- events = ["Root", CHILDREN, "RootExit"]; +- } else { +- events = getEvents(node2); +- } +- return { +- eventIndex: 0, +- events, +- iterator: 0, +- node: node2, +- visitorIndex: 0, +- visitors: [] +- }; +-} +-function cleanMarks(node2) { +- node2[isClean] = false; +- if (node2.nodes) node2.nodes.forEach((i) => cleanMarks(i)); +- return node2; +-} +-let postcss$2 = {}; +-let LazyResult$2 = class LazyResult { +- constructor(processor2, css, opts) { +- this.stringified = false; +- this.processed = false; +- let root2; +- if (typeof css === "object" && css !== null && (css.type === "root" || css.type === "document")) { +- root2 = cleanMarks(css); +- } else if (css instanceof LazyResult || css instanceof Result$2) { +- root2 = cleanMarks(css.root); +- if (css.map) { +- if (typeof opts.map === "undefined") opts.map = {}; +- if (!opts.map.inline) opts.map.inline = false; +- opts.map.prev = css.map; +- } +- } else { +- let parser2 = parse$2; +- if (opts.syntax) parser2 = opts.syntax.parse; +- if (opts.parser) parser2 = opts.parser; +- if (parser2.parse) parser2 = parser2.parse; +- try { +- root2 = parser2(css, opts); +- } catch (error) { +- this.processed = true; +- this.error = error; +- } +- if (root2 && !root2[my]) { +- Container$1.rebuild(root2); +- } +- } +- this.result = new Result$2(processor2, root2, opts); +- this.helpers = { ...postcss$2, postcss: postcss$2, result: this.result }; +- this.plugins = this.processor.plugins.map((plugin2) => { +- if (typeof plugin2 === "object" && plugin2.prepare) { +- return { ...plugin2, ...plugin2.prepare(this.result) }; +- } else { +- return plugin2; +- } +- }); +- } +- async() { +- if (this.error) return Promise.reject(this.error); +- if (this.processed) return Promise.resolve(this.result); +- if (!this.processing) { +- this.processing = this.runAsync(); +- } +- return this.processing; +- } +- catch(onRejected) { +- return this.async().catch(onRejected); +- } +- finally(onFinally) { +- return this.async().then(onFinally, onFinally); +- } +- getAsyncError() { +- throw new Error("Use process(css).then(cb) to work with async plugins"); +- } +- handleError(error, node2) { +- let plugin2 = this.result.lastPlugin; +- try { +- if (node2) node2.addToError(error); +- this.error = error; +- if (error.name === "CssSyntaxError" && !error.plugin) { +- error.plugin = plugin2.postcssPlugin; +- error.setMessage(); +- } else if (plugin2.postcssVersion) { +- if (process.env.NODE_ENV !== "production") { +- let pluginName = plugin2.postcssPlugin; +- let pluginVer = plugin2.postcssVersion; +- let runtimeVer = this.result.processor.version; +- let a = pluginVer.split("."); +- let b = runtimeVer.split("."); +- if (a[0] !== b[0] || parseInt(a[1]) > parseInt(b[1])) { +- console.error( +- "Unknown error from PostCSS plugin. Your current PostCSS version is " + runtimeVer + ", but " + pluginName + " uses " + pluginVer + ". Perhaps this is the source of the error below." +- ); +- } +- } +- } +- } catch (err) { +- if (console && console.error) console.error(err); +- } +- return error; +- } +- prepareVisitors() { +- this.listeners = {}; +- let add = (plugin2, type, cb) => { +- if (!this.listeners[type]) this.listeners[type] = []; +- this.listeners[type].push([plugin2, cb]); +- }; +- for (let plugin2 of this.plugins) { +- if (typeof plugin2 === "object") { +- for (let event in plugin2) { +- if (!PLUGIN_PROPS[event] && /^[A-Z]/.test(event)) { +- throw new Error( +- `Unknown event ${event} in ${plugin2.postcssPlugin}. Try to update PostCSS (${this.processor.version} now).` +- ); +- } +- if (!NOT_VISITORS[event]) { +- if (typeof plugin2[event] === "object") { +- for (let filter in plugin2[event]) { +- if (filter === "*") { +- add(plugin2, event, plugin2[event][filter]); +- } else { +- add( +- plugin2, +- event + "-" + filter.toLowerCase(), +- plugin2[event][filter] +- ); +- } +- } +- } else if (typeof plugin2[event] === "function") { +- add(plugin2, event, plugin2[event]); +- } +- } +- } +- } +- } +- this.hasListener = Object.keys(this.listeners).length > 0; +- } +- async runAsync() { +- this.plugin = 0; +- for (let i = 0; i < this.plugins.length; i++) { +- let plugin2 = this.plugins[i]; +- let promise = this.runOnRoot(plugin2); +- if (isPromise(promise)) { +- try { +- await promise; +- } catch (error) { +- throw this.handleError(error); +- } +- } +- } +- this.prepareVisitors(); +- if (this.hasListener) { +- let root2 = this.result.root; +- while (!root2[isClean]) { +- root2[isClean] = true; +- let stack = [toStack(root2)]; +- while (stack.length > 0) { +- let promise = this.visitTick(stack); +- if (isPromise(promise)) { +- try { +- await promise; +- } catch (e) { +- let node2 = stack[stack.length - 1].node; +- throw this.handleError(e, node2); +- } +- } +- } +- } +- if (this.listeners.OnceExit) { +- for (let [plugin2, visitor] of this.listeners.OnceExit) { +- this.result.lastPlugin = plugin2; +- try { +- if (root2.type === "document") { +- let roots = root2.nodes.map( +- (subRoot) => visitor(subRoot, this.helpers) +- ); +- await Promise.all(roots); +- } else { +- await visitor(root2, this.helpers); +- } +- } catch (e) { +- throw this.handleError(e); +- } +- } +- } +- } +- this.processed = true; +- return this.stringify(); +- } +- runOnRoot(plugin2) { +- this.result.lastPlugin = plugin2; +- try { +- if (typeof plugin2 === "object" && plugin2.Once) { +- if (this.result.root.type === "document") { +- let roots = this.result.root.nodes.map( +- (root2) => plugin2.Once(root2, this.helpers) +- ); +- if (isPromise(roots[0])) { +- return Promise.all(roots); +- } +- return roots; +- } +- return plugin2.Once(this.result.root, this.helpers); +- } else if (typeof plugin2 === "function") { +- return plugin2(this.result.root, this.result); +- } +- } catch (error) { +- throw this.handleError(error); +- } +- } +- stringify() { +- if (this.error) throw this.error; +- if (this.stringified) return this.result; +- this.stringified = true; +- this.sync(); +- let opts = this.result.opts; +- let str = stringify$2; +- if (opts.syntax) str = opts.syntax.stringify; +- if (opts.stringifier) str = opts.stringifier; +- if (str.stringify) str = str.stringify; +- let map = new MapGenerator$1(str, this.result.root, this.result.opts); +- let data = map.generate(); +- this.result.css = data[0]; +- this.result.map = data[1]; +- return this.result; +- } +- sync() { +- if (this.error) throw this.error; +- if (this.processed) return this.result; +- this.processed = true; +- if (this.processing) { +- throw this.getAsyncError(); +- } +- for (let plugin2 of this.plugins) { +- let promise = this.runOnRoot(plugin2); +- if (isPromise(promise)) { +- throw this.getAsyncError(); +- } +- } +- this.prepareVisitors(); +- if (this.hasListener) { +- let root2 = this.result.root; +- while (!root2[isClean]) { +- root2[isClean] = true; +- this.walkSync(root2); +- } +- if (this.listeners.OnceExit) { +- if (root2.type === "document") { +- for (let subRoot of root2.nodes) { +- this.visitSync(this.listeners.OnceExit, subRoot); +- } +- } else { +- this.visitSync(this.listeners.OnceExit, root2); +- } +- } +- } +- return this.result; +- } +- then(onFulfilled, onRejected) { +- if (process.env.NODE_ENV !== "production") { +- if (!("from" in this.opts)) { +- warnOnce$1( +- "Without `from` option PostCSS could generate wrong source map and will not find Browserslist config. Set it to CSS file path or to `undefined` to prevent this warning." +- ); +- } +- } +- return this.async().then(onFulfilled, onRejected); +- } +- toString() { +- return this.css; +- } +- visitSync(visitors, node2) { +- for (let [plugin2, visitor] of visitors) { +- this.result.lastPlugin = plugin2; +- let promise; +- try { +- promise = visitor(node2, this.helpers); +- } catch (e) { +- throw this.handleError(e, node2.proxyOf); +- } +- if (node2.type !== "root" && node2.type !== "document" && !node2.parent) { +- return true; +- } +- if (isPromise(promise)) { +- throw this.getAsyncError(); +- } +- } +- } +- visitTick(stack) { +- let visit2 = stack[stack.length - 1]; +- let { node: node2, visitors } = visit2; +- if (node2.type !== "root" && node2.type !== "document" && !node2.parent) { +- stack.pop(); +- return; +- } +- if (visitors.length > 0 && visit2.visitorIndex < visitors.length) { +- let [plugin2, visitor] = visitors[visit2.visitorIndex]; +- visit2.visitorIndex += 1; +- if (visit2.visitorIndex === visitors.length) { +- visit2.visitors = []; +- visit2.visitorIndex = 0; +- } +- this.result.lastPlugin = plugin2; +- try { +- return visitor(node2.toProxy(), this.helpers); +- } catch (e) { +- throw this.handleError(e, node2); +- } +- } +- if (visit2.iterator !== 0) { +- let iterator = visit2.iterator; +- let child; +- while (child = node2.nodes[node2.indexes[iterator]]) { +- node2.indexes[iterator] += 1; +- if (!child[isClean]) { +- child[isClean] = true; +- stack.push(toStack(child)); +- return; +- } +- } +- visit2.iterator = 0; +- delete node2.indexes[iterator]; +- } +- let events = visit2.events; +- while (visit2.eventIndex < events.length) { +- let event = events[visit2.eventIndex]; +- visit2.eventIndex += 1; +- if (event === CHILDREN) { +- if (node2.nodes && node2.nodes.length) { +- node2[isClean] = true; +- visit2.iterator = node2.getIterator(); +- } +- return; +- } else if (this.listeners[event]) { +- visit2.visitors = this.listeners[event]; +- return; +- } +- } +- stack.pop(); +- } +- walkSync(node2) { +- node2[isClean] = true; +- let events = getEvents(node2); +- for (let event of events) { +- if (event === CHILDREN) { +- if (node2.nodes) { +- node2.each((child) => { +- if (!child[isClean]) this.walkSync(child); +- }); +- } +- } else { +- let visitors = this.listeners[event]; +- if (visitors) { +- if (this.visitSync(visitors, node2.toProxy())) return; +- } +- } +- } +- } +- warnings() { +- return this.sync().warnings(); +- } +- get content() { +- return this.stringify().content; +- } +- get css() { +- return this.stringify().css; +- } +- get map() { +- return this.stringify().map; +- } +- get messages() { +- return this.sync().messages; +- } +- get opts() { +- return this.result.opts; +- } +- get processor() { +- return this.result.processor; +- } +- get root() { +- return this.sync().root; +- } +- get [Symbol.toStringTag]() { +- return "LazyResult"; +- } +-}; +-LazyResult$2.registerPostcss = (dependant) => { +- postcss$2 = dependant; +-}; +-var lazyResult = LazyResult$2; +-LazyResult$2.default = LazyResult$2; +-Root$3.registerLazyResult(LazyResult$2); +-Document$2.registerLazyResult(LazyResult$2); +-let MapGenerator2 = mapGenerator; +-let stringify$1 = stringify_1; +-let warnOnce2 = warnOnce$2; +-let parse$1 = parse_1; +-const Result$1 = result; +-let NoWorkResult$1 = class NoWorkResult { +- constructor(processor2, css, opts) { +- css = css.toString(); +- this.stringified = false; +- this._processor = processor2; +- this._css = css; +- this._opts = opts; +- this._map = void 0; +- let root2; +- let str = stringify$1; +- this.result = new Result$1(this._processor, root2, this._opts); +- this.result.css = css; +- let self = this; +- Object.defineProperty(this.result, "root", { +- get() { +- return self.root; +- } +- }); +- let map = new MapGenerator2(str, root2, this._opts, css); +- if (map.isMap()) { +- let [generatedCSS, generatedMap] = map.generate(); +- if (generatedCSS) { +- this.result.css = generatedCSS; +- } +- if (generatedMap) { +- this.result.map = generatedMap; +- } +- } else { +- map.clearAnnotation(); +- this.result.css = map.css; +- } +- } +- async() { +- if (this.error) return Promise.reject(this.error); +- return Promise.resolve(this.result); +- } +- catch(onRejected) { +- return this.async().catch(onRejected); +- } +- finally(onFinally) { +- return this.async().then(onFinally, onFinally); +- } +- sync() { +- if (this.error) throw this.error; +- return this.result; +- } +- then(onFulfilled, onRejected) { +- if (process.env.NODE_ENV !== "production") { +- if (!("from" in this._opts)) { +- warnOnce2( +- "Without `from` option PostCSS could generate wrong source map and will not find Browserslist config. Set it to CSS file path or to `undefined` to prevent this warning." +- ); +- } +- } +- return this.async().then(onFulfilled, onRejected); +- } +- toString() { +- return this._css; +- } +- warnings() { +- return []; +- } +- get content() { +- return this.result.css; +- } +- get css() { +- return this.result.css; +- } +- get map() { +- return this.result.map; +- } +- get messages() { +- return []; +- } +- get opts() { +- return this.result.opts; +- } +- get processor() { +- return this.result.processor; +- } +- get root() { +- if (this._root) { +- return this._root; +- } +- let root2; +- let parser2 = parse$1; +- try { +- root2 = parser2(this._css, this._opts); +- } catch (error) { +- this.error = error; +- } +- if (this.error) { +- throw this.error; +- } else { +- this._root = root2; +- return root2; +- } +- } +- get [Symbol.toStringTag]() { +- return "NoWorkResult"; +- } +-}; +-var noWorkResult = NoWorkResult$1; +-NoWorkResult$1.default = NoWorkResult$1; +-let NoWorkResult2 = noWorkResult; +-let LazyResult$1 = lazyResult; +-let Document$1 = document$1; +-let Root$2 = root; +-let Processor$1 = class Processor { +- constructor(plugins = []) { +- this.version = "8.4.38"; +- this.plugins = this.normalize(plugins); +- } +- normalize(plugins) { +- let normalized = []; +- for (let i of plugins) { +- if (i.postcss === true) { +- i = i(); +- } else if (i.postcss) { +- i = i.postcss; +- } +- if (typeof i === "object" && Array.isArray(i.plugins)) { +- normalized = normalized.concat(i.plugins); +- } else if (typeof i === "object" && i.postcssPlugin) { +- normalized.push(i); +- } else if (typeof i === "function") { +- normalized.push(i); +- } else if (typeof i === "object" && (i.parse || i.stringify)) { +- if (process.env.NODE_ENV !== "production") { +- throw new Error( +- "PostCSS syntaxes cannot be used as plugins. Instead, please use one of the syntax/parser/stringifier options as outlined in your PostCSS runner documentation." +- ); +- } +- } else { +- throw new Error(i + " is not a PostCSS plugin"); +- } +- } +- return normalized; +- } +- process(css, opts = {}) { +- if (!this.plugins.length && !opts.parser && !opts.stringifier && !opts.syntax) { +- return new NoWorkResult2(this, css, opts); +- } else { +- return new LazyResult$1(this, css, opts); +- } +- } +- use(plugin2) { +- this.plugins = this.plugins.concat(this.normalize([plugin2])); +- return this; +- } +-}; +-var processor = Processor$1; +-Processor$1.default = Processor$1; +-Root$2.registerProcessor(Processor$1); +-Document$1.registerProcessor(Processor$1); +-let Declaration$1 = declaration; +-let PreviousMap2 = previousMap; +-let Comment$1 = comment; +-let AtRule$1 = atRule; +-let Input$1 = input; +-let Root$1 = root; +-let Rule$1 = rule; +-function fromJSON$1(json, inputs) { +- if (Array.isArray(json)) return json.map((n) => fromJSON$1(n)); +- let { inputs: ownInputs, ...defaults } = json; +- if (ownInputs) { +- inputs = []; +- for (let input2 of ownInputs) { +- let inputHydrated = { ...input2, __proto__: Input$1.prototype }; +- if (inputHydrated.map) { +- inputHydrated.map = { +- ...inputHydrated.map, +- __proto__: PreviousMap2.prototype +- }; +- } +- inputs.push(inputHydrated); +- } +- } +- if (defaults.nodes) { +- defaults.nodes = json.nodes.map((n) => fromJSON$1(n, inputs)); +- } +- if (defaults.source) { +- let { inputId, ...source } = defaults.source; +- defaults.source = source; +- if (inputId != null) { +- defaults.source.input = inputs[inputId]; +- } +- } +- if (defaults.type === "root") { +- return new Root$1(defaults); +- } else if (defaults.type === "decl") { +- return new Declaration$1(defaults); +- } else if (defaults.type === "rule") { +- return new Rule$1(defaults); +- } else if (defaults.type === "comment") { +- return new Comment$1(defaults); +- } else if (defaults.type === "atrule") { +- return new AtRule$1(defaults); +- } else { +- throw new Error("Unknown node type: " + json.type); +- } +-} +-var fromJSON_1 = fromJSON$1; +-fromJSON$1.default = fromJSON$1; +-let CssSyntaxError2 = cssSyntaxError; +-let Declaration2 = declaration; +-let LazyResult2 = lazyResult; +-let Container2 = container; +-let Processor2 = processor; +-let stringify = stringify_1; +-let fromJSON = fromJSON_1; +-let Document2 = document$1; +-let Warning2 = warning; +-let Comment2 = comment; +-let AtRule2 = atRule; +-let Result2 = result; +-let Input2 = input; +-let parse = parse_1; +-let list = list_1; +-let Rule2 = rule; +-let Root2 = root; +-let Node2 = node; +-function postcss(...plugins) { +- if (plugins.length === 1 && Array.isArray(plugins[0])) { +- plugins = plugins[0]; +- } +- return new Processor2(plugins); +-} +-postcss.plugin = function plugin(name, initializer) { +- let warningPrinted = false; +- function creator(...args) { +- if (console && console.warn && !warningPrinted) { +- warningPrinted = true; +- console.warn( +- name + ": postcss.plugin was deprecated. Migration guide:\nhttps://evilmartians.com/chronicles/postcss-8-plugin-migration" +- ); +- if (process.env.LANG && process.env.LANG.startsWith("cn")) { +- console.warn( +- name + ": 里面 postcss.plugin 被弃用. 迁移指南:\nhttps://www.w3ctech.com/topic/2226" +- ); +- } +- } +- let transformer = initializer(...args); +- transformer.postcssPlugin = name; +- transformer.postcssVersion = new Processor2().version; +- return transformer; +- } +- let cache; +- Object.defineProperty(creator, "postcss", { +- get() { +- if (!cache) cache = creator(); +- return cache; +- } +- }); +- creator.process = function(css, processOpts, pluginOpts) { +- return postcss([creator(pluginOpts)]).process(css, processOpts); +- }; +- return creator; +-}; +-postcss.stringify = stringify; +-postcss.parse = parse; +-postcss.fromJSON = fromJSON; +-postcss.list = list; +-postcss.comment = (defaults) => new Comment2(defaults); +-postcss.atRule = (defaults) => new AtRule2(defaults); +-postcss.decl = (defaults) => new Declaration2(defaults); +-postcss.rule = (defaults) => new Rule2(defaults); +-postcss.root = (defaults) => new Root2(defaults); +-postcss.document = (defaults) => new Document2(defaults); +-postcss.CssSyntaxError = CssSyntaxError2; +-postcss.Declaration = Declaration2; +-postcss.Container = Container2; +-postcss.Processor = Processor2; +-postcss.Document = Document2; +-postcss.Comment = Comment2; +-postcss.Warning = Warning2; +-postcss.AtRule = AtRule2; +-postcss.Result = Result2; +-postcss.Input = Input2; +-postcss.Rule = Rule2; +-postcss.Root = Root2; +-postcss.Node = Node2; +-LazyResult2.registerPostcss(postcss); +-var postcss_1 = postcss; +-postcss.default = postcss; +-const postcss$1 = /* @__PURE__ */ getDefaultExportFromCjs(postcss_1); +-postcss$1.stringify; +-postcss$1.fromJSON; +-postcss$1.plugin; +-postcss$1.parse; +-postcss$1.list; +-postcss$1.document; +-postcss$1.comment; +-postcss$1.atRule; +-postcss$1.rule; +-postcss$1.decl; +-postcss$1.root; +-postcss$1.CssSyntaxError; +-postcss$1.Declaration; +-postcss$1.Container; +-postcss$1.Processor; +-postcss$1.Document; +-postcss$1.Comment; +-postcss$1.Warning; +-postcss$1.AtRule; +-postcss$1.Result; +-postcss$1.Input; +-postcss$1.Rule; +-postcss$1.Root; +-postcss$1.Node; + const tagMap = { + script: "noscript", + // camel case svg element tag names diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml index f2732c517..485110952 100644 --- a/pnpm-lock.yaml +++ b/pnpm-lock.yaml @@ -5,6 +5,12 @@ settings: excludeLinksFromLockfile: false patchedDependencies: + '@rrweb/record@2.0.0-alpha.17': + hash: or7biymn4kjyhnfwbz74vqezxa + path: patches/@rrweb__record@2.0.0-alpha.17.patch + rrweb-snapshot@2.0.0-alpha.17: + hash: rlxgtlyuih2b32ogrmldlbq2li + path: patches/rrweb-snapshot@2.0.0-alpha.17.patch rrweb@2.0.0-alpha.17: hash: xlkuvshzdprjlpxe7nzsj3spyi path: patches/rrweb@2.0.0-alpha.17.patch @@ -68,7 +74,7 @@ devDependencies: version: 12.1.1(rollup@4.24.0)(tslib@2.5.0)(typescript@5.5.4) '@rrweb/record': specifier: 2.0.0-alpha.17 - version: 2.0.0-alpha.17 + version: 2.0.0-alpha.17(patch_hash=or7biymn4kjyhnfwbz74vqezxa) '@rrweb/rrweb-plugin-console-record': specifier: 2.0.0-alpha.17 version: 2.0.0-alpha.17(rrweb@2.0.0-alpha.17) @@ -209,7 +215,7 @@ devDependencies: version: 5.12.0(rollup@4.24.0) rrweb-snapshot: specifier: 2.0.0-alpha.17 - version: 2.0.0-alpha.17 + version: 2.0.0-alpha.17(patch_hash=rlxgtlyuih2b32ogrmldlbq2li) sinon: specifier: 9.0.2 version: 9.0.2 @@ -2802,12 +2808,13 @@ packages: dev: true optional: true - /@rrweb/record@2.0.0-alpha.17: + /@rrweb/record@2.0.0-alpha.17(patch_hash=or7biymn4kjyhnfwbz74vqezxa): resolution: {integrity: sha512-Je+lzjeWMF8/I0IDoXFzkGPKT8j7AkaBup5YcwUHlkp18VhLVze416MvI6915teE27uUA2ScXMXzG0Yiu5VTIw==} dependencies: '@rrweb/types': 2.0.0-alpha.17 rrweb: 2.0.0-alpha.17(patch_hash=xlkuvshzdprjlpxe7nzsj3spyi) dev: true + patched: true /@rrweb/rrweb-plugin-console-record@2.0.0-alpha.17(rrweb@2.0.0-alpha.17): resolution: {integrity: sha512-tjNJ3wWUDMMf275xr4Rb5tVYF2UR+wXvSxnyS9tRKnRa574PQQvx7sGbqM/O9AytYjnbiTrAMqNR7OFysGCMwQ==} @@ -2820,7 +2827,7 @@ packages: /@rrweb/types@2.0.0-alpha.17: resolution: {integrity: sha512-AfDTVUuCyCaIG0lTSqYtrZqJX39ZEYzs4fYKnexhQ+id+kbZIpIJtaut5cto6dWZbB3SEe4fW0o90Po3LvTmfg==} dependencies: - rrweb-snapshot: 2.0.0-alpha.17 + rrweb-snapshot: 2.0.0-alpha.17(patch_hash=rlxgtlyuih2b32ogrmldlbq2li) dev: true /@rrweb/utils@2.0.0-alpha.17: @@ -9410,14 +9417,15 @@ packages: /rrdom@2.0.0-alpha.17: resolution: {integrity: sha512-b6caDiNcFO96Opp7TGdcVd4OLGSXu5dJe+A0IDiAu8mk7OmhqZCSDlgQdTKmdO5wMf4zPsUTgb8H/aNvR3kDHA==} dependencies: - rrweb-snapshot: 2.0.0-alpha.17 + rrweb-snapshot: 2.0.0-alpha.17(patch_hash=rlxgtlyuih2b32ogrmldlbq2li) dev: true - /rrweb-snapshot@2.0.0-alpha.17: + /rrweb-snapshot@2.0.0-alpha.17(patch_hash=rlxgtlyuih2b32ogrmldlbq2li): resolution: {integrity: sha512-GBg5pV8LHOTbeVmH2VHLEFR0mc2QpQMzAvcoxEGfPNWgWHc8UvKCyq7pqN1vA+fDZ+yXXbixeO0kB2pzVvFCBw==} dependencies: postcss: 8.4.47 dev: true + patched: true /rrweb@2.0.0-alpha.17(patch_hash=xlkuvshzdprjlpxe7nzsj3spyi): resolution: {integrity: sha512-GQxBkCC4r9XL2bwSdv7iIS49M3cEA8OtObVq0rrQ4GUT4+h7omucGQ4x7m5YN5Vq1oalStBaBlYqF7yRnfG3JA==} @@ -9429,7 +9437,7 @@ packages: base64-arraybuffer: 1.0.2 mitt: 3.0.0 rrdom: 2.0.0-alpha.17 - rrweb-snapshot: 2.0.0-alpha.17 + rrweb-snapshot: 2.0.0-alpha.17(patch_hash=rlxgtlyuih2b32ogrmldlbq2li) dev: true patched: true From 02e946e3c86a04f85dc723e7c366d1355d327122 Mon Sep 17 00:00:00 2001 From: David Newell Date: Fri, 1 Nov 2024 12:26:48 +0000 Subject: [PATCH 16/21] replace packages for better typing --- package.json | 5 +- patches/rrweb-snapshot@2.0.0-alpha.17.patch | 3533 ----------------- patches/rrweb@2.0.0-alpha.17.patch | 81 - pnpm-lock.yaml | 25 +- .../replay/mutation-rate-limiter.test.ts | 5 +- .../replay/sessionrecording-utils.ts | 85 +- src/extensions/replay/sessionrecording.ts | 2 +- src/types.ts | 6 +- 8 files changed, 54 insertions(+), 3688 deletions(-) delete mode 100644 patches/rrweb-snapshot@2.0.0-alpha.17.patch delete mode 100644 patches/rrweb@2.0.0-alpha.17.patch diff --git a/package.json b/package.json index 71fbe1c82..69809143d 100644 --- a/package.json +++ b/package.json @@ -105,7 +105,6 @@ "rollup": "^4.24.0", "rollup-plugin-dts": "^6.1.1", "rollup-plugin-visualizer": "^5.12.0", - "rrweb-snapshot": "2.0.0-alpha.17", "sinon": "9.0.2", "testcafe": "1.19.0", "testcafe-browser-provider-browserstack": "1.14.0", @@ -127,9 +126,7 @@ ], "pnpm": { "patchedDependencies": { - "rrweb@2.0.0-alpha.17": "patches/rrweb@2.0.0-alpha.17.patch", - "@rrweb/record@2.0.0-alpha.17": "patches/@rrweb__record@2.0.0-alpha.17.patch", - "rrweb-snapshot@2.0.0-alpha.17": "patches/rrweb-snapshot@2.0.0-alpha.17.patch" + "@rrweb/record@2.0.0-alpha.17": "patches/@rrweb__record@2.0.0-alpha.17.patch" } } } diff --git a/patches/rrweb-snapshot@2.0.0-alpha.17.patch b/patches/rrweb-snapshot@2.0.0-alpha.17.patch deleted file mode 100644 index ac805f159..000000000 --- a/patches/rrweb-snapshot@2.0.0-alpha.17.patch +++ /dev/null @@ -1,3533 +0,0 @@ -diff --git a/dist/rrweb-snapshot.js b/dist/rrweb-snapshot.js -index c3a1e22f28b6d23821809dc4730b31acc39c87e9..9a8bed21e4920dc081d642fd68b4b2a2820e228a 100644 ---- a/dist/rrweb-snapshot.js -+++ b/dist/rrweb-snapshot.js -@@ -1423,3528 +1423,6 @@ function getAugmentedNamespace(n) { - }); - return a; - } --var picocolors_browser = { exports: {} }; --var x = String; --var create = function() { -- return { isColorSupported: false, reset: x, bold: x, dim: x, italic: x, underline: x, inverse: x, hidden: x, strikethrough: x, black: x, red: x, green: x, yellow: x, blue: x, magenta: x, cyan: x, white: x, gray: x, bgBlack: x, bgRed: x, bgGreen: x, bgYellow: x, bgBlue: x, bgMagenta: x, bgCyan: x, bgWhite: x }; --}; --picocolors_browser.exports = create(); --picocolors_browser.exports.createColors = create; --var picocolors_browserExports = picocolors_browser.exports; --const __viteBrowserExternal = {}; --const __viteBrowserExternal$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({ -- __proto__: null, -- default: __viteBrowserExternal --}, Symbol.toStringTag, { value: "Module" })); --const require$$2 = /* @__PURE__ */ getAugmentedNamespace(__viteBrowserExternal$1); --let pico = picocolors_browserExports; --let terminalHighlight$1 = require$$2; --let CssSyntaxError$3 = class CssSyntaxError extends Error { -- constructor(message, line, column, source, file, plugin2) { -- super(message); -- this.name = "CssSyntaxError"; -- this.reason = message; -- if (file) { -- this.file = file; -- } -- if (source) { -- this.source = source; -- } -- if (plugin2) { -- this.plugin = plugin2; -- } -- if (typeof line !== "undefined" && typeof column !== "undefined") { -- if (typeof line === "number") { -- this.line = line; -- this.column = column; -- } else { -- this.line = line.line; -- this.column = line.column; -- this.endLine = column.line; -- this.endColumn = column.column; -- } -- } -- this.setMessage(); -- if (Error.captureStackTrace) { -- Error.captureStackTrace(this, CssSyntaxError); -- } -- } -- setMessage() { -- this.message = this.plugin ? this.plugin + ": " : ""; -- this.message += this.file ? this.file : ""; -- if (typeof this.line !== "undefined") { -- this.message += ":" + this.line + ":" + this.column; -- } -- this.message += ": " + this.reason; -- } -- showSourceCode(color) { -- if (!this.source) return ""; -- let css = this.source; -- if (color == null) color = pico.isColorSupported; -- if (terminalHighlight$1) { -- if (color) css = terminalHighlight$1(css); -- } -- let lines = css.split(/\r?\n/); -- let start = Math.max(this.line - 3, 0); -- let end = Math.min(this.line + 2, lines.length); -- let maxWidth = String(end).length; -- let mark, aside; -- if (color) { -- let { bold, gray, red } = pico.createColors(true); -- mark = (text) => bold(red(text)); -- aside = (text) => gray(text); -- } else { -- mark = aside = (str) => str; -- } -- return lines.slice(start, end).map((line, index2) => { -- let number = start + 1 + index2; -- let gutter = " " + (" " + number).slice(-maxWidth) + " | "; -- if (number === this.line) { -- let spacing = aside(gutter.replace(/\d/g, " ")) + line.slice(0, this.column - 1).replace(/[^\t]/g, " "); -- return mark(">") + aside(gutter) + line + "\n " + spacing + mark("^"); -- } -- return " " + aside(gutter) + line; -- }).join("\n"); -- } -- toString() { -- let code = this.showSourceCode(); -- if (code) { -- code = "\n\n" + code + "\n"; -- } -- return this.name + ": " + this.message + code; -- } --}; --var cssSyntaxError = CssSyntaxError$3; --CssSyntaxError$3.default = CssSyntaxError$3; --var symbols = {}; --symbols.isClean = Symbol("isClean"); --symbols.my = Symbol("my"); --const DEFAULT_RAW = { -- after: "\n", -- beforeClose: "\n", -- beforeComment: "\n", -- beforeDecl: "\n", -- beforeOpen: " ", -- beforeRule: "\n", -- colon: ": ", -- commentLeft: " ", -- commentRight: " ", -- emptyBody: "", -- indent: " ", -- semicolon: false --}; --function capitalize(str) { -- return str[0].toUpperCase() + str.slice(1); --} --let Stringifier$2 = class Stringifier { -- constructor(builder) { -- this.builder = builder; -- } -- atrule(node2, semicolon) { -- let name = "@" + node2.name; -- let params = node2.params ? this.rawValue(node2, "params") : ""; -- if (typeof node2.raws.afterName !== "undefined") { -- name += node2.raws.afterName; -- } else if (params) { -- name += " "; -- } -- if (node2.nodes) { -- this.block(node2, name + params); -- } else { -- let end = (node2.raws.between || "") + (semicolon ? ";" : ""); -- this.builder(name + params + end, node2); -- } -- } -- beforeAfter(node2, detect) { -- let value; -- if (node2.type === "decl") { -- value = this.raw(node2, null, "beforeDecl"); -- } else if (node2.type === "comment") { -- value = this.raw(node2, null, "beforeComment"); -- } else if (detect === "before") { -- value = this.raw(node2, null, "beforeRule"); -- } else { -- value = this.raw(node2, null, "beforeClose"); -- } -- let buf = node2.parent; -- let depth = 0; -- while (buf && buf.type !== "root") { -- depth += 1; -- buf = buf.parent; -- } -- if (value.includes("\n")) { -- let indent = this.raw(node2, null, "indent"); -- if (indent.length) { -- for (let step = 0; step < depth; step++) value += indent; -- } -- } -- return value; -- } -- block(node2, start) { -- let between = this.raw(node2, "between", "beforeOpen"); -- this.builder(start + between + "{", node2, "start"); -- let after; -- if (node2.nodes && node2.nodes.length) { -- this.body(node2); -- after = this.raw(node2, "after"); -- } else { -- after = this.raw(node2, "after", "emptyBody"); -- } -- if (after) this.builder(after); -- this.builder("}", node2, "end"); -- } -- body(node2) { -- let last = node2.nodes.length - 1; -- while (last > 0) { -- if (node2.nodes[last].type !== "comment") break; -- last -= 1; -- } -- let semicolon = this.raw(node2, "semicolon"); -- for (let i = 0; i < node2.nodes.length; i++) { -- let child = node2.nodes[i]; -- let before = this.raw(child, "before"); -- if (before) this.builder(before); -- this.stringify(child, last !== i || semicolon); -- } -- } -- comment(node2) { -- let left = this.raw(node2, "left", "commentLeft"); -- let right = this.raw(node2, "right", "commentRight"); -- this.builder("/*" + left + node2.text + right + "*/", node2); -- } -- decl(node2, semicolon) { -- let between = this.raw(node2, "between", "colon"); -- let string = node2.prop + between + this.rawValue(node2, "value"); -- if (node2.important) { -- string += node2.raws.important || " !important"; -- } -- if (semicolon) string += ";"; -- this.builder(string, node2); -- } -- document(node2) { -- this.body(node2); -- } -- raw(node2, own, detect) { -- let value; -- if (!detect) detect = own; -- if (own) { -- value = node2.raws[own]; -- if (typeof value !== "undefined") return value; -- } -- let parent = node2.parent; -- if (detect === "before") { -- if (!parent || parent.type === "root" && parent.first === node2) { -- return ""; -- } -- if (parent && parent.type === "document") { -- return ""; -- } -- } -- if (!parent) return DEFAULT_RAW[detect]; -- let root2 = node2.root(); -- if (!root2.rawCache) root2.rawCache = {}; -- if (typeof root2.rawCache[detect] !== "undefined") { -- return root2.rawCache[detect]; -- } -- if (detect === "before" || detect === "after") { -- return this.beforeAfter(node2, detect); -- } else { -- let method = "raw" + capitalize(detect); -- if (this[method]) { -- value = this[method](root2, node2); -- } else { -- root2.walk((i) => { -- value = i.raws[own]; -- if (typeof value !== "undefined") return false; -- }); -- } -- } -- if (typeof value === "undefined") value = DEFAULT_RAW[detect]; -- root2.rawCache[detect] = value; -- return value; -- } -- rawBeforeClose(root2) { -- let value; -- root2.walk((i) => { -- if (i.nodes && i.nodes.length > 0) { -- if (typeof i.raws.after !== "undefined") { -- value = i.raws.after; -- if (value.includes("\n")) { -- value = value.replace(/[^\n]+$/, ""); -- } -- return false; -- } -- } -- }); -- if (value) value = value.replace(/\S/g, ""); -- return value; -- } -- rawBeforeComment(root2, node2) { -- let value; -- root2.walkComments((i) => { -- if (typeof i.raws.before !== "undefined") { -- value = i.raws.before; -- if (value.includes("\n")) { -- value = value.replace(/[^\n]+$/, ""); -- } -- return false; -- } -- }); -- if (typeof value === "undefined") { -- value = this.raw(node2, null, "beforeDecl"); -- } else if (value) { -- value = value.replace(/\S/g, ""); -- } -- return value; -- } -- rawBeforeDecl(root2, node2) { -- let value; -- root2.walkDecls((i) => { -- if (typeof i.raws.before !== "undefined") { -- value = i.raws.before; -- if (value.includes("\n")) { -- value = value.replace(/[^\n]+$/, ""); -- } -- return false; -- } -- }); -- if (typeof value === "undefined") { -- value = this.raw(node2, null, "beforeRule"); -- } else if (value) { -- value = value.replace(/\S/g, ""); -- } -- return value; -- } -- rawBeforeOpen(root2) { -- let value; -- root2.walk((i) => { -- if (i.type !== "decl") { -- value = i.raws.between; -- if (typeof value !== "undefined") return false; -- } -- }); -- return value; -- } -- rawBeforeRule(root2) { -- let value; -- root2.walk((i) => { -- if (i.nodes && (i.parent !== root2 || root2.first !== i)) { -- if (typeof i.raws.before !== "undefined") { -- value = i.raws.before; -- if (value.includes("\n")) { -- value = value.replace(/[^\n]+$/, ""); -- } -- return false; -- } -- } -- }); -- if (value) value = value.replace(/\S/g, ""); -- return value; -- } -- rawColon(root2) { -- let value; -- root2.walkDecls((i) => { -- if (typeof i.raws.between !== "undefined") { -- value = i.raws.between.replace(/[^\s:]/g, ""); -- return false; -- } -- }); -- return value; -- } -- rawEmptyBody(root2) { -- let value; -- root2.walk((i) => { -- if (i.nodes && i.nodes.length === 0) { -- value = i.raws.after; -- if (typeof value !== "undefined") return false; -- } -- }); -- return value; -- } -- rawIndent(root2) { -- if (root2.raws.indent) return root2.raws.indent; -- let value; -- root2.walk((i) => { -- let p = i.parent; -- if (p && p !== root2 && p.parent && p.parent === root2) { -- if (typeof i.raws.before !== "undefined") { -- let parts = i.raws.before.split("\n"); -- value = parts[parts.length - 1]; -- value = value.replace(/\S/g, ""); -- return false; -- } -- } -- }); -- return value; -- } -- rawSemicolon(root2) { -- let value; -- root2.walk((i) => { -- if (i.nodes && i.nodes.length && i.last.type === "decl") { -- value = i.raws.semicolon; -- if (typeof value !== "undefined") return false; -- } -- }); -- return value; -- } -- rawValue(node2, prop) { -- let value = node2[prop]; -- let raw = node2.raws[prop]; -- if (raw && raw.value === value) { -- return raw.raw; -- } -- return value; -- } -- root(node2) { -- this.body(node2); -- if (node2.raws.after) this.builder(node2.raws.after); -- } -- rule(node2) { -- this.block(node2, this.rawValue(node2, "selector")); -- if (node2.raws.ownSemicolon) { -- this.builder(node2.raws.ownSemicolon, node2, "end"); -- } -- } -- stringify(node2, semicolon) { -- if (!this[node2.type]) { -- throw new Error( -- "Unknown AST node type " + node2.type + ". Maybe you need to change PostCSS stringifier." -- ); -- } -- this[node2.type](node2, semicolon); -- } --}; --var stringifier = Stringifier$2; --Stringifier$2.default = Stringifier$2; --let Stringifier$1 = stringifier; --function stringify$4(node2, builder) { -- let str = new Stringifier$1(builder); -- str.stringify(node2); --} --var stringify_1 = stringify$4; --stringify$4.default = stringify$4; --let { isClean: isClean$2, my: my$2 } = symbols; --let CssSyntaxError$2 = cssSyntaxError; --let Stringifier2 = stringifier; --let stringify$3 = stringify_1; --function cloneNode(obj, parent) { -- let cloned = new obj.constructor(); -- for (let i in obj) { -- if (!Object.prototype.hasOwnProperty.call(obj, i)) { -- continue; -- } -- if (i === "proxyCache") continue; -- let value = obj[i]; -- let type = typeof value; -- if (i === "parent" && type === "object") { -- if (parent) cloned[i] = parent; -- } else if (i === "source") { -- cloned[i] = value; -- } else if (Array.isArray(value)) { -- cloned[i] = value.map((j) => cloneNode(j, cloned)); -- } else { -- if (type === "object" && value !== null) value = cloneNode(value); -- cloned[i] = value; -- } -- } -- return cloned; --} --let Node$4 = class Node { -- constructor(defaults = {}) { -- this.raws = {}; -- this[isClean$2] = false; -- this[my$2] = true; -- for (let name in defaults) { -- if (name === "nodes") { -- this.nodes = []; -- for (let node2 of defaults[name]) { -- if (typeof node2.clone === "function") { -- this.append(node2.clone()); -- } else { -- this.append(node2); -- } -- } -- } else { -- this[name] = defaults[name]; -- } -- } -- } -- addToError(error) { -- error.postcssNode = this; -- if (error.stack && this.source && /\n\s{4}at /.test(error.stack)) { -- let s = this.source; -- error.stack = error.stack.replace( -- /\n\s{4}at /, -- `$&${s.input.from}:${s.start.line}:${s.start.column}$&` -- ); -- } -- return error; -- } -- after(add) { -- this.parent.insertAfter(this, add); -- return this; -- } -- assign(overrides = {}) { -- for (let name in overrides) { -- this[name] = overrides[name]; -- } -- return this; -- } -- before(add) { -- this.parent.insertBefore(this, add); -- return this; -- } -- cleanRaws(keepBetween) { -- delete this.raws.before; -- delete this.raws.after; -- if (!keepBetween) delete this.raws.between; -- } -- clone(overrides = {}) { -- let cloned = cloneNode(this); -- for (let name in overrides) { -- cloned[name] = overrides[name]; -- } -- return cloned; -- } -- cloneAfter(overrides = {}) { -- let cloned = this.clone(overrides); -- this.parent.insertAfter(this, cloned); -- return cloned; -- } -- cloneBefore(overrides = {}) { -- let cloned = this.clone(overrides); -- this.parent.insertBefore(this, cloned); -- return cloned; -- } -- error(message, opts = {}) { -- if (this.source) { -- let { end, start } = this.rangeBy(opts); -- return this.source.input.error( -- message, -- { column: start.column, line: start.line }, -- { column: end.column, line: end.line }, -- opts -- ); -- } -- return new CssSyntaxError$2(message); -- } -- getProxyProcessor() { -- return { -- get(node2, prop) { -- if (prop === "proxyOf") { -- return node2; -- } else if (prop === "root") { -- return () => node2.root().toProxy(); -- } else { -- return node2[prop]; -- } -- }, -- set(node2, prop, value) { -- if (node2[prop] === value) return true; -- node2[prop] = value; -- if (prop === "prop" || prop === "value" || prop === "name" || prop === "params" || prop === "important" || /* c8 ignore next */ -- prop === "text") { -- node2.markDirty(); -- } -- return true; -- } -- }; -- } -- markDirty() { -- if (this[isClean$2]) { -- this[isClean$2] = false; -- let next = this; -- while (next = next.parent) { -- next[isClean$2] = false; -- } -- } -- } -- next() { -- if (!this.parent) return void 0; -- let index2 = this.parent.index(this); -- return this.parent.nodes[index2 + 1]; -- } -- positionBy(opts, stringRepresentation) { -- let pos = this.source.start; -- if (opts.index) { -- pos = this.positionInside(opts.index, stringRepresentation); -- } else if (opts.word) { -- stringRepresentation = this.toString(); -- let index2 = stringRepresentation.indexOf(opts.word); -- if (index2 !== -1) pos = this.positionInside(index2, stringRepresentation); -- } -- return pos; -- } -- positionInside(index2, stringRepresentation) { -- let string = stringRepresentation || this.toString(); -- let column = this.source.start.column; -- let line = this.source.start.line; -- for (let i = 0; i < index2; i++) { -- if (string[i] === "\n") { -- column = 1; -- line += 1; -- } else { -- column += 1; -- } -- } -- return { column, line }; -- } -- prev() { -- if (!this.parent) return void 0; -- let index2 = this.parent.index(this); -- return this.parent.nodes[index2 - 1]; -- } -- rangeBy(opts) { -- let start = { -- column: this.source.start.column, -- line: this.source.start.line -- }; -- let end = this.source.end ? { -- column: this.source.end.column + 1, -- line: this.source.end.line -- } : { -- column: start.column + 1, -- line: start.line -- }; -- if (opts.word) { -- let stringRepresentation = this.toString(); -- let index2 = stringRepresentation.indexOf(opts.word); -- if (index2 !== -1) { -- start = this.positionInside(index2, stringRepresentation); -- end = this.positionInside(index2 + opts.word.length, stringRepresentation); -- } -- } else { -- if (opts.start) { -- start = { -- column: opts.start.column, -- line: opts.start.line -- }; -- } else if (opts.index) { -- start = this.positionInside(opts.index); -- } -- if (opts.end) { -- end = { -- column: opts.end.column, -- line: opts.end.line -- }; -- } else if (typeof opts.endIndex === "number") { -- end = this.positionInside(opts.endIndex); -- } else if (opts.index) { -- end = this.positionInside(opts.index + 1); -- } -- } -- if (end.line < start.line || end.line === start.line && end.column <= start.column) { -- end = { column: start.column + 1, line: start.line }; -- } -- return { end, start }; -- } -- raw(prop, defaultType) { -- let str = new Stringifier2(); -- return str.raw(this, prop, defaultType); -- } -- remove() { -- if (this.parent) { -- this.parent.removeChild(this); -- } -- this.parent = void 0; -- return this; -- } -- replaceWith(...nodes) { -- if (this.parent) { -- let bookmark = this; -- let foundSelf = false; -- for (let node2 of nodes) { -- if (node2 === this) { -- foundSelf = true; -- } else if (foundSelf) { -- this.parent.insertAfter(bookmark, node2); -- bookmark = node2; -- } else { -- this.parent.insertBefore(bookmark, node2); -- } -- } -- if (!foundSelf) { -- this.remove(); -- } -- } -- return this; -- } -- root() { -- let result2 = this; -- while (result2.parent && result2.parent.type !== "document") { -- result2 = result2.parent; -- } -- return result2; -- } -- toJSON(_, inputs) { -- let fixed = {}; -- let emitInputs = inputs == null; -- inputs = inputs || /* @__PURE__ */ new Map(); -- let inputsNextIndex = 0; -- for (let name in this) { -- if (!Object.prototype.hasOwnProperty.call(this, name)) { -- continue; -- } -- if (name === "parent" || name === "proxyCache") continue; -- let value = this[name]; -- if (Array.isArray(value)) { -- fixed[name] = value.map((i) => { -- if (typeof i === "object" && i.toJSON) { -- return i.toJSON(null, inputs); -- } else { -- return i; -- } -- }); -- } else if (typeof value === "object" && value.toJSON) { -- fixed[name] = value.toJSON(null, inputs); -- } else if (name === "source") { -- let inputId = inputs.get(value.input); -- if (inputId == null) { -- inputId = inputsNextIndex; -- inputs.set(value.input, inputsNextIndex); -- inputsNextIndex++; -- } -- fixed[name] = { -- end: value.end, -- inputId, -- start: value.start -- }; -- } else { -- fixed[name] = value; -- } -- } -- if (emitInputs) { -- fixed.inputs = [...inputs.keys()].map((input2) => input2.toJSON()); -- } -- return fixed; -- } -- toProxy() { -- if (!this.proxyCache) { -- this.proxyCache = new Proxy(this, this.getProxyProcessor()); -- } -- return this.proxyCache; -- } -- toString(stringifier2 = stringify$3) { -- if (stringifier2.stringify) stringifier2 = stringifier2.stringify; -- let result2 = ""; -- stringifier2(this, (i) => { -- result2 += i; -- }); -- return result2; -- } -- warn(result2, text, opts) { -- let data = { node: this }; -- for (let i in opts) data[i] = opts[i]; -- return result2.warn(text, data); -- } -- get proxyOf() { -- return this; -- } --}; --var node = Node$4; --Node$4.default = Node$4; --let Node$3 = node; --let Declaration$4 = class Declaration extends Node$3 { -- constructor(defaults) { -- if (defaults && typeof defaults.value !== "undefined" && typeof defaults.value !== "string") { -- defaults = { ...defaults, value: String(defaults.value) }; -- } -- super(defaults); -- this.type = "decl"; -- } -- get variable() { -- return this.prop.startsWith("--") || this.prop[0] === "$"; -- } --}; --var declaration = Declaration$4; --Declaration$4.default = Declaration$4; --let urlAlphabet = "useandom-26T198340PX75pxJACKVERYMINDBUSHWOLF_GQZbfghjklqvwyzrict"; --let customAlphabet = (alphabet, defaultSize = 21) => { -- return (size = defaultSize) => { -- let id = ""; -- let i = size; -- while (i--) { -- id += alphabet[Math.random() * alphabet.length | 0]; -- } -- return id; -- }; --}; --let nanoid$1 = (size = 21) => { -- let id = ""; -- let i = size; -- while (i--) { -- id += urlAlphabet[Math.random() * 64 | 0]; -- } -- return id; --}; --var nonSecure = { nanoid: nanoid$1, customAlphabet }; --let { SourceMapConsumer: SourceMapConsumer$2, SourceMapGenerator: SourceMapGenerator$2 } = require$$2; --let { existsSync, readFileSync } = require$$2; --let { dirname: dirname$1, join } = require$$2; --function fromBase64(str) { -- if (Buffer) { -- return Buffer.from(str, "base64").toString(); -- } else { -- return window.atob(str); -- } --} --let PreviousMap$2 = class PreviousMap { -- constructor(css, opts) { -- if (opts.map === false) return; -- this.loadAnnotation(css); -- this.inline = this.startWith(this.annotation, "data:"); -- let prev = opts.map ? opts.map.prev : void 0; -- let text = this.loadMap(opts.from, prev); -- if (!this.mapFile && opts.from) { -- this.mapFile = opts.from; -- } -- if (this.mapFile) this.root = dirname$1(this.mapFile); -- if (text) this.text = text; -- } -- consumer() { -- if (!this.consumerCache) { -- this.consumerCache = new SourceMapConsumer$2(this.text); -- } -- return this.consumerCache; -- } -- decodeInline(text) { -- let baseCharsetUri = /^data:application\/json;charset=utf-?8;base64,/; -- let baseUri = /^data:application\/json;base64,/; -- let charsetUri = /^data:application\/json;charset=utf-?8,/; -- let uri = /^data:application\/json,/; -- if (charsetUri.test(text) || uri.test(text)) { -- return decodeURIComponent(text.substr(RegExp.lastMatch.length)); -- } -- if (baseCharsetUri.test(text) || baseUri.test(text)) { -- return fromBase64(text.substr(RegExp.lastMatch.length)); -- } -- let encoding = text.match(/data:application\/json;([^,]+),/)[1]; -- throw new Error("Unsupported source map encoding " + encoding); -- } -- getAnnotationURL(sourceMapString) { -- return sourceMapString.replace(/^\/\*\s*# sourceMappingURL=/, "").trim(); -- } -- isMap(map) { -- if (typeof map !== "object") return false; -- return typeof map.mappings === "string" || typeof map._mappings === "string" || Array.isArray(map.sections); -- } -- loadAnnotation(css) { -- let comments = css.match(/\/\*\s*# sourceMappingURL=/gm); -- if (!comments) return; -- let start = css.lastIndexOf(comments.pop()); -- let end = css.indexOf("*/", start); -- if (start > -1 && end > -1) { -- this.annotation = this.getAnnotationURL(css.substring(start, end)); -- } -- } -- loadFile(path) { -- this.root = dirname$1(path); -- if (existsSync(path)) { -- this.mapFile = path; -- return readFileSync(path, "utf-8").toString().trim(); -- } -- } -- loadMap(file, prev) { -- if (prev === false) return false; -- if (prev) { -- if (typeof prev === "string") { -- return prev; -- } else if (typeof prev === "function") { -- let prevPath = prev(file); -- if (prevPath) { -- let map = this.loadFile(prevPath); -- if (!map) { -- throw new Error( -- "Unable to load previous source map: " + prevPath.toString() -- ); -- } -- return map; -- } -- } else if (prev instanceof SourceMapConsumer$2) { -- return SourceMapGenerator$2.fromSourceMap(prev).toString(); -- } else if (prev instanceof SourceMapGenerator$2) { -- return prev.toString(); -- } else if (this.isMap(prev)) { -- return JSON.stringify(prev); -- } else { -- throw new Error( -- "Unsupported previous source map format: " + prev.toString() -- ); -- } -- } else if (this.inline) { -- return this.decodeInline(this.annotation); -- } else if (this.annotation) { -- let map = this.annotation; -- if (file) map = join(dirname$1(file), map); -- return this.loadFile(map); -- } -- } -- startWith(string, start) { -- if (!string) return false; -- return string.substr(0, start.length) === start; -- } -- withContent() { -- return !!(this.consumer().sourcesContent && this.consumer().sourcesContent.length > 0); -- } --}; --var previousMap = PreviousMap$2; --PreviousMap$2.default = PreviousMap$2; --let { SourceMapConsumer: SourceMapConsumer$1, SourceMapGenerator: SourceMapGenerator$1 } = require$$2; --let { fileURLToPath, pathToFileURL: pathToFileURL$1 } = require$$2; --let { isAbsolute, resolve: resolve$1 } = require$$2; --let { nanoid } = nonSecure; --let terminalHighlight = require$$2; --let CssSyntaxError$1 = cssSyntaxError; --let PreviousMap$1 = previousMap; --let fromOffsetCache = Symbol("fromOffsetCache"); --let sourceMapAvailable$1 = Boolean(SourceMapConsumer$1 && SourceMapGenerator$1); --let pathAvailable$1 = Boolean(resolve$1 && isAbsolute); --let Input$4 = class Input { -- constructor(css, opts = {}) { -- if (css === null || typeof css === "undefined" || typeof css === "object" && !css.toString) { -- throw new Error(`PostCSS received ${css} instead of CSS string`); -- } -- this.css = css.toString(); -- if (this.css[0] === "\uFEFF" || this.css[0] === "￾") { -- this.hasBOM = true; -- this.css = this.css.slice(1); -- } else { -- this.hasBOM = false; -- } -- if (opts.from) { -- if (!pathAvailable$1 || /^\w+:\/\//.test(opts.from) || isAbsolute(opts.from)) { -- this.file = opts.from; -- } else { -- this.file = resolve$1(opts.from); -- } -- } -- if (pathAvailable$1 && sourceMapAvailable$1) { -- let map = new PreviousMap$1(this.css, opts); -- if (map.text) { -- this.map = map; -- let file = map.consumer().file; -- if (!this.file && file) this.file = this.mapResolve(file); -- } -- } -- if (!this.file) { -- this.id = ""; -- } -- if (this.map) this.map.file = this.from; -- } -- error(message, line, column, opts = {}) { -- let result2, endLine, endColumn; -- if (line && typeof line === "object") { -- let start = line; -- let end = column; -- if (typeof start.offset === "number") { -- let pos = this.fromOffset(start.offset); -- line = pos.line; -- column = pos.col; -- } else { -- line = start.line; -- column = start.column; -- } -- if (typeof end.offset === "number") { -- let pos = this.fromOffset(end.offset); -- endLine = pos.line; -- endColumn = pos.col; -- } else { -- endLine = end.line; -- endColumn = end.column; -- } -- } else if (!column) { -- let pos = this.fromOffset(line); -- line = pos.line; -- column = pos.col; -- } -- let origin = this.origin(line, column, endLine, endColumn); -- if (origin) { -- result2 = new CssSyntaxError$1( -- message, -- origin.endLine === void 0 ? origin.line : { column: origin.column, line: origin.line }, -- origin.endLine === void 0 ? origin.column : { column: origin.endColumn, line: origin.endLine }, -- origin.source, -- origin.file, -- opts.plugin -- ); -- } else { -- result2 = new CssSyntaxError$1( -- message, -- endLine === void 0 ? line : { column, line }, -- endLine === void 0 ? column : { column: endColumn, line: endLine }, -- this.css, -- this.file, -- opts.plugin -- ); -- } -- result2.input = { column, endColumn, endLine, line, source: this.css }; -- if (this.file) { -- if (pathToFileURL$1) { -- result2.input.url = pathToFileURL$1(this.file).toString(); -- } -- result2.input.file = this.file; -- } -- return result2; -- } -- fromOffset(offset) { -- let lastLine, lineToIndex; -- if (!this[fromOffsetCache]) { -- let lines = this.css.split("\n"); -- lineToIndex = new Array(lines.length); -- let prevIndex = 0; -- for (let i = 0, l = lines.length; i < l; i++) { -- lineToIndex[i] = prevIndex; -- prevIndex += lines[i].length + 1; -- } -- this[fromOffsetCache] = lineToIndex; -- } else { -- lineToIndex = this[fromOffsetCache]; -- } -- lastLine = lineToIndex[lineToIndex.length - 1]; -- let min = 0; -- if (offset >= lastLine) { -- min = lineToIndex.length - 1; -- } else { -- let max = lineToIndex.length - 2; -- let mid; -- while (min < max) { -- mid = min + (max - min >> 1); -- if (offset < lineToIndex[mid]) { -- max = mid - 1; -- } else if (offset >= lineToIndex[mid + 1]) { -- min = mid + 1; -- } else { -- min = mid; -- break; -- } -- } -- } -- return { -- col: offset - lineToIndex[min] + 1, -- line: min + 1 -- }; -- } -- mapResolve(file) { -- if (/^\w+:\/\//.test(file)) { -- return file; -- } -- return resolve$1(this.map.consumer().sourceRoot || this.map.root || ".", file); -- } -- origin(line, column, endLine, endColumn) { -- if (!this.map) return false; -- let consumer = this.map.consumer(); -- let from = consumer.originalPositionFor({ column, line }); -- if (!from.source) return false; -- let to; -- if (typeof endLine === "number") { -- to = consumer.originalPositionFor({ column: endColumn, line: endLine }); -- } -- let fromUrl; -- if (isAbsolute(from.source)) { -- fromUrl = pathToFileURL$1(from.source); -- } else { -- fromUrl = new URL( -- from.source, -- this.map.consumer().sourceRoot || pathToFileURL$1(this.map.mapFile) -- ); -- } -- let result2 = { -- column: from.column, -- endColumn: to && to.column, -- endLine: to && to.line, -- line: from.line, -- url: fromUrl.toString() -- }; -- if (fromUrl.protocol === "file:") { -- if (fileURLToPath) { -- result2.file = fileURLToPath(fromUrl); -- } else { -- throw new Error(`file: protocol is not available in this PostCSS build`); -- } -- } -- let source = consumer.sourceContentFor(from.source); -- if (source) result2.source = source; -- return result2; -- } -- toJSON() { -- let json = {}; -- for (let name of ["hasBOM", "css", "file", "id"]) { -- if (this[name] != null) { -- json[name] = this[name]; -- } -- } -- if (this.map) { -- json.map = { ...this.map }; -- if (json.map.consumerCache) { -- json.map.consumerCache = void 0; -- } -- } -- return json; -- } -- get from() { -- return this.file || this.id; -- } --}; --var input = Input$4; --Input$4.default = Input$4; --if (terminalHighlight && terminalHighlight.registerInput) { -- terminalHighlight.registerInput(Input$4); --} --let { SourceMapConsumer, SourceMapGenerator } = require$$2; --let { dirname, relative, resolve, sep } = require$$2; --let { pathToFileURL } = require$$2; --let Input$3 = input; --let sourceMapAvailable = Boolean(SourceMapConsumer && SourceMapGenerator); --let pathAvailable = Boolean(dirname && resolve && relative && sep); --let MapGenerator$2 = class MapGenerator { -- constructor(stringify2, root2, opts, cssString) { -- this.stringify = stringify2; -- this.mapOpts = opts.map || {}; -- this.root = root2; -- this.opts = opts; -- this.css = cssString; -- this.originalCSS = cssString; -- this.usesFileUrls = !this.mapOpts.from && this.mapOpts.absolute; -- this.memoizedFileURLs = /* @__PURE__ */ new Map(); -- this.memoizedPaths = /* @__PURE__ */ new Map(); -- this.memoizedURLs = /* @__PURE__ */ new Map(); -- } -- addAnnotation() { -- let content; -- if (this.isInline()) { -- content = "data:application/json;base64," + this.toBase64(this.map.toString()); -- } else if (typeof this.mapOpts.annotation === "string") { -- content = this.mapOpts.annotation; -- } else if (typeof this.mapOpts.annotation === "function") { -- content = this.mapOpts.annotation(this.opts.to, this.root); -- } else { -- content = this.outputFile() + ".map"; -- } -- let eol = "\n"; -- if (this.css.includes("\r\n")) eol = "\r\n"; -- this.css += eol + "/*# sourceMappingURL=" + content + " */"; -- } -- applyPrevMaps() { -- for (let prev of this.previous()) { -- let from = this.toUrl(this.path(prev.file)); -- let root2 = prev.root || dirname(prev.file); -- let map; -- if (this.mapOpts.sourcesContent === false) { -- map = new SourceMapConsumer(prev.text); -- if (map.sourcesContent) { -- map.sourcesContent = null; -- } -- } else { -- map = prev.consumer(); -- } -- this.map.applySourceMap(map, from, this.toUrl(this.path(root2))); -- } -- } -- clearAnnotation() { -- if (this.mapOpts.annotation === false) return; -- if (this.root) { -- let node2; -- for (let i = this.root.nodes.length - 1; i >= 0; i--) { -- node2 = this.root.nodes[i]; -- if (node2.type !== "comment") continue; -- if (node2.text.indexOf("# sourceMappingURL=") === 0) { -- this.root.removeChild(i); -- } -- } -- } else if (this.css) { -- this.css = this.css.replace(/\n*?\/\*#[\S\s]*?\*\/$/gm, ""); -- } -- } -- generate() { -- this.clearAnnotation(); -- if (pathAvailable && sourceMapAvailable && this.isMap()) { -- return this.generateMap(); -- } else { -- let result2 = ""; -- this.stringify(this.root, (i) => { -- result2 += i; -- }); -- return [result2]; -- } -- } -- generateMap() { -- if (this.root) { -- this.generateString(); -- } else if (this.previous().length === 1) { -- let prev = this.previous()[0].consumer(); -- prev.file = this.outputFile(); -- this.map = SourceMapGenerator.fromSourceMap(prev, { -- ignoreInvalidMapping: true -- }); -- } else { -- this.map = new SourceMapGenerator({ -- file: this.outputFile(), -- ignoreInvalidMapping: true -- }); -- this.map.addMapping({ -- generated: { column: 0, line: 1 }, -- original: { column: 0, line: 1 }, -- source: this.opts.from ? this.toUrl(this.path(this.opts.from)) : "" -- }); -- } -- if (this.isSourcesContent()) this.setSourcesContent(); -- if (this.root && this.previous().length > 0) this.applyPrevMaps(); -- if (this.isAnnotation()) this.addAnnotation(); -- if (this.isInline()) { -- return [this.css]; -- } else { -- return [this.css, this.map]; -- } -- } -- generateString() { -- this.css = ""; -- this.map = new SourceMapGenerator({ -- file: this.outputFile(), -- ignoreInvalidMapping: true -- }); -- let line = 1; -- let column = 1; -- let noSource = ""; -- let mapping = { -- generated: { column: 0, line: 0 }, -- original: { column: 0, line: 0 }, -- source: "" -- }; -- let lines, last; -- this.stringify(this.root, (str, node2, type) => { -- this.css += str; -- if (node2 && type !== "end") { -- mapping.generated.line = line; -- mapping.generated.column = column - 1; -- if (node2.source && node2.source.start) { -- mapping.source = this.sourcePath(node2); -- mapping.original.line = node2.source.start.line; -- mapping.original.column = node2.source.start.column - 1; -- this.map.addMapping(mapping); -- } else { -- mapping.source = noSource; -- mapping.original.line = 1; -- mapping.original.column = 0; -- this.map.addMapping(mapping); -- } -- } -- lines = str.match(/\n/g); -- if (lines) { -- line += lines.length; -- last = str.lastIndexOf("\n"); -- column = str.length - last; -- } else { -- column += str.length; -- } -- if (node2 && type !== "start") { -- let p = node2.parent || { raws: {} }; -- let childless = node2.type === "decl" || node2.type === "atrule" && !node2.nodes; -- if (!childless || node2 !== p.last || p.raws.semicolon) { -- if (node2.source && node2.source.end) { -- mapping.source = this.sourcePath(node2); -- mapping.original.line = node2.source.end.line; -- mapping.original.column = node2.source.end.column - 1; -- mapping.generated.line = line; -- mapping.generated.column = column - 2; -- this.map.addMapping(mapping); -- } else { -- mapping.source = noSource; -- mapping.original.line = 1; -- mapping.original.column = 0; -- mapping.generated.line = line; -- mapping.generated.column = column - 1; -- this.map.addMapping(mapping); -- } -- } -- } -- }); -- } -- isAnnotation() { -- if (this.isInline()) { -- return true; -- } -- if (typeof this.mapOpts.annotation !== "undefined") { -- return this.mapOpts.annotation; -- } -- if (this.previous().length) { -- return this.previous().some((i) => i.annotation); -- } -- return true; -- } -- isInline() { -- if (typeof this.mapOpts.inline !== "undefined") { -- return this.mapOpts.inline; -- } -- let annotation = this.mapOpts.annotation; -- if (typeof annotation !== "undefined" && annotation !== true) { -- return false; -- } -- if (this.previous().length) { -- return this.previous().some((i) => i.inline); -- } -- return true; -- } -- isMap() { -- if (typeof this.opts.map !== "undefined") { -- return !!this.opts.map; -- } -- return this.previous().length > 0; -- } -- isSourcesContent() { -- if (typeof this.mapOpts.sourcesContent !== "undefined") { -- return this.mapOpts.sourcesContent; -- } -- if (this.previous().length) { -- return this.previous().some((i) => i.withContent()); -- } -- return true; -- } -- outputFile() { -- if (this.opts.to) { -- return this.path(this.opts.to); -- } else if (this.opts.from) { -- return this.path(this.opts.from); -- } else { -- return "to.css"; -- } -- } -- path(file) { -- if (this.mapOpts.absolute) return file; -- if (file.charCodeAt(0) === 60) return file; -- if (/^\w+:\/\//.test(file)) return file; -- let cached = this.memoizedPaths.get(file); -- if (cached) return cached; -- let from = this.opts.to ? dirname(this.opts.to) : "."; -- if (typeof this.mapOpts.annotation === "string") { -- from = dirname(resolve(from, this.mapOpts.annotation)); -- } -- let path = relative(from, file); -- this.memoizedPaths.set(file, path); -- return path; -- } -- previous() { -- if (!this.previousMaps) { -- this.previousMaps = []; -- if (this.root) { -- this.root.walk((node2) => { -- if (node2.source && node2.source.input.map) { -- let map = node2.source.input.map; -- if (!this.previousMaps.includes(map)) { -- this.previousMaps.push(map); -- } -- } -- }); -- } else { -- let input2 = new Input$3(this.originalCSS, this.opts); -- if (input2.map) this.previousMaps.push(input2.map); -- } -- } -- return this.previousMaps; -- } -- setSourcesContent() { -- let already = {}; -- if (this.root) { -- this.root.walk((node2) => { -- if (node2.source) { -- let from = node2.source.input.from; -- if (from && !already[from]) { -- already[from] = true; -- let fromUrl = this.usesFileUrls ? this.toFileUrl(from) : this.toUrl(this.path(from)); -- this.map.setSourceContent(fromUrl, node2.source.input.css); -- } -- } -- }); -- } else if (this.css) { -- let from = this.opts.from ? this.toUrl(this.path(this.opts.from)) : ""; -- this.map.setSourceContent(from, this.css); -- } -- } -- sourcePath(node2) { -- if (this.mapOpts.from) { -- return this.toUrl(this.mapOpts.from); -- } else if (this.usesFileUrls) { -- return this.toFileUrl(node2.source.input.from); -- } else { -- return this.toUrl(this.path(node2.source.input.from)); -- } -- } -- toBase64(str) { -- if (Buffer) { -- return Buffer.from(str).toString("base64"); -- } else { -- return window.btoa(unescape(encodeURIComponent(str))); -- } -- } -- toFileUrl(path) { -- let cached = this.memoizedFileURLs.get(path); -- if (cached) return cached; -- if (pathToFileURL) { -- let fileURL = pathToFileURL(path).toString(); -- this.memoizedFileURLs.set(path, fileURL); -- return fileURL; -- } else { -- throw new Error( -- "`map.absolute` option is not available in this PostCSS build" -- ); -- } -- } -- toUrl(path) { -- let cached = this.memoizedURLs.get(path); -- if (cached) return cached; -- if (sep === "\\") { -- path = path.replace(/\\/g, "/"); -- } -- let url = encodeURI(path).replace(/[#?]/g, encodeURIComponent); -- this.memoizedURLs.set(path, url); -- return url; -- } --}; --var mapGenerator = MapGenerator$2; --let Node$2 = node; --let Comment$4 = class Comment extends Node$2 { -- constructor(defaults) { -- super(defaults); -- this.type = "comment"; -- } --}; --var comment = Comment$4; --Comment$4.default = Comment$4; --let { isClean: isClean$1, my: my$1 } = symbols; --let Declaration$3 = declaration; --let Comment$3 = comment; --let Node$1 = node; --let parse$4, Rule$4, AtRule$4, Root$6; --function cleanSource(nodes) { -- return nodes.map((i) => { -- if (i.nodes) i.nodes = cleanSource(i.nodes); -- delete i.source; -- return i; -- }); --} --function markDirtyUp(node2) { -- node2[isClean$1] = false; -- if (node2.proxyOf.nodes) { -- for (let i of node2.proxyOf.nodes) { -- markDirtyUp(i); -- } -- } --} --let Container$7 = class Container extends Node$1 { -- append(...children) { -- for (let child of children) { -- let nodes = this.normalize(child, this.last); -- for (let node2 of nodes) this.proxyOf.nodes.push(node2); -- } -- this.markDirty(); -- return this; -- } -- cleanRaws(keepBetween) { -- super.cleanRaws(keepBetween); -- if (this.nodes) { -- for (let node2 of this.nodes) node2.cleanRaws(keepBetween); -- } -- } -- each(callback) { -- if (!this.proxyOf.nodes) return void 0; -- let iterator = this.getIterator(); -- let index2, result2; -- while (this.indexes[iterator] < this.proxyOf.nodes.length) { -- index2 = this.indexes[iterator]; -- result2 = callback(this.proxyOf.nodes[index2], index2); -- if (result2 === false) break; -- this.indexes[iterator] += 1; -- } -- delete this.indexes[iterator]; -- return result2; -- } -- every(condition) { -- return this.nodes.every(condition); -- } -- getIterator() { -- if (!this.lastEach) this.lastEach = 0; -- if (!this.indexes) this.indexes = {}; -- this.lastEach += 1; -- let iterator = this.lastEach; -- this.indexes[iterator] = 0; -- return iterator; -- } -- getProxyProcessor() { -- return { -- get(node2, prop) { -- if (prop === "proxyOf") { -- return node2; -- } else if (!node2[prop]) { -- return node2[prop]; -- } else if (prop === "each" || typeof prop === "string" && prop.startsWith("walk")) { -- return (...args) => { -- return node2[prop]( -- ...args.map((i) => { -- if (typeof i === "function") { -- return (child, index2) => i(child.toProxy(), index2); -- } else { -- return i; -- } -- }) -- ); -- }; -- } else if (prop === "every" || prop === "some") { -- return (cb) => { -- return node2[prop]( -- (child, ...other) => cb(child.toProxy(), ...other) -- ); -- }; -- } else if (prop === "root") { -- return () => node2.root().toProxy(); -- } else if (prop === "nodes") { -- return node2.nodes.map((i) => i.toProxy()); -- } else if (prop === "first" || prop === "last") { -- return node2[prop].toProxy(); -- } else { -- return node2[prop]; -- } -- }, -- set(node2, prop, value) { -- if (node2[prop] === value) return true; -- node2[prop] = value; -- if (prop === "name" || prop === "params" || prop === "selector") { -- node2.markDirty(); -- } -- return true; -- } -- }; -- } -- index(child) { -- if (typeof child === "number") return child; -- if (child.proxyOf) child = child.proxyOf; -- return this.proxyOf.nodes.indexOf(child); -- } -- insertAfter(exist, add) { -- let existIndex = this.index(exist); -- let nodes = this.normalize(add, this.proxyOf.nodes[existIndex]).reverse(); -- existIndex = this.index(exist); -- for (let node2 of nodes) this.proxyOf.nodes.splice(existIndex + 1, 0, node2); -- let index2; -- for (let id in this.indexes) { -- index2 = this.indexes[id]; -- if (existIndex < index2) { -- this.indexes[id] = index2 + nodes.length; -- } -- } -- this.markDirty(); -- return this; -- } -- insertBefore(exist, add) { -- let existIndex = this.index(exist); -- let type = existIndex === 0 ? "prepend" : false; -- let nodes = this.normalize(add, this.proxyOf.nodes[existIndex], type).reverse(); -- existIndex = this.index(exist); -- for (let node2 of nodes) this.proxyOf.nodes.splice(existIndex, 0, node2); -- let index2; -- for (let id in this.indexes) { -- index2 = this.indexes[id]; -- if (existIndex <= index2) { -- this.indexes[id] = index2 + nodes.length; -- } -- } -- this.markDirty(); -- return this; -- } -- normalize(nodes, sample) { -- if (typeof nodes === "string") { -- nodes = cleanSource(parse$4(nodes).nodes); -- } else if (typeof nodes === "undefined") { -- nodes = []; -- } else if (Array.isArray(nodes)) { -- nodes = nodes.slice(0); -- for (let i of nodes) { -- if (i.parent) i.parent.removeChild(i, "ignore"); -- } -- } else if (nodes.type === "root" && this.type !== "document") { -- nodes = nodes.nodes.slice(0); -- for (let i of nodes) { -- if (i.parent) i.parent.removeChild(i, "ignore"); -- } -- } else if (nodes.type) { -- nodes = [nodes]; -- } else if (nodes.prop) { -- if (typeof nodes.value === "undefined") { -- throw new Error("Value field is missed in node creation"); -- } else if (typeof nodes.value !== "string") { -- nodes.value = String(nodes.value); -- } -- nodes = [new Declaration$3(nodes)]; -- } else if (nodes.selector) { -- nodes = [new Rule$4(nodes)]; -- } else if (nodes.name) { -- nodes = [new AtRule$4(nodes)]; -- } else if (nodes.text) { -- nodes = [new Comment$3(nodes)]; -- } else { -- throw new Error("Unknown node type in node creation"); -- } -- let processed = nodes.map((i) => { -- if (!i[my$1]) Container.rebuild(i); -- i = i.proxyOf; -- if (i.parent) i.parent.removeChild(i); -- if (i[isClean$1]) markDirtyUp(i); -- if (typeof i.raws.before === "undefined") { -- if (sample && typeof sample.raws.before !== "undefined") { -- i.raws.before = sample.raws.before.replace(/\S/g, ""); -- } -- } -- i.parent = this.proxyOf; -- return i; -- }); -- return processed; -- } -- prepend(...children) { -- children = children.reverse(); -- for (let child of children) { -- let nodes = this.normalize(child, this.first, "prepend").reverse(); -- for (let node2 of nodes) this.proxyOf.nodes.unshift(node2); -- for (let id in this.indexes) { -- this.indexes[id] = this.indexes[id] + nodes.length; -- } -- } -- this.markDirty(); -- return this; -- } -- push(child) { -- child.parent = this; -- this.proxyOf.nodes.push(child); -- return this; -- } -- removeAll() { -- for (let node2 of this.proxyOf.nodes) node2.parent = void 0; -- this.proxyOf.nodes = []; -- this.markDirty(); -- return this; -- } -- removeChild(child) { -- child = this.index(child); -- this.proxyOf.nodes[child].parent = void 0; -- this.proxyOf.nodes.splice(child, 1); -- let index2; -- for (let id in this.indexes) { -- index2 = this.indexes[id]; -- if (index2 >= child) { -- this.indexes[id] = index2 - 1; -- } -- } -- this.markDirty(); -- return this; -- } -- replaceValues(pattern, opts, callback) { -- if (!callback) { -- callback = opts; -- opts = {}; -- } -- this.walkDecls((decl) => { -- if (opts.props && !opts.props.includes(decl.prop)) return; -- if (opts.fast && !decl.value.includes(opts.fast)) return; -- decl.value = decl.value.replace(pattern, callback); -- }); -- this.markDirty(); -- return this; -- } -- some(condition) { -- return this.nodes.some(condition); -- } -- walk(callback) { -- return this.each((child, i) => { -- let result2; -- try { -- result2 = callback(child, i); -- } catch (e) { -- throw child.addToError(e); -- } -- if (result2 !== false && child.walk) { -- result2 = child.walk(callback); -- } -- return result2; -- }); -- } -- walkAtRules(name, callback) { -- if (!callback) { -- callback = name; -- return this.walk((child, i) => { -- if (child.type === "atrule") { -- return callback(child, i); -- } -- }); -- } -- if (name instanceof RegExp) { -- return this.walk((child, i) => { -- if (child.type === "atrule" && name.test(child.name)) { -- return callback(child, i); -- } -- }); -- } -- return this.walk((child, i) => { -- if (child.type === "atrule" && child.name === name) { -- return callback(child, i); -- } -- }); -- } -- walkComments(callback) { -- return this.walk((child, i) => { -- if (child.type === "comment") { -- return callback(child, i); -- } -- }); -- } -- walkDecls(prop, callback) { -- if (!callback) { -- callback = prop; -- return this.walk((child, i) => { -- if (child.type === "decl") { -- return callback(child, i); -- } -- }); -- } -- if (prop instanceof RegExp) { -- return this.walk((child, i) => { -- if (child.type === "decl" && prop.test(child.prop)) { -- return callback(child, i); -- } -- }); -- } -- return this.walk((child, i) => { -- if (child.type === "decl" && child.prop === prop) { -- return callback(child, i); -- } -- }); -- } -- walkRules(selector, callback) { -- if (!callback) { -- callback = selector; -- return this.walk((child, i) => { -- if (child.type === "rule") { -- return callback(child, i); -- } -- }); -- } -- if (selector instanceof RegExp) { -- return this.walk((child, i) => { -- if (child.type === "rule" && selector.test(child.selector)) { -- return callback(child, i); -- } -- }); -- } -- return this.walk((child, i) => { -- if (child.type === "rule" && child.selector === selector) { -- return callback(child, i); -- } -- }); -- } -- get first() { -- if (!this.proxyOf.nodes) return void 0; -- return this.proxyOf.nodes[0]; -- } -- get last() { -- if (!this.proxyOf.nodes) return void 0; -- return this.proxyOf.nodes[this.proxyOf.nodes.length - 1]; -- } --}; --Container$7.registerParse = (dependant) => { -- parse$4 = dependant; --}; --Container$7.registerRule = (dependant) => { -- Rule$4 = dependant; --}; --Container$7.registerAtRule = (dependant) => { -- AtRule$4 = dependant; --}; --Container$7.registerRoot = (dependant) => { -- Root$6 = dependant; --}; --var container = Container$7; --Container$7.default = Container$7; --Container$7.rebuild = (node2) => { -- if (node2.type === "atrule") { -- Object.setPrototypeOf(node2, AtRule$4.prototype); -- } else if (node2.type === "rule") { -- Object.setPrototypeOf(node2, Rule$4.prototype); -- } else if (node2.type === "decl") { -- Object.setPrototypeOf(node2, Declaration$3.prototype); -- } else if (node2.type === "comment") { -- Object.setPrototypeOf(node2, Comment$3.prototype); -- } else if (node2.type === "root") { -- Object.setPrototypeOf(node2, Root$6.prototype); -- } -- node2[my$1] = true; -- if (node2.nodes) { -- node2.nodes.forEach((child) => { -- Container$7.rebuild(child); -- }); -- } --}; --let Container$6 = container; --let LazyResult$4, Processor$3; --let Document$3 = class Document extends Container$6 { -- constructor(defaults) { -- super({ type: "document", ...defaults }); -- if (!this.nodes) { -- this.nodes = []; -- } -- } -- toResult(opts = {}) { -- let lazy = new LazyResult$4(new Processor$3(), this, opts); -- return lazy.stringify(); -- } --}; --Document$3.registerLazyResult = (dependant) => { -- LazyResult$4 = dependant; --}; --Document$3.registerProcessor = (dependant) => { -- Processor$3 = dependant; --}; --var document$1 = Document$3; --Document$3.default = Document$3; --let printed = {}; --var warnOnce$2 = function warnOnce(message) { -- if (printed[message]) return; -- printed[message] = true; -- if (typeof console !== "undefined" && console.warn) { -- console.warn(message); -- } --}; --let Warning$2 = class Warning { -- constructor(text, opts = {}) { -- this.type = "warning"; -- this.text = text; -- if (opts.node && opts.node.source) { -- let range = opts.node.rangeBy(opts); -- this.line = range.start.line; -- this.column = range.start.column; -- this.endLine = range.end.line; -- this.endColumn = range.end.column; -- } -- for (let opt in opts) this[opt] = opts[opt]; -- } -- toString() { -- if (this.node) { -- return this.node.error(this.text, { -- index: this.index, -- plugin: this.plugin, -- word: this.word -- }).message; -- } -- if (this.plugin) { -- return this.plugin + ": " + this.text; -- } -- return this.text; -- } --}; --var warning = Warning$2; --Warning$2.default = Warning$2; --let Warning$1 = warning; --let Result$3 = class Result { -- constructor(processor2, root2, opts) { -- this.processor = processor2; -- this.messages = []; -- this.root = root2; -- this.opts = opts; -- this.css = void 0; -- this.map = void 0; -- } -- toString() { -- return this.css; -- } -- warn(text, opts = {}) { -- if (!opts.plugin) { -- if (this.lastPlugin && this.lastPlugin.postcssPlugin) { -- opts.plugin = this.lastPlugin.postcssPlugin; -- } -- } -- let warning2 = new Warning$1(text, opts); -- this.messages.push(warning2); -- return warning2; -- } -- warnings() { -- return this.messages.filter((i) => i.type === "warning"); -- } -- get content() { -- return this.css; -- } --}; --var result = Result$3; --Result$3.default = Result$3; --const SINGLE_QUOTE = "'".charCodeAt(0); --const DOUBLE_QUOTE = '"'.charCodeAt(0); --const BACKSLASH = "\\".charCodeAt(0); --const SLASH = "/".charCodeAt(0); --const NEWLINE = "\n".charCodeAt(0); --const SPACE = " ".charCodeAt(0); --const FEED = "\f".charCodeAt(0); --const TAB = " ".charCodeAt(0); --const CR = "\r".charCodeAt(0); --const OPEN_SQUARE = "[".charCodeAt(0); --const CLOSE_SQUARE = "]".charCodeAt(0); --const OPEN_PARENTHESES = "(".charCodeAt(0); --const CLOSE_PARENTHESES = ")".charCodeAt(0); --const OPEN_CURLY = "{".charCodeAt(0); --const CLOSE_CURLY = "}".charCodeAt(0); --const SEMICOLON = ";".charCodeAt(0); --const ASTERISK = "*".charCodeAt(0); --const COLON = ":".charCodeAt(0); --const AT = "@".charCodeAt(0); --const RE_AT_END = /[\t\n\f\r "#'()/;[\\\]{}]/g; --const RE_WORD_END = /[\t\n\f\r !"#'():;@[\\\]{}]|\/(?=\*)/g; --const RE_BAD_BRACKET = /.[\r\n"'(/\\]/; --const RE_HEX_ESCAPE = /[\da-f]/i; --var tokenize = function tokenizer(input2, options = {}) { -- let css = input2.css.valueOf(); -- let ignore = options.ignoreErrors; -- let code, next, quote, content, escape; -- let escaped, escapePos, prev, n, currentToken; -- let length = css.length; -- let pos = 0; -- let buffer = []; -- let returned = []; -- function position() { -- return pos; -- } -- function unclosed(what) { -- throw input2.error("Unclosed " + what, pos); -- } -- function endOfFile() { -- return returned.length === 0 && pos >= length; -- } -- function nextToken(opts) { -- if (returned.length) return returned.pop(); -- if (pos >= length) return; -- let ignoreUnclosed = opts ? opts.ignoreUnclosed : false; -- code = css.charCodeAt(pos); -- switch (code) { -- case NEWLINE: -- case SPACE: -- case TAB: -- case CR: -- case FEED: { -- next = pos; -- do { -- next += 1; -- code = css.charCodeAt(next); -- } while (code === SPACE || code === NEWLINE || code === TAB || code === CR || code === FEED); -- currentToken = ["space", css.slice(pos, next)]; -- pos = next - 1; -- break; -- } -- case OPEN_SQUARE: -- case CLOSE_SQUARE: -- case OPEN_CURLY: -- case CLOSE_CURLY: -- case COLON: -- case SEMICOLON: -- case CLOSE_PARENTHESES: { -- let controlChar = String.fromCharCode(code); -- currentToken = [controlChar, controlChar, pos]; -- break; -- } -- case OPEN_PARENTHESES: { -- prev = buffer.length ? buffer.pop()[1] : ""; -- n = css.charCodeAt(pos + 1); -- if (prev === "url" && n !== SINGLE_QUOTE && n !== DOUBLE_QUOTE && n !== SPACE && n !== NEWLINE && n !== TAB && n !== FEED && n !== CR) { -- next = pos; -- do { -- escaped = false; -- next = css.indexOf(")", next + 1); -- if (next === -1) { -- if (ignore || ignoreUnclosed) { -- next = pos; -- break; -- } else { -- unclosed("bracket"); -- } -- } -- escapePos = next; -- while (css.charCodeAt(escapePos - 1) === BACKSLASH) { -- escapePos -= 1; -- escaped = !escaped; -- } -- } while (escaped); -- currentToken = ["brackets", css.slice(pos, next + 1), pos, next]; -- pos = next; -- } else { -- next = css.indexOf(")", pos + 1); -- content = css.slice(pos, next + 1); -- if (next === -1 || RE_BAD_BRACKET.test(content)) { -- currentToken = ["(", "(", pos]; -- } else { -- currentToken = ["brackets", content, pos, next]; -- pos = next; -- } -- } -- break; -- } -- case SINGLE_QUOTE: -- case DOUBLE_QUOTE: { -- quote = code === SINGLE_QUOTE ? "'" : '"'; -- next = pos; -- do { -- escaped = false; -- next = css.indexOf(quote, next + 1); -- if (next === -1) { -- if (ignore || ignoreUnclosed) { -- next = pos + 1; -- break; -- } else { -- unclosed("string"); -- } -- } -- escapePos = next; -- while (css.charCodeAt(escapePos - 1) === BACKSLASH) { -- escapePos -= 1; -- escaped = !escaped; -- } -- } while (escaped); -- currentToken = ["string", css.slice(pos, next + 1), pos, next]; -- pos = next; -- break; -- } -- case AT: { -- RE_AT_END.lastIndex = pos + 1; -- RE_AT_END.test(css); -- if (RE_AT_END.lastIndex === 0) { -- next = css.length - 1; -- } else { -- next = RE_AT_END.lastIndex - 2; -- } -- currentToken = ["at-word", css.slice(pos, next + 1), pos, next]; -- pos = next; -- break; -- } -- case BACKSLASH: { -- next = pos; -- escape = true; -- while (css.charCodeAt(next + 1) === BACKSLASH) { -- next += 1; -- escape = !escape; -- } -- code = css.charCodeAt(next + 1); -- if (escape && code !== SLASH && code !== SPACE && code !== NEWLINE && code !== TAB && code !== CR && code !== FEED) { -- next += 1; -- if (RE_HEX_ESCAPE.test(css.charAt(next))) { -- while (RE_HEX_ESCAPE.test(css.charAt(next + 1))) { -- next += 1; -- } -- if (css.charCodeAt(next + 1) === SPACE) { -- next += 1; -- } -- } -- } -- currentToken = ["word", css.slice(pos, next + 1), pos, next]; -- pos = next; -- break; -- } -- default: { -- if (code === SLASH && css.charCodeAt(pos + 1) === ASTERISK) { -- next = css.indexOf("*/", pos + 2) + 1; -- if (next === 0) { -- if (ignore || ignoreUnclosed) { -- next = css.length; -- } else { -- unclosed("comment"); -- } -- } -- currentToken = ["comment", css.slice(pos, next + 1), pos, next]; -- pos = next; -- } else { -- RE_WORD_END.lastIndex = pos + 1; -- RE_WORD_END.test(css); -- if (RE_WORD_END.lastIndex === 0) { -- next = css.length - 1; -- } else { -- next = RE_WORD_END.lastIndex - 2; -- } -- currentToken = ["word", css.slice(pos, next + 1), pos, next]; -- buffer.push(currentToken); -- pos = next; -- } -- break; -- } -- } -- pos++; -- return currentToken; -- } -- function back(token) { -- returned.push(token); -- } -- return { -- back, -- endOfFile, -- nextToken, -- position -- }; --}; --let Container$5 = container; --let AtRule$3 = class AtRule extends Container$5 { -- constructor(defaults) { -- super(defaults); -- this.type = "atrule"; -- } -- append(...children) { -- if (!this.proxyOf.nodes) this.nodes = []; -- return super.append(...children); -- } -- prepend(...children) { -- if (!this.proxyOf.nodes) this.nodes = []; -- return super.prepend(...children); -- } --}; --var atRule = AtRule$3; --AtRule$3.default = AtRule$3; --Container$5.registerAtRule(AtRule$3); --let Container$4 = container; --let LazyResult$3, Processor$2; --let Root$5 = class Root extends Container$4 { -- constructor(defaults) { -- super(defaults); -- this.type = "root"; -- if (!this.nodes) this.nodes = []; -- } -- normalize(child, sample, type) { -- let nodes = super.normalize(child); -- if (sample) { -- if (type === "prepend") { -- if (this.nodes.length > 1) { -- sample.raws.before = this.nodes[1].raws.before; -- } else { -- delete sample.raws.before; -- } -- } else if (this.first !== sample) { -- for (let node2 of nodes) { -- node2.raws.before = sample.raws.before; -- } -- } -- } -- return nodes; -- } -- removeChild(child, ignore) { -- let index2 = this.index(child); -- if (!ignore && index2 === 0 && this.nodes.length > 1) { -- this.nodes[1].raws.before = this.nodes[index2].raws.before; -- } -- return super.removeChild(child); -- } -- toResult(opts = {}) { -- let lazy = new LazyResult$3(new Processor$2(), this, opts); -- return lazy.stringify(); -- } --}; --Root$5.registerLazyResult = (dependant) => { -- LazyResult$3 = dependant; --}; --Root$5.registerProcessor = (dependant) => { -- Processor$2 = dependant; --}; --var root = Root$5; --Root$5.default = Root$5; --Container$4.registerRoot(Root$5); --let list$2 = { -- comma(string) { -- return list$2.split(string, [","], true); -- }, -- space(string) { -- let spaces = [" ", "\n", " "]; -- return list$2.split(string, spaces); -- }, -- split(string, separators, last) { -- let array = []; -- let current = ""; -- let split = false; -- let func = 0; -- let inQuote = false; -- let prevQuote = ""; -- let escape = false; -- for (let letter of string) { -- if (escape) { -- escape = false; -- } else if (letter === "\\") { -- escape = true; -- } else if (inQuote) { -- if (letter === prevQuote) { -- inQuote = false; -- } -- } else if (letter === '"' || letter === "'") { -- inQuote = true; -- prevQuote = letter; -- } else if (letter === "(") { -- func += 1; -- } else if (letter === ")") { -- if (func > 0) func -= 1; -- } else if (func === 0) { -- if (separators.includes(letter)) split = true; -- } -- if (split) { -- if (current !== "") array.push(current.trim()); -- current = ""; -- split = false; -- } else { -- current += letter; -- } -- } -- if (last || current !== "") array.push(current.trim()); -- return array; -- } --}; --var list_1 = list$2; --list$2.default = list$2; --let Container$3 = container; --let list$1 = list_1; --let Rule$3 = class Rule extends Container$3 { -- constructor(defaults) { -- super(defaults); -- this.type = "rule"; -- if (!this.nodes) this.nodes = []; -- } -- get selectors() { -- return list$1.comma(this.selector); -- } -- set selectors(values) { -- let match = this.selector ? this.selector.match(/,\s*/) : null; -- let sep2 = match ? match[0] : "," + this.raw("between", "beforeOpen"); -- this.selector = values.join(sep2); -- } --}; --var rule = Rule$3; --Rule$3.default = Rule$3; --Container$3.registerRule(Rule$3); --let Declaration$2 = declaration; --let tokenizer2 = tokenize; --let Comment$2 = comment; --let AtRule$2 = atRule; --let Root$4 = root; --let Rule$2 = rule; --const SAFE_COMMENT_NEIGHBOR = { -- empty: true, -- space: true --}; --function findLastWithPosition(tokens) { -- for (let i = tokens.length - 1; i >= 0; i--) { -- let token = tokens[i]; -- let pos = token[3] || token[2]; -- if (pos) return pos; -- } --} --let Parser$1 = class Parser { -- constructor(input2) { -- this.input = input2; -- this.root = new Root$4(); -- this.current = this.root; -- this.spaces = ""; -- this.semicolon = false; -- this.createTokenizer(); -- this.root.source = { input: input2, start: { column: 1, line: 1, offset: 0 } }; -- } -- atrule(token) { -- let node2 = new AtRule$2(); -- node2.name = token[1].slice(1); -- if (node2.name === "") { -- this.unnamedAtrule(node2, token); -- } -- this.init(node2, token[2]); -- let type; -- let prev; -- let shift; -- let last = false; -- let open = false; -- let params = []; -- let brackets = []; -- while (!this.tokenizer.endOfFile()) { -- token = this.tokenizer.nextToken(); -- type = token[0]; -- if (type === "(" || type === "[") { -- brackets.push(type === "(" ? ")" : "]"); -- } else if (type === "{" && brackets.length > 0) { -- brackets.push("}"); -- } else if (type === brackets[brackets.length - 1]) { -- brackets.pop(); -- } -- if (brackets.length === 0) { -- if (type === ";") { -- node2.source.end = this.getPosition(token[2]); -- node2.source.end.offset++; -- this.semicolon = true; -- break; -- } else if (type === "{") { -- open = true; -- break; -- } else if (type === "}") { -- if (params.length > 0) { -- shift = params.length - 1; -- prev = params[shift]; -- while (prev && prev[0] === "space") { -- prev = params[--shift]; -- } -- if (prev) { -- node2.source.end = this.getPosition(prev[3] || prev[2]); -- node2.source.end.offset++; -- } -- } -- this.end(token); -- break; -- } else { -- params.push(token); -- } -- } else { -- params.push(token); -- } -- if (this.tokenizer.endOfFile()) { -- last = true; -- break; -- } -- } -- node2.raws.between = this.spacesAndCommentsFromEnd(params); -- if (params.length) { -- node2.raws.afterName = this.spacesAndCommentsFromStart(params); -- this.raw(node2, "params", params); -- if (last) { -- token = params[params.length - 1]; -- node2.source.end = this.getPosition(token[3] || token[2]); -- node2.source.end.offset++; -- this.spaces = node2.raws.between; -- node2.raws.between = ""; -- } -- } else { -- node2.raws.afterName = ""; -- node2.params = ""; -- } -- if (open) { -- node2.nodes = []; -- this.current = node2; -- } -- } -- checkMissedSemicolon(tokens) { -- let colon = this.colon(tokens); -- if (colon === false) return; -- let founded = 0; -- let token; -- for (let j = colon - 1; j >= 0; j--) { -- token = tokens[j]; -- if (token[0] !== "space") { -- founded += 1; -- if (founded === 2) break; -- } -- } -- throw this.input.error( -- "Missed semicolon", -- token[0] === "word" ? token[3] + 1 : token[2] -- ); -- } -- colon(tokens) { -- let brackets = 0; -- let token, type, prev; -- for (let [i, element] of tokens.entries()) { -- token = element; -- type = token[0]; -- if (type === "(") { -- brackets += 1; -- } -- if (type === ")") { -- brackets -= 1; -- } -- if (brackets === 0 && type === ":") { -- if (!prev) { -- this.doubleColon(token); -- } else if (prev[0] === "word" && prev[1] === "progid") { -- continue; -- } else { -- return i; -- } -- } -- prev = token; -- } -- return false; -- } -- comment(token) { -- let node2 = new Comment$2(); -- this.init(node2, token[2]); -- node2.source.end = this.getPosition(token[3] || token[2]); -- node2.source.end.offset++; -- let text = token[1].slice(2, -2); -- if (/^\s*$/.test(text)) { -- node2.text = ""; -- node2.raws.left = text; -- node2.raws.right = ""; -- } else { -- let match = text.match(/^(\s*)([^]*\S)(\s*)$/); -- node2.text = match[2]; -- node2.raws.left = match[1]; -- node2.raws.right = match[3]; -- } -- } -- createTokenizer() { -- this.tokenizer = tokenizer2(this.input); -- } -- decl(tokens, customProperty) { -- let node2 = new Declaration$2(); -- this.init(node2, tokens[0][2]); -- let last = tokens[tokens.length - 1]; -- if (last[0] === ";") { -- this.semicolon = true; -- tokens.pop(); -- } -- node2.source.end = this.getPosition( -- last[3] || last[2] || findLastWithPosition(tokens) -- ); -- node2.source.end.offset++; -- while (tokens[0][0] !== "word") { -- if (tokens.length === 1) this.unknownWord(tokens); -- node2.raws.before += tokens.shift()[1]; -- } -- node2.source.start = this.getPosition(tokens[0][2]); -- node2.prop = ""; -- while (tokens.length) { -- let type = tokens[0][0]; -- if (type === ":" || type === "space" || type === "comment") { -- break; -- } -- node2.prop += tokens.shift()[1]; -- } -- node2.raws.between = ""; -- let token; -- while (tokens.length) { -- token = tokens.shift(); -- if (token[0] === ":") { -- node2.raws.between += token[1]; -- break; -- } else { -- if (token[0] === "word" && /\w/.test(token[1])) { -- this.unknownWord([token]); -- } -- node2.raws.between += token[1]; -- } -- } -- if (node2.prop[0] === "_" || node2.prop[0] === "*") { -- node2.raws.before += node2.prop[0]; -- node2.prop = node2.prop.slice(1); -- } -- let firstSpaces = []; -- let next; -- while (tokens.length) { -- next = tokens[0][0]; -- if (next !== "space" && next !== "comment") break; -- firstSpaces.push(tokens.shift()); -- } -- this.precheckMissedSemicolon(tokens); -- for (let i = tokens.length - 1; i >= 0; i--) { -- token = tokens[i]; -- if (token[1].toLowerCase() === "!important") { -- node2.important = true; -- let string = this.stringFrom(tokens, i); -- string = this.spacesFromEnd(tokens) + string; -- if (string !== " !important") node2.raws.important = string; -- break; -- } else if (token[1].toLowerCase() === "important") { -- let cache = tokens.slice(0); -- let str = ""; -- for (let j = i; j > 0; j--) { -- let type = cache[j][0]; -- if (str.trim().indexOf("!") === 0 && type !== "space") { -- break; -- } -- str = cache.pop()[1] + str; -- } -- if (str.trim().indexOf("!") === 0) { -- node2.important = true; -- node2.raws.important = str; -- tokens = cache; -- } -- } -- if (token[0] !== "space" && token[0] !== "comment") { -- break; -- } -- } -- let hasWord = tokens.some((i) => i[0] !== "space" && i[0] !== "comment"); -- if (hasWord) { -- node2.raws.between += firstSpaces.map((i) => i[1]).join(""); -- firstSpaces = []; -- } -- this.raw(node2, "value", firstSpaces.concat(tokens), customProperty); -- if (node2.value.includes(":") && !customProperty) { -- this.checkMissedSemicolon(tokens); -- } -- } -- doubleColon(token) { -- throw this.input.error( -- "Double colon", -- { offset: token[2] }, -- { offset: token[2] + token[1].length } -- ); -- } -- emptyRule(token) { -- let node2 = new Rule$2(); -- this.init(node2, token[2]); -- node2.selector = ""; -- node2.raws.between = ""; -- this.current = node2; -- } -- end(token) { -- if (this.current.nodes && this.current.nodes.length) { -- this.current.raws.semicolon = this.semicolon; -- } -- this.semicolon = false; -- this.current.raws.after = (this.current.raws.after || "") + this.spaces; -- this.spaces = ""; -- if (this.current.parent) { -- this.current.source.end = this.getPosition(token[2]); -- this.current.source.end.offset++; -- this.current = this.current.parent; -- } else { -- this.unexpectedClose(token); -- } -- } -- endFile() { -- if (this.current.parent) this.unclosedBlock(); -- if (this.current.nodes && this.current.nodes.length) { -- this.current.raws.semicolon = this.semicolon; -- } -- this.current.raws.after = (this.current.raws.after || "") + this.spaces; -- this.root.source.end = this.getPosition(this.tokenizer.position()); -- } -- freeSemicolon(token) { -- this.spaces += token[1]; -- if (this.current.nodes) { -- let prev = this.current.nodes[this.current.nodes.length - 1]; -- if (prev && prev.type === "rule" && !prev.raws.ownSemicolon) { -- prev.raws.ownSemicolon = this.spaces; -- this.spaces = ""; -- } -- } -- } -- // Helpers -- getPosition(offset) { -- let pos = this.input.fromOffset(offset); -- return { -- column: pos.col, -- line: pos.line, -- offset -- }; -- } -- init(node2, offset) { -- this.current.push(node2); -- node2.source = { -- input: this.input, -- start: this.getPosition(offset) -- }; -- node2.raws.before = this.spaces; -- this.spaces = ""; -- if (node2.type !== "comment") this.semicolon = false; -- } -- other(start) { -- let end = false; -- let type = null; -- let colon = false; -- let bracket = null; -- let brackets = []; -- let customProperty = start[1].startsWith("--"); -- let tokens = []; -- let token = start; -- while (token) { -- type = token[0]; -- tokens.push(token); -- if (type === "(" || type === "[") { -- if (!bracket) bracket = token; -- brackets.push(type === "(" ? ")" : "]"); -- } else if (customProperty && colon && type === "{") { -- if (!bracket) bracket = token; -- brackets.push("}"); -- } else if (brackets.length === 0) { -- if (type === ";") { -- if (colon) { -- this.decl(tokens, customProperty); -- return; -- } else { -- break; -- } -- } else if (type === "{") { -- this.rule(tokens); -- return; -- } else if (type === "}") { -- this.tokenizer.back(tokens.pop()); -- end = true; -- break; -- } else if (type === ":") { -- colon = true; -- } -- } else if (type === brackets[brackets.length - 1]) { -- brackets.pop(); -- if (brackets.length === 0) bracket = null; -- } -- token = this.tokenizer.nextToken(); -- } -- if (this.tokenizer.endOfFile()) end = true; -- if (brackets.length > 0) this.unclosedBracket(bracket); -- if (end && colon) { -- if (!customProperty) { -- while (tokens.length) { -- token = tokens[tokens.length - 1][0]; -- if (token !== "space" && token !== "comment") break; -- this.tokenizer.back(tokens.pop()); -- } -- } -- this.decl(tokens, customProperty); -- } else { -- this.unknownWord(tokens); -- } -- } -- parse() { -- let token; -- while (!this.tokenizer.endOfFile()) { -- token = this.tokenizer.nextToken(); -- switch (token[0]) { -- case "space": -- this.spaces += token[1]; -- break; -- case ";": -- this.freeSemicolon(token); -- break; -- case "}": -- this.end(token); -- break; -- case "comment": -- this.comment(token); -- break; -- case "at-word": -- this.atrule(token); -- break; -- case "{": -- this.emptyRule(token); -- break; -- default: -- this.other(token); -- break; -- } -- } -- this.endFile(); -- } -- precheckMissedSemicolon() { -- } -- raw(node2, prop, tokens, customProperty) { -- let token, type; -- let length = tokens.length; -- let value = ""; -- let clean = true; -- let next, prev; -- for (let i = 0; i < length; i += 1) { -- token = tokens[i]; -- type = token[0]; -- if (type === "space" && i === length - 1 && !customProperty) { -- clean = false; -- } else if (type === "comment") { -- prev = tokens[i - 1] ? tokens[i - 1][0] : "empty"; -- next = tokens[i + 1] ? tokens[i + 1][0] : "empty"; -- if (!SAFE_COMMENT_NEIGHBOR[prev] && !SAFE_COMMENT_NEIGHBOR[next]) { -- if (value.slice(-1) === ",") { -- clean = false; -- } else { -- value += token[1]; -- } -- } else { -- clean = false; -- } -- } else { -- value += token[1]; -- } -- } -- if (!clean) { -- let raw = tokens.reduce((all, i) => all + i[1], ""); -- node2.raws[prop] = { raw, value }; -- } -- node2[prop] = value; -- } -- rule(tokens) { -- tokens.pop(); -- let node2 = new Rule$2(); -- this.init(node2, tokens[0][2]); -- node2.raws.between = this.spacesAndCommentsFromEnd(tokens); -- this.raw(node2, "selector", tokens); -- this.current = node2; -- } -- spacesAndCommentsFromEnd(tokens) { -- let lastTokenType; -- let spaces = ""; -- while (tokens.length) { -- lastTokenType = tokens[tokens.length - 1][0]; -- if (lastTokenType !== "space" && lastTokenType !== "comment") break; -- spaces = tokens.pop()[1] + spaces; -- } -- return spaces; -- } -- // Errors -- spacesAndCommentsFromStart(tokens) { -- let next; -- let spaces = ""; -- while (tokens.length) { -- next = tokens[0][0]; -- if (next !== "space" && next !== "comment") break; -- spaces += tokens.shift()[1]; -- } -- return spaces; -- } -- spacesFromEnd(tokens) { -- let lastTokenType; -- let spaces = ""; -- while (tokens.length) { -- lastTokenType = tokens[tokens.length - 1][0]; -- if (lastTokenType !== "space") break; -- spaces = tokens.pop()[1] + spaces; -- } -- return spaces; -- } -- stringFrom(tokens, from) { -- let result2 = ""; -- for (let i = from; i < tokens.length; i++) { -- result2 += tokens[i][1]; -- } -- tokens.splice(from, tokens.length - from); -- return result2; -- } -- unclosedBlock() { -- let pos = this.current.source.start; -- throw this.input.error("Unclosed block", pos.line, pos.column); -- } -- unclosedBracket(bracket) { -- throw this.input.error( -- "Unclosed bracket", -- { offset: bracket[2] }, -- { offset: bracket[2] + 1 } -- ); -- } -- unexpectedClose(token) { -- throw this.input.error( -- "Unexpected }", -- { offset: token[2] }, -- { offset: token[2] + 1 } -- ); -- } -- unknownWord(tokens) { -- throw this.input.error( -- "Unknown word", -- { offset: tokens[0][2] }, -- { offset: tokens[0][2] + tokens[0][1].length } -- ); -- } -- unnamedAtrule(node2, token) { -- throw this.input.error( -- "At-rule without name", -- { offset: token[2] }, -- { offset: token[2] + token[1].length } -- ); -- } --}; --var parser = Parser$1; --let Container$2 = container; --let Parser2 = parser; --let Input$2 = input; --function parse$3(css, opts) { -- let input2 = new Input$2(css, opts); -- let parser2 = new Parser2(input2); -- try { -- parser2.parse(); -- } catch (e) { -- if (process.env.NODE_ENV !== "production") { -- if (e.name === "CssSyntaxError" && opts && opts.from) { -- if (/\.scss$/i.test(opts.from)) { -- e.message += "\nYou tried to parse SCSS with the standard CSS parser; try again with the postcss-scss parser"; -- } else if (/\.sass/i.test(opts.from)) { -- e.message += "\nYou tried to parse Sass with the standard CSS parser; try again with the postcss-sass parser"; -- } else if (/\.less$/i.test(opts.from)) { -- e.message += "\nYou tried to parse Less with the standard CSS parser; try again with the postcss-less parser"; -- } -- } -- } -- throw e; -- } -- return parser2.root; --} --var parse_1 = parse$3; --parse$3.default = parse$3; --Container$2.registerParse(parse$3); --let { isClean, my } = symbols; --let MapGenerator$1 = mapGenerator; --let stringify$2 = stringify_1; --let Container$1 = container; --let Document$2 = document$1; --let warnOnce$1 = warnOnce$2; --let Result$2 = result; --let parse$2 = parse_1; --let Root$3 = root; --const TYPE_TO_CLASS_NAME = { -- atrule: "AtRule", -- comment: "Comment", -- decl: "Declaration", -- document: "Document", -- root: "Root", -- rule: "Rule" --}; --const PLUGIN_PROPS = { -- AtRule: true, -- AtRuleExit: true, -- Comment: true, -- CommentExit: true, -- Declaration: true, -- DeclarationExit: true, -- Document: true, -- DocumentExit: true, -- Once: true, -- OnceExit: true, -- postcssPlugin: true, -- prepare: true, -- Root: true, -- RootExit: true, -- Rule: true, -- RuleExit: true --}; --const NOT_VISITORS = { -- Once: true, -- postcssPlugin: true, -- prepare: true --}; --const CHILDREN = 0; --function isPromise(obj) { -- return typeof obj === "object" && typeof obj.then === "function"; --} --function getEvents(node2) { -- let key = false; -- let type = TYPE_TO_CLASS_NAME[node2.type]; -- if (node2.type === "decl") { -- key = node2.prop.toLowerCase(); -- } else if (node2.type === "atrule") { -- key = node2.name.toLowerCase(); -- } -- if (key && node2.append) { -- return [ -- type, -- type + "-" + key, -- CHILDREN, -- type + "Exit", -- type + "Exit-" + key -- ]; -- } else if (key) { -- return [type, type + "-" + key, type + "Exit", type + "Exit-" + key]; -- } else if (node2.append) { -- return [type, CHILDREN, type + "Exit"]; -- } else { -- return [type, type + "Exit"]; -- } --} --function toStack(node2) { -- let events; -- if (node2.type === "document") { -- events = ["Document", CHILDREN, "DocumentExit"]; -- } else if (node2.type === "root") { -- events = ["Root", CHILDREN, "RootExit"]; -- } else { -- events = getEvents(node2); -- } -- return { -- eventIndex: 0, -- events, -- iterator: 0, -- node: node2, -- visitorIndex: 0, -- visitors: [] -- }; --} --function cleanMarks(node2) { -- node2[isClean] = false; -- if (node2.nodes) node2.nodes.forEach((i) => cleanMarks(i)); -- return node2; --} --let postcss$2 = {}; --let LazyResult$2 = class LazyResult { -- constructor(processor2, css, opts) { -- this.stringified = false; -- this.processed = false; -- let root2; -- if (typeof css === "object" && css !== null && (css.type === "root" || css.type === "document")) { -- root2 = cleanMarks(css); -- } else if (css instanceof LazyResult || css instanceof Result$2) { -- root2 = cleanMarks(css.root); -- if (css.map) { -- if (typeof opts.map === "undefined") opts.map = {}; -- if (!opts.map.inline) opts.map.inline = false; -- opts.map.prev = css.map; -- } -- } else { -- let parser2 = parse$2; -- if (opts.syntax) parser2 = opts.syntax.parse; -- if (opts.parser) parser2 = opts.parser; -- if (parser2.parse) parser2 = parser2.parse; -- try { -- root2 = parser2(css, opts); -- } catch (error) { -- this.processed = true; -- this.error = error; -- } -- if (root2 && !root2[my]) { -- Container$1.rebuild(root2); -- } -- } -- this.result = new Result$2(processor2, root2, opts); -- this.helpers = { ...postcss$2, postcss: postcss$2, result: this.result }; -- this.plugins = this.processor.plugins.map((plugin2) => { -- if (typeof plugin2 === "object" && plugin2.prepare) { -- return { ...plugin2, ...plugin2.prepare(this.result) }; -- } else { -- return plugin2; -- } -- }); -- } -- async() { -- if (this.error) return Promise.reject(this.error); -- if (this.processed) return Promise.resolve(this.result); -- if (!this.processing) { -- this.processing = this.runAsync(); -- } -- return this.processing; -- } -- catch(onRejected) { -- return this.async().catch(onRejected); -- } -- finally(onFinally) { -- return this.async().then(onFinally, onFinally); -- } -- getAsyncError() { -- throw new Error("Use process(css).then(cb) to work with async plugins"); -- } -- handleError(error, node2) { -- let plugin2 = this.result.lastPlugin; -- try { -- if (node2) node2.addToError(error); -- this.error = error; -- if (error.name === "CssSyntaxError" && !error.plugin) { -- error.plugin = plugin2.postcssPlugin; -- error.setMessage(); -- } else if (plugin2.postcssVersion) { -- if (process.env.NODE_ENV !== "production") { -- let pluginName = plugin2.postcssPlugin; -- let pluginVer = plugin2.postcssVersion; -- let runtimeVer = this.result.processor.version; -- let a = pluginVer.split("."); -- let b = runtimeVer.split("."); -- if (a[0] !== b[0] || parseInt(a[1]) > parseInt(b[1])) { -- console.error( -- "Unknown error from PostCSS plugin. Your current PostCSS version is " + runtimeVer + ", but " + pluginName + " uses " + pluginVer + ". Perhaps this is the source of the error below." -- ); -- } -- } -- } -- } catch (err) { -- if (console && console.error) console.error(err); -- } -- return error; -- } -- prepareVisitors() { -- this.listeners = {}; -- let add = (plugin2, type, cb) => { -- if (!this.listeners[type]) this.listeners[type] = []; -- this.listeners[type].push([plugin2, cb]); -- }; -- for (let plugin2 of this.plugins) { -- if (typeof plugin2 === "object") { -- for (let event in plugin2) { -- if (!PLUGIN_PROPS[event] && /^[A-Z]/.test(event)) { -- throw new Error( -- `Unknown event ${event} in ${plugin2.postcssPlugin}. Try to update PostCSS (${this.processor.version} now).` -- ); -- } -- if (!NOT_VISITORS[event]) { -- if (typeof plugin2[event] === "object") { -- for (let filter in plugin2[event]) { -- if (filter === "*") { -- add(plugin2, event, plugin2[event][filter]); -- } else { -- add( -- plugin2, -- event + "-" + filter.toLowerCase(), -- plugin2[event][filter] -- ); -- } -- } -- } else if (typeof plugin2[event] === "function") { -- add(plugin2, event, plugin2[event]); -- } -- } -- } -- } -- } -- this.hasListener = Object.keys(this.listeners).length > 0; -- } -- async runAsync() { -- this.plugin = 0; -- for (let i = 0; i < this.plugins.length; i++) { -- let plugin2 = this.plugins[i]; -- let promise = this.runOnRoot(plugin2); -- if (isPromise(promise)) { -- try { -- await promise; -- } catch (error) { -- throw this.handleError(error); -- } -- } -- } -- this.prepareVisitors(); -- if (this.hasListener) { -- let root2 = this.result.root; -- while (!root2[isClean]) { -- root2[isClean] = true; -- let stack = [toStack(root2)]; -- while (stack.length > 0) { -- let promise = this.visitTick(stack); -- if (isPromise(promise)) { -- try { -- await promise; -- } catch (e) { -- let node2 = stack[stack.length - 1].node; -- throw this.handleError(e, node2); -- } -- } -- } -- } -- if (this.listeners.OnceExit) { -- for (let [plugin2, visitor] of this.listeners.OnceExit) { -- this.result.lastPlugin = plugin2; -- try { -- if (root2.type === "document") { -- let roots = root2.nodes.map( -- (subRoot) => visitor(subRoot, this.helpers) -- ); -- await Promise.all(roots); -- } else { -- await visitor(root2, this.helpers); -- } -- } catch (e) { -- throw this.handleError(e); -- } -- } -- } -- } -- this.processed = true; -- return this.stringify(); -- } -- runOnRoot(plugin2) { -- this.result.lastPlugin = plugin2; -- try { -- if (typeof plugin2 === "object" && plugin2.Once) { -- if (this.result.root.type === "document") { -- let roots = this.result.root.nodes.map( -- (root2) => plugin2.Once(root2, this.helpers) -- ); -- if (isPromise(roots[0])) { -- return Promise.all(roots); -- } -- return roots; -- } -- return plugin2.Once(this.result.root, this.helpers); -- } else if (typeof plugin2 === "function") { -- return plugin2(this.result.root, this.result); -- } -- } catch (error) { -- throw this.handleError(error); -- } -- } -- stringify() { -- if (this.error) throw this.error; -- if (this.stringified) return this.result; -- this.stringified = true; -- this.sync(); -- let opts = this.result.opts; -- let str = stringify$2; -- if (opts.syntax) str = opts.syntax.stringify; -- if (opts.stringifier) str = opts.stringifier; -- if (str.stringify) str = str.stringify; -- let map = new MapGenerator$1(str, this.result.root, this.result.opts); -- let data = map.generate(); -- this.result.css = data[0]; -- this.result.map = data[1]; -- return this.result; -- } -- sync() { -- if (this.error) throw this.error; -- if (this.processed) return this.result; -- this.processed = true; -- if (this.processing) { -- throw this.getAsyncError(); -- } -- for (let plugin2 of this.plugins) { -- let promise = this.runOnRoot(plugin2); -- if (isPromise(promise)) { -- throw this.getAsyncError(); -- } -- } -- this.prepareVisitors(); -- if (this.hasListener) { -- let root2 = this.result.root; -- while (!root2[isClean]) { -- root2[isClean] = true; -- this.walkSync(root2); -- } -- if (this.listeners.OnceExit) { -- if (root2.type === "document") { -- for (let subRoot of root2.nodes) { -- this.visitSync(this.listeners.OnceExit, subRoot); -- } -- } else { -- this.visitSync(this.listeners.OnceExit, root2); -- } -- } -- } -- return this.result; -- } -- then(onFulfilled, onRejected) { -- if (process.env.NODE_ENV !== "production") { -- if (!("from" in this.opts)) { -- warnOnce$1( -- "Without `from` option PostCSS could generate wrong source map and will not find Browserslist config. Set it to CSS file path or to `undefined` to prevent this warning." -- ); -- } -- } -- return this.async().then(onFulfilled, onRejected); -- } -- toString() { -- return this.css; -- } -- visitSync(visitors, node2) { -- for (let [plugin2, visitor] of visitors) { -- this.result.lastPlugin = plugin2; -- let promise; -- try { -- promise = visitor(node2, this.helpers); -- } catch (e) { -- throw this.handleError(e, node2.proxyOf); -- } -- if (node2.type !== "root" && node2.type !== "document" && !node2.parent) { -- return true; -- } -- if (isPromise(promise)) { -- throw this.getAsyncError(); -- } -- } -- } -- visitTick(stack) { -- let visit2 = stack[stack.length - 1]; -- let { node: node2, visitors } = visit2; -- if (node2.type !== "root" && node2.type !== "document" && !node2.parent) { -- stack.pop(); -- return; -- } -- if (visitors.length > 0 && visit2.visitorIndex < visitors.length) { -- let [plugin2, visitor] = visitors[visit2.visitorIndex]; -- visit2.visitorIndex += 1; -- if (visit2.visitorIndex === visitors.length) { -- visit2.visitors = []; -- visit2.visitorIndex = 0; -- } -- this.result.lastPlugin = plugin2; -- try { -- return visitor(node2.toProxy(), this.helpers); -- } catch (e) { -- throw this.handleError(e, node2); -- } -- } -- if (visit2.iterator !== 0) { -- let iterator = visit2.iterator; -- let child; -- while (child = node2.nodes[node2.indexes[iterator]]) { -- node2.indexes[iterator] += 1; -- if (!child[isClean]) { -- child[isClean] = true; -- stack.push(toStack(child)); -- return; -- } -- } -- visit2.iterator = 0; -- delete node2.indexes[iterator]; -- } -- let events = visit2.events; -- while (visit2.eventIndex < events.length) { -- let event = events[visit2.eventIndex]; -- visit2.eventIndex += 1; -- if (event === CHILDREN) { -- if (node2.nodes && node2.nodes.length) { -- node2[isClean] = true; -- visit2.iterator = node2.getIterator(); -- } -- return; -- } else if (this.listeners[event]) { -- visit2.visitors = this.listeners[event]; -- return; -- } -- } -- stack.pop(); -- } -- walkSync(node2) { -- node2[isClean] = true; -- let events = getEvents(node2); -- for (let event of events) { -- if (event === CHILDREN) { -- if (node2.nodes) { -- node2.each((child) => { -- if (!child[isClean]) this.walkSync(child); -- }); -- } -- } else { -- let visitors = this.listeners[event]; -- if (visitors) { -- if (this.visitSync(visitors, node2.toProxy())) return; -- } -- } -- } -- } -- warnings() { -- return this.sync().warnings(); -- } -- get content() { -- return this.stringify().content; -- } -- get css() { -- return this.stringify().css; -- } -- get map() { -- return this.stringify().map; -- } -- get messages() { -- return this.sync().messages; -- } -- get opts() { -- return this.result.opts; -- } -- get processor() { -- return this.result.processor; -- } -- get root() { -- return this.sync().root; -- } -- get [Symbol.toStringTag]() { -- return "LazyResult"; -- } --}; --LazyResult$2.registerPostcss = (dependant) => { -- postcss$2 = dependant; --}; --var lazyResult = LazyResult$2; --LazyResult$2.default = LazyResult$2; --Root$3.registerLazyResult(LazyResult$2); --Document$2.registerLazyResult(LazyResult$2); --let MapGenerator2 = mapGenerator; --let stringify$1 = stringify_1; --let warnOnce2 = warnOnce$2; --let parse$1 = parse_1; --const Result$1 = result; --let NoWorkResult$1 = class NoWorkResult { -- constructor(processor2, css, opts) { -- css = css.toString(); -- this.stringified = false; -- this._processor = processor2; -- this._css = css; -- this._opts = opts; -- this._map = void 0; -- let root2; -- let str = stringify$1; -- this.result = new Result$1(this._processor, root2, this._opts); -- this.result.css = css; -- let self = this; -- Object.defineProperty(this.result, "root", { -- get() { -- return self.root; -- } -- }); -- let map = new MapGenerator2(str, root2, this._opts, css); -- if (map.isMap()) { -- let [generatedCSS, generatedMap] = map.generate(); -- if (generatedCSS) { -- this.result.css = generatedCSS; -- } -- if (generatedMap) { -- this.result.map = generatedMap; -- } -- } else { -- map.clearAnnotation(); -- this.result.css = map.css; -- } -- } -- async() { -- if (this.error) return Promise.reject(this.error); -- return Promise.resolve(this.result); -- } -- catch(onRejected) { -- return this.async().catch(onRejected); -- } -- finally(onFinally) { -- return this.async().then(onFinally, onFinally); -- } -- sync() { -- if (this.error) throw this.error; -- return this.result; -- } -- then(onFulfilled, onRejected) { -- if (process.env.NODE_ENV !== "production") { -- if (!("from" in this._opts)) { -- warnOnce2( -- "Without `from` option PostCSS could generate wrong source map and will not find Browserslist config. Set it to CSS file path or to `undefined` to prevent this warning." -- ); -- } -- } -- return this.async().then(onFulfilled, onRejected); -- } -- toString() { -- return this._css; -- } -- warnings() { -- return []; -- } -- get content() { -- return this.result.css; -- } -- get css() { -- return this.result.css; -- } -- get map() { -- return this.result.map; -- } -- get messages() { -- return []; -- } -- get opts() { -- return this.result.opts; -- } -- get processor() { -- return this.result.processor; -- } -- get root() { -- if (this._root) { -- return this._root; -- } -- let root2; -- let parser2 = parse$1; -- try { -- root2 = parser2(this._css, this._opts); -- } catch (error) { -- this.error = error; -- } -- if (this.error) { -- throw this.error; -- } else { -- this._root = root2; -- return root2; -- } -- } -- get [Symbol.toStringTag]() { -- return "NoWorkResult"; -- } --}; --var noWorkResult = NoWorkResult$1; --NoWorkResult$1.default = NoWorkResult$1; --let NoWorkResult2 = noWorkResult; --let LazyResult$1 = lazyResult; --let Document$1 = document$1; --let Root$2 = root; --let Processor$1 = class Processor { -- constructor(plugins = []) { -- this.version = "8.4.38"; -- this.plugins = this.normalize(plugins); -- } -- normalize(plugins) { -- let normalized = []; -- for (let i of plugins) { -- if (i.postcss === true) { -- i = i(); -- } else if (i.postcss) { -- i = i.postcss; -- } -- if (typeof i === "object" && Array.isArray(i.plugins)) { -- normalized = normalized.concat(i.plugins); -- } else if (typeof i === "object" && i.postcssPlugin) { -- normalized.push(i); -- } else if (typeof i === "function") { -- normalized.push(i); -- } else if (typeof i === "object" && (i.parse || i.stringify)) { -- if (process.env.NODE_ENV !== "production") { -- throw new Error( -- "PostCSS syntaxes cannot be used as plugins. Instead, please use one of the syntax/parser/stringifier options as outlined in your PostCSS runner documentation." -- ); -- } -- } else { -- throw new Error(i + " is not a PostCSS plugin"); -- } -- } -- return normalized; -- } -- process(css, opts = {}) { -- if (!this.plugins.length && !opts.parser && !opts.stringifier && !opts.syntax) { -- return new NoWorkResult2(this, css, opts); -- } else { -- return new LazyResult$1(this, css, opts); -- } -- } -- use(plugin2) { -- this.plugins = this.plugins.concat(this.normalize([plugin2])); -- return this; -- } --}; --var processor = Processor$1; --Processor$1.default = Processor$1; --Root$2.registerProcessor(Processor$1); --Document$1.registerProcessor(Processor$1); --let Declaration$1 = declaration; --let PreviousMap2 = previousMap; --let Comment$1 = comment; --let AtRule$1 = atRule; --let Input$1 = input; --let Root$1 = root; --let Rule$1 = rule; --function fromJSON$1(json, inputs) { -- if (Array.isArray(json)) return json.map((n) => fromJSON$1(n)); -- let { inputs: ownInputs, ...defaults } = json; -- if (ownInputs) { -- inputs = []; -- for (let input2 of ownInputs) { -- let inputHydrated = { ...input2, __proto__: Input$1.prototype }; -- if (inputHydrated.map) { -- inputHydrated.map = { -- ...inputHydrated.map, -- __proto__: PreviousMap2.prototype -- }; -- } -- inputs.push(inputHydrated); -- } -- } -- if (defaults.nodes) { -- defaults.nodes = json.nodes.map((n) => fromJSON$1(n, inputs)); -- } -- if (defaults.source) { -- let { inputId, ...source } = defaults.source; -- defaults.source = source; -- if (inputId != null) { -- defaults.source.input = inputs[inputId]; -- } -- } -- if (defaults.type === "root") { -- return new Root$1(defaults); -- } else if (defaults.type === "decl") { -- return new Declaration$1(defaults); -- } else if (defaults.type === "rule") { -- return new Rule$1(defaults); -- } else if (defaults.type === "comment") { -- return new Comment$1(defaults); -- } else if (defaults.type === "atrule") { -- return new AtRule$1(defaults); -- } else { -- throw new Error("Unknown node type: " + json.type); -- } --} --var fromJSON_1 = fromJSON$1; --fromJSON$1.default = fromJSON$1; --let CssSyntaxError2 = cssSyntaxError; --let Declaration2 = declaration; --let LazyResult2 = lazyResult; --let Container2 = container; --let Processor2 = processor; --let stringify = stringify_1; --let fromJSON = fromJSON_1; --let Document2 = document$1; --let Warning2 = warning; --let Comment2 = comment; --let AtRule2 = atRule; --let Result2 = result; --let Input2 = input; --let parse = parse_1; --let list = list_1; --let Rule2 = rule; --let Root2 = root; --let Node2 = node; --function postcss(...plugins) { -- if (plugins.length === 1 && Array.isArray(plugins[0])) { -- plugins = plugins[0]; -- } -- return new Processor2(plugins); --} --postcss.plugin = function plugin(name, initializer) { -- let warningPrinted = false; -- function creator(...args) { -- if (console && console.warn && !warningPrinted) { -- warningPrinted = true; -- console.warn( -- name + ": postcss.plugin was deprecated. Migration guide:\nhttps://evilmartians.com/chronicles/postcss-8-plugin-migration" -- ); -- if (process.env.LANG && process.env.LANG.startsWith("cn")) { -- console.warn( -- name + ": 里面 postcss.plugin 被弃用. 迁移指南:\nhttps://www.w3ctech.com/topic/2226" -- ); -- } -- } -- let transformer = initializer(...args); -- transformer.postcssPlugin = name; -- transformer.postcssVersion = new Processor2().version; -- return transformer; -- } -- let cache; -- Object.defineProperty(creator, "postcss", { -- get() { -- if (!cache) cache = creator(); -- return cache; -- } -- }); -- creator.process = function(css, processOpts, pluginOpts) { -- return postcss([creator(pluginOpts)]).process(css, processOpts); -- }; -- return creator; --}; --postcss.stringify = stringify; --postcss.parse = parse; --postcss.fromJSON = fromJSON; --postcss.list = list; --postcss.comment = (defaults) => new Comment2(defaults); --postcss.atRule = (defaults) => new AtRule2(defaults); --postcss.decl = (defaults) => new Declaration2(defaults); --postcss.rule = (defaults) => new Rule2(defaults); --postcss.root = (defaults) => new Root2(defaults); --postcss.document = (defaults) => new Document2(defaults); --postcss.CssSyntaxError = CssSyntaxError2; --postcss.Declaration = Declaration2; --postcss.Container = Container2; --postcss.Processor = Processor2; --postcss.Document = Document2; --postcss.Comment = Comment2; --postcss.Warning = Warning2; --postcss.AtRule = AtRule2; --postcss.Result = Result2; --postcss.Input = Input2; --postcss.Rule = Rule2; --postcss.Root = Root2; --postcss.Node = Node2; --LazyResult2.registerPostcss(postcss); --var postcss_1 = postcss; --postcss.default = postcss; --const postcss$1 = /* @__PURE__ */ getDefaultExportFromCjs(postcss_1); --postcss$1.stringify; --postcss$1.fromJSON; --postcss$1.plugin; --postcss$1.parse; --postcss$1.list; --postcss$1.document; --postcss$1.comment; --postcss$1.atRule; --postcss$1.rule; --postcss$1.decl; --postcss$1.root; --postcss$1.CssSyntaxError; --postcss$1.Declaration; --postcss$1.Container; --postcss$1.Processor; --postcss$1.Document; --postcss$1.Comment; --postcss$1.Warning; --postcss$1.AtRule; --postcss$1.Result; --postcss$1.Input; --postcss$1.Rule; --postcss$1.Root; --postcss$1.Node; - const tagMap = { - script: "noscript", - // camel case svg element tag names diff --git a/patches/rrweb@2.0.0-alpha.17.patch b/patches/rrweb@2.0.0-alpha.17.patch deleted file mode 100644 index 7caa5db40..000000000 --- a/patches/rrweb@2.0.0-alpha.17.patch +++ /dev/null @@ -1,81 +0,0 @@ -diff --git a/dist/rrweb.js b/dist/rrweb.js -index 12f4ad3c7f897fe8a9ee2f4595dcf37f302d17c5..43f6bd95676c456e187b7bd68ba7af56e7b09f29 100644 ---- a/dist/rrweb.js -+++ b/dist/rrweb.js -@@ -246,6 +246,9 @@ function isCSSImportRule(rule2) { - function isCSSStyleRule(rule2) { - return "selectorText" in rule2; - } -+function findStylesheet(doc, href) { -+ return Array.from(doc.styleSheets).find((s) => s.href === href); -+} - class Mirror { - constructor() { - __publicField$1(this, "idNodeMap", /* @__PURE__ */ new Map()); -@@ -821,9 +824,14 @@ function serializeElementNode(n2, options) { - } - } - if (tagName === "link" && inlineStylesheet) { -- const stylesheet = Array.from(doc.styleSheets).find((s2) => { -- return s2.href === n2.href; -- }); -+ const href = n2.href; -+ let stylesheet = findStylesheet(doc, href); -+ if (!stylesheet && href.includes('.css')) { -+ const rootDomain = window.location.origin; -+ const stylesheetPath = href.replace(window.location.href, ''); -+ const potentialStylesheetHref = rootDomain + '/' + stylesheetPath; -+ stylesheet = findStylesheet(doc, potentialStylesheetHref); -+ } - let cssText = null; - if (stylesheet) { - cssText = stringifyStylesheet(stylesheet); -@@ -13276,11 +13284,19 @@ class CanvasManager { - let rafId; - const getCanvas = () => { - const matchedCanvas = []; -- win.document.querySelectorAll("canvas").forEach((canvas) => { -- if (!isBlocked(canvas, blockClass, blockSelector, true)) { -- matchedCanvas.push(canvas); -- } -- }); -+ const searchCanvas = (root) => { -+ root.querySelectorAll("canvas").forEach((canvas) => { -+ if (!isBlocked(canvas, blockClass, blockSelector, true)) { -+ matchedCanvas.push(canvas); -+ } -+ }); -+ root.querySelectorAll("*").forEach((elem) => { -+ if (elem.shadowRoot) { -+ searchCanvas(elem.shadowRoot); -+ } -+ }); -+ }; -+ searchCanvas(win.document); - return matchedCanvas; - }; - const takeCanvasSnapshots = (timestamp) => { -@@ -13301,13 +13317,20 @@ class CanvasManager { - context.clear(context.COLOR_BUFFER_BIT); - } - } -- const bitmap = await createImageBitmap(canvas); -+ // createImageBitmap throws if resizing to 0 -+ // Fallback to intrinsic size if canvas has not yet rendered -+ const width = canvas.clientWidth || canvas.width; -+ const height = canvas.clientHeight || canvas.height; -+ const bitmap = await createImageBitmap(canvas, { -+ resizeWidth: width, -+ resizeHeight: height -+ }); - worker.postMessage( - { - id, - bitmap, -- width: canvas.width, -- height: canvas.height, -+ width: width, -+ height: height, - dataURLOptions: options.dataURLOptions - }, - [bitmap] diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml index 485110952..ab12253a4 100644 --- a/pnpm-lock.yaml +++ b/pnpm-lock.yaml @@ -8,12 +8,6 @@ patchedDependencies: '@rrweb/record@2.0.0-alpha.17': hash: or7biymn4kjyhnfwbz74vqezxa path: patches/@rrweb__record@2.0.0-alpha.17.patch - rrweb-snapshot@2.0.0-alpha.17: - hash: rlxgtlyuih2b32ogrmldlbq2li - path: patches/rrweb-snapshot@2.0.0-alpha.17.patch - rrweb@2.0.0-alpha.17: - hash: xlkuvshzdprjlpxe7nzsj3spyi - path: patches/rrweb@2.0.0-alpha.17.patch dependencies: core-js: @@ -213,9 +207,6 @@ devDependencies: rollup-plugin-visualizer: specifier: ^5.12.0 version: 5.12.0(rollup@4.24.0) - rrweb-snapshot: - specifier: 2.0.0-alpha.17 - version: 2.0.0-alpha.17(patch_hash=rlxgtlyuih2b32ogrmldlbq2li) sinon: specifier: 9.0.2 version: 9.0.2 @@ -2812,7 +2803,7 @@ packages: resolution: {integrity: sha512-Je+lzjeWMF8/I0IDoXFzkGPKT8j7AkaBup5YcwUHlkp18VhLVze416MvI6915teE27uUA2ScXMXzG0Yiu5VTIw==} dependencies: '@rrweb/types': 2.0.0-alpha.17 - rrweb: 2.0.0-alpha.17(patch_hash=xlkuvshzdprjlpxe7nzsj3spyi) + rrweb: 2.0.0-alpha.17 dev: true patched: true @@ -2821,13 +2812,13 @@ packages: peerDependencies: rrweb: ^2.0.0-alpha.17 dependencies: - rrweb: 2.0.0-alpha.17(patch_hash=xlkuvshzdprjlpxe7nzsj3spyi) + rrweb: 2.0.0-alpha.17 dev: true /@rrweb/types@2.0.0-alpha.17: resolution: {integrity: sha512-AfDTVUuCyCaIG0lTSqYtrZqJX39ZEYzs4fYKnexhQ+id+kbZIpIJtaut5cto6dWZbB3SEe4fW0o90Po3LvTmfg==} dependencies: - rrweb-snapshot: 2.0.0-alpha.17(patch_hash=rlxgtlyuih2b32ogrmldlbq2li) + rrweb-snapshot: 2.0.0-alpha.17 dev: true /@rrweb/utils@2.0.0-alpha.17: @@ -9417,17 +9408,16 @@ packages: /rrdom@2.0.0-alpha.17: resolution: {integrity: sha512-b6caDiNcFO96Opp7TGdcVd4OLGSXu5dJe+A0IDiAu8mk7OmhqZCSDlgQdTKmdO5wMf4zPsUTgb8H/aNvR3kDHA==} dependencies: - rrweb-snapshot: 2.0.0-alpha.17(patch_hash=rlxgtlyuih2b32ogrmldlbq2li) + rrweb-snapshot: 2.0.0-alpha.17 dev: true - /rrweb-snapshot@2.0.0-alpha.17(patch_hash=rlxgtlyuih2b32ogrmldlbq2li): + /rrweb-snapshot@2.0.0-alpha.17: resolution: {integrity: sha512-GBg5pV8LHOTbeVmH2VHLEFR0mc2QpQMzAvcoxEGfPNWgWHc8UvKCyq7pqN1vA+fDZ+yXXbixeO0kB2pzVvFCBw==} dependencies: postcss: 8.4.47 dev: true - patched: true - /rrweb@2.0.0-alpha.17(patch_hash=xlkuvshzdprjlpxe7nzsj3spyi): + /rrweb@2.0.0-alpha.17: resolution: {integrity: sha512-GQxBkCC4r9XL2bwSdv7iIS49M3cEA8OtObVq0rrQ4GUT4+h7omucGQ4x7m5YN5Vq1oalStBaBlYqF7yRnfG3JA==} dependencies: '@rrweb/types': 2.0.0-alpha.17 @@ -9437,9 +9427,8 @@ packages: base64-arraybuffer: 1.0.2 mitt: 3.0.0 rrdom: 2.0.0-alpha.17 - rrweb-snapshot: 2.0.0-alpha.17(patch_hash=rlxgtlyuih2b32ogrmldlbq2li) + rrweb-snapshot: 2.0.0-alpha.17 dev: true - patched: true /rsvp@4.8.5: resolution: {integrity: sha512-nfMOlASu9OnRJo1mbEk2cz0D56a1MBNrJ7orjRZQG10XDyuvwksKbuXNp6qa+kbn839HwjwhBzhFmdsaEAfauA==} diff --git a/src/__tests__/extensions/replay/mutation-rate-limiter.test.ts b/src/__tests__/extensions/replay/mutation-rate-limiter.test.ts index a0791b3eb..d45595b30 100644 --- a/src/__tests__/extensions/replay/mutation-rate-limiter.test.ts +++ b/src/__tests__/extensions/replay/mutation-rate-limiter.test.ts @@ -6,7 +6,6 @@ import { } from '../../../extensions/replay/sessionrecording-utils' import { jest } from '@jest/globals' import { eventWithTime, mutationData } from '@rrweb/types' -import { serializedNodeWithId } from 'rrweb-snapshot' jest.useFakeTimers() const makeEvent = (mutations: { @@ -72,7 +71,7 @@ describe('MutationRateLimiter', () => { test('returns event if _any_ adds are left', () => { const event = makeEvent({ - adds: [{ parentId: 0, nextId: 0, node: {} as unknown as serializedNodeWithId }], + adds: [{ parentId: 0, nextId: 0, node: {} as unknown as any }], attributes: [{ id: 1, attributes: { a: 'ttribute' } }], }) @@ -82,7 +81,7 @@ describe('MutationRateLimiter', () => { expect(result).toStrictEqual( makeEvent({ - adds: [{ parentId: 0, nextId: 0, node: {} as unknown as serializedNodeWithId }], + adds: [{ parentId: 0, nextId: 0, node: {} as unknown as any }], attributes: [], }) ) diff --git a/src/extensions/replay/sessionrecording-utils.ts b/src/extensions/replay/sessionrecording-utils.ts index aba786e87..86a29df48 100644 --- a/src/extensions/replay/sessionrecording-utils.ts +++ b/src/extensions/replay/sessionrecording-utils.ts @@ -1,15 +1,5 @@ -import type { - blockClass, - eventWithTime, - hooksParam, - KeepIframeSrcFn, - listenerHandler, - maskTextClass, - pluginEvent, - RecordPlugin, - SamplingStrategy, -} from '@rrweb/types' -import type { DataURLOptions, MaskInputFn, MaskInputOptions, MaskTextFn, Mirror, SlimDOMOptions } from 'rrweb-snapshot' +import type { eventWithTime, listenerHandler, pluginEvent } from '@rrweb/types' +import type { record } from '@rrweb/record' import { isObject } from '../../utils/type-utils' import { SnapshotBuffer } from './sessionrecording' @@ -51,43 +41,48 @@ export const MUTATION_SOURCE_TYPE = 0 export const MAX_MESSAGE_SIZE = 5000000 // ~5mb export type rrwebRecord = { - (options: recordOptions): listenerHandler + (options: recordOptions): listenerHandler addCustomEvent: (tag: string, payload: any) => void takeFullSnapshot: () => void - mirror: Mirror + mirror: { + getId(n: Node | undefined | null): number + getNode(id: number): Node | null + } } -export declare type recordOptions = { - emit?: (e: T, isCheckout?: boolean) => void - checkoutEveryNth?: number - checkoutEveryNms?: number - blockClass?: blockClass - blockSelector?: string - ignoreClass?: string - maskTextClass?: maskTextClass - maskTextSelector?: string - maskAllInputs?: boolean - maskInputOptions?: MaskInputOptions - maskInputFn?: MaskInputFn - maskTextFn?: MaskTextFn - slimDOMOptions?: SlimDOMOptions | 'all' | true - ignoreCSSAttributes?: Set - inlineStylesheet?: boolean - hooks?: hooksParam - // packFn?: PackFn - sampling?: SamplingStrategy - dataURLOptions?: DataURLOptions - recordCanvas?: boolean - recordCrossOriginIframes?: boolean - recordAfter?: 'DOMContentLoaded' | 'load' - userTriggeredOnInput?: boolean - collectFonts?: boolean - inlineImages?: boolean - plugins?: RecordPlugin[] - mousemoveWait?: number - keepIframeSrcFn?: KeepIframeSrcFn - // errorHandler?: ErrorHandler -} +export declare type recordOptions = Exclude>[0], undefined> + +// export declare type recordOptions = { +// emit?: (e: T, isCheckout?: boolean) => void +// checkoutEveryNth?: number +// checkoutEveryNms?: number +// blockClass?: blockClass +// blockSelector?: string +// ignoreClass?: string +// maskTextClass?: maskTextClass +// maskTextSelector?: string +// maskAllInputs?: boolean +// maskInputOptions?: MaskInputOptions +// maskInputFn?: MaskInputFn +// maskTextFn?: MaskTextFn +// slimDOMOptions?: SlimDOMOptions | 'all' | true +// ignoreCSSAttributes?: Set +// inlineStylesheet?: boolean +// hooks?: hooksParam +// // packFn?: PackFn +// sampling?: SamplingStrategy +// dataURLOptions?: DataURLOptions +// recordCanvas?: boolean +// recordCrossOriginIframes?: boolean +// recordAfter?: 'DOMContentLoaded' | 'load' +// userTriggeredOnInput?: boolean +// collectFonts?: boolean +// inlineImages?: boolean +// plugins?: RecordPlugin[] +// mousemoveWait?: number +// keepIframeSrcFn?: KeepIframeSrcFn +// // errorHandler?: ErrorHandler +// } /* * Check whether a data payload is nearing 5mb. If it is, it checks the data for diff --git a/src/extensions/replay/sessionrecording.ts b/src/extensions/replay/sessionrecording.ts index 67fa99336..5815afc48 100644 --- a/src/extensions/replay/sessionrecording.ts +++ b/src/extensions/replay/sessionrecording.ts @@ -836,7 +836,7 @@ export class SessionRecording { private _onScriptLoaded() { // rrweb config info: https://github.com/rrweb-io/rrweb/blob/7d5d0033258d6c29599fb08412202d9a2c7b9413/src/record/index.ts#L28 - const sessionRecordingOptions: recordOptions = { + const sessionRecordingOptions: recordOptions = { // select set of rrweb config options we expose to our users // see https://github.com/rrweb-io/rrweb/blob/master/guide.md blockClass: 'ph-no-capture', diff --git a/src/types.ts b/src/types.ts index 0f6c5cfc9..950d92678 100644 --- a/src/types.ts +++ b/src/types.ts @@ -1,6 +1,6 @@ -import type { MaskInputOptions, SlimDOMOptions } from 'rrweb-snapshot' import { PostHog } from './posthog-core' import type { SegmentAnalytics } from './extensions/segment-integration' +import { recordOptions } from './extensions/replay/sessionrecording-utils' export type Property = any export type Properties = Record @@ -278,9 +278,9 @@ export interface SessionRecordingOptions { maskTextSelector?: string | null maskTextFn?: ((text: string, element: HTMLElement | null) => string) | null maskAllInputs?: boolean - maskInputOptions?: MaskInputOptions + maskInputOptions?: recordOptions['maskInputOptions'] maskInputFn?: ((text: string, element?: HTMLElement) => string) | null - slimDOMOptions?: SlimDOMOptions | 'all' | true + slimDOMOptions?: recordOptions['slimDOMOptions'] collectFonts?: boolean inlineStylesheet?: boolean recordCrossOriginIframes?: boolean From a7a33bc680c6e32426f6c05a09bd4b1d696eea26 Mon Sep 17 00:00:00 2001 From: David Newell Date: Sun, 3 Nov 2024 14:28:50 +0000 Subject: [PATCH 17/21] remove postcss from console plugin --- package.json | 3 +- ...plugin-console-record@2.0.0-alpha.17.patch | 7086 +++++++++++++++++ pnpm-lock.yaml | 8 +- 3 files changed, 7094 insertions(+), 3 deletions(-) create mode 100644 patches/@rrweb__rrweb-plugin-console-record@2.0.0-alpha.17.patch diff --git a/package.json b/package.json index 69809143d..7e144bb23 100644 --- a/package.json +++ b/package.json @@ -126,7 +126,8 @@ ], "pnpm": { "patchedDependencies": { - "@rrweb/record@2.0.0-alpha.17": "patches/@rrweb__record@2.0.0-alpha.17.patch" + "@rrweb/record@2.0.0-alpha.17": "patches/@rrweb__record@2.0.0-alpha.17.patch", + "@rrweb/rrweb-plugin-console-record@2.0.0-alpha.17": "patches/@rrweb__rrweb-plugin-console-record@2.0.0-alpha.17.patch" } } } diff --git a/patches/@rrweb__rrweb-plugin-console-record@2.0.0-alpha.17.patch b/patches/@rrweb__rrweb-plugin-console-record@2.0.0-alpha.17.patch new file mode 100644 index 000000000..eb229d0c7 --- /dev/null +++ b/patches/@rrweb__rrweb-plugin-console-record@2.0.0-alpha.17.patch @@ -0,0 +1,7086 @@ +diff --git a/dist/rrweb-plugin-console-record.js b/dist/rrweb-plugin-console-record.js +index 408935669bc688ed93e2ccee433b4f75ad28e8f7..f0296b84fb80c459c09b07b7a200902f550c0ec6 100644 +--- a/dist/rrweb-plugin-console-record.js ++++ b/dist/rrweb-plugin-console-record.js +@@ -258,7080 +258,7 @@ function getAugmentedNamespace$1(n2) { + }); + return a2; + } +-var picocolors_browser$1 = { exports: {} }; +-var x$1 = String; +-var create$1 = function() { +- return { isColorSupported: false, reset: x$1, bold: x$1, dim: x$1, italic: x$1, underline: x$1, inverse: x$1, hidden: x$1, strikethrough: x$1, black: x$1, red: x$1, green: x$1, yellow: x$1, blue: x$1, magenta: x$1, cyan: x$1, white: x$1, gray: x$1, bgBlack: x$1, bgRed: x$1, bgGreen: x$1, bgYellow: x$1, bgBlue: x$1, bgMagenta: x$1, bgCyan: x$1, bgWhite: x$1 }; +-}; +-picocolors_browser$1.exports = create$1(); +-picocolors_browser$1.exports.createColors = create$1; +-var picocolors_browserExports$1 = picocolors_browser$1.exports; +-const __viteBrowserExternal$2 = {}; +-const __viteBrowserExternal$1$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({ +- __proto__: null, +- default: __viteBrowserExternal$2 +-}, Symbol.toStringTag, { value: "Module" })); +-const require$$2$1 = /* @__PURE__ */ getAugmentedNamespace$1(__viteBrowserExternal$1$1); +-let pico$1 = picocolors_browserExports$1; +-let terminalHighlight$1$1 = require$$2$1; +-let CssSyntaxError$3$1 = class CssSyntaxError extends Error { +- constructor(message, line, column, source, file, plugin22) { +- super(message); +- this.name = "CssSyntaxError"; +- this.reason = message; +- if (file) { +- this.file = file; +- } +- if (source) { +- this.source = source; +- } +- if (plugin22) { +- this.plugin = plugin22; +- } +- if (typeof line !== "undefined" && typeof column !== "undefined") { +- if (typeof line === "number") { +- this.line = line; +- this.column = column; +- } else { +- this.line = line.line; +- this.column = line.column; +- this.endLine = column.line; +- this.endColumn = column.column; +- } +- } +- this.setMessage(); +- if (Error.captureStackTrace) { +- Error.captureStackTrace(this, CssSyntaxError); +- } +- } +- setMessage() { +- this.message = this.plugin ? this.plugin + ": " : ""; +- this.message += this.file ? this.file : ""; +- if (typeof this.line !== "undefined") { +- this.message += ":" + this.line + ":" + this.column; +- } +- this.message += ": " + this.reason; +- } +- showSourceCode(color) { +- if (!this.source) return ""; +- let css = this.source; +- if (color == null) color = pico$1.isColorSupported; +- if (terminalHighlight$1$1) { +- if (color) css = terminalHighlight$1$1(css); +- } +- let lines = css.split(/\r?\n/); +- let start = Math.max(this.line - 3, 0); +- let end = Math.min(this.line + 2, lines.length); +- let maxWidth = String(end).length; +- let mark, aside; +- if (color) { +- let { bold, gray, red } = pico$1.createColors(true); +- mark = (text) => bold(red(text)); +- aside = (text) => gray(text); +- } else { +- mark = aside = (str) => str; +- } +- return lines.slice(start, end).map((line, index2) => { +- let number = start + 1 + index2; +- let gutter = " " + (" " + number).slice(-maxWidth) + " | "; +- if (number === this.line) { +- let spacing = aside(gutter.replace(/\d/g, " ")) + line.slice(0, this.column - 1).replace(/[^\t]/g, " "); +- return mark(">") + aside(gutter) + line + "\n " + spacing + mark("^"); +- } +- return " " + aside(gutter) + line; +- }).join("\n"); +- } +- toString() { +- let code = this.showSourceCode(); +- if (code) { +- code = "\n\n" + code + "\n"; +- } +- return this.name + ": " + this.message + code; +- } +-}; +-var cssSyntaxError$1 = CssSyntaxError$3$1; +-CssSyntaxError$3$1.default = CssSyntaxError$3$1; +-var symbols$1 = {}; +-symbols$1.isClean = Symbol("isClean"); +-symbols$1.my = Symbol("my"); +-const DEFAULT_RAW$1 = { +- after: "\n", +- beforeClose: "\n", +- beforeComment: "\n", +- beforeDecl: "\n", +- beforeOpen: " ", +- beforeRule: "\n", +- colon: ": ", +- commentLeft: " ", +- commentRight: " ", +- emptyBody: "", +- indent: " ", +- semicolon: false +-}; +-function capitalize$1(str) { +- return str[0].toUpperCase() + str.slice(1); +-} +-let Stringifier$2$1 = class Stringifier { +- constructor(builder) { +- this.builder = builder; +- } +- atrule(node2, semicolon) { +- let name = "@" + node2.name; +- let params = node2.params ? this.rawValue(node2, "params") : ""; +- if (typeof node2.raws.afterName !== "undefined") { +- name += node2.raws.afterName; +- } else if (params) { +- name += " "; +- } +- if (node2.nodes) { +- this.block(node2, name + params); +- } else { +- let end = (node2.raws.between || "") + (semicolon ? ";" : ""); +- this.builder(name + params + end, node2); +- } +- } +- beforeAfter(node2, detect) { +- let value; +- if (node2.type === "decl") { +- value = this.raw(node2, null, "beforeDecl"); +- } else if (node2.type === "comment") { +- value = this.raw(node2, null, "beforeComment"); +- } else if (detect === "before") { +- value = this.raw(node2, null, "beforeRule"); +- } else { +- value = this.raw(node2, null, "beforeClose"); +- } +- let buf = node2.parent; +- let depth = 0; +- while (buf && buf.type !== "root") { +- depth += 1; +- buf = buf.parent; +- } +- if (value.includes("\n")) { +- let indent = this.raw(node2, null, "indent"); +- if (indent.length) { +- for (let step = 0; step < depth; step++) value += indent; +- } +- } +- return value; +- } +- block(node2, start) { +- let between = this.raw(node2, "between", "beforeOpen"); +- this.builder(start + between + "{", node2, "start"); +- let after; +- if (node2.nodes && node2.nodes.length) { +- this.body(node2); +- after = this.raw(node2, "after"); +- } else { +- after = this.raw(node2, "after", "emptyBody"); +- } +- if (after) this.builder(after); +- this.builder("}", node2, "end"); +- } +- body(node2) { +- let last = node2.nodes.length - 1; +- while (last > 0) { +- if (node2.nodes[last].type !== "comment") break; +- last -= 1; +- } +- let semicolon = this.raw(node2, "semicolon"); +- for (let i2 = 0; i2 < node2.nodes.length; i2++) { +- let child = node2.nodes[i2]; +- let before = this.raw(child, "before"); +- if (before) this.builder(before); +- this.stringify(child, last !== i2 || semicolon); +- } +- } +- comment(node2) { +- let left = this.raw(node2, "left", "commentLeft"); +- let right = this.raw(node2, "right", "commentRight"); +- this.builder("/*" + left + node2.text + right + "*/", node2); +- } +- decl(node2, semicolon) { +- let between = this.raw(node2, "between", "colon"); +- let string = node2.prop + between + this.rawValue(node2, "value"); +- if (node2.important) { +- string += node2.raws.important || " !important"; +- } +- if (semicolon) string += ";"; +- this.builder(string, node2); +- } +- document(node2) { +- this.body(node2); +- } +- raw(node2, own, detect) { +- let value; +- if (!detect) detect = own; +- if (own) { +- value = node2.raws[own]; +- if (typeof value !== "undefined") return value; +- } +- let parent = node2.parent; +- if (detect === "before") { +- if (!parent || parent.type === "root" && parent.first === node2) { +- return ""; +- } +- if (parent && parent.type === "document") { +- return ""; +- } +- } +- if (!parent) return DEFAULT_RAW$1[detect]; +- let root2 = node2.root(); +- if (!root2.rawCache) root2.rawCache = {}; +- if (typeof root2.rawCache[detect] !== "undefined") { +- return root2.rawCache[detect]; +- } +- if (detect === "before" || detect === "after") { +- return this.beforeAfter(node2, detect); +- } else { +- let method = "raw" + capitalize$1(detect); +- if (this[method]) { +- value = this[method](root2, node2); +- } else { +- root2.walk((i2) => { +- value = i2.raws[own]; +- if (typeof value !== "undefined") return false; +- }); +- } +- } +- if (typeof value === "undefined") value = DEFAULT_RAW$1[detect]; +- root2.rawCache[detect] = value; +- return value; +- } +- rawBeforeClose(root2) { +- let value; +- root2.walk((i2) => { +- if (i2.nodes && i2.nodes.length > 0) { +- if (typeof i2.raws.after !== "undefined") { +- value = i2.raws.after; +- if (value.includes("\n")) { +- value = value.replace(/[^\n]+$/, ""); +- } +- return false; +- } +- } +- }); +- if (value) value = value.replace(/\S/g, ""); +- return value; +- } +- rawBeforeComment(root2, node2) { +- let value; +- root2.walkComments((i2) => { +- if (typeof i2.raws.before !== "undefined") { +- value = i2.raws.before; +- if (value.includes("\n")) { +- value = value.replace(/[^\n]+$/, ""); +- } +- return false; +- } +- }); +- if (typeof value === "undefined") { +- value = this.raw(node2, null, "beforeDecl"); +- } else if (value) { +- value = value.replace(/\S/g, ""); +- } +- return value; +- } +- rawBeforeDecl(root2, node2) { +- let value; +- root2.walkDecls((i2) => { +- if (typeof i2.raws.before !== "undefined") { +- value = i2.raws.before; +- if (value.includes("\n")) { +- value = value.replace(/[^\n]+$/, ""); +- } +- return false; +- } +- }); +- if (typeof value === "undefined") { +- value = this.raw(node2, null, "beforeRule"); +- } else if (value) { +- value = value.replace(/\S/g, ""); +- } +- return value; +- } +- rawBeforeOpen(root2) { +- let value; +- root2.walk((i2) => { +- if (i2.type !== "decl") { +- value = i2.raws.between; +- if (typeof value !== "undefined") return false; +- } +- }); +- return value; +- } +- rawBeforeRule(root2) { +- let value; +- root2.walk((i2) => { +- if (i2.nodes && (i2.parent !== root2 || root2.first !== i2)) { +- if (typeof i2.raws.before !== "undefined") { +- value = i2.raws.before; +- if (value.includes("\n")) { +- value = value.replace(/[^\n]+$/, ""); +- } +- return false; +- } +- } +- }); +- if (value) value = value.replace(/\S/g, ""); +- return value; +- } +- rawColon(root2) { +- let value; +- root2.walkDecls((i2) => { +- if (typeof i2.raws.between !== "undefined") { +- value = i2.raws.between.replace(/[^\s:]/g, ""); +- return false; +- } +- }); +- return value; +- } +- rawEmptyBody(root2) { +- let value; +- root2.walk((i2) => { +- if (i2.nodes && i2.nodes.length === 0) { +- value = i2.raws.after; +- if (typeof value !== "undefined") return false; +- } +- }); +- return value; +- } +- rawIndent(root2) { +- if (root2.raws.indent) return root2.raws.indent; +- let value; +- root2.walk((i2) => { +- let p = i2.parent; +- if (p && p !== root2 && p.parent && p.parent === root2) { +- if (typeof i2.raws.before !== "undefined") { +- let parts = i2.raws.before.split("\n"); +- value = parts[parts.length - 1]; +- value = value.replace(/\S/g, ""); +- return false; +- } +- } +- }); +- return value; +- } +- rawSemicolon(root2) { +- let value; +- root2.walk((i2) => { +- if (i2.nodes && i2.nodes.length && i2.last.type === "decl") { +- value = i2.raws.semicolon; +- if (typeof value !== "undefined") return false; +- } +- }); +- return value; +- } +- rawValue(node2, prop) { +- let value = node2[prop]; +- let raw = node2.raws[prop]; +- if (raw && raw.value === value) { +- return raw.raw; +- } +- return value; +- } +- root(node2) { +- this.body(node2); +- if (node2.raws.after) this.builder(node2.raws.after); +- } +- rule(node2) { +- this.block(node2, this.rawValue(node2, "selector")); +- if (node2.raws.ownSemicolon) { +- this.builder(node2.raws.ownSemicolon, node2, "end"); +- } +- } +- stringify(node2, semicolon) { +- if (!this[node2.type]) { +- throw new Error( +- "Unknown AST node type " + node2.type + ". Maybe you need to change PostCSS stringifier." +- ); +- } +- this[node2.type](node2, semicolon); +- } +-}; +-var stringifier$1 = Stringifier$2$1; +-Stringifier$2$1.default = Stringifier$2$1; +-let Stringifier$1$1 = stringifier$1; +-function stringify$4$1(node2, builder) { +- let str = new Stringifier$1$1(builder); +- str.stringify(node2); +-} +-var stringify_1$1 = stringify$4$1; +-stringify$4$1.default = stringify$4$1; +-let { isClean: isClean$2$1, my: my$2$1 } = symbols$1; +-let CssSyntaxError$2$1 = cssSyntaxError$1; +-let Stringifier2$1 = stringifier$1; +-let stringify$3$1 = stringify_1$1; +-function cloneNode$1(obj, parent) { +- let cloned = new obj.constructor(); +- for (let i2 in obj) { +- if (!Object.prototype.hasOwnProperty.call(obj, i2)) { +- continue; +- } +- if (i2 === "proxyCache") continue; +- let value = obj[i2]; +- let type = typeof value; +- if (i2 === "parent" && type === "object") { +- if (parent) cloned[i2] = parent; +- } else if (i2 === "source") { +- cloned[i2] = value; +- } else if (Array.isArray(value)) { +- cloned[i2] = value.map((j) => cloneNode$1(j, cloned)); +- } else { +- if (type === "object" && value !== null) value = cloneNode$1(value); +- cloned[i2] = value; +- } +- } +- return cloned; +-} +-let Node$4$1 = class Node2 { +- constructor(defaults = {}) { +- this.raws = {}; +- this[isClean$2$1] = false; +- this[my$2$1] = true; +- for (let name in defaults) { +- if (name === "nodes") { +- this.nodes = []; +- for (let node2 of defaults[name]) { +- if (typeof node2.clone === "function") { +- this.append(node2.clone()); +- } else { +- this.append(node2); +- } +- } +- } else { +- this[name] = defaults[name]; +- } +- } +- } +- addToError(error) { +- error.postcssNode = this; +- if (error.stack && this.source && /\n\s{4}at /.test(error.stack)) { +- let s2 = this.source; +- error.stack = error.stack.replace( +- /\n\s{4}at /, +- `$&${s2.input.from}:${s2.start.line}:${s2.start.column}$&` +- ); +- } +- return error; +- } +- after(add) { +- this.parent.insertAfter(this, add); +- return this; +- } +- assign(overrides = {}) { +- for (let name in overrides) { +- this[name] = overrides[name]; +- } +- return this; +- } +- before(add) { +- this.parent.insertBefore(this, add); +- return this; +- } +- cleanRaws(keepBetween) { +- delete this.raws.before; +- delete this.raws.after; +- if (!keepBetween) delete this.raws.between; +- } +- clone(overrides = {}) { +- let cloned = cloneNode$1(this); +- for (let name in overrides) { +- cloned[name] = overrides[name]; +- } +- return cloned; +- } +- cloneAfter(overrides = {}) { +- let cloned = this.clone(overrides); +- this.parent.insertAfter(this, cloned); +- return cloned; +- } +- cloneBefore(overrides = {}) { +- let cloned = this.clone(overrides); +- this.parent.insertBefore(this, cloned); +- return cloned; +- } +- error(message, opts = {}) { +- if (this.source) { +- let { end, start } = this.rangeBy(opts); +- return this.source.input.error( +- message, +- { column: start.column, line: start.line }, +- { column: end.column, line: end.line }, +- opts +- ); +- } +- return new CssSyntaxError$2$1(message); +- } +- getProxyProcessor() { +- return { +- get(node2, prop) { +- if (prop === "proxyOf") { +- return node2; +- } else if (prop === "root") { +- return () => node2.root().toProxy(); +- } else { +- return node2[prop]; +- } +- }, +- set(node2, prop, value) { +- if (node2[prop] === value) return true; +- node2[prop] = value; +- if (prop === "prop" || prop === "value" || prop === "name" || prop === "params" || prop === "important" || /* c8 ignore next */ +- prop === "text") { +- node2.markDirty(); +- } +- return true; +- } +- }; +- } +- markDirty() { +- if (this[isClean$2$1]) { +- this[isClean$2$1] = false; +- let next = this; +- while (next = next.parent) { +- next[isClean$2$1] = false; +- } +- } +- } +- next() { +- if (!this.parent) return void 0; +- let index2 = this.parent.index(this); +- return this.parent.nodes[index2 + 1]; +- } +- positionBy(opts, stringRepresentation) { +- let pos = this.source.start; +- if (opts.index) { +- pos = this.positionInside(opts.index, stringRepresentation); +- } else if (opts.word) { +- stringRepresentation = this.toString(); +- let index2 = stringRepresentation.indexOf(opts.word); +- if (index2 !== -1) pos = this.positionInside(index2, stringRepresentation); +- } +- return pos; +- } +- positionInside(index2, stringRepresentation) { +- let string = stringRepresentation || this.toString(); +- let column = this.source.start.column; +- let line = this.source.start.line; +- for (let i2 = 0; i2 < index2; i2++) { +- if (string[i2] === "\n") { +- column = 1; +- line += 1; +- } else { +- column += 1; +- } +- } +- return { column, line }; +- } +- prev() { +- if (!this.parent) return void 0; +- let index2 = this.parent.index(this); +- return this.parent.nodes[index2 - 1]; +- } +- rangeBy(opts) { +- let start = { +- column: this.source.start.column, +- line: this.source.start.line +- }; +- let end = this.source.end ? { +- column: this.source.end.column + 1, +- line: this.source.end.line +- } : { +- column: start.column + 1, +- line: start.line +- }; +- if (opts.word) { +- let stringRepresentation = this.toString(); +- let index2 = stringRepresentation.indexOf(opts.word); +- if (index2 !== -1) { +- start = this.positionInside(index2, stringRepresentation); +- end = this.positionInside(index2 + opts.word.length, stringRepresentation); +- } +- } else { +- if (opts.start) { +- start = { +- column: opts.start.column, +- line: opts.start.line +- }; +- } else if (opts.index) { +- start = this.positionInside(opts.index); +- } +- if (opts.end) { +- end = { +- column: opts.end.column, +- line: opts.end.line +- }; +- } else if (typeof opts.endIndex === "number") { +- end = this.positionInside(opts.endIndex); +- } else if (opts.index) { +- end = this.positionInside(opts.index + 1); +- } +- } +- if (end.line < start.line || end.line === start.line && end.column <= start.column) { +- end = { column: start.column + 1, line: start.line }; +- } +- return { end, start }; +- } +- raw(prop, defaultType) { +- let str = new Stringifier2$1(); +- return str.raw(this, prop, defaultType); +- } +- remove() { +- if (this.parent) { +- this.parent.removeChild(this); +- } +- this.parent = void 0; +- return this; +- } +- replaceWith(...nodes) { +- if (this.parent) { +- let bookmark = this; +- let foundSelf = false; +- for (let node2 of nodes) { +- if (node2 === this) { +- foundSelf = true; +- } else if (foundSelf) { +- this.parent.insertAfter(bookmark, node2); +- bookmark = node2; +- } else { +- this.parent.insertBefore(bookmark, node2); +- } +- } +- if (!foundSelf) { +- this.remove(); +- } +- } +- return this; +- } +- root() { +- let result2 = this; +- while (result2.parent && result2.parent.type !== "document") { +- result2 = result2.parent; +- } +- return result2; +- } +- toJSON(_, inputs) { +- let fixed = {}; +- let emitInputs = inputs == null; +- inputs = inputs || /* @__PURE__ */ new Map(); +- let inputsNextIndex = 0; +- for (let name in this) { +- if (!Object.prototype.hasOwnProperty.call(this, name)) { +- continue; +- } +- if (name === "parent" || name === "proxyCache") continue; +- let value = this[name]; +- if (Array.isArray(value)) { +- fixed[name] = value.map((i2) => { +- if (typeof i2 === "object" && i2.toJSON) { +- return i2.toJSON(null, inputs); +- } else { +- return i2; +- } +- }); +- } else if (typeof value === "object" && value.toJSON) { +- fixed[name] = value.toJSON(null, inputs); +- } else if (name === "source") { +- let inputId = inputs.get(value.input); +- if (inputId == null) { +- inputId = inputsNextIndex; +- inputs.set(value.input, inputsNextIndex); +- inputsNextIndex++; +- } +- fixed[name] = { +- end: value.end, +- inputId, +- start: value.start +- }; +- } else { +- fixed[name] = value; +- } +- } +- if (emitInputs) { +- fixed.inputs = [...inputs.keys()].map((input2) => input2.toJSON()); +- } +- return fixed; +- } +- toProxy() { +- if (!this.proxyCache) { +- this.proxyCache = new Proxy(this, this.getProxyProcessor()); +- } +- return this.proxyCache; +- } +- toString(stringifier2 = stringify$3$1) { +- if (stringifier2.stringify) stringifier2 = stringifier2.stringify; +- let result2 = ""; +- stringifier2(this, (i2) => { +- result2 += i2; +- }); +- return result2; +- } +- warn(result2, text, opts) { +- let data = { node: this }; +- for (let i2 in opts) data[i2] = opts[i2]; +- return result2.warn(text, data); +- } +- get proxyOf() { +- return this; +- } +-}; +-var node$1 = Node$4$1; +-Node$4$1.default = Node$4$1; +-let Node$3$1 = node$1; +-let Declaration$4$1 = class Declaration extends Node$3$1 { +- constructor(defaults) { +- if (defaults && typeof defaults.value !== "undefined" && typeof defaults.value !== "string") { +- defaults = { ...defaults, value: String(defaults.value) }; +- } +- super(defaults); +- this.type = "decl"; +- } +- get variable() { +- return this.prop.startsWith("--") || this.prop[0] === "$"; +- } +-}; +-var declaration$1 = Declaration$4$1; +-Declaration$4$1.default = Declaration$4$1; +-let urlAlphabet$1 = "useandom-26T198340PX75pxJACKVERYMINDBUSHWOLF_GQZbfghjklqvwyzrict"; +-let customAlphabet$1 = (alphabet, defaultSize = 21) => { +- return (size = defaultSize) => { +- let id = ""; +- let i2 = size; +- while (i2--) { +- id += alphabet[Math.random() * alphabet.length | 0]; +- } +- return id; +- }; +-}; +-let nanoid$1$1 = (size = 21) => { +- let id = ""; +- let i2 = size; +- while (i2--) { +- id += urlAlphabet$1[Math.random() * 64 | 0]; +- } +- return id; +-}; +-var nonSecure$1 = { nanoid: nanoid$1$1, customAlphabet: customAlphabet$1 }; +-let { SourceMapConsumer: SourceMapConsumer$2$1, SourceMapGenerator: SourceMapGenerator$2$1 } = require$$2$1; +-let { existsSync: existsSync$1, readFileSync: readFileSync$1 } = require$$2$1; +-let { dirname: dirname$1$1, join: join$1 } = require$$2$1; +-function fromBase64$1(str) { +- if (Buffer) { +- return Buffer.from(str, "base64").toString(); +- } else { +- return window.atob(str); +- } +-} +-let PreviousMap$2$1 = class PreviousMap { +- constructor(css, opts) { +- if (opts.map === false) return; +- this.loadAnnotation(css); +- this.inline = this.startWith(this.annotation, "data:"); +- let prev = opts.map ? opts.map.prev : void 0; +- let text = this.loadMap(opts.from, prev); +- if (!this.mapFile && opts.from) { +- this.mapFile = opts.from; +- } +- if (this.mapFile) this.root = dirname$1$1(this.mapFile); +- if (text) this.text = text; +- } +- consumer() { +- if (!this.consumerCache) { +- this.consumerCache = new SourceMapConsumer$2$1(this.text); +- } +- return this.consumerCache; +- } +- decodeInline(text) { +- let baseCharsetUri = /^data:application\/json;charset=utf-?8;base64,/; +- let baseUri = /^data:application\/json;base64,/; +- let charsetUri = /^data:application\/json;charset=utf-?8,/; +- let uri = /^data:application\/json,/; +- if (charsetUri.test(text) || uri.test(text)) { +- return decodeURIComponent(text.substr(RegExp.lastMatch.length)); +- } +- if (baseCharsetUri.test(text) || baseUri.test(text)) { +- return fromBase64$1(text.substr(RegExp.lastMatch.length)); +- } +- let encoding = text.match(/data:application\/json;([^,]+),/)[1]; +- throw new Error("Unsupported source map encoding " + encoding); +- } +- getAnnotationURL(sourceMapString) { +- return sourceMapString.replace(/^\/\*\s*# sourceMappingURL=/, "").trim(); +- } +- isMap(map) { +- if (typeof map !== "object") return false; +- return typeof map.mappings === "string" || typeof map._mappings === "string" || Array.isArray(map.sections); +- } +- loadAnnotation(css) { +- let comments = css.match(/\/\*\s*# sourceMappingURL=/gm); +- if (!comments) return; +- let start = css.lastIndexOf(comments.pop()); +- let end = css.indexOf("*/", start); +- if (start > -1 && end > -1) { +- this.annotation = this.getAnnotationURL(css.substring(start, end)); +- } +- } +- loadFile(path) { +- this.root = dirname$1$1(path); +- if (existsSync$1(path)) { +- this.mapFile = path; +- return readFileSync$1(path, "utf-8").toString().trim(); +- } +- } +- loadMap(file, prev) { +- if (prev === false) return false; +- if (prev) { +- if (typeof prev === "string") { +- return prev; +- } else if (typeof prev === "function") { +- let prevPath = prev(file); +- if (prevPath) { +- let map = this.loadFile(prevPath); +- if (!map) { +- throw new Error( +- "Unable to load previous source map: " + prevPath.toString() +- ); +- } +- return map; +- } +- } else if (prev instanceof SourceMapConsumer$2$1) { +- return SourceMapGenerator$2$1.fromSourceMap(prev).toString(); +- } else if (prev instanceof SourceMapGenerator$2$1) { +- return prev.toString(); +- } else if (this.isMap(prev)) { +- return JSON.stringify(prev); +- } else { +- throw new Error( +- "Unsupported previous source map format: " + prev.toString() +- ); +- } +- } else if (this.inline) { +- return this.decodeInline(this.annotation); +- } else if (this.annotation) { +- let map = this.annotation; +- if (file) map = join$1(dirname$1$1(file), map); +- return this.loadFile(map); +- } +- } +- startWith(string, start) { +- if (!string) return false; +- return string.substr(0, start.length) === start; +- } +- withContent() { +- return !!(this.consumer().sourcesContent && this.consumer().sourcesContent.length > 0); +- } +-}; +-var previousMap$1 = PreviousMap$2$1; +-PreviousMap$2$1.default = PreviousMap$2$1; +-let { SourceMapConsumer: SourceMapConsumer$1$1, SourceMapGenerator: SourceMapGenerator$1$1 } = require$$2$1; +-let { fileURLToPath: fileURLToPath$1, pathToFileURL: pathToFileURL$1$1 } = require$$2$1; +-let { isAbsolute: isAbsolute$1, resolve: resolve$1$1 } = require$$2$1; +-let { nanoid: nanoid$2 } = nonSecure$1; +-let terminalHighlight$2 = require$$2$1; +-let CssSyntaxError$1$1 = cssSyntaxError$1; +-let PreviousMap$1$1 = previousMap$1; +-let fromOffsetCache$1 = Symbol("fromOffsetCache"); +-let sourceMapAvailable$1$1 = Boolean(SourceMapConsumer$1$1 && SourceMapGenerator$1$1); +-let pathAvailable$1$1 = Boolean(resolve$1$1 && isAbsolute$1); +-let Input$4$1 = class Input { +- constructor(css, opts = {}) { +- if (css === null || typeof css === "undefined" || typeof css === "object" && !css.toString) { +- throw new Error(`PostCSS received ${css} instead of CSS string`); +- } +- this.css = css.toString(); +- if (this.css[0] === "\uFEFF" || this.css[0] === "￾") { +- this.hasBOM = true; +- this.css = this.css.slice(1); +- } else { +- this.hasBOM = false; +- } +- if (opts.from) { +- if (!pathAvailable$1$1 || /^\w+:\/\//.test(opts.from) || isAbsolute$1(opts.from)) { +- this.file = opts.from; +- } else { +- this.file = resolve$1$1(opts.from); +- } +- } +- if (pathAvailable$1$1 && sourceMapAvailable$1$1) { +- let map = new PreviousMap$1$1(this.css, opts); +- if (map.text) { +- this.map = map; +- let file = map.consumer().file; +- if (!this.file && file) this.file = this.mapResolve(file); +- } +- } +- if (!this.file) { +- this.id = ""; +- } +- if (this.map) this.map.file = this.from; +- } +- error(message, line, column, opts = {}) { +- let result2, endLine, endColumn; +- if (line && typeof line === "object") { +- let start = line; +- let end = column; +- if (typeof start.offset === "number") { +- let pos = this.fromOffset(start.offset); +- line = pos.line; +- column = pos.col; +- } else { +- line = start.line; +- column = start.column; +- } +- if (typeof end.offset === "number") { +- let pos = this.fromOffset(end.offset); +- endLine = pos.line; +- endColumn = pos.col; +- } else { +- endLine = end.line; +- endColumn = end.column; +- } +- } else if (!column) { +- let pos = this.fromOffset(line); +- line = pos.line; +- column = pos.col; +- } +- let origin = this.origin(line, column, endLine, endColumn); +- if (origin) { +- result2 = new CssSyntaxError$1$1( +- message, +- origin.endLine === void 0 ? origin.line : { column: origin.column, line: origin.line }, +- origin.endLine === void 0 ? origin.column : { column: origin.endColumn, line: origin.endLine }, +- origin.source, +- origin.file, +- opts.plugin +- ); +- } else { +- result2 = new CssSyntaxError$1$1( +- message, +- endLine === void 0 ? line : { column, line }, +- endLine === void 0 ? column : { column: endColumn, line: endLine }, +- this.css, +- this.file, +- opts.plugin +- ); +- } +- result2.input = { column, endColumn, endLine, line, source: this.css }; +- if (this.file) { +- if (pathToFileURL$1$1) { +- result2.input.url = pathToFileURL$1$1(this.file).toString(); +- } +- result2.input.file = this.file; +- } +- return result2; +- } +- fromOffset(offset) { +- let lastLine, lineToIndex; +- if (!this[fromOffsetCache$1]) { +- let lines = this.css.split("\n"); +- lineToIndex = new Array(lines.length); +- let prevIndex = 0; +- for (let i2 = 0, l2 = lines.length; i2 < l2; i2++) { +- lineToIndex[i2] = prevIndex; +- prevIndex += lines[i2].length + 1; +- } +- this[fromOffsetCache$1] = lineToIndex; +- } else { +- lineToIndex = this[fromOffsetCache$1]; +- } +- lastLine = lineToIndex[lineToIndex.length - 1]; +- let min = 0; +- if (offset >= lastLine) { +- min = lineToIndex.length - 1; +- } else { +- let max = lineToIndex.length - 2; +- let mid; +- while (min < max) { +- mid = min + (max - min >> 1); +- if (offset < lineToIndex[mid]) { +- max = mid - 1; +- } else if (offset >= lineToIndex[mid + 1]) { +- min = mid + 1; +- } else { +- min = mid; +- break; +- } +- } +- } +- return { +- col: offset - lineToIndex[min] + 1, +- line: min + 1 +- }; +- } +- mapResolve(file) { +- if (/^\w+:\/\//.test(file)) { +- return file; +- } +- return resolve$1$1(this.map.consumer().sourceRoot || this.map.root || ".", file); +- } +- origin(line, column, endLine, endColumn) { +- if (!this.map) return false; +- let consumer = this.map.consumer(); +- let from = consumer.originalPositionFor({ column, line }); +- if (!from.source) return false; +- let to; +- if (typeof endLine === "number") { +- to = consumer.originalPositionFor({ column: endColumn, line: endLine }); +- } +- let fromUrl; +- if (isAbsolute$1(from.source)) { +- fromUrl = pathToFileURL$1$1(from.source); +- } else { +- fromUrl = new URL( +- from.source, +- this.map.consumer().sourceRoot || pathToFileURL$1$1(this.map.mapFile) +- ); +- } +- let result2 = { +- column: from.column, +- endColumn: to && to.column, +- endLine: to && to.line, +- line: from.line, +- url: fromUrl.toString() +- }; +- if (fromUrl.protocol === "file:") { +- if (fileURLToPath$1) { +- result2.file = fileURLToPath$1(fromUrl); +- } else { +- throw new Error(`file: protocol is not available in this PostCSS build`); +- } +- } +- let source = consumer.sourceContentFor(from.source); +- if (source) result2.source = source; +- return result2; +- } +- toJSON() { +- let json = {}; +- for (let name of ["hasBOM", "css", "file", "id"]) { +- if (this[name] != null) { +- json[name] = this[name]; +- } +- } +- if (this.map) { +- json.map = { ...this.map }; +- if (json.map.consumerCache) { +- json.map.consumerCache = void 0; +- } +- } +- return json; +- } +- get from() { +- return this.file || this.id; +- } +-}; +-var input$1 = Input$4$1; +-Input$4$1.default = Input$4$1; +-if (terminalHighlight$2 && terminalHighlight$2.registerInput) { +- terminalHighlight$2.registerInput(Input$4$1); +-} +-let { SourceMapConsumer: SourceMapConsumer$3, SourceMapGenerator: SourceMapGenerator$3 } = require$$2$1; +-let { dirname: dirname$2, relative: relative$1, resolve: resolve$2, sep: sep$1 } = require$$2$1; +-let { pathToFileURL: pathToFileURL$2 } = require$$2$1; +-let Input$3$1 = input$1; +-let sourceMapAvailable$2 = Boolean(SourceMapConsumer$3 && SourceMapGenerator$3); +-let pathAvailable$2 = Boolean(dirname$2 && resolve$2 && relative$1 && sep$1); +-let MapGenerator$2$1 = class MapGenerator { +- constructor(stringify2, root2, opts, cssString) { +- this.stringify = stringify2; +- this.mapOpts = opts.map || {}; +- this.root = root2; +- this.opts = opts; +- this.css = cssString; +- this.originalCSS = cssString; +- this.usesFileUrls = !this.mapOpts.from && this.mapOpts.absolute; +- this.memoizedFileURLs = /* @__PURE__ */ new Map(); +- this.memoizedPaths = /* @__PURE__ */ new Map(); +- this.memoizedURLs = /* @__PURE__ */ new Map(); +- } +- addAnnotation() { +- let content; +- if (this.isInline()) { +- content = "data:application/json;base64," + this.toBase64(this.map.toString()); +- } else if (typeof this.mapOpts.annotation === "string") { +- content = this.mapOpts.annotation; +- } else if (typeof this.mapOpts.annotation === "function") { +- content = this.mapOpts.annotation(this.opts.to, this.root); +- } else { +- content = this.outputFile() + ".map"; +- } +- let eol = "\n"; +- if (this.css.includes("\r\n")) eol = "\r\n"; +- this.css += eol + "/*# sourceMappingURL=" + content + " */"; +- } +- applyPrevMaps() { +- for (let prev of this.previous()) { +- let from = this.toUrl(this.path(prev.file)); +- let root2 = prev.root || dirname$2(prev.file); +- let map; +- if (this.mapOpts.sourcesContent === false) { +- map = new SourceMapConsumer$3(prev.text); +- if (map.sourcesContent) { +- map.sourcesContent = null; +- } +- } else { +- map = prev.consumer(); +- } +- this.map.applySourceMap(map, from, this.toUrl(this.path(root2))); +- } +- } +- clearAnnotation() { +- if (this.mapOpts.annotation === false) return; +- if (this.root) { +- let node2; +- for (let i2 = this.root.nodes.length - 1; i2 >= 0; i2--) { +- node2 = this.root.nodes[i2]; +- if (node2.type !== "comment") continue; +- if (node2.text.indexOf("# sourceMappingURL=") === 0) { +- this.root.removeChild(i2); +- } +- } +- } else if (this.css) { +- this.css = this.css.replace(/\n*?\/\*#[\S\s]*?\*\/$/gm, ""); +- } +- } +- generate() { +- this.clearAnnotation(); +- if (pathAvailable$2 && sourceMapAvailable$2 && this.isMap()) { +- return this.generateMap(); +- } else { +- let result2 = ""; +- this.stringify(this.root, (i2) => { +- result2 += i2; +- }); +- return [result2]; +- } +- } +- generateMap() { +- if (this.root) { +- this.generateString(); +- } else if (this.previous().length === 1) { +- let prev = this.previous()[0].consumer(); +- prev.file = this.outputFile(); +- this.map = SourceMapGenerator$3.fromSourceMap(prev, { +- ignoreInvalidMapping: true +- }); +- } else { +- this.map = new SourceMapGenerator$3({ +- file: this.outputFile(), +- ignoreInvalidMapping: true +- }); +- this.map.addMapping({ +- generated: { column: 0, line: 1 }, +- original: { column: 0, line: 1 }, +- source: this.opts.from ? this.toUrl(this.path(this.opts.from)) : "" +- }); +- } +- if (this.isSourcesContent()) this.setSourcesContent(); +- if (this.root && this.previous().length > 0) this.applyPrevMaps(); +- if (this.isAnnotation()) this.addAnnotation(); +- if (this.isInline()) { +- return [this.css]; +- } else { +- return [this.css, this.map]; +- } +- } +- generateString() { +- this.css = ""; +- this.map = new SourceMapGenerator$3({ +- file: this.outputFile(), +- ignoreInvalidMapping: true +- }); +- let line = 1; +- let column = 1; +- let noSource = ""; +- let mapping = { +- generated: { column: 0, line: 0 }, +- original: { column: 0, line: 0 }, +- source: "" +- }; +- let lines, last; +- this.stringify(this.root, (str, node2, type) => { +- this.css += str; +- if (node2 && type !== "end") { +- mapping.generated.line = line; +- mapping.generated.column = column - 1; +- if (node2.source && node2.source.start) { +- mapping.source = this.sourcePath(node2); +- mapping.original.line = node2.source.start.line; +- mapping.original.column = node2.source.start.column - 1; +- this.map.addMapping(mapping); +- } else { +- mapping.source = noSource; +- mapping.original.line = 1; +- mapping.original.column = 0; +- this.map.addMapping(mapping); +- } +- } +- lines = str.match(/\n/g); +- if (lines) { +- line += lines.length; +- last = str.lastIndexOf("\n"); +- column = str.length - last; +- } else { +- column += str.length; +- } +- if (node2 && type !== "start") { +- let p = node2.parent || { raws: {} }; +- let childless = node2.type === "decl" || node2.type === "atrule" && !node2.nodes; +- if (!childless || node2 !== p.last || p.raws.semicolon) { +- if (node2.source && node2.source.end) { +- mapping.source = this.sourcePath(node2); +- mapping.original.line = node2.source.end.line; +- mapping.original.column = node2.source.end.column - 1; +- mapping.generated.line = line; +- mapping.generated.column = column - 2; +- this.map.addMapping(mapping); +- } else { +- mapping.source = noSource; +- mapping.original.line = 1; +- mapping.original.column = 0; +- mapping.generated.line = line; +- mapping.generated.column = column - 1; +- this.map.addMapping(mapping); +- } +- } +- } +- }); +- } +- isAnnotation() { +- if (this.isInline()) { +- return true; +- } +- if (typeof this.mapOpts.annotation !== "undefined") { +- return this.mapOpts.annotation; +- } +- if (this.previous().length) { +- return this.previous().some((i2) => i2.annotation); +- } +- return true; +- } +- isInline() { +- if (typeof this.mapOpts.inline !== "undefined") { +- return this.mapOpts.inline; +- } +- let annotation = this.mapOpts.annotation; +- if (typeof annotation !== "undefined" && annotation !== true) { +- return false; +- } +- if (this.previous().length) { +- return this.previous().some((i2) => i2.inline); +- } +- return true; +- } +- isMap() { +- if (typeof this.opts.map !== "undefined") { +- return !!this.opts.map; +- } +- return this.previous().length > 0; +- } +- isSourcesContent() { +- if (typeof this.mapOpts.sourcesContent !== "undefined") { +- return this.mapOpts.sourcesContent; +- } +- if (this.previous().length) { +- return this.previous().some((i2) => i2.withContent()); +- } +- return true; +- } +- outputFile() { +- if (this.opts.to) { +- return this.path(this.opts.to); +- } else if (this.opts.from) { +- return this.path(this.opts.from); +- } else { +- return "to.css"; +- } +- } +- path(file) { +- if (this.mapOpts.absolute) return file; +- if (file.charCodeAt(0) === 60) return file; +- if (/^\w+:\/\//.test(file)) return file; +- let cached = this.memoizedPaths.get(file); +- if (cached) return cached; +- let from = this.opts.to ? dirname$2(this.opts.to) : "."; +- if (typeof this.mapOpts.annotation === "string") { +- from = dirname$2(resolve$2(from, this.mapOpts.annotation)); +- } +- let path = relative$1(from, file); +- this.memoizedPaths.set(file, path); +- return path; +- } +- previous() { +- if (!this.previousMaps) { +- this.previousMaps = []; +- if (this.root) { +- this.root.walk((node2) => { +- if (node2.source && node2.source.input.map) { +- let map = node2.source.input.map; +- if (!this.previousMaps.includes(map)) { +- this.previousMaps.push(map); +- } +- } +- }); +- } else { +- let input2 = new Input$3$1(this.originalCSS, this.opts); +- if (input2.map) this.previousMaps.push(input2.map); +- } +- } +- return this.previousMaps; +- } +- setSourcesContent() { +- let already = {}; +- if (this.root) { +- this.root.walk((node2) => { +- if (node2.source) { +- let from = node2.source.input.from; +- if (from && !already[from]) { +- already[from] = true; +- let fromUrl = this.usesFileUrls ? this.toFileUrl(from) : this.toUrl(this.path(from)); +- this.map.setSourceContent(fromUrl, node2.source.input.css); +- } +- } +- }); +- } else if (this.css) { +- let from = this.opts.from ? this.toUrl(this.path(this.opts.from)) : ""; +- this.map.setSourceContent(from, this.css); +- } +- } +- sourcePath(node2) { +- if (this.mapOpts.from) { +- return this.toUrl(this.mapOpts.from); +- } else if (this.usesFileUrls) { +- return this.toFileUrl(node2.source.input.from); +- } else { +- return this.toUrl(this.path(node2.source.input.from)); +- } +- } +- toBase64(str) { +- if (Buffer) { +- return Buffer.from(str).toString("base64"); +- } else { +- return window.btoa(unescape(encodeURIComponent(str))); +- } +- } +- toFileUrl(path) { +- let cached = this.memoizedFileURLs.get(path); +- if (cached) return cached; +- if (pathToFileURL$2) { +- let fileURL = pathToFileURL$2(path).toString(); +- this.memoizedFileURLs.set(path, fileURL); +- return fileURL; +- } else { +- throw new Error( +- "`map.absolute` option is not available in this PostCSS build" +- ); +- } +- } +- toUrl(path) { +- let cached = this.memoizedURLs.get(path); +- if (cached) return cached; +- if (sep$1 === "\\") { +- path = path.replace(/\\/g, "/"); +- } +- let url = encodeURI(path).replace(/[#?]/g, encodeURIComponent); +- this.memoizedURLs.set(path, url); +- return url; +- } +-}; +-var mapGenerator$1 = MapGenerator$2$1; +-let Node$2$1 = node$1; +-let Comment$4$1 = class Comment extends Node$2$1 { +- constructor(defaults) { +- super(defaults); +- this.type = "comment"; +- } +-}; +-var comment$1 = Comment$4$1; +-Comment$4$1.default = Comment$4$1; +-let { isClean: isClean$1$1, my: my$1$1 } = symbols$1; +-let Declaration$3$1 = declaration$1; +-let Comment$3$1 = comment$1; +-let Node$1$1 = node$1; +-let parse$4$1, Rule$4$1, AtRule$4$1, Root$6$1; +-function cleanSource$1(nodes) { +- return nodes.map((i2) => { +- if (i2.nodes) i2.nodes = cleanSource$1(i2.nodes); +- delete i2.source; +- return i2; +- }); +-} +-function markDirtyUp$1(node2) { +- node2[isClean$1$1] = false; +- if (node2.proxyOf.nodes) { +- for (let i2 of node2.proxyOf.nodes) { +- markDirtyUp$1(i2); +- } +- } +-} +-let Container$7$1 = class Container extends Node$1$1 { +- append(...children) { +- for (let child of children) { +- let nodes = this.normalize(child, this.last); +- for (let node2 of nodes) this.proxyOf.nodes.push(node2); +- } +- this.markDirty(); +- return this; +- } +- cleanRaws(keepBetween) { +- super.cleanRaws(keepBetween); +- if (this.nodes) { +- for (let node2 of this.nodes) node2.cleanRaws(keepBetween); +- } +- } +- each(callback) { +- if (!this.proxyOf.nodes) return void 0; +- let iterator = this.getIterator(); +- let index2, result2; +- while (this.indexes[iterator] < this.proxyOf.nodes.length) { +- index2 = this.indexes[iterator]; +- result2 = callback(this.proxyOf.nodes[index2], index2); +- if (result2 === false) break; +- this.indexes[iterator] += 1; +- } +- delete this.indexes[iterator]; +- return result2; +- } +- every(condition) { +- return this.nodes.every(condition); +- } +- getIterator() { +- if (!this.lastEach) this.lastEach = 0; +- if (!this.indexes) this.indexes = {}; +- this.lastEach += 1; +- let iterator = this.lastEach; +- this.indexes[iterator] = 0; +- return iterator; +- } +- getProxyProcessor() { +- return { +- get(node2, prop) { +- if (prop === "proxyOf") { +- return node2; +- } else if (!node2[prop]) { +- return node2[prop]; +- } else if (prop === "each" || typeof prop === "string" && prop.startsWith("walk")) { +- return (...args) => { +- return node2[prop]( +- ...args.map((i2) => { +- if (typeof i2 === "function") { +- return (child, index2) => i2(child.toProxy(), index2); +- } else { +- return i2; +- } +- }) +- ); +- }; +- } else if (prop === "every" || prop === "some") { +- return (cb) => { +- return node2[prop]( +- (child, ...other) => cb(child.toProxy(), ...other) +- ); +- }; +- } else if (prop === "root") { +- return () => node2.root().toProxy(); +- } else if (prop === "nodes") { +- return node2.nodes.map((i2) => i2.toProxy()); +- } else if (prop === "first" || prop === "last") { +- return node2[prop].toProxy(); +- } else { +- return node2[prop]; +- } +- }, +- set(node2, prop, value) { +- if (node2[prop] === value) return true; +- node2[prop] = value; +- if (prop === "name" || prop === "params" || prop === "selector") { +- node2.markDirty(); +- } +- return true; +- } +- }; +- } +- index(child) { +- if (typeof child === "number") return child; +- if (child.proxyOf) child = child.proxyOf; +- return this.proxyOf.nodes.indexOf(child); +- } +- insertAfter(exist, add) { +- let existIndex = this.index(exist); +- let nodes = this.normalize(add, this.proxyOf.nodes[existIndex]).reverse(); +- existIndex = this.index(exist); +- for (let node2 of nodes) this.proxyOf.nodes.splice(existIndex + 1, 0, node2); +- let index2; +- for (let id in this.indexes) { +- index2 = this.indexes[id]; +- if (existIndex < index2) { +- this.indexes[id] = index2 + nodes.length; +- } +- } +- this.markDirty(); +- return this; +- } +- insertBefore(exist, add) { +- let existIndex = this.index(exist); +- let type = existIndex === 0 ? "prepend" : false; +- let nodes = this.normalize(add, this.proxyOf.nodes[existIndex], type).reverse(); +- existIndex = this.index(exist); +- for (let node2 of nodes) this.proxyOf.nodes.splice(existIndex, 0, node2); +- let index2; +- for (let id in this.indexes) { +- index2 = this.indexes[id]; +- if (existIndex <= index2) { +- this.indexes[id] = index2 + nodes.length; +- } +- } +- this.markDirty(); +- return this; +- } +- normalize(nodes, sample) { +- if (typeof nodes === "string") { +- nodes = cleanSource$1(parse$4$1(nodes).nodes); +- } else if (typeof nodes === "undefined") { +- nodes = []; +- } else if (Array.isArray(nodes)) { +- nodes = nodes.slice(0); +- for (let i2 of nodes) { +- if (i2.parent) i2.parent.removeChild(i2, "ignore"); +- } +- } else if (nodes.type === "root" && this.type !== "document") { +- nodes = nodes.nodes.slice(0); +- for (let i2 of nodes) { +- if (i2.parent) i2.parent.removeChild(i2, "ignore"); +- } +- } else if (nodes.type) { +- nodes = [nodes]; +- } else if (nodes.prop) { +- if (typeof nodes.value === "undefined") { +- throw new Error("Value field is missed in node creation"); +- } else if (typeof nodes.value !== "string") { +- nodes.value = String(nodes.value); +- } +- nodes = [new Declaration$3$1(nodes)]; +- } else if (nodes.selector) { +- nodes = [new Rule$4$1(nodes)]; +- } else if (nodes.name) { +- nodes = [new AtRule$4$1(nodes)]; +- } else if (nodes.text) { +- nodes = [new Comment$3$1(nodes)]; +- } else { +- throw new Error("Unknown node type in node creation"); +- } +- let processed = nodes.map((i2) => { +- if (!i2[my$1$1]) Container.rebuild(i2); +- i2 = i2.proxyOf; +- if (i2.parent) i2.parent.removeChild(i2); +- if (i2[isClean$1$1]) markDirtyUp$1(i2); +- if (typeof i2.raws.before === "undefined") { +- if (sample && typeof sample.raws.before !== "undefined") { +- i2.raws.before = sample.raws.before.replace(/\S/g, ""); +- } +- } +- i2.parent = this.proxyOf; +- return i2; +- }); +- return processed; +- } +- prepend(...children) { +- children = children.reverse(); +- for (let child of children) { +- let nodes = this.normalize(child, this.first, "prepend").reverse(); +- for (let node2 of nodes) this.proxyOf.nodes.unshift(node2); +- for (let id in this.indexes) { +- this.indexes[id] = this.indexes[id] + nodes.length; +- } +- } +- this.markDirty(); +- return this; +- } +- push(child) { +- child.parent = this; +- this.proxyOf.nodes.push(child); +- return this; +- } +- removeAll() { +- for (let node2 of this.proxyOf.nodes) node2.parent = void 0; +- this.proxyOf.nodes = []; +- this.markDirty(); +- return this; +- } +- removeChild(child) { +- child = this.index(child); +- this.proxyOf.nodes[child].parent = void 0; +- this.proxyOf.nodes.splice(child, 1); +- let index2; +- for (let id in this.indexes) { +- index2 = this.indexes[id]; +- if (index2 >= child) { +- this.indexes[id] = index2 - 1; +- } +- } +- this.markDirty(); +- return this; +- } +- replaceValues(pattern, opts, callback) { +- if (!callback) { +- callback = opts; +- opts = {}; +- } +- this.walkDecls((decl) => { +- if (opts.props && !opts.props.includes(decl.prop)) return; +- if (opts.fast && !decl.value.includes(opts.fast)) return; +- decl.value = decl.value.replace(pattern, callback); +- }); +- this.markDirty(); +- return this; +- } +- some(condition) { +- return this.nodes.some(condition); +- } +- walk(callback) { +- return this.each((child, i2) => { +- let result2; +- try { +- result2 = callback(child, i2); +- } catch (e2) { +- throw child.addToError(e2); +- } +- if (result2 !== false && child.walk) { +- result2 = child.walk(callback); +- } +- return result2; +- }); +- } +- walkAtRules(name, callback) { +- if (!callback) { +- callback = name; +- return this.walk((child, i2) => { +- if (child.type === "atrule") { +- return callback(child, i2); +- } +- }); +- } +- if (name instanceof RegExp) { +- return this.walk((child, i2) => { +- if (child.type === "atrule" && name.test(child.name)) { +- return callback(child, i2); +- } +- }); +- } +- return this.walk((child, i2) => { +- if (child.type === "atrule" && child.name === name) { +- return callback(child, i2); +- } +- }); +- } +- walkComments(callback) { +- return this.walk((child, i2) => { +- if (child.type === "comment") { +- return callback(child, i2); +- } +- }); +- } +- walkDecls(prop, callback) { +- if (!callback) { +- callback = prop; +- return this.walk((child, i2) => { +- if (child.type === "decl") { +- return callback(child, i2); +- } +- }); +- } +- if (prop instanceof RegExp) { +- return this.walk((child, i2) => { +- if (child.type === "decl" && prop.test(child.prop)) { +- return callback(child, i2); +- } +- }); +- } +- return this.walk((child, i2) => { +- if (child.type === "decl" && child.prop === prop) { +- return callback(child, i2); +- } +- }); +- } +- walkRules(selector, callback) { +- if (!callback) { +- callback = selector; +- return this.walk((child, i2) => { +- if (child.type === "rule") { +- return callback(child, i2); +- } +- }); +- } +- if (selector instanceof RegExp) { +- return this.walk((child, i2) => { +- if (child.type === "rule" && selector.test(child.selector)) { +- return callback(child, i2); +- } +- }); +- } +- return this.walk((child, i2) => { +- if (child.type === "rule" && child.selector === selector) { +- return callback(child, i2); +- } +- }); +- } +- get first() { +- if (!this.proxyOf.nodes) return void 0; +- return this.proxyOf.nodes[0]; +- } +- get last() { +- if (!this.proxyOf.nodes) return void 0; +- return this.proxyOf.nodes[this.proxyOf.nodes.length - 1]; +- } +-}; +-Container$7$1.registerParse = (dependant) => { +- parse$4$1 = dependant; +-}; +-Container$7$1.registerRule = (dependant) => { +- Rule$4$1 = dependant; +-}; +-Container$7$1.registerAtRule = (dependant) => { +- AtRule$4$1 = dependant; +-}; +-Container$7$1.registerRoot = (dependant) => { +- Root$6$1 = dependant; +-}; +-var container$1 = Container$7$1; +-Container$7$1.default = Container$7$1; +-Container$7$1.rebuild = (node2) => { +- if (node2.type === "atrule") { +- Object.setPrototypeOf(node2, AtRule$4$1.prototype); +- } else if (node2.type === "rule") { +- Object.setPrototypeOf(node2, Rule$4$1.prototype); +- } else if (node2.type === "decl") { +- Object.setPrototypeOf(node2, Declaration$3$1.prototype); +- } else if (node2.type === "comment") { +- Object.setPrototypeOf(node2, Comment$3$1.prototype); +- } else if (node2.type === "root") { +- Object.setPrototypeOf(node2, Root$6$1.prototype); +- } +- node2[my$1$1] = true; +- if (node2.nodes) { +- node2.nodes.forEach((child) => { +- Container$7$1.rebuild(child); +- }); +- } +-}; +-let Container$6$1 = container$1; +-let LazyResult$4$1, Processor$3$1; +-let Document$3$1 = class Document2 extends Container$6$1 { +- constructor(defaults) { +- super({ type: "document", ...defaults }); +- if (!this.nodes) { +- this.nodes = []; +- } +- } +- toResult(opts = {}) { +- let lazy = new LazyResult$4$1(new Processor$3$1(), this, opts); +- return lazy.stringify(); +- } +-}; +-Document$3$1.registerLazyResult = (dependant) => { +- LazyResult$4$1 = dependant; +-}; +-Document$3$1.registerProcessor = (dependant) => { +- Processor$3$1 = dependant; +-}; +-var document$1$1 = Document$3$1; +-Document$3$1.default = Document$3$1; +-let printed$1 = {}; +-var warnOnce$2$1 = function warnOnce(message) { +- if (printed$1[message]) return; +- printed$1[message] = true; +- if (typeof console !== "undefined" && console.warn) { +- console.warn(message); +- } +-}; +-let Warning$2$1 = class Warning { +- constructor(text, opts = {}) { +- this.type = "warning"; +- this.text = text; +- if (opts.node && opts.node.source) { +- let range = opts.node.rangeBy(opts); +- this.line = range.start.line; +- this.column = range.start.column; +- this.endLine = range.end.line; +- this.endColumn = range.end.column; +- } +- for (let opt in opts) this[opt] = opts[opt]; +- } +- toString() { +- if (this.node) { +- return this.node.error(this.text, { +- index: this.index, +- plugin: this.plugin, +- word: this.word +- }).message; +- } +- if (this.plugin) { +- return this.plugin + ": " + this.text; +- } +- return this.text; +- } +-}; +-var warning$1 = Warning$2$1; +-Warning$2$1.default = Warning$2$1; +-let Warning$1$1 = warning$1; +-let Result$3$1 = class Result { +- constructor(processor2, root2, opts) { +- this.processor = processor2; +- this.messages = []; +- this.root = root2; +- this.opts = opts; +- this.css = void 0; +- this.map = void 0; +- } +- toString() { +- return this.css; +- } +- warn(text, opts = {}) { +- if (!opts.plugin) { +- if (this.lastPlugin && this.lastPlugin.postcssPlugin) { +- opts.plugin = this.lastPlugin.postcssPlugin; +- } +- } +- let warning2 = new Warning$1$1(text, opts); +- this.messages.push(warning2); +- return warning2; +- } +- warnings() { +- return this.messages.filter((i2) => i2.type === "warning"); +- } +- get content() { +- return this.css; +- } +-}; +-var result$1 = Result$3$1; +-Result$3$1.default = Result$3$1; +-const SINGLE_QUOTE$1 = "'".charCodeAt(0); +-const DOUBLE_QUOTE$1 = '"'.charCodeAt(0); +-const BACKSLASH$1 = "\\".charCodeAt(0); +-const SLASH$1 = "/".charCodeAt(0); +-const NEWLINE$1 = "\n".charCodeAt(0); +-const SPACE$1 = " ".charCodeAt(0); +-const FEED$1 = "\f".charCodeAt(0); +-const TAB$1 = " ".charCodeAt(0); +-const CR$1 = "\r".charCodeAt(0); +-const OPEN_SQUARE$1 = "[".charCodeAt(0); +-const CLOSE_SQUARE$1 = "]".charCodeAt(0); +-const OPEN_PARENTHESES$1 = "(".charCodeAt(0); +-const CLOSE_PARENTHESES$1 = ")".charCodeAt(0); +-const OPEN_CURLY$1 = "{".charCodeAt(0); +-const CLOSE_CURLY$1 = "}".charCodeAt(0); +-const SEMICOLON$1 = ";".charCodeAt(0); +-const ASTERISK$1 = "*".charCodeAt(0); +-const COLON$1 = ":".charCodeAt(0); +-const AT$1 = "@".charCodeAt(0); +-const RE_AT_END$1 = /[\t\n\f\r "#'()/;[\\\]{}]/g; +-const RE_WORD_END$1 = /[\t\n\f\r !"#'():;@[\\\]{}]|\/(?=\*)/g; +-const RE_BAD_BRACKET$1 = /.[\r\n"'(/\\]/; +-const RE_HEX_ESCAPE$1 = /[\da-f]/i; +-var tokenize$1 = function tokenizer(input2, options = {}) { +- let css = input2.css.valueOf(); +- let ignore = options.ignoreErrors; +- let code, next, quote, content, escape; +- let escaped, escapePos, prev, n2, currentToken; +- let length = css.length; +- let pos = 0; +- let buffer = []; +- let returned = []; +- function position() { +- return pos; +- } +- function unclosed(what) { +- throw input2.error("Unclosed " + what, pos); +- } +- function endOfFile() { +- return returned.length === 0 && pos >= length; +- } +- function nextToken(opts) { +- if (returned.length) return returned.pop(); +- if (pos >= length) return; +- let ignoreUnclosed = opts ? opts.ignoreUnclosed : false; +- code = css.charCodeAt(pos); +- switch (code) { +- case NEWLINE$1: +- case SPACE$1: +- case TAB$1: +- case CR$1: +- case FEED$1: { +- next = pos; +- do { +- next += 1; +- code = css.charCodeAt(next); +- } while (code === SPACE$1 || code === NEWLINE$1 || code === TAB$1 || code === CR$1 || code === FEED$1); +- currentToken = ["space", css.slice(pos, next)]; +- pos = next - 1; +- break; +- } +- case OPEN_SQUARE$1: +- case CLOSE_SQUARE$1: +- case OPEN_CURLY$1: +- case CLOSE_CURLY$1: +- case COLON$1: +- case SEMICOLON$1: +- case CLOSE_PARENTHESES$1: { +- let controlChar = String.fromCharCode(code); +- currentToken = [controlChar, controlChar, pos]; +- break; +- } +- case OPEN_PARENTHESES$1: { +- prev = buffer.length ? buffer.pop()[1] : ""; +- n2 = css.charCodeAt(pos + 1); +- if (prev === "url" && n2 !== SINGLE_QUOTE$1 && n2 !== DOUBLE_QUOTE$1 && n2 !== SPACE$1 && n2 !== NEWLINE$1 && n2 !== TAB$1 && n2 !== FEED$1 && n2 !== CR$1) { +- next = pos; +- do { +- escaped = false; +- next = css.indexOf(")", next + 1); +- if (next === -1) { +- if (ignore || ignoreUnclosed) { +- next = pos; +- break; +- } else { +- unclosed("bracket"); +- } +- } +- escapePos = next; +- while (css.charCodeAt(escapePos - 1) === BACKSLASH$1) { +- escapePos -= 1; +- escaped = !escaped; +- } +- } while (escaped); +- currentToken = ["brackets", css.slice(pos, next + 1), pos, next]; +- pos = next; +- } else { +- next = css.indexOf(")", pos + 1); +- content = css.slice(pos, next + 1); +- if (next === -1 || RE_BAD_BRACKET$1.test(content)) { +- currentToken = ["(", "(", pos]; +- } else { +- currentToken = ["brackets", content, pos, next]; +- pos = next; +- } +- } +- break; +- } +- case SINGLE_QUOTE$1: +- case DOUBLE_QUOTE$1: { +- quote = code === SINGLE_QUOTE$1 ? "'" : '"'; +- next = pos; +- do { +- escaped = false; +- next = css.indexOf(quote, next + 1); +- if (next === -1) { +- if (ignore || ignoreUnclosed) { +- next = pos + 1; +- break; +- } else { +- unclosed("string"); +- } +- } +- escapePos = next; +- while (css.charCodeAt(escapePos - 1) === BACKSLASH$1) { +- escapePos -= 1; +- escaped = !escaped; +- } +- } while (escaped); +- currentToken = ["string", css.slice(pos, next + 1), pos, next]; +- pos = next; +- break; +- } +- case AT$1: { +- RE_AT_END$1.lastIndex = pos + 1; +- RE_AT_END$1.test(css); +- if (RE_AT_END$1.lastIndex === 0) { +- next = css.length - 1; +- } else { +- next = RE_AT_END$1.lastIndex - 2; +- } +- currentToken = ["at-word", css.slice(pos, next + 1), pos, next]; +- pos = next; +- break; +- } +- case BACKSLASH$1: { +- next = pos; +- escape = true; +- while (css.charCodeAt(next + 1) === BACKSLASH$1) { +- next += 1; +- escape = !escape; +- } +- code = css.charCodeAt(next + 1); +- if (escape && code !== SLASH$1 && code !== SPACE$1 && code !== NEWLINE$1 && code !== TAB$1 && code !== CR$1 && code !== FEED$1) { +- next += 1; +- if (RE_HEX_ESCAPE$1.test(css.charAt(next))) { +- while (RE_HEX_ESCAPE$1.test(css.charAt(next + 1))) { +- next += 1; +- } +- if (css.charCodeAt(next + 1) === SPACE$1) { +- next += 1; +- } +- } +- } +- currentToken = ["word", css.slice(pos, next + 1), pos, next]; +- pos = next; +- break; +- } +- default: { +- if (code === SLASH$1 && css.charCodeAt(pos + 1) === ASTERISK$1) { +- next = css.indexOf("*/", pos + 2) + 1; +- if (next === 0) { +- if (ignore || ignoreUnclosed) { +- next = css.length; +- } else { +- unclosed("comment"); +- } +- } +- currentToken = ["comment", css.slice(pos, next + 1), pos, next]; +- pos = next; +- } else { +- RE_WORD_END$1.lastIndex = pos + 1; +- RE_WORD_END$1.test(css); +- if (RE_WORD_END$1.lastIndex === 0) { +- next = css.length - 1; +- } else { +- next = RE_WORD_END$1.lastIndex - 2; +- } +- currentToken = ["word", css.slice(pos, next + 1), pos, next]; +- buffer.push(currentToken); +- pos = next; +- } +- break; +- } +- } +- pos++; +- return currentToken; +- } +- function back(token) { +- returned.push(token); +- } +- return { +- back, +- endOfFile, +- nextToken, +- position +- }; +-}; +-let Container$5$1 = container$1; +-let AtRule$3$1 = class AtRule extends Container$5$1 { +- constructor(defaults) { +- super(defaults); +- this.type = "atrule"; +- } +- append(...children) { +- if (!this.proxyOf.nodes) this.nodes = []; +- return super.append(...children); +- } +- prepend(...children) { +- if (!this.proxyOf.nodes) this.nodes = []; +- return super.prepend(...children); +- } +-}; +-var atRule$1 = AtRule$3$1; +-AtRule$3$1.default = AtRule$3$1; +-Container$5$1.registerAtRule(AtRule$3$1); +-let Container$4$1 = container$1; +-let LazyResult$3$1, Processor$2$1; +-let Root$5$1 = class Root extends Container$4$1 { +- constructor(defaults) { +- super(defaults); +- this.type = "root"; +- if (!this.nodes) this.nodes = []; +- } +- normalize(child, sample, type) { +- let nodes = super.normalize(child); +- if (sample) { +- if (type === "prepend") { +- if (this.nodes.length > 1) { +- sample.raws.before = this.nodes[1].raws.before; +- } else { +- delete sample.raws.before; +- } +- } else if (this.first !== sample) { +- for (let node2 of nodes) { +- node2.raws.before = sample.raws.before; +- } +- } +- } +- return nodes; +- } +- removeChild(child, ignore) { +- let index2 = this.index(child); +- if (!ignore && index2 === 0 && this.nodes.length > 1) { +- this.nodes[1].raws.before = this.nodes[index2].raws.before; +- } +- return super.removeChild(child); +- } +- toResult(opts = {}) { +- let lazy = new LazyResult$3$1(new Processor$2$1(), this, opts); +- return lazy.stringify(); +- } +-}; +-Root$5$1.registerLazyResult = (dependant) => { +- LazyResult$3$1 = dependant; +-}; +-Root$5$1.registerProcessor = (dependant) => { +- Processor$2$1 = dependant; +-}; +-var root$1 = Root$5$1; +-Root$5$1.default = Root$5$1; +-Container$4$1.registerRoot(Root$5$1); +-let list$2$1 = { +- comma(string) { +- return list$2$1.split(string, [","], true); +- }, +- space(string) { +- let spaces = [" ", "\n", " "]; +- return list$2$1.split(string, spaces); +- }, +- split(string, separators, last) { +- let array = []; +- let current = ""; +- let split = false; +- let func = 0; +- let inQuote = false; +- let prevQuote = ""; +- let escape = false; +- for (let letter of string) { +- if (escape) { +- escape = false; +- } else if (letter === "\\") { +- escape = true; +- } else if (inQuote) { +- if (letter === prevQuote) { +- inQuote = false; +- } +- } else if (letter === '"' || letter === "'") { +- inQuote = true; +- prevQuote = letter; +- } else if (letter === "(") { +- func += 1; +- } else if (letter === ")") { +- if (func > 0) func -= 1; +- } else if (func === 0) { +- if (separators.includes(letter)) split = true; +- } +- if (split) { +- if (current !== "") array.push(current.trim()); +- current = ""; +- split = false; +- } else { +- current += letter; +- } +- } +- if (last || current !== "") array.push(current.trim()); +- return array; +- } +-}; +-var list_1$1 = list$2$1; +-list$2$1.default = list$2$1; +-let Container$3$1 = container$1; +-let list$1$1 = list_1$1; +-let Rule$3$1 = class Rule extends Container$3$1 { +- constructor(defaults) { +- super(defaults); +- this.type = "rule"; +- if (!this.nodes) this.nodes = []; +- } +- get selectors() { +- return list$1$1.comma(this.selector); +- } +- set selectors(values) { +- let match = this.selector ? this.selector.match(/,\s*/) : null; +- let sep2 = match ? match[0] : "," + this.raw("between", "beforeOpen"); +- this.selector = values.join(sep2); +- } +-}; +-var rule$1 = Rule$3$1; +-Rule$3$1.default = Rule$3$1; +-Container$3$1.registerRule(Rule$3$1); +-let Declaration$2$1 = declaration$1; +-let tokenizer2$1 = tokenize$1; +-let Comment$2$1 = comment$1; +-let AtRule$2$1 = atRule$1; +-let Root$4$1 = root$1; +-let Rule$2$1 = rule$1; +-const SAFE_COMMENT_NEIGHBOR$1 = { +- empty: true, +- space: true +-}; +-function findLastWithPosition$1(tokens) { +- for (let i2 = tokens.length - 1; i2 >= 0; i2--) { +- let token = tokens[i2]; +- let pos = token[3] || token[2]; +- if (pos) return pos; +- } +-} +-let Parser$1$1 = class Parser { +- constructor(input2) { +- this.input = input2; +- this.root = new Root$4$1(); +- this.current = this.root; +- this.spaces = ""; +- this.semicolon = false; +- this.createTokenizer(); +- this.root.source = { input: input2, start: { column: 1, line: 1, offset: 0 } }; +- } +- atrule(token) { +- let node2 = new AtRule$2$1(); +- node2.name = token[1].slice(1); +- if (node2.name === "") { +- this.unnamedAtrule(node2, token); +- } +- this.init(node2, token[2]); +- let type; +- let prev; +- let shift; +- let last = false; +- let open = false; +- let params = []; +- let brackets = []; +- while (!this.tokenizer.endOfFile()) { +- token = this.tokenizer.nextToken(); +- type = token[0]; +- if (type === "(" || type === "[") { +- brackets.push(type === "(" ? ")" : "]"); +- } else if (type === "{" && brackets.length > 0) { +- brackets.push("}"); +- } else if (type === brackets[brackets.length - 1]) { +- brackets.pop(); +- } +- if (brackets.length === 0) { +- if (type === ";") { +- node2.source.end = this.getPosition(token[2]); +- node2.source.end.offset++; +- this.semicolon = true; +- break; +- } else if (type === "{") { +- open = true; +- break; +- } else if (type === "}") { +- if (params.length > 0) { +- shift = params.length - 1; +- prev = params[shift]; +- while (prev && prev[0] === "space") { +- prev = params[--shift]; +- } +- if (prev) { +- node2.source.end = this.getPosition(prev[3] || prev[2]); +- node2.source.end.offset++; +- } +- } +- this.end(token); +- break; +- } else { +- params.push(token); +- } +- } else { +- params.push(token); +- } +- if (this.tokenizer.endOfFile()) { +- last = true; +- break; +- } +- } +- node2.raws.between = this.spacesAndCommentsFromEnd(params); +- if (params.length) { +- node2.raws.afterName = this.spacesAndCommentsFromStart(params); +- this.raw(node2, "params", params); +- if (last) { +- token = params[params.length - 1]; +- node2.source.end = this.getPosition(token[3] || token[2]); +- node2.source.end.offset++; +- this.spaces = node2.raws.between; +- node2.raws.between = ""; +- } +- } else { +- node2.raws.afterName = ""; +- node2.params = ""; +- } +- if (open) { +- node2.nodes = []; +- this.current = node2; +- } +- } +- checkMissedSemicolon(tokens) { +- let colon = this.colon(tokens); +- if (colon === false) return; +- let founded = 0; +- let token; +- for (let j = colon - 1; j >= 0; j--) { +- token = tokens[j]; +- if (token[0] !== "space") { +- founded += 1; +- if (founded === 2) break; +- } +- } +- throw this.input.error( +- "Missed semicolon", +- token[0] === "word" ? token[3] + 1 : token[2] +- ); +- } +- colon(tokens) { +- let brackets = 0; +- let token, type, prev; +- for (let [i2, element] of tokens.entries()) { +- token = element; +- type = token[0]; +- if (type === "(") { +- brackets += 1; +- } +- if (type === ")") { +- brackets -= 1; +- } +- if (brackets === 0 && type === ":") { +- if (!prev) { +- this.doubleColon(token); +- } else if (prev[0] === "word" && prev[1] === "progid") { +- continue; +- } else { +- return i2; +- } +- } +- prev = token; +- } +- return false; +- } +- comment(token) { +- let node2 = new Comment$2$1(); +- this.init(node2, token[2]); +- node2.source.end = this.getPosition(token[3] || token[2]); +- node2.source.end.offset++; +- let text = token[1].slice(2, -2); +- if (/^\s*$/.test(text)) { +- node2.text = ""; +- node2.raws.left = text; +- node2.raws.right = ""; +- } else { +- let match = text.match(/^(\s*)([^]*\S)(\s*)$/); +- node2.text = match[2]; +- node2.raws.left = match[1]; +- node2.raws.right = match[3]; +- } +- } +- createTokenizer() { +- this.tokenizer = tokenizer2$1(this.input); +- } +- decl(tokens, customProperty) { +- let node2 = new Declaration$2$1(); +- this.init(node2, tokens[0][2]); +- let last = tokens[tokens.length - 1]; +- if (last[0] === ";") { +- this.semicolon = true; +- tokens.pop(); +- } +- node2.source.end = this.getPosition( +- last[3] || last[2] || findLastWithPosition$1(tokens) +- ); +- node2.source.end.offset++; +- while (tokens[0][0] !== "word") { +- if (tokens.length === 1) this.unknownWord(tokens); +- node2.raws.before += tokens.shift()[1]; +- } +- node2.source.start = this.getPosition(tokens[0][2]); +- node2.prop = ""; +- while (tokens.length) { +- let type = tokens[0][0]; +- if (type === ":" || type === "space" || type === "comment") { +- break; +- } +- node2.prop += tokens.shift()[1]; +- } +- node2.raws.between = ""; +- let token; +- while (tokens.length) { +- token = tokens.shift(); +- if (token[0] === ":") { +- node2.raws.between += token[1]; +- break; +- } else { +- if (token[0] === "word" && /\w/.test(token[1])) { +- this.unknownWord([token]); +- } +- node2.raws.between += token[1]; +- } +- } +- if (node2.prop[0] === "_" || node2.prop[0] === "*") { +- node2.raws.before += node2.prop[0]; +- node2.prop = node2.prop.slice(1); +- } +- let firstSpaces = []; +- let next; +- while (tokens.length) { +- next = tokens[0][0]; +- if (next !== "space" && next !== "comment") break; +- firstSpaces.push(tokens.shift()); +- } +- this.precheckMissedSemicolon(tokens); +- for (let i2 = tokens.length - 1; i2 >= 0; i2--) { +- token = tokens[i2]; +- if (token[1].toLowerCase() === "!important") { +- node2.important = true; +- let string = this.stringFrom(tokens, i2); +- string = this.spacesFromEnd(tokens) + string; +- if (string !== " !important") node2.raws.important = string; +- break; +- } else if (token[1].toLowerCase() === "important") { +- let cache = tokens.slice(0); +- let str = ""; +- for (let j = i2; j > 0; j--) { +- let type = cache[j][0]; +- if (str.trim().indexOf("!") === 0 && type !== "space") { +- break; +- } +- str = cache.pop()[1] + str; +- } +- if (str.trim().indexOf("!") === 0) { +- node2.important = true; +- node2.raws.important = str; +- tokens = cache; +- } +- } +- if (token[0] !== "space" && token[0] !== "comment") { +- break; +- } +- } +- let hasWord = tokens.some((i2) => i2[0] !== "space" && i2[0] !== "comment"); +- if (hasWord) { +- node2.raws.between += firstSpaces.map((i2) => i2[1]).join(""); +- firstSpaces = []; +- } +- this.raw(node2, "value", firstSpaces.concat(tokens), customProperty); +- if (node2.value.includes(":") && !customProperty) { +- this.checkMissedSemicolon(tokens); +- } +- } +- doubleColon(token) { +- throw this.input.error( +- "Double colon", +- { offset: token[2] }, +- { offset: token[2] + token[1].length } +- ); +- } +- emptyRule(token) { +- let node2 = new Rule$2$1(); +- this.init(node2, token[2]); +- node2.selector = ""; +- node2.raws.between = ""; +- this.current = node2; +- } +- end(token) { +- if (this.current.nodes && this.current.nodes.length) { +- this.current.raws.semicolon = this.semicolon; +- } +- this.semicolon = false; +- this.current.raws.after = (this.current.raws.after || "") + this.spaces; +- this.spaces = ""; +- if (this.current.parent) { +- this.current.source.end = this.getPosition(token[2]); +- this.current.source.end.offset++; +- this.current = this.current.parent; +- } else { +- this.unexpectedClose(token); +- } +- } +- endFile() { +- if (this.current.parent) this.unclosedBlock(); +- if (this.current.nodes && this.current.nodes.length) { +- this.current.raws.semicolon = this.semicolon; +- } +- this.current.raws.after = (this.current.raws.after || "") + this.spaces; +- this.root.source.end = this.getPosition(this.tokenizer.position()); +- } +- freeSemicolon(token) { +- this.spaces += token[1]; +- if (this.current.nodes) { +- let prev = this.current.nodes[this.current.nodes.length - 1]; +- if (prev && prev.type === "rule" && !prev.raws.ownSemicolon) { +- prev.raws.ownSemicolon = this.spaces; +- this.spaces = ""; +- } +- } +- } +- // Helpers +- getPosition(offset) { +- let pos = this.input.fromOffset(offset); +- return { +- column: pos.col, +- line: pos.line, +- offset +- }; +- } +- init(node2, offset) { +- this.current.push(node2); +- node2.source = { +- input: this.input, +- start: this.getPosition(offset) +- }; +- node2.raws.before = this.spaces; +- this.spaces = ""; +- if (node2.type !== "comment") this.semicolon = false; +- } +- other(start) { +- let end = false; +- let type = null; +- let colon = false; +- let bracket = null; +- let brackets = []; +- let customProperty = start[1].startsWith("--"); +- let tokens = []; +- let token = start; +- while (token) { +- type = token[0]; +- tokens.push(token); +- if (type === "(" || type === "[") { +- if (!bracket) bracket = token; +- brackets.push(type === "(" ? ")" : "]"); +- } else if (customProperty && colon && type === "{") { +- if (!bracket) bracket = token; +- brackets.push("}"); +- } else if (brackets.length === 0) { +- if (type === ";") { +- if (colon) { +- this.decl(tokens, customProperty); +- return; +- } else { +- break; +- } +- } else if (type === "{") { +- this.rule(tokens); +- return; +- } else if (type === "}") { +- this.tokenizer.back(tokens.pop()); +- end = true; +- break; +- } else if (type === ":") { +- colon = true; +- } +- } else if (type === brackets[brackets.length - 1]) { +- brackets.pop(); +- if (brackets.length === 0) bracket = null; +- } +- token = this.tokenizer.nextToken(); +- } +- if (this.tokenizer.endOfFile()) end = true; +- if (brackets.length > 0) this.unclosedBracket(bracket); +- if (end && colon) { +- if (!customProperty) { +- while (tokens.length) { +- token = tokens[tokens.length - 1][0]; +- if (token !== "space" && token !== "comment") break; +- this.tokenizer.back(tokens.pop()); +- } +- } +- this.decl(tokens, customProperty); +- } else { +- this.unknownWord(tokens); +- } +- } +- parse() { +- let token; +- while (!this.tokenizer.endOfFile()) { +- token = this.tokenizer.nextToken(); +- switch (token[0]) { +- case "space": +- this.spaces += token[1]; +- break; +- case ";": +- this.freeSemicolon(token); +- break; +- case "}": +- this.end(token); +- break; +- case "comment": +- this.comment(token); +- break; +- case "at-word": +- this.atrule(token); +- break; +- case "{": +- this.emptyRule(token); +- break; +- default: +- this.other(token); +- break; +- } +- } +- this.endFile(); +- } +- precheckMissedSemicolon() { +- } +- raw(node2, prop, tokens, customProperty) { +- let token, type; +- let length = tokens.length; +- let value = ""; +- let clean = true; +- let next, prev; +- for (let i2 = 0; i2 < length; i2 += 1) { +- token = tokens[i2]; +- type = token[0]; +- if (type === "space" && i2 === length - 1 && !customProperty) { +- clean = false; +- } else if (type === "comment") { +- prev = tokens[i2 - 1] ? tokens[i2 - 1][0] : "empty"; +- next = tokens[i2 + 1] ? tokens[i2 + 1][0] : "empty"; +- if (!SAFE_COMMENT_NEIGHBOR$1[prev] && !SAFE_COMMENT_NEIGHBOR$1[next]) { +- if (value.slice(-1) === ",") { +- clean = false; +- } else { +- value += token[1]; +- } +- } else { +- clean = false; +- } +- } else { +- value += token[1]; +- } +- } +- if (!clean) { +- let raw = tokens.reduce((all, i2) => all + i2[1], ""); +- node2.raws[prop] = { raw, value }; +- } +- node2[prop] = value; +- } +- rule(tokens) { +- tokens.pop(); +- let node2 = new Rule$2$1(); +- this.init(node2, tokens[0][2]); +- node2.raws.between = this.spacesAndCommentsFromEnd(tokens); +- this.raw(node2, "selector", tokens); +- this.current = node2; +- } +- spacesAndCommentsFromEnd(tokens) { +- let lastTokenType; +- let spaces = ""; +- while (tokens.length) { +- lastTokenType = tokens[tokens.length - 1][0]; +- if (lastTokenType !== "space" && lastTokenType !== "comment") break; +- spaces = tokens.pop()[1] + spaces; +- } +- return spaces; +- } +- // Errors +- spacesAndCommentsFromStart(tokens) { +- let next; +- let spaces = ""; +- while (tokens.length) { +- next = tokens[0][0]; +- if (next !== "space" && next !== "comment") break; +- spaces += tokens.shift()[1]; +- } +- return spaces; +- } +- spacesFromEnd(tokens) { +- let lastTokenType; +- let spaces = ""; +- while (tokens.length) { +- lastTokenType = tokens[tokens.length - 1][0]; +- if (lastTokenType !== "space") break; +- spaces = tokens.pop()[1] + spaces; +- } +- return spaces; +- } +- stringFrom(tokens, from) { +- let result2 = ""; +- for (let i2 = from; i2 < tokens.length; i2++) { +- result2 += tokens[i2][1]; +- } +- tokens.splice(from, tokens.length - from); +- return result2; +- } +- unclosedBlock() { +- let pos = this.current.source.start; +- throw this.input.error("Unclosed block", pos.line, pos.column); +- } +- unclosedBracket(bracket) { +- throw this.input.error( +- "Unclosed bracket", +- { offset: bracket[2] }, +- { offset: bracket[2] + 1 } +- ); +- } +- unexpectedClose(token) { +- throw this.input.error( +- "Unexpected }", +- { offset: token[2] }, +- { offset: token[2] + 1 } +- ); +- } +- unknownWord(tokens) { +- throw this.input.error( +- "Unknown word", +- { offset: tokens[0][2] }, +- { offset: tokens[0][2] + tokens[0][1].length } +- ); +- } +- unnamedAtrule(node2, token) { +- throw this.input.error( +- "At-rule without name", +- { offset: token[2] }, +- { offset: token[2] + token[1].length } +- ); +- } +-}; +-var parser$1 = Parser$1$1; +-let Container$2$1 = container$1; +-let Parser2$1 = parser$1; +-let Input$2$1 = input$1; +-function parse$3$1(css, opts) { +- let input2 = new Input$2$1(css, opts); +- let parser2 = new Parser2$1(input2); +- try { +- parser2.parse(); +- } catch (e2) { +- if (process.env.NODE_ENV !== "production") { +- if (e2.name === "CssSyntaxError" && opts && opts.from) { +- if (/\.scss$/i.test(opts.from)) { +- e2.message += "\nYou tried to parse SCSS with the standard CSS parser; try again with the postcss-scss parser"; +- } else if (/\.sass/i.test(opts.from)) { +- e2.message += "\nYou tried to parse Sass with the standard CSS parser; try again with the postcss-sass parser"; +- } else if (/\.less$/i.test(opts.from)) { +- e2.message += "\nYou tried to parse Less with the standard CSS parser; try again with the postcss-less parser"; +- } +- } +- } +- throw e2; +- } +- return parser2.root; +-} +-var parse_1$1 = parse$3$1; +-parse$3$1.default = parse$3$1; +-Container$2$1.registerParse(parse$3$1); +-let { isClean: isClean$3, my: my$3 } = symbols$1; +-let MapGenerator$1$1 = mapGenerator$1; +-let stringify$2$1 = stringify_1$1; +-let Container$1$1 = container$1; +-let Document$2$1 = document$1$1; +-let warnOnce$1$1 = warnOnce$2$1; +-let Result$2$1 = result$1; +-let parse$2$1 = parse_1$1; +-let Root$3$1 = root$1; +-const TYPE_TO_CLASS_NAME$1 = { +- atrule: "AtRule", +- comment: "Comment", +- decl: "Declaration", +- document: "Document", +- root: "Root", +- rule: "Rule" +-}; +-const PLUGIN_PROPS$1 = { +- AtRule: true, +- AtRuleExit: true, +- Comment: true, +- CommentExit: true, +- Declaration: true, +- DeclarationExit: true, +- Document: true, +- DocumentExit: true, +- Once: true, +- OnceExit: true, +- postcssPlugin: true, +- prepare: true, +- Root: true, +- RootExit: true, +- Rule: true, +- RuleExit: true +-}; +-const NOT_VISITORS$1 = { +- Once: true, +- postcssPlugin: true, +- prepare: true +-}; +-const CHILDREN$1 = 0; +-function isPromise$1(obj) { +- return typeof obj === "object" && typeof obj.then === "function"; +-} +-function getEvents$1(node2) { +- let key = false; +- let type = TYPE_TO_CLASS_NAME$1[node2.type]; +- if (node2.type === "decl") { +- key = node2.prop.toLowerCase(); +- } else if (node2.type === "atrule") { +- key = node2.name.toLowerCase(); +- } +- if (key && node2.append) { +- return [ +- type, +- type + "-" + key, +- CHILDREN$1, +- type + "Exit", +- type + "Exit-" + key +- ]; +- } else if (key) { +- return [type, type + "-" + key, type + "Exit", type + "Exit-" + key]; +- } else if (node2.append) { +- return [type, CHILDREN$1, type + "Exit"]; +- } else { +- return [type, type + "Exit"]; +- } +-} +-function toStack$1(node2) { +- let events; +- if (node2.type === "document") { +- events = ["Document", CHILDREN$1, "DocumentExit"]; +- } else if (node2.type === "root") { +- events = ["Root", CHILDREN$1, "RootExit"]; +- } else { +- events = getEvents$1(node2); +- } +- return { +- eventIndex: 0, +- events, +- iterator: 0, +- node: node2, +- visitorIndex: 0, +- visitors: [] +- }; +-} +-function cleanMarks$1(node2) { +- node2[isClean$3] = false; +- if (node2.nodes) node2.nodes.forEach((i2) => cleanMarks$1(i2)); +- return node2; +-} +-let postcss$2$1 = {}; +-let LazyResult$2$1 = class LazyResult { +- constructor(processor2, css, opts) { +- this.stringified = false; +- this.processed = false; +- let root2; +- if (typeof css === "object" && css !== null && (css.type === "root" || css.type === "document")) { +- root2 = cleanMarks$1(css); +- } else if (css instanceof LazyResult || css instanceof Result$2$1) { +- root2 = cleanMarks$1(css.root); +- if (css.map) { +- if (typeof opts.map === "undefined") opts.map = {}; +- if (!opts.map.inline) opts.map.inline = false; +- opts.map.prev = css.map; +- } +- } else { +- let parser2 = parse$2$1; +- if (opts.syntax) parser2 = opts.syntax.parse; +- if (opts.parser) parser2 = opts.parser; +- if (parser2.parse) parser2 = parser2.parse; +- try { +- root2 = parser2(css, opts); +- } catch (error) { +- this.processed = true; +- this.error = error; +- } +- if (root2 && !root2[my$3]) { +- Container$1$1.rebuild(root2); +- } +- } +- this.result = new Result$2$1(processor2, root2, opts); +- this.helpers = { ...postcss$2$1, postcss: postcss$2$1, result: this.result }; +- this.plugins = this.processor.plugins.map((plugin22) => { +- if (typeof plugin22 === "object" && plugin22.prepare) { +- return { ...plugin22, ...plugin22.prepare(this.result) }; +- } else { +- return plugin22; +- } +- }); +- } +- async() { +- if (this.error) return Promise.reject(this.error); +- if (this.processed) return Promise.resolve(this.result); +- if (!this.processing) { +- this.processing = this.runAsync(); +- } +- return this.processing; +- } +- catch(onRejected) { +- return this.async().catch(onRejected); +- } +- finally(onFinally) { +- return this.async().then(onFinally, onFinally); +- } +- getAsyncError() { +- throw new Error("Use process(css).then(cb) to work with async plugins"); +- } +- handleError(error, node2) { +- let plugin22 = this.result.lastPlugin; +- try { +- if (node2) node2.addToError(error); +- this.error = error; +- if (error.name === "CssSyntaxError" && !error.plugin) { +- error.plugin = plugin22.postcssPlugin; +- error.setMessage(); +- } else if (plugin22.postcssVersion) { +- if (process.env.NODE_ENV !== "production") { +- let pluginName = plugin22.postcssPlugin; +- let pluginVer = plugin22.postcssVersion; +- let runtimeVer = this.result.processor.version; +- let a2 = pluginVer.split("."); +- let b = runtimeVer.split("."); +- if (a2[0] !== b[0] || parseInt(a2[1]) > parseInt(b[1])) { +- console.error( +- "Unknown error from PostCSS plugin. Your current PostCSS version is " + runtimeVer + ", but " + pluginName + " uses " + pluginVer + ". Perhaps this is the source of the error below." +- ); +- } +- } +- } +- } catch (err) { +- if (console && console.error) console.error(err); +- } +- return error; +- } +- prepareVisitors() { +- this.listeners = {}; +- let add = (plugin22, type, cb) => { +- if (!this.listeners[type]) this.listeners[type] = []; +- this.listeners[type].push([plugin22, cb]); +- }; +- for (let plugin22 of this.plugins) { +- if (typeof plugin22 === "object") { +- for (let event in plugin22) { +- if (!PLUGIN_PROPS$1[event] && /^[A-Z]/.test(event)) { +- throw new Error( +- `Unknown event ${event} in ${plugin22.postcssPlugin}. Try to update PostCSS (${this.processor.version} now).` +- ); +- } +- if (!NOT_VISITORS$1[event]) { +- if (typeof plugin22[event] === "object") { +- for (let filter in plugin22[event]) { +- if (filter === "*") { +- add(plugin22, event, plugin22[event][filter]); +- } else { +- add( +- plugin22, +- event + "-" + filter.toLowerCase(), +- plugin22[event][filter] +- ); +- } +- } +- } else if (typeof plugin22[event] === "function") { +- add(plugin22, event, plugin22[event]); +- } +- } +- } +- } +- } +- this.hasListener = Object.keys(this.listeners).length > 0; +- } +- async runAsync() { +- this.plugin = 0; +- for (let i2 = 0; i2 < this.plugins.length; i2++) { +- let plugin22 = this.plugins[i2]; +- let promise = this.runOnRoot(plugin22); +- if (isPromise$1(promise)) { +- try { +- await promise; +- } catch (error) { +- throw this.handleError(error); +- } +- } +- } +- this.prepareVisitors(); +- if (this.hasListener) { +- let root2 = this.result.root; +- while (!root2[isClean$3]) { +- root2[isClean$3] = true; +- let stack = [toStack$1(root2)]; +- while (stack.length > 0) { +- let promise = this.visitTick(stack); +- if (isPromise$1(promise)) { +- try { +- await promise; +- } catch (e2) { +- let node2 = stack[stack.length - 1].node; +- throw this.handleError(e2, node2); +- } +- } +- } +- } +- if (this.listeners.OnceExit) { +- for (let [plugin22, visitor] of this.listeners.OnceExit) { +- this.result.lastPlugin = plugin22; +- try { +- if (root2.type === "document") { +- let roots = root2.nodes.map( +- (subRoot) => visitor(subRoot, this.helpers) +- ); +- await Promise.all(roots); +- } else { +- await visitor(root2, this.helpers); +- } +- } catch (e2) { +- throw this.handleError(e2); +- } +- } +- } +- } +- this.processed = true; +- return this.stringify(); +- } +- runOnRoot(plugin22) { +- this.result.lastPlugin = plugin22; +- try { +- if (typeof plugin22 === "object" && plugin22.Once) { +- if (this.result.root.type === "document") { +- let roots = this.result.root.nodes.map( +- (root2) => plugin22.Once(root2, this.helpers) +- ); +- if (isPromise$1(roots[0])) { +- return Promise.all(roots); +- } +- return roots; +- } +- return plugin22.Once(this.result.root, this.helpers); +- } else if (typeof plugin22 === "function") { +- return plugin22(this.result.root, this.result); +- } +- } catch (error) { +- throw this.handleError(error); +- } +- } +- stringify() { +- if (this.error) throw this.error; +- if (this.stringified) return this.result; +- this.stringified = true; +- this.sync(); +- let opts = this.result.opts; +- let str = stringify$2$1; +- if (opts.syntax) str = opts.syntax.stringify; +- if (opts.stringifier) str = opts.stringifier; +- if (str.stringify) str = str.stringify; +- let map = new MapGenerator$1$1(str, this.result.root, this.result.opts); +- let data = map.generate(); +- this.result.css = data[0]; +- this.result.map = data[1]; +- return this.result; +- } +- sync() { +- if (this.error) throw this.error; +- if (this.processed) return this.result; +- this.processed = true; +- if (this.processing) { +- throw this.getAsyncError(); +- } +- for (let plugin22 of this.plugins) { +- let promise = this.runOnRoot(plugin22); +- if (isPromise$1(promise)) { +- throw this.getAsyncError(); +- } +- } +- this.prepareVisitors(); +- if (this.hasListener) { +- let root2 = this.result.root; +- while (!root2[isClean$3]) { +- root2[isClean$3] = true; +- this.walkSync(root2); +- } +- if (this.listeners.OnceExit) { +- if (root2.type === "document") { +- for (let subRoot of root2.nodes) { +- this.visitSync(this.listeners.OnceExit, subRoot); +- } +- } else { +- this.visitSync(this.listeners.OnceExit, root2); +- } +- } +- } +- return this.result; +- } +- then(onFulfilled, onRejected) { +- if (process.env.NODE_ENV !== "production") { +- if (!("from" in this.opts)) { +- warnOnce$1$1( +- "Without `from` option PostCSS could generate wrong source map and will not find Browserslist config. Set it to CSS file path or to `undefined` to prevent this warning." +- ); +- } +- } +- return this.async().then(onFulfilled, onRejected); +- } +- toString() { +- return this.css; +- } +- visitSync(visitors, node2) { +- for (let [plugin22, visitor] of visitors) { +- this.result.lastPlugin = plugin22; +- let promise; +- try { +- promise = visitor(node2, this.helpers); +- } catch (e2) { +- throw this.handleError(e2, node2.proxyOf); +- } +- if (node2.type !== "root" && node2.type !== "document" && !node2.parent) { +- return true; +- } +- if (isPromise$1(promise)) { +- throw this.getAsyncError(); +- } +- } +- } +- visitTick(stack) { +- let visit2 = stack[stack.length - 1]; +- let { node: node2, visitors } = visit2; +- if (node2.type !== "root" && node2.type !== "document" && !node2.parent) { +- stack.pop(); +- return; +- } +- if (visitors.length > 0 && visit2.visitorIndex < visitors.length) { +- let [plugin22, visitor] = visitors[visit2.visitorIndex]; +- visit2.visitorIndex += 1; +- if (visit2.visitorIndex === visitors.length) { +- visit2.visitors = []; +- visit2.visitorIndex = 0; +- } +- this.result.lastPlugin = plugin22; +- try { +- return visitor(node2.toProxy(), this.helpers); +- } catch (e2) { +- throw this.handleError(e2, node2); +- } +- } +- if (visit2.iterator !== 0) { +- let iterator = visit2.iterator; +- let child; +- while (child = node2.nodes[node2.indexes[iterator]]) { +- node2.indexes[iterator] += 1; +- if (!child[isClean$3]) { +- child[isClean$3] = true; +- stack.push(toStack$1(child)); +- return; +- } +- } +- visit2.iterator = 0; +- delete node2.indexes[iterator]; +- } +- let events = visit2.events; +- while (visit2.eventIndex < events.length) { +- let event = events[visit2.eventIndex]; +- visit2.eventIndex += 1; +- if (event === CHILDREN$1) { +- if (node2.nodes && node2.nodes.length) { +- node2[isClean$3] = true; +- visit2.iterator = node2.getIterator(); +- } +- return; +- } else if (this.listeners[event]) { +- visit2.visitors = this.listeners[event]; +- return; +- } +- } +- stack.pop(); +- } +- walkSync(node2) { +- node2[isClean$3] = true; +- let events = getEvents$1(node2); +- for (let event of events) { +- if (event === CHILDREN$1) { +- if (node2.nodes) { +- node2.each((child) => { +- if (!child[isClean$3]) this.walkSync(child); +- }); +- } +- } else { +- let visitors = this.listeners[event]; +- if (visitors) { +- if (this.visitSync(visitors, node2.toProxy())) return; +- } +- } +- } +- } +- warnings() { +- return this.sync().warnings(); +- } +- get content() { +- return this.stringify().content; +- } +- get css() { +- return this.stringify().css; +- } +- get map() { +- return this.stringify().map; +- } +- get messages() { +- return this.sync().messages; +- } +- get opts() { +- return this.result.opts; +- } +- get processor() { +- return this.result.processor; +- } +- get root() { +- return this.sync().root; +- } +- get [Symbol.toStringTag]() { +- return "LazyResult"; +- } +-}; +-LazyResult$2$1.registerPostcss = (dependant) => { +- postcss$2$1 = dependant; +-}; +-var lazyResult$1 = LazyResult$2$1; +-LazyResult$2$1.default = LazyResult$2$1; +-Root$3$1.registerLazyResult(LazyResult$2$1); +-Document$2$1.registerLazyResult(LazyResult$2$1); +-let MapGenerator2$1 = mapGenerator$1; +-let stringify$1$1 = stringify_1$1; +-let warnOnce2$1 = warnOnce$2$1; +-let parse$1$1 = parse_1$1; +-const Result$1$1 = result$1; +-let NoWorkResult$1$1 = class NoWorkResult { +- constructor(processor2, css, opts) { +- css = css.toString(); +- this.stringified = false; +- this._processor = processor2; +- this._css = css; +- this._opts = opts; +- this._map = void 0; +- let root2; +- let str = stringify$1$1; +- this.result = new Result$1$1(this._processor, root2, this._opts); +- this.result.css = css; +- let self = this; +- Object.defineProperty(this.result, "root", { +- get() { +- return self.root; +- } +- }); +- let map = new MapGenerator2$1(str, root2, this._opts, css); +- if (map.isMap()) { +- let [generatedCSS, generatedMap] = map.generate(); +- if (generatedCSS) { +- this.result.css = generatedCSS; +- } +- if (generatedMap) { +- this.result.map = generatedMap; +- } +- } else { +- map.clearAnnotation(); +- this.result.css = map.css; +- } +- } +- async() { +- if (this.error) return Promise.reject(this.error); +- return Promise.resolve(this.result); +- } +- catch(onRejected) { +- return this.async().catch(onRejected); +- } +- finally(onFinally) { +- return this.async().then(onFinally, onFinally); +- } +- sync() { +- if (this.error) throw this.error; +- return this.result; +- } +- then(onFulfilled, onRejected) { +- if (process.env.NODE_ENV !== "production") { +- if (!("from" in this._opts)) { +- warnOnce2$1( +- "Without `from` option PostCSS could generate wrong source map and will not find Browserslist config. Set it to CSS file path or to `undefined` to prevent this warning." +- ); +- } +- } +- return this.async().then(onFulfilled, onRejected); +- } +- toString() { +- return this._css; +- } +- warnings() { +- return []; +- } +- get content() { +- return this.result.css; +- } +- get css() { +- return this.result.css; +- } +- get map() { +- return this.result.map; +- } +- get messages() { +- return []; +- } +- get opts() { +- return this.result.opts; +- } +- get processor() { +- return this.result.processor; +- } +- get root() { +- if (this._root) { +- return this._root; +- } +- let root2; +- let parser2 = parse$1$1; +- try { +- root2 = parser2(this._css, this._opts); +- } catch (error) { +- this.error = error; +- } +- if (this.error) { +- throw this.error; +- } else { +- this._root = root2; +- return root2; +- } +- } +- get [Symbol.toStringTag]() { +- return "NoWorkResult"; +- } +-}; +-var noWorkResult$1 = NoWorkResult$1$1; +-NoWorkResult$1$1.default = NoWorkResult$1$1; +-let NoWorkResult2$1 = noWorkResult$1; +-let LazyResult$1$1 = lazyResult$1; +-let Document$1$1 = document$1$1; +-let Root$2$1 = root$1; +-let Processor$1$1 = class Processor { +- constructor(plugins = []) { +- this.version = "8.4.38"; +- this.plugins = this.normalize(plugins); +- } +- normalize(plugins) { +- let normalized = []; +- for (let i2 of plugins) { +- if (i2.postcss === true) { +- i2 = i2(); +- } else if (i2.postcss) { +- i2 = i2.postcss; +- } +- if (typeof i2 === "object" && Array.isArray(i2.plugins)) { +- normalized = normalized.concat(i2.plugins); +- } else if (typeof i2 === "object" && i2.postcssPlugin) { +- normalized.push(i2); +- } else if (typeof i2 === "function") { +- normalized.push(i2); +- } else if (typeof i2 === "object" && (i2.parse || i2.stringify)) { +- if (process.env.NODE_ENV !== "production") { +- throw new Error( +- "PostCSS syntaxes cannot be used as plugins. Instead, please use one of the syntax/parser/stringifier options as outlined in your PostCSS runner documentation." +- ); +- } +- } else { +- throw new Error(i2 + " is not a PostCSS plugin"); +- } +- } +- return normalized; +- } +- process(css, opts = {}) { +- if (!this.plugins.length && !opts.parser && !opts.stringifier && !opts.syntax) { +- return new NoWorkResult2$1(this, css, opts); +- } else { +- return new LazyResult$1$1(this, css, opts); +- } +- } +- use(plugin22) { +- this.plugins = this.plugins.concat(this.normalize([plugin22])); +- return this; +- } +-}; +-var processor$1 = Processor$1$1; +-Processor$1$1.default = Processor$1$1; +-Root$2$1.registerProcessor(Processor$1$1); +-Document$1$1.registerProcessor(Processor$1$1); +-let Declaration$1$1 = declaration$1; +-let PreviousMap2$1 = previousMap$1; +-let Comment$1$1 = comment$1; +-let AtRule$1$1 = atRule$1; +-let Input$1$1 = input$1; +-let Root$1$1 = root$1; +-let Rule$1$1 = rule$1; +-function fromJSON$1$1(json, inputs) { +- if (Array.isArray(json)) return json.map((n2) => fromJSON$1$1(n2)); +- let { inputs: ownInputs, ...defaults } = json; +- if (ownInputs) { +- inputs = []; +- for (let input2 of ownInputs) { +- let inputHydrated = { ...input2, __proto__: Input$1$1.prototype }; +- if (inputHydrated.map) { +- inputHydrated.map = { +- ...inputHydrated.map, +- __proto__: PreviousMap2$1.prototype +- }; +- } +- inputs.push(inputHydrated); +- } +- } +- if (defaults.nodes) { +- defaults.nodes = json.nodes.map((n2) => fromJSON$1$1(n2, inputs)); +- } +- if (defaults.source) { +- let { inputId, ...source } = defaults.source; +- defaults.source = source; +- if (inputId != null) { +- defaults.source.input = inputs[inputId]; +- } +- } +- if (defaults.type === "root") { +- return new Root$1$1(defaults); +- } else if (defaults.type === "decl") { +- return new Declaration$1$1(defaults); +- } else if (defaults.type === "rule") { +- return new Rule$1$1(defaults); +- } else if (defaults.type === "comment") { +- return new Comment$1$1(defaults); +- } else if (defaults.type === "atrule") { +- return new AtRule$1$1(defaults); +- } else { +- throw new Error("Unknown node type: " + json.type); +- } +-} +-var fromJSON_1$1 = fromJSON$1$1; +-fromJSON$1$1.default = fromJSON$1$1; +-let CssSyntaxError2$1 = cssSyntaxError$1; +-let Declaration2$1 = declaration$1; +-let LazyResult2$1 = lazyResult$1; +-let Container2$1 = container$1; +-let Processor2$1 = processor$1; +-let stringify$5 = stringify_1$1; +-let fromJSON$2 = fromJSON_1$1; +-let Document22 = document$1$1; +-let Warning2$1 = warning$1; +-let Comment2$1 = comment$1; +-let AtRule2$1 = atRule$1; +-let Result2$1 = result$1; +-let Input2$1 = input$1; +-let parse$5 = parse_1$1; +-let list$3 = list_1$1; +-let Rule2$1 = rule$1; +-let Root2$1 = root$1; +-let Node2$1 = node$1; +-function postcss$3(...plugins) { +- if (plugins.length === 1 && Array.isArray(plugins[0])) { +- plugins = plugins[0]; +- } +- return new Processor2$1(plugins); +-} +-postcss$3.plugin = function plugin(name, initializer) { +- let warningPrinted = false; +- function creator(...args) { +- if (console && console.warn && !warningPrinted) { +- warningPrinted = true; +- console.warn( +- name + ": postcss.plugin was deprecated. Migration guide:\nhttps://evilmartians.com/chronicles/postcss-8-plugin-migration" +- ); +- if (process.env.LANG && process.env.LANG.startsWith("cn")) { +- console.warn( +- name + ": 里面 postcss.plugin 被弃用. 迁移指南:\nhttps://www.w3ctech.com/topic/2226" +- ); +- } +- } +- let transformer = initializer(...args); +- transformer.postcssPlugin = name; +- transformer.postcssVersion = new Processor2$1().version; +- return transformer; +- } +- let cache; +- Object.defineProperty(creator, "postcss", { +- get() { +- if (!cache) cache = creator(); +- return cache; +- } +- }); +- creator.process = function(css, processOpts, pluginOpts) { +- return postcss$3([creator(pluginOpts)]).process(css, processOpts); +- }; +- return creator; +-}; +-postcss$3.stringify = stringify$5; +-postcss$3.parse = parse$5; +-postcss$3.fromJSON = fromJSON$2; +-postcss$3.list = list$3; +-postcss$3.comment = (defaults) => new Comment2$1(defaults); +-postcss$3.atRule = (defaults) => new AtRule2$1(defaults); +-postcss$3.decl = (defaults) => new Declaration2$1(defaults); +-postcss$3.rule = (defaults) => new Rule2$1(defaults); +-postcss$3.root = (defaults) => new Root2$1(defaults); +-postcss$3.document = (defaults) => new Document22(defaults); +-postcss$3.CssSyntaxError = CssSyntaxError2$1; +-postcss$3.Declaration = Declaration2$1; +-postcss$3.Container = Container2$1; +-postcss$3.Processor = Processor2$1; +-postcss$3.Document = Document22; +-postcss$3.Comment = Comment2$1; +-postcss$3.Warning = Warning2$1; +-postcss$3.AtRule = AtRule2$1; +-postcss$3.Result = Result2$1; +-postcss$3.Input = Input2$1; +-postcss$3.Rule = Rule2$1; +-postcss$3.Root = Root2$1; +-postcss$3.Node = Node2$1; +-LazyResult2$1.registerPostcss(postcss$3); +-var postcss_1$1 = postcss$3; +-postcss$3.default = postcss$3; +-const postcss$1$1 = /* @__PURE__ */ getDefaultExportFromCjs$1(postcss_1$1); +-postcss$1$1.stringify; +-postcss$1$1.fromJSON; +-postcss$1$1.plugin; +-postcss$1$1.parse; +-postcss$1$1.list; +-postcss$1$1.document; +-postcss$1$1.comment; +-postcss$1$1.atRule; +-postcss$1$1.rule; +-postcss$1$1.decl; +-postcss$1$1.root; +-postcss$1$1.CssSyntaxError; +-postcss$1$1.Declaration; +-postcss$1$1.Container; +-postcss$1$1.Processor; +-postcss$1$1.Document; +-postcss$1$1.Comment; +-postcss$1$1.Warning; +-postcss$1$1.AtRule; +-postcss$1$1.Result; +-postcss$1$1.Input; +-postcss$1$1.Rule; +-postcss$1$1.Root; +-postcss$1$1.Node; +-var __defProp22 = Object.defineProperty; +-var __defNormalProp22 = (obj, key, value) => key in obj ? __defProp22(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value; +-var __publicField22 = (obj, key, value) => __defNormalProp22(obj, typeof key !== "symbol" ? key + "" : key, value); +-function getDefaultExportFromCjs(x2) { +- return x2 && x2.__esModule && Object.prototype.hasOwnProperty.call(x2, "default") ? x2["default"] : x2; +-} +-function getAugmentedNamespace(n2) { +- if (n2.__esModule) return n2; +- var f2 = n2.default; +- if (typeof f2 == "function") { +- var a2 = function a22() { +- if (this instanceof a22) { +- return Reflect.construct(f2, arguments, this.constructor); +- } +- return f2.apply(this, arguments); +- }; +- a2.prototype = f2.prototype; +- } else a2 = {}; +- Object.defineProperty(a2, "__esModule", { value: true }); +- Object.keys(n2).forEach(function(k) { +- var d = Object.getOwnPropertyDescriptor(n2, k); +- Object.defineProperty(a2, k, d.get ? d : { +- enumerable: true, +- get: function() { +- return n2[k]; +- } +- }); +- }); +- return a2; +-} +-var picocolors_browser = { exports: {} }; +-var x = String; +-var create = function() { +- return { isColorSupported: false, reset: x, bold: x, dim: x, italic: x, underline: x, inverse: x, hidden: x, strikethrough: x, black: x, red: x, green: x, yellow: x, blue: x, magenta: x, cyan: x, white: x, gray: x, bgBlack: x, bgRed: x, bgGreen: x, bgYellow: x, bgBlue: x, bgMagenta: x, bgCyan: x, bgWhite: x }; +-}; +-picocolors_browser.exports = create(); +-picocolors_browser.exports.createColors = create; +-var picocolors_browserExports = picocolors_browser.exports; +-const __viteBrowserExternal = {}; +-const __viteBrowserExternal$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({ +- __proto__: null, +- default: __viteBrowserExternal +-}, Symbol.toStringTag, { value: "Module" })); +-const require$$2 = /* @__PURE__ */ getAugmentedNamespace(__viteBrowserExternal$1); +-let pico = picocolors_browserExports; +-let terminalHighlight$1 = require$$2; +-let CssSyntaxError$3 = class CssSyntaxError2 extends Error { +- constructor(message, line, column, source, file, plugin22) { +- super(message); +- this.name = "CssSyntaxError"; +- this.reason = message; +- if (file) { +- this.file = file; +- } +- if (source) { +- this.source = source; +- } +- if (plugin22) { +- this.plugin = plugin22; +- } +- if (typeof line !== "undefined" && typeof column !== "undefined") { +- if (typeof line === "number") { +- this.line = line; +- this.column = column; +- } else { +- this.line = line.line; +- this.column = line.column; +- this.endLine = column.line; +- this.endColumn = column.column; +- } +- } +- this.setMessage(); +- if (Error.captureStackTrace) { +- Error.captureStackTrace(this, CssSyntaxError2); +- } +- } +- setMessage() { +- this.message = this.plugin ? this.plugin + ": " : ""; +- this.message += this.file ? this.file : ""; +- if (typeof this.line !== "undefined") { +- this.message += ":" + this.line + ":" + this.column; +- } +- this.message += ": " + this.reason; +- } +- showSourceCode(color) { +- if (!this.source) return ""; +- let css = this.source; +- if (color == null) color = pico.isColorSupported; +- if (terminalHighlight$1) { +- if (color) css = terminalHighlight$1(css); +- } +- let lines = css.split(/\r?\n/); +- let start = Math.max(this.line - 3, 0); +- let end = Math.min(this.line + 2, lines.length); +- let maxWidth = String(end).length; +- let mark, aside; +- if (color) { +- let { bold, gray, red } = pico.createColors(true); +- mark = (text) => bold(red(text)); +- aside = (text) => gray(text); +- } else { +- mark = aside = (str) => str; +- } +- return lines.slice(start, end).map((line, index2) => { +- let number = start + 1 + index2; +- let gutter = " " + (" " + number).slice(-maxWidth) + " | "; +- if (number === this.line) { +- let spacing = aside(gutter.replace(/\d/g, " ")) + line.slice(0, this.column - 1).replace(/[^\t]/g, " "); +- return mark(">") + aside(gutter) + line + "\n " + spacing + mark("^"); +- } +- return " " + aside(gutter) + line; +- }).join("\n"); +- } +- toString() { +- let code = this.showSourceCode(); +- if (code) { +- code = "\n\n" + code + "\n"; +- } +- return this.name + ": " + this.message + code; +- } +-}; +-var cssSyntaxError = CssSyntaxError$3; +-CssSyntaxError$3.default = CssSyntaxError$3; +-var symbols = {}; +-symbols.isClean = Symbol("isClean"); +-symbols.my = Symbol("my"); +-const DEFAULT_RAW = { +- after: "\n", +- beforeClose: "\n", +- beforeComment: "\n", +- beforeDecl: "\n", +- beforeOpen: " ", +- beforeRule: "\n", +- colon: ": ", +- commentLeft: " ", +- commentRight: " ", +- emptyBody: "", +- indent: " ", +- semicolon: false +-}; +-function capitalize(str) { +- return str[0].toUpperCase() + str.slice(1); +-} +-let Stringifier$2 = class Stringifier2 { +- constructor(builder) { +- this.builder = builder; +- } +- atrule(node2, semicolon) { +- let name = "@" + node2.name; +- let params = node2.params ? this.rawValue(node2, "params") : ""; +- if (typeof node2.raws.afterName !== "undefined") { +- name += node2.raws.afterName; +- } else if (params) { +- name += " "; +- } +- if (node2.nodes) { +- this.block(node2, name + params); +- } else { +- let end = (node2.raws.between || "") + (semicolon ? ";" : ""); +- this.builder(name + params + end, node2); +- } +- } +- beforeAfter(node2, detect) { +- let value; +- if (node2.type === "decl") { +- value = this.raw(node2, null, "beforeDecl"); +- } else if (node2.type === "comment") { +- value = this.raw(node2, null, "beforeComment"); +- } else if (detect === "before") { +- value = this.raw(node2, null, "beforeRule"); +- } else { +- value = this.raw(node2, null, "beforeClose"); +- } +- let buf = node2.parent; +- let depth = 0; +- while (buf && buf.type !== "root") { +- depth += 1; +- buf = buf.parent; +- } +- if (value.includes("\n")) { +- let indent = this.raw(node2, null, "indent"); +- if (indent.length) { +- for (let step = 0; step < depth; step++) value += indent; +- } +- } +- return value; +- } +- block(node2, start) { +- let between = this.raw(node2, "between", "beforeOpen"); +- this.builder(start + between + "{", node2, "start"); +- let after; +- if (node2.nodes && node2.nodes.length) { +- this.body(node2); +- after = this.raw(node2, "after"); +- } else { +- after = this.raw(node2, "after", "emptyBody"); +- } +- if (after) this.builder(after); +- this.builder("}", node2, "end"); +- } +- body(node2) { +- let last = node2.nodes.length - 1; +- while (last > 0) { +- if (node2.nodes[last].type !== "comment") break; +- last -= 1; +- } +- let semicolon = this.raw(node2, "semicolon"); +- for (let i2 = 0; i2 < node2.nodes.length; i2++) { +- let child = node2.nodes[i2]; +- let before = this.raw(child, "before"); +- if (before) this.builder(before); +- this.stringify(child, last !== i2 || semicolon); +- } +- } +- comment(node2) { +- let left = this.raw(node2, "left", "commentLeft"); +- let right = this.raw(node2, "right", "commentRight"); +- this.builder("/*" + left + node2.text + right + "*/", node2); +- } +- decl(node2, semicolon) { +- let between = this.raw(node2, "between", "colon"); +- let string = node2.prop + between + this.rawValue(node2, "value"); +- if (node2.important) { +- string += node2.raws.important || " !important"; +- } +- if (semicolon) string += ";"; +- this.builder(string, node2); +- } +- document(node2) { +- this.body(node2); +- } +- raw(node2, own, detect) { +- let value; +- if (!detect) detect = own; +- if (own) { +- value = node2.raws[own]; +- if (typeof value !== "undefined") return value; +- } +- let parent = node2.parent; +- if (detect === "before") { +- if (!parent || parent.type === "root" && parent.first === node2) { +- return ""; +- } +- if (parent && parent.type === "document") { +- return ""; +- } +- } +- if (!parent) return DEFAULT_RAW[detect]; +- let root2 = node2.root(); +- if (!root2.rawCache) root2.rawCache = {}; +- if (typeof root2.rawCache[detect] !== "undefined") { +- return root2.rawCache[detect]; +- } +- if (detect === "before" || detect === "after") { +- return this.beforeAfter(node2, detect); +- } else { +- let method = "raw" + capitalize(detect); +- if (this[method]) { +- value = this[method](root2, node2); +- } else { +- root2.walk((i2) => { +- value = i2.raws[own]; +- if (typeof value !== "undefined") return false; +- }); +- } +- } +- if (typeof value === "undefined") value = DEFAULT_RAW[detect]; +- root2.rawCache[detect] = value; +- return value; +- } +- rawBeforeClose(root2) { +- let value; +- root2.walk((i2) => { +- if (i2.nodes && i2.nodes.length > 0) { +- if (typeof i2.raws.after !== "undefined") { +- value = i2.raws.after; +- if (value.includes("\n")) { +- value = value.replace(/[^\n]+$/, ""); +- } +- return false; +- } +- } +- }); +- if (value) value = value.replace(/\S/g, ""); +- return value; +- } +- rawBeforeComment(root2, node2) { +- let value; +- root2.walkComments((i2) => { +- if (typeof i2.raws.before !== "undefined") { +- value = i2.raws.before; +- if (value.includes("\n")) { +- value = value.replace(/[^\n]+$/, ""); +- } +- return false; +- } +- }); +- if (typeof value === "undefined") { +- value = this.raw(node2, null, "beforeDecl"); +- } else if (value) { +- value = value.replace(/\S/g, ""); +- } +- return value; +- } +- rawBeforeDecl(root2, node2) { +- let value; +- root2.walkDecls((i2) => { +- if (typeof i2.raws.before !== "undefined") { +- value = i2.raws.before; +- if (value.includes("\n")) { +- value = value.replace(/[^\n]+$/, ""); +- } +- return false; +- } +- }); +- if (typeof value === "undefined") { +- value = this.raw(node2, null, "beforeRule"); +- } else if (value) { +- value = value.replace(/\S/g, ""); +- } +- return value; +- } +- rawBeforeOpen(root2) { +- let value; +- root2.walk((i2) => { +- if (i2.type !== "decl") { +- value = i2.raws.between; +- if (typeof value !== "undefined") return false; +- } +- }); +- return value; +- } +- rawBeforeRule(root2) { +- let value; +- root2.walk((i2) => { +- if (i2.nodes && (i2.parent !== root2 || root2.first !== i2)) { +- if (typeof i2.raws.before !== "undefined") { +- value = i2.raws.before; +- if (value.includes("\n")) { +- value = value.replace(/[^\n]+$/, ""); +- } +- return false; +- } +- } +- }); +- if (value) value = value.replace(/\S/g, ""); +- return value; +- } +- rawColon(root2) { +- let value; +- root2.walkDecls((i2) => { +- if (typeof i2.raws.between !== "undefined") { +- value = i2.raws.between.replace(/[^\s:]/g, ""); +- return false; +- } +- }); +- return value; +- } +- rawEmptyBody(root2) { +- let value; +- root2.walk((i2) => { +- if (i2.nodes && i2.nodes.length === 0) { +- value = i2.raws.after; +- if (typeof value !== "undefined") return false; +- } +- }); +- return value; +- } +- rawIndent(root2) { +- if (root2.raws.indent) return root2.raws.indent; +- let value; +- root2.walk((i2) => { +- let p = i2.parent; +- if (p && p !== root2 && p.parent && p.parent === root2) { +- if (typeof i2.raws.before !== "undefined") { +- let parts = i2.raws.before.split("\n"); +- value = parts[parts.length - 1]; +- value = value.replace(/\S/g, ""); +- return false; +- } +- } +- }); +- return value; +- } +- rawSemicolon(root2) { +- let value; +- root2.walk((i2) => { +- if (i2.nodes && i2.nodes.length && i2.last.type === "decl") { +- value = i2.raws.semicolon; +- if (typeof value !== "undefined") return false; +- } +- }); +- return value; +- } +- rawValue(node2, prop) { +- let value = node2[prop]; +- let raw = node2.raws[prop]; +- if (raw && raw.value === value) { +- return raw.raw; +- } +- return value; +- } +- root(node2) { +- this.body(node2); +- if (node2.raws.after) this.builder(node2.raws.after); +- } +- rule(node2) { +- this.block(node2, this.rawValue(node2, "selector")); +- if (node2.raws.ownSemicolon) { +- this.builder(node2.raws.ownSemicolon, node2, "end"); +- } +- } +- stringify(node2, semicolon) { +- if (!this[node2.type]) { +- throw new Error( +- "Unknown AST node type " + node2.type + ". Maybe you need to change PostCSS stringifier." +- ); +- } +- this[node2.type](node2, semicolon); +- } +-}; +-var stringifier = Stringifier$2; +-Stringifier$2.default = Stringifier$2; +-let Stringifier$1 = stringifier; +-function stringify$4(node2, builder) { +- let str = new Stringifier$1(builder); +- str.stringify(node2); +-} +-var stringify_1 = stringify$4; +-stringify$4.default = stringify$4; +-let { isClean: isClean$2, my: my$2 } = symbols; +-let CssSyntaxError$2 = cssSyntaxError; +-let Stringifier22 = stringifier; +-let stringify$3 = stringify_1; +-function cloneNode(obj, parent) { +- let cloned = new obj.constructor(); +- for (let i2 in obj) { +- if (!Object.prototype.hasOwnProperty.call(obj, i2)) { +- continue; +- } +- if (i2 === "proxyCache") continue; +- let value = obj[i2]; +- let type = typeof value; +- if (i2 === "parent" && type === "object") { +- if (parent) cloned[i2] = parent; +- } else if (i2 === "source") { +- cloned[i2] = value; +- } else if (Array.isArray(value)) { +- cloned[i2] = value.map((j) => cloneNode(j, cloned)); +- } else { +- if (type === "object" && value !== null) value = cloneNode(value); +- cloned[i2] = value; +- } +- } +- return cloned; +-} +-let Node$4 = class Node3 { +- constructor(defaults = {}) { +- this.raws = {}; +- this[isClean$2] = false; +- this[my$2] = true; +- for (let name in defaults) { +- if (name === "nodes") { +- this.nodes = []; +- for (let node2 of defaults[name]) { +- if (typeof node2.clone === "function") { +- this.append(node2.clone()); +- } else { +- this.append(node2); +- } +- } +- } else { +- this[name] = defaults[name]; +- } +- } +- } +- addToError(error) { +- error.postcssNode = this; +- if (error.stack && this.source && /\n\s{4}at /.test(error.stack)) { +- let s2 = this.source; +- error.stack = error.stack.replace( +- /\n\s{4}at /, +- `$&${s2.input.from}:${s2.start.line}:${s2.start.column}$&` +- ); +- } +- return error; +- } +- after(add) { +- this.parent.insertAfter(this, add); +- return this; +- } +- assign(overrides = {}) { +- for (let name in overrides) { +- this[name] = overrides[name]; +- } +- return this; +- } +- before(add) { +- this.parent.insertBefore(this, add); +- return this; +- } +- cleanRaws(keepBetween) { +- delete this.raws.before; +- delete this.raws.after; +- if (!keepBetween) delete this.raws.between; +- } +- clone(overrides = {}) { +- let cloned = cloneNode(this); +- for (let name in overrides) { +- cloned[name] = overrides[name]; +- } +- return cloned; +- } +- cloneAfter(overrides = {}) { +- let cloned = this.clone(overrides); +- this.parent.insertAfter(this, cloned); +- return cloned; +- } +- cloneBefore(overrides = {}) { +- let cloned = this.clone(overrides); +- this.parent.insertBefore(this, cloned); +- return cloned; +- } +- error(message, opts = {}) { +- if (this.source) { +- let { end, start } = this.rangeBy(opts); +- return this.source.input.error( +- message, +- { column: start.column, line: start.line }, +- { column: end.column, line: end.line }, +- opts +- ); +- } +- return new CssSyntaxError$2(message); +- } +- getProxyProcessor() { +- return { +- get(node2, prop) { +- if (prop === "proxyOf") { +- return node2; +- } else if (prop === "root") { +- return () => node2.root().toProxy(); +- } else { +- return node2[prop]; +- } +- }, +- set(node2, prop, value) { +- if (node2[prop] === value) return true; +- node2[prop] = value; +- if (prop === "prop" || prop === "value" || prop === "name" || prop === "params" || prop === "important" || /* c8 ignore next */ +- prop === "text") { +- node2.markDirty(); +- } +- return true; +- } +- }; +- } +- markDirty() { +- if (this[isClean$2]) { +- this[isClean$2] = false; +- let next = this; +- while (next = next.parent) { +- next[isClean$2] = false; +- } +- } +- } +- next() { +- if (!this.parent) return void 0; +- let index2 = this.parent.index(this); +- return this.parent.nodes[index2 + 1]; +- } +- positionBy(opts, stringRepresentation) { +- let pos = this.source.start; +- if (opts.index) { +- pos = this.positionInside(opts.index, stringRepresentation); +- } else if (opts.word) { +- stringRepresentation = this.toString(); +- let index2 = stringRepresentation.indexOf(opts.word); +- if (index2 !== -1) pos = this.positionInside(index2, stringRepresentation); +- } +- return pos; +- } +- positionInside(index2, stringRepresentation) { +- let string = stringRepresentation || this.toString(); +- let column = this.source.start.column; +- let line = this.source.start.line; +- for (let i2 = 0; i2 < index2; i2++) { +- if (string[i2] === "\n") { +- column = 1; +- line += 1; +- } else { +- column += 1; +- } +- } +- return { column, line }; +- } +- prev() { +- if (!this.parent) return void 0; +- let index2 = this.parent.index(this); +- return this.parent.nodes[index2 - 1]; +- } +- rangeBy(opts) { +- let start = { +- column: this.source.start.column, +- line: this.source.start.line +- }; +- let end = this.source.end ? { +- column: this.source.end.column + 1, +- line: this.source.end.line +- } : { +- column: start.column + 1, +- line: start.line +- }; +- if (opts.word) { +- let stringRepresentation = this.toString(); +- let index2 = stringRepresentation.indexOf(opts.word); +- if (index2 !== -1) { +- start = this.positionInside(index2, stringRepresentation); +- end = this.positionInside(index2 + opts.word.length, stringRepresentation); +- } +- } else { +- if (opts.start) { +- start = { +- column: opts.start.column, +- line: opts.start.line +- }; +- } else if (opts.index) { +- start = this.positionInside(opts.index); +- } +- if (opts.end) { +- end = { +- column: opts.end.column, +- line: opts.end.line +- }; +- } else if (typeof opts.endIndex === "number") { +- end = this.positionInside(opts.endIndex); +- } else if (opts.index) { +- end = this.positionInside(opts.index + 1); +- } +- } +- if (end.line < start.line || end.line === start.line && end.column <= start.column) { +- end = { column: start.column + 1, line: start.line }; +- } +- return { end, start }; +- } +- raw(prop, defaultType) { +- let str = new Stringifier22(); +- return str.raw(this, prop, defaultType); +- } +- remove() { +- if (this.parent) { +- this.parent.removeChild(this); +- } +- this.parent = void 0; +- return this; +- } +- replaceWith(...nodes) { +- if (this.parent) { +- let bookmark = this; +- let foundSelf = false; +- for (let node2 of nodes) { +- if (node2 === this) { +- foundSelf = true; +- } else if (foundSelf) { +- this.parent.insertAfter(bookmark, node2); +- bookmark = node2; +- } else { +- this.parent.insertBefore(bookmark, node2); +- } +- } +- if (!foundSelf) { +- this.remove(); +- } +- } +- return this; +- } +- root() { +- let result2 = this; +- while (result2.parent && result2.parent.type !== "document") { +- result2 = result2.parent; +- } +- return result2; +- } +- toJSON(_, inputs) { +- let fixed = {}; +- let emitInputs = inputs == null; +- inputs = inputs || /* @__PURE__ */ new Map(); +- let inputsNextIndex = 0; +- for (let name in this) { +- if (!Object.prototype.hasOwnProperty.call(this, name)) { +- continue; +- } +- if (name === "parent" || name === "proxyCache") continue; +- let value = this[name]; +- if (Array.isArray(value)) { +- fixed[name] = value.map((i2) => { +- if (typeof i2 === "object" && i2.toJSON) { +- return i2.toJSON(null, inputs); +- } else { +- return i2; +- } +- }); +- } else if (typeof value === "object" && value.toJSON) { +- fixed[name] = value.toJSON(null, inputs); +- } else if (name === "source") { +- let inputId = inputs.get(value.input); +- if (inputId == null) { +- inputId = inputsNextIndex; +- inputs.set(value.input, inputsNextIndex); +- inputsNextIndex++; +- } +- fixed[name] = { +- end: value.end, +- inputId, +- start: value.start +- }; +- } else { +- fixed[name] = value; +- } +- } +- if (emitInputs) { +- fixed.inputs = [...inputs.keys()].map((input2) => input2.toJSON()); +- } +- return fixed; +- } +- toProxy() { +- if (!this.proxyCache) { +- this.proxyCache = new Proxy(this, this.getProxyProcessor()); +- } +- return this.proxyCache; +- } +- toString(stringifier2 = stringify$3) { +- if (stringifier2.stringify) stringifier2 = stringifier2.stringify; +- let result2 = ""; +- stringifier2(this, (i2) => { +- result2 += i2; +- }); +- return result2; +- } +- warn(result2, text, opts) { +- let data = { node: this }; +- for (let i2 in opts) data[i2] = opts[i2]; +- return result2.warn(text, data); +- } +- get proxyOf() { +- return this; +- } +-}; +-var node = Node$4; +-Node$4.default = Node$4; +-let Node$3 = node; +-let Declaration$4 = class Declaration2 extends Node$3 { +- constructor(defaults) { +- if (defaults && typeof defaults.value !== "undefined" && typeof defaults.value !== "string") { +- defaults = { ...defaults, value: String(defaults.value) }; +- } +- super(defaults); +- this.type = "decl"; +- } +- get variable() { +- return this.prop.startsWith("--") || this.prop[0] === "$"; +- } +-}; +-var declaration = Declaration$4; +-Declaration$4.default = Declaration$4; +-let urlAlphabet = "useandom-26T198340PX75pxJACKVERYMINDBUSHWOLF_GQZbfghjklqvwyzrict"; +-let customAlphabet = (alphabet, defaultSize = 21) => { +- return (size = defaultSize) => { +- let id = ""; +- let i2 = size; +- while (i2--) { +- id += alphabet[Math.random() * alphabet.length | 0]; +- } +- return id; +- }; +-}; +-let nanoid$1 = (size = 21) => { +- let id = ""; +- let i2 = size; +- while (i2--) { +- id += urlAlphabet[Math.random() * 64 | 0]; +- } +- return id; +-}; +-var nonSecure = { nanoid: nanoid$1, customAlphabet }; +-let { SourceMapConsumer: SourceMapConsumer$2, SourceMapGenerator: SourceMapGenerator$2 } = require$$2; +-let { existsSync, readFileSync } = require$$2; +-let { dirname: dirname$1, join } = require$$2; +-function fromBase64(str) { +- if (Buffer) { +- return Buffer.from(str, "base64").toString(); +- } else { +- return window.atob(str); +- } +-} +-let PreviousMap$2 = class PreviousMap2 { +- constructor(css, opts) { +- if (opts.map === false) return; +- this.loadAnnotation(css); +- this.inline = this.startWith(this.annotation, "data:"); +- let prev = opts.map ? opts.map.prev : void 0; +- let text = this.loadMap(opts.from, prev); +- if (!this.mapFile && opts.from) { +- this.mapFile = opts.from; +- } +- if (this.mapFile) this.root = dirname$1(this.mapFile); +- if (text) this.text = text; +- } +- consumer() { +- if (!this.consumerCache) { +- this.consumerCache = new SourceMapConsumer$2(this.text); +- } +- return this.consumerCache; +- } +- decodeInline(text) { +- let baseCharsetUri = /^data:application\/json;charset=utf-?8;base64,/; +- let baseUri = /^data:application\/json;base64,/; +- let charsetUri = /^data:application\/json;charset=utf-?8,/; +- let uri = /^data:application\/json,/; +- if (charsetUri.test(text) || uri.test(text)) { +- return decodeURIComponent(text.substr(RegExp.lastMatch.length)); +- } +- if (baseCharsetUri.test(text) || baseUri.test(text)) { +- return fromBase64(text.substr(RegExp.lastMatch.length)); +- } +- let encoding = text.match(/data:application\/json;([^,]+),/)[1]; +- throw new Error("Unsupported source map encoding " + encoding); +- } +- getAnnotationURL(sourceMapString) { +- return sourceMapString.replace(/^\/\*\s*# sourceMappingURL=/, "").trim(); +- } +- isMap(map) { +- if (typeof map !== "object") return false; +- return typeof map.mappings === "string" || typeof map._mappings === "string" || Array.isArray(map.sections); +- } +- loadAnnotation(css) { +- let comments = css.match(/\/\*\s*# sourceMappingURL=/gm); +- if (!comments) return; +- let start = css.lastIndexOf(comments.pop()); +- let end = css.indexOf("*/", start); +- if (start > -1 && end > -1) { +- this.annotation = this.getAnnotationURL(css.substring(start, end)); +- } +- } +- loadFile(path) { +- this.root = dirname$1(path); +- if (existsSync(path)) { +- this.mapFile = path; +- return readFileSync(path, "utf-8").toString().trim(); +- } +- } +- loadMap(file, prev) { +- if (prev === false) return false; +- if (prev) { +- if (typeof prev === "string") { +- return prev; +- } else if (typeof prev === "function") { +- let prevPath = prev(file); +- if (prevPath) { +- let map = this.loadFile(prevPath); +- if (!map) { +- throw new Error( +- "Unable to load previous source map: " + prevPath.toString() +- ); +- } +- return map; +- } +- } else if (prev instanceof SourceMapConsumer$2) { +- return SourceMapGenerator$2.fromSourceMap(prev).toString(); +- } else if (prev instanceof SourceMapGenerator$2) { +- return prev.toString(); +- } else if (this.isMap(prev)) { +- return JSON.stringify(prev); +- } else { +- throw new Error( +- "Unsupported previous source map format: " + prev.toString() +- ); +- } +- } else if (this.inline) { +- return this.decodeInline(this.annotation); +- } else if (this.annotation) { +- let map = this.annotation; +- if (file) map = join(dirname$1(file), map); +- return this.loadFile(map); +- } +- } +- startWith(string, start) { +- if (!string) return false; +- return string.substr(0, start.length) === start; +- } +- withContent() { +- return !!(this.consumer().sourcesContent && this.consumer().sourcesContent.length > 0); +- } +-}; +-var previousMap = PreviousMap$2; +-PreviousMap$2.default = PreviousMap$2; +-let { SourceMapConsumer: SourceMapConsumer$1, SourceMapGenerator: SourceMapGenerator$1 } = require$$2; +-let { fileURLToPath, pathToFileURL: pathToFileURL$1 } = require$$2; +-let { isAbsolute, resolve: resolve$1 } = require$$2; +-let { nanoid } = nonSecure; +-let terminalHighlight = require$$2; +-let CssSyntaxError$1 = cssSyntaxError; +-let PreviousMap$1 = previousMap; +-let fromOffsetCache = Symbol("fromOffsetCache"); +-let sourceMapAvailable$1 = Boolean(SourceMapConsumer$1 && SourceMapGenerator$1); +-let pathAvailable$1 = Boolean(resolve$1 && isAbsolute); +-let Input$4 = class Input2 { +- constructor(css, opts = {}) { +- if (css === null || typeof css === "undefined" || typeof css === "object" && !css.toString) { +- throw new Error(`PostCSS received ${css} instead of CSS string`); +- } +- this.css = css.toString(); +- if (this.css[0] === "\uFEFF" || this.css[0] === "￾") { +- this.hasBOM = true; +- this.css = this.css.slice(1); +- } else { +- this.hasBOM = false; +- } +- if (opts.from) { +- if (!pathAvailable$1 || /^\w+:\/\//.test(opts.from) || isAbsolute(opts.from)) { +- this.file = opts.from; +- } else { +- this.file = resolve$1(opts.from); +- } +- } +- if (pathAvailable$1 && sourceMapAvailable$1) { +- let map = new PreviousMap$1(this.css, opts); +- if (map.text) { +- this.map = map; +- let file = map.consumer().file; +- if (!this.file && file) this.file = this.mapResolve(file); +- } +- } +- if (!this.file) { +- this.id = ""; +- } +- if (this.map) this.map.file = this.from; +- } +- error(message, line, column, opts = {}) { +- let result2, endLine, endColumn; +- if (line && typeof line === "object") { +- let start = line; +- let end = column; +- if (typeof start.offset === "number") { +- let pos = this.fromOffset(start.offset); +- line = pos.line; +- column = pos.col; +- } else { +- line = start.line; +- column = start.column; +- } +- if (typeof end.offset === "number") { +- let pos = this.fromOffset(end.offset); +- endLine = pos.line; +- endColumn = pos.col; +- } else { +- endLine = end.line; +- endColumn = end.column; +- } +- } else if (!column) { +- let pos = this.fromOffset(line); +- line = pos.line; +- column = pos.col; +- } +- let origin = this.origin(line, column, endLine, endColumn); +- if (origin) { +- result2 = new CssSyntaxError$1( +- message, +- origin.endLine === void 0 ? origin.line : { column: origin.column, line: origin.line }, +- origin.endLine === void 0 ? origin.column : { column: origin.endColumn, line: origin.endLine }, +- origin.source, +- origin.file, +- opts.plugin +- ); +- } else { +- result2 = new CssSyntaxError$1( +- message, +- endLine === void 0 ? line : { column, line }, +- endLine === void 0 ? column : { column: endColumn, line: endLine }, +- this.css, +- this.file, +- opts.plugin +- ); +- } +- result2.input = { column, endColumn, endLine, line, source: this.css }; +- if (this.file) { +- if (pathToFileURL$1) { +- result2.input.url = pathToFileURL$1(this.file).toString(); +- } +- result2.input.file = this.file; +- } +- return result2; +- } +- fromOffset(offset) { +- let lastLine, lineToIndex; +- if (!this[fromOffsetCache]) { +- let lines = this.css.split("\n"); +- lineToIndex = new Array(lines.length); +- let prevIndex = 0; +- for (let i2 = 0, l2 = lines.length; i2 < l2; i2++) { +- lineToIndex[i2] = prevIndex; +- prevIndex += lines[i2].length + 1; +- } +- this[fromOffsetCache] = lineToIndex; +- } else { +- lineToIndex = this[fromOffsetCache]; +- } +- lastLine = lineToIndex[lineToIndex.length - 1]; +- let min = 0; +- if (offset >= lastLine) { +- min = lineToIndex.length - 1; +- } else { +- let max = lineToIndex.length - 2; +- let mid; +- while (min < max) { +- mid = min + (max - min >> 1); +- if (offset < lineToIndex[mid]) { +- max = mid - 1; +- } else if (offset >= lineToIndex[mid + 1]) { +- min = mid + 1; +- } else { +- min = mid; +- break; +- } +- } +- } +- return { +- col: offset - lineToIndex[min] + 1, +- line: min + 1 +- }; +- } +- mapResolve(file) { +- if (/^\w+:\/\//.test(file)) { +- return file; +- } +- return resolve$1(this.map.consumer().sourceRoot || this.map.root || ".", file); +- } +- origin(line, column, endLine, endColumn) { +- if (!this.map) return false; +- let consumer = this.map.consumer(); +- let from = consumer.originalPositionFor({ column, line }); +- if (!from.source) return false; +- let to; +- if (typeof endLine === "number") { +- to = consumer.originalPositionFor({ column: endColumn, line: endLine }); +- } +- let fromUrl; +- if (isAbsolute(from.source)) { +- fromUrl = pathToFileURL$1(from.source); +- } else { +- fromUrl = new URL( +- from.source, +- this.map.consumer().sourceRoot || pathToFileURL$1(this.map.mapFile) +- ); +- } +- let result2 = { +- column: from.column, +- endColumn: to && to.column, +- endLine: to && to.line, +- line: from.line, +- url: fromUrl.toString() +- }; +- if (fromUrl.protocol === "file:") { +- if (fileURLToPath) { +- result2.file = fileURLToPath(fromUrl); +- } else { +- throw new Error(`file: protocol is not available in this PostCSS build`); +- } +- } +- let source = consumer.sourceContentFor(from.source); +- if (source) result2.source = source; +- return result2; +- } +- toJSON() { +- let json = {}; +- for (let name of ["hasBOM", "css", "file", "id"]) { +- if (this[name] != null) { +- json[name] = this[name]; +- } +- } +- if (this.map) { +- json.map = { ...this.map }; +- if (json.map.consumerCache) { +- json.map.consumerCache = void 0; +- } +- } +- return json; +- } +- get from() { +- return this.file || this.id; +- } +-}; +-var input = Input$4; +-Input$4.default = Input$4; +-if (terminalHighlight && terminalHighlight.registerInput) { +- terminalHighlight.registerInput(Input$4); +-} +-let { SourceMapConsumer, SourceMapGenerator } = require$$2; +-let { dirname, relative, resolve, sep } = require$$2; +-let { pathToFileURL } = require$$2; +-let Input$3 = input; +-let sourceMapAvailable = Boolean(SourceMapConsumer && SourceMapGenerator); +-let pathAvailable = Boolean(dirname && resolve && relative && sep); +-let MapGenerator$2 = class MapGenerator2 { +- constructor(stringify2, root2, opts, cssString) { +- this.stringify = stringify2; +- this.mapOpts = opts.map || {}; +- this.root = root2; +- this.opts = opts; +- this.css = cssString; +- this.originalCSS = cssString; +- this.usesFileUrls = !this.mapOpts.from && this.mapOpts.absolute; +- this.memoizedFileURLs = /* @__PURE__ */ new Map(); +- this.memoizedPaths = /* @__PURE__ */ new Map(); +- this.memoizedURLs = /* @__PURE__ */ new Map(); +- } +- addAnnotation() { +- let content; +- if (this.isInline()) { +- content = "data:application/json;base64," + this.toBase64(this.map.toString()); +- } else if (typeof this.mapOpts.annotation === "string") { +- content = this.mapOpts.annotation; +- } else if (typeof this.mapOpts.annotation === "function") { +- content = this.mapOpts.annotation(this.opts.to, this.root); +- } else { +- content = this.outputFile() + ".map"; +- } +- let eol = "\n"; +- if (this.css.includes("\r\n")) eol = "\r\n"; +- this.css += eol + "/*# sourceMappingURL=" + content + " */"; +- } +- applyPrevMaps() { +- for (let prev of this.previous()) { +- let from = this.toUrl(this.path(prev.file)); +- let root2 = prev.root || dirname(prev.file); +- let map; +- if (this.mapOpts.sourcesContent === false) { +- map = new SourceMapConsumer(prev.text); +- if (map.sourcesContent) { +- map.sourcesContent = null; +- } +- } else { +- map = prev.consumer(); +- } +- this.map.applySourceMap(map, from, this.toUrl(this.path(root2))); +- } +- } +- clearAnnotation() { +- if (this.mapOpts.annotation === false) return; +- if (this.root) { +- let node2; +- for (let i2 = this.root.nodes.length - 1; i2 >= 0; i2--) { +- node2 = this.root.nodes[i2]; +- if (node2.type !== "comment") continue; +- if (node2.text.indexOf("# sourceMappingURL=") === 0) { +- this.root.removeChild(i2); +- } +- } +- } else if (this.css) { +- this.css = this.css.replace(/\n*?\/\*#[\S\s]*?\*\/$/gm, ""); +- } +- } +- generate() { +- this.clearAnnotation(); +- if (pathAvailable && sourceMapAvailable && this.isMap()) { +- return this.generateMap(); +- } else { +- let result2 = ""; +- this.stringify(this.root, (i2) => { +- result2 += i2; +- }); +- return [result2]; +- } +- } +- generateMap() { +- if (this.root) { +- this.generateString(); +- } else if (this.previous().length === 1) { +- let prev = this.previous()[0].consumer(); +- prev.file = this.outputFile(); +- this.map = SourceMapGenerator.fromSourceMap(prev, { +- ignoreInvalidMapping: true +- }); +- } else { +- this.map = new SourceMapGenerator({ +- file: this.outputFile(), +- ignoreInvalidMapping: true +- }); +- this.map.addMapping({ +- generated: { column: 0, line: 1 }, +- original: { column: 0, line: 1 }, +- source: this.opts.from ? this.toUrl(this.path(this.opts.from)) : "" +- }); +- } +- if (this.isSourcesContent()) this.setSourcesContent(); +- if (this.root && this.previous().length > 0) this.applyPrevMaps(); +- if (this.isAnnotation()) this.addAnnotation(); +- if (this.isInline()) { +- return [this.css]; +- } else { +- return [this.css, this.map]; +- } +- } +- generateString() { +- this.css = ""; +- this.map = new SourceMapGenerator({ +- file: this.outputFile(), +- ignoreInvalidMapping: true +- }); +- let line = 1; +- let column = 1; +- let noSource = ""; +- let mapping = { +- generated: { column: 0, line: 0 }, +- original: { column: 0, line: 0 }, +- source: "" +- }; +- let lines, last; +- this.stringify(this.root, (str, node2, type) => { +- this.css += str; +- if (node2 && type !== "end") { +- mapping.generated.line = line; +- mapping.generated.column = column - 1; +- if (node2.source && node2.source.start) { +- mapping.source = this.sourcePath(node2); +- mapping.original.line = node2.source.start.line; +- mapping.original.column = node2.source.start.column - 1; +- this.map.addMapping(mapping); +- } else { +- mapping.source = noSource; +- mapping.original.line = 1; +- mapping.original.column = 0; +- this.map.addMapping(mapping); +- } +- } +- lines = str.match(/\n/g); +- if (lines) { +- line += lines.length; +- last = str.lastIndexOf("\n"); +- column = str.length - last; +- } else { +- column += str.length; +- } +- if (node2 && type !== "start") { +- let p = node2.parent || { raws: {} }; +- let childless = node2.type === "decl" || node2.type === "atrule" && !node2.nodes; +- if (!childless || node2 !== p.last || p.raws.semicolon) { +- if (node2.source && node2.source.end) { +- mapping.source = this.sourcePath(node2); +- mapping.original.line = node2.source.end.line; +- mapping.original.column = node2.source.end.column - 1; +- mapping.generated.line = line; +- mapping.generated.column = column - 2; +- this.map.addMapping(mapping); +- } else { +- mapping.source = noSource; +- mapping.original.line = 1; +- mapping.original.column = 0; +- mapping.generated.line = line; +- mapping.generated.column = column - 1; +- this.map.addMapping(mapping); +- } +- } +- } +- }); +- } +- isAnnotation() { +- if (this.isInline()) { +- return true; +- } +- if (typeof this.mapOpts.annotation !== "undefined") { +- return this.mapOpts.annotation; +- } +- if (this.previous().length) { +- return this.previous().some((i2) => i2.annotation); +- } +- return true; +- } +- isInline() { +- if (typeof this.mapOpts.inline !== "undefined") { +- return this.mapOpts.inline; +- } +- let annotation = this.mapOpts.annotation; +- if (typeof annotation !== "undefined" && annotation !== true) { +- return false; +- } +- if (this.previous().length) { +- return this.previous().some((i2) => i2.inline); +- } +- return true; +- } +- isMap() { +- if (typeof this.opts.map !== "undefined") { +- return !!this.opts.map; +- } +- return this.previous().length > 0; +- } +- isSourcesContent() { +- if (typeof this.mapOpts.sourcesContent !== "undefined") { +- return this.mapOpts.sourcesContent; +- } +- if (this.previous().length) { +- return this.previous().some((i2) => i2.withContent()); +- } +- return true; +- } +- outputFile() { +- if (this.opts.to) { +- return this.path(this.opts.to); +- } else if (this.opts.from) { +- return this.path(this.opts.from); +- } else { +- return "to.css"; +- } +- } +- path(file) { +- if (this.mapOpts.absolute) return file; +- if (file.charCodeAt(0) === 60) return file; +- if (/^\w+:\/\//.test(file)) return file; +- let cached = this.memoizedPaths.get(file); +- if (cached) return cached; +- let from = this.opts.to ? dirname(this.opts.to) : "."; +- if (typeof this.mapOpts.annotation === "string") { +- from = dirname(resolve(from, this.mapOpts.annotation)); +- } +- let path = relative(from, file); +- this.memoizedPaths.set(file, path); +- return path; +- } +- previous() { +- if (!this.previousMaps) { +- this.previousMaps = []; +- if (this.root) { +- this.root.walk((node2) => { +- if (node2.source && node2.source.input.map) { +- let map = node2.source.input.map; +- if (!this.previousMaps.includes(map)) { +- this.previousMaps.push(map); +- } +- } +- }); +- } else { +- let input2 = new Input$3(this.originalCSS, this.opts); +- if (input2.map) this.previousMaps.push(input2.map); +- } +- } +- return this.previousMaps; +- } +- setSourcesContent() { +- let already = {}; +- if (this.root) { +- this.root.walk((node2) => { +- if (node2.source) { +- let from = node2.source.input.from; +- if (from && !already[from]) { +- already[from] = true; +- let fromUrl = this.usesFileUrls ? this.toFileUrl(from) : this.toUrl(this.path(from)); +- this.map.setSourceContent(fromUrl, node2.source.input.css); +- } +- } +- }); +- } else if (this.css) { +- let from = this.opts.from ? this.toUrl(this.path(this.opts.from)) : ""; +- this.map.setSourceContent(from, this.css); +- } +- } +- sourcePath(node2) { +- if (this.mapOpts.from) { +- return this.toUrl(this.mapOpts.from); +- } else if (this.usesFileUrls) { +- return this.toFileUrl(node2.source.input.from); +- } else { +- return this.toUrl(this.path(node2.source.input.from)); +- } +- } +- toBase64(str) { +- if (Buffer) { +- return Buffer.from(str).toString("base64"); +- } else { +- return window.btoa(unescape(encodeURIComponent(str))); +- } +- } +- toFileUrl(path) { +- let cached = this.memoizedFileURLs.get(path); +- if (cached) return cached; +- if (pathToFileURL) { +- let fileURL = pathToFileURL(path).toString(); +- this.memoizedFileURLs.set(path, fileURL); +- return fileURL; +- } else { +- throw new Error( +- "`map.absolute` option is not available in this PostCSS build" +- ); +- } +- } +- toUrl(path) { +- let cached = this.memoizedURLs.get(path); +- if (cached) return cached; +- if (sep === "\\") { +- path = path.replace(/\\/g, "/"); +- } +- let url = encodeURI(path).replace(/[#?]/g, encodeURIComponent); +- this.memoizedURLs.set(path, url); +- return url; +- } +-}; +-var mapGenerator = MapGenerator$2; +-let Node$2 = node; +-let Comment$4 = class Comment2 extends Node$2 { +- constructor(defaults) { +- super(defaults); +- this.type = "comment"; +- } +-}; +-var comment = Comment$4; +-Comment$4.default = Comment$4; +-let { isClean: isClean$1, my: my$1 } = symbols; +-let Declaration$3 = declaration; +-let Comment$3 = comment; +-let Node$1 = node; +-let parse$4, Rule$4, AtRule$4, Root$6; +-function cleanSource(nodes) { +- return nodes.map((i2) => { +- if (i2.nodes) i2.nodes = cleanSource(i2.nodes); +- delete i2.source; +- return i2; +- }); +-} +-function markDirtyUp(node2) { +- node2[isClean$1] = false; +- if (node2.proxyOf.nodes) { +- for (let i2 of node2.proxyOf.nodes) { +- markDirtyUp(i2); +- } +- } +-} +-let Container$7 = class Container2 extends Node$1 { +- append(...children) { +- for (let child of children) { +- let nodes = this.normalize(child, this.last); +- for (let node2 of nodes) this.proxyOf.nodes.push(node2); +- } +- this.markDirty(); +- return this; +- } +- cleanRaws(keepBetween) { +- super.cleanRaws(keepBetween); +- if (this.nodes) { +- for (let node2 of this.nodes) node2.cleanRaws(keepBetween); +- } +- } +- each(callback) { +- if (!this.proxyOf.nodes) return void 0; +- let iterator = this.getIterator(); +- let index2, result2; +- while (this.indexes[iterator] < this.proxyOf.nodes.length) { +- index2 = this.indexes[iterator]; +- result2 = callback(this.proxyOf.nodes[index2], index2); +- if (result2 === false) break; +- this.indexes[iterator] += 1; +- } +- delete this.indexes[iterator]; +- return result2; +- } +- every(condition) { +- return this.nodes.every(condition); +- } +- getIterator() { +- if (!this.lastEach) this.lastEach = 0; +- if (!this.indexes) this.indexes = {}; +- this.lastEach += 1; +- let iterator = this.lastEach; +- this.indexes[iterator] = 0; +- return iterator; +- } +- getProxyProcessor() { +- return { +- get(node2, prop) { +- if (prop === "proxyOf") { +- return node2; +- } else if (!node2[prop]) { +- return node2[prop]; +- } else if (prop === "each" || typeof prop === "string" && prop.startsWith("walk")) { +- return (...args) => { +- return node2[prop]( +- ...args.map((i2) => { +- if (typeof i2 === "function") { +- return (child, index2) => i2(child.toProxy(), index2); +- } else { +- return i2; +- } +- }) +- ); +- }; +- } else if (prop === "every" || prop === "some") { +- return (cb) => { +- return node2[prop]( +- (child, ...other) => cb(child.toProxy(), ...other) +- ); +- }; +- } else if (prop === "root") { +- return () => node2.root().toProxy(); +- } else if (prop === "nodes") { +- return node2.nodes.map((i2) => i2.toProxy()); +- } else if (prop === "first" || prop === "last") { +- return node2[prop].toProxy(); +- } else { +- return node2[prop]; +- } +- }, +- set(node2, prop, value) { +- if (node2[prop] === value) return true; +- node2[prop] = value; +- if (prop === "name" || prop === "params" || prop === "selector") { +- node2.markDirty(); +- } +- return true; +- } +- }; +- } +- index(child) { +- if (typeof child === "number") return child; +- if (child.proxyOf) child = child.proxyOf; +- return this.proxyOf.nodes.indexOf(child); +- } +- insertAfter(exist, add) { +- let existIndex = this.index(exist); +- let nodes = this.normalize(add, this.proxyOf.nodes[existIndex]).reverse(); +- existIndex = this.index(exist); +- for (let node2 of nodes) this.proxyOf.nodes.splice(existIndex + 1, 0, node2); +- let index2; +- for (let id in this.indexes) { +- index2 = this.indexes[id]; +- if (existIndex < index2) { +- this.indexes[id] = index2 + nodes.length; +- } +- } +- this.markDirty(); +- return this; +- } +- insertBefore(exist, add) { +- let existIndex = this.index(exist); +- let type = existIndex === 0 ? "prepend" : false; +- let nodes = this.normalize(add, this.proxyOf.nodes[existIndex], type).reverse(); +- existIndex = this.index(exist); +- for (let node2 of nodes) this.proxyOf.nodes.splice(existIndex, 0, node2); +- let index2; +- for (let id in this.indexes) { +- index2 = this.indexes[id]; +- if (existIndex <= index2) { +- this.indexes[id] = index2 + nodes.length; +- } +- } +- this.markDirty(); +- return this; +- } +- normalize(nodes, sample) { +- if (typeof nodes === "string") { +- nodes = cleanSource(parse$4(nodes).nodes); +- } else if (typeof nodes === "undefined") { +- nodes = []; +- } else if (Array.isArray(nodes)) { +- nodes = nodes.slice(0); +- for (let i2 of nodes) { +- if (i2.parent) i2.parent.removeChild(i2, "ignore"); +- } +- } else if (nodes.type === "root" && this.type !== "document") { +- nodes = nodes.nodes.slice(0); +- for (let i2 of nodes) { +- if (i2.parent) i2.parent.removeChild(i2, "ignore"); +- } +- } else if (nodes.type) { +- nodes = [nodes]; +- } else if (nodes.prop) { +- if (typeof nodes.value === "undefined") { +- throw new Error("Value field is missed in node creation"); +- } else if (typeof nodes.value !== "string") { +- nodes.value = String(nodes.value); +- } +- nodes = [new Declaration$3(nodes)]; +- } else if (nodes.selector) { +- nodes = [new Rule$4(nodes)]; +- } else if (nodes.name) { +- nodes = [new AtRule$4(nodes)]; +- } else if (nodes.text) { +- nodes = [new Comment$3(nodes)]; +- } else { +- throw new Error("Unknown node type in node creation"); +- } +- let processed = nodes.map((i2) => { +- if (!i2[my$1]) Container2.rebuild(i2); +- i2 = i2.proxyOf; +- if (i2.parent) i2.parent.removeChild(i2); +- if (i2[isClean$1]) markDirtyUp(i2); +- if (typeof i2.raws.before === "undefined") { +- if (sample && typeof sample.raws.before !== "undefined") { +- i2.raws.before = sample.raws.before.replace(/\S/g, ""); +- } +- } +- i2.parent = this.proxyOf; +- return i2; +- }); +- return processed; +- } +- prepend(...children) { +- children = children.reverse(); +- for (let child of children) { +- let nodes = this.normalize(child, this.first, "prepend").reverse(); +- for (let node2 of nodes) this.proxyOf.nodes.unshift(node2); +- for (let id in this.indexes) { +- this.indexes[id] = this.indexes[id] + nodes.length; +- } +- } +- this.markDirty(); +- return this; +- } +- push(child) { +- child.parent = this; +- this.proxyOf.nodes.push(child); +- return this; +- } +- removeAll() { +- for (let node2 of this.proxyOf.nodes) node2.parent = void 0; +- this.proxyOf.nodes = []; +- this.markDirty(); +- return this; +- } +- removeChild(child) { +- child = this.index(child); +- this.proxyOf.nodes[child].parent = void 0; +- this.proxyOf.nodes.splice(child, 1); +- let index2; +- for (let id in this.indexes) { +- index2 = this.indexes[id]; +- if (index2 >= child) { +- this.indexes[id] = index2 - 1; +- } +- } +- this.markDirty(); +- return this; +- } +- replaceValues(pattern, opts, callback) { +- if (!callback) { +- callback = opts; +- opts = {}; +- } +- this.walkDecls((decl) => { +- if (opts.props && !opts.props.includes(decl.prop)) return; +- if (opts.fast && !decl.value.includes(opts.fast)) return; +- decl.value = decl.value.replace(pattern, callback); +- }); +- this.markDirty(); +- return this; +- } +- some(condition) { +- return this.nodes.some(condition); +- } +- walk(callback) { +- return this.each((child, i2) => { +- let result2; +- try { +- result2 = callback(child, i2); +- } catch (e2) { +- throw child.addToError(e2); +- } +- if (result2 !== false && child.walk) { +- result2 = child.walk(callback); +- } +- return result2; +- }); +- } +- walkAtRules(name, callback) { +- if (!callback) { +- callback = name; +- return this.walk((child, i2) => { +- if (child.type === "atrule") { +- return callback(child, i2); +- } +- }); +- } +- if (name instanceof RegExp) { +- return this.walk((child, i2) => { +- if (child.type === "atrule" && name.test(child.name)) { +- return callback(child, i2); +- } +- }); +- } +- return this.walk((child, i2) => { +- if (child.type === "atrule" && child.name === name) { +- return callback(child, i2); +- } +- }); +- } +- walkComments(callback) { +- return this.walk((child, i2) => { +- if (child.type === "comment") { +- return callback(child, i2); +- } +- }); +- } +- walkDecls(prop, callback) { +- if (!callback) { +- callback = prop; +- return this.walk((child, i2) => { +- if (child.type === "decl") { +- return callback(child, i2); +- } +- }); +- } +- if (prop instanceof RegExp) { +- return this.walk((child, i2) => { +- if (child.type === "decl" && prop.test(child.prop)) { +- return callback(child, i2); +- } +- }); +- } +- return this.walk((child, i2) => { +- if (child.type === "decl" && child.prop === prop) { +- return callback(child, i2); +- } +- }); +- } +- walkRules(selector, callback) { +- if (!callback) { +- callback = selector; +- return this.walk((child, i2) => { +- if (child.type === "rule") { +- return callback(child, i2); +- } +- }); +- } +- if (selector instanceof RegExp) { +- return this.walk((child, i2) => { +- if (child.type === "rule" && selector.test(child.selector)) { +- return callback(child, i2); +- } +- }); +- } +- return this.walk((child, i2) => { +- if (child.type === "rule" && child.selector === selector) { +- return callback(child, i2); +- } +- }); +- } +- get first() { +- if (!this.proxyOf.nodes) return void 0; +- return this.proxyOf.nodes[0]; +- } +- get last() { +- if (!this.proxyOf.nodes) return void 0; +- return this.proxyOf.nodes[this.proxyOf.nodes.length - 1]; +- } +-}; +-Container$7.registerParse = (dependant) => { +- parse$4 = dependant; +-}; +-Container$7.registerRule = (dependant) => { +- Rule$4 = dependant; +-}; +-Container$7.registerAtRule = (dependant) => { +- AtRule$4 = dependant; +-}; +-Container$7.registerRoot = (dependant) => { +- Root$6 = dependant; +-}; +-var container = Container$7; +-Container$7.default = Container$7; +-Container$7.rebuild = (node2) => { +- if (node2.type === "atrule") { +- Object.setPrototypeOf(node2, AtRule$4.prototype); +- } else if (node2.type === "rule") { +- Object.setPrototypeOf(node2, Rule$4.prototype); +- } else if (node2.type === "decl") { +- Object.setPrototypeOf(node2, Declaration$3.prototype); +- } else if (node2.type === "comment") { +- Object.setPrototypeOf(node2, Comment$3.prototype); +- } else if (node2.type === "root") { +- Object.setPrototypeOf(node2, Root$6.prototype); +- } +- node2[my$1] = true; +- if (node2.nodes) { +- node2.nodes.forEach((child) => { +- Container$7.rebuild(child); +- }); +- } +-}; +-let Container$6 = container; +-let LazyResult$4, Processor$3; +-let Document$3 = class Document23 extends Container$6 { +- constructor(defaults) { +- super({ type: "document", ...defaults }); +- if (!this.nodes) { +- this.nodes = []; +- } +- } +- toResult(opts = {}) { +- let lazy = new LazyResult$4(new Processor$3(), this, opts); +- return lazy.stringify(); +- } +-}; +-Document$3.registerLazyResult = (dependant) => { +- LazyResult$4 = dependant; +-}; +-Document$3.registerProcessor = (dependant) => { +- Processor$3 = dependant; +-}; +-var document$1 = Document$3; +-Document$3.default = Document$3; +-let printed = {}; +-var warnOnce$2 = function warnOnce2(message) { +- if (printed[message]) return; +- printed[message] = true; +- if (typeof console !== "undefined" && console.warn) { +- console.warn(message); +- } +-}; +-let Warning$2 = class Warning2 { +- constructor(text, opts = {}) { +- this.type = "warning"; +- this.text = text; +- if (opts.node && opts.node.source) { +- let range = opts.node.rangeBy(opts); +- this.line = range.start.line; +- this.column = range.start.column; +- this.endLine = range.end.line; +- this.endColumn = range.end.column; +- } +- for (let opt in opts) this[opt] = opts[opt]; +- } +- toString() { +- if (this.node) { +- return this.node.error(this.text, { +- index: this.index, +- plugin: this.plugin, +- word: this.word +- }).message; +- } +- if (this.plugin) { +- return this.plugin + ": " + this.text; +- } +- return this.text; +- } +-}; +-var warning = Warning$2; +-Warning$2.default = Warning$2; +-let Warning$1 = warning; +-let Result$3 = class Result2 { +- constructor(processor2, root2, opts) { +- this.processor = processor2; +- this.messages = []; +- this.root = root2; +- this.opts = opts; +- this.css = void 0; +- this.map = void 0; +- } +- toString() { +- return this.css; +- } +- warn(text, opts = {}) { +- if (!opts.plugin) { +- if (this.lastPlugin && this.lastPlugin.postcssPlugin) { +- opts.plugin = this.lastPlugin.postcssPlugin; +- } +- } +- let warning2 = new Warning$1(text, opts); +- this.messages.push(warning2); +- return warning2; +- } +- warnings() { +- return this.messages.filter((i2) => i2.type === "warning"); +- } +- get content() { +- return this.css; +- } +-}; +-var result = Result$3; +-Result$3.default = Result$3; +-const SINGLE_QUOTE = "'".charCodeAt(0); +-const DOUBLE_QUOTE = '"'.charCodeAt(0); +-const BACKSLASH = "\\".charCodeAt(0); +-const SLASH = "/".charCodeAt(0); +-const NEWLINE = "\n".charCodeAt(0); +-const SPACE = " ".charCodeAt(0); +-const FEED = "\f".charCodeAt(0); +-const TAB = " ".charCodeAt(0); +-const CR = "\r".charCodeAt(0); +-const OPEN_SQUARE = "[".charCodeAt(0); +-const CLOSE_SQUARE = "]".charCodeAt(0); +-const OPEN_PARENTHESES = "(".charCodeAt(0); +-const CLOSE_PARENTHESES = ")".charCodeAt(0); +-const OPEN_CURLY = "{".charCodeAt(0); +-const CLOSE_CURLY = "}".charCodeAt(0); +-const SEMICOLON = ";".charCodeAt(0); +-const ASTERISK = "*".charCodeAt(0); +-const COLON = ":".charCodeAt(0); +-const AT = "@".charCodeAt(0); +-const RE_AT_END = /[\t\n\f\r "#'()/;[\\\]{}]/g; +-const RE_WORD_END = /[\t\n\f\r !"#'():;@[\\\]{}]|\/(?=\*)/g; +-const RE_BAD_BRACKET = /.[\r\n"'(/\\]/; +-const RE_HEX_ESCAPE = /[\da-f]/i; +-var tokenize = function tokenizer2(input2, options = {}) { +- let css = input2.css.valueOf(); +- let ignore = options.ignoreErrors; +- let code, next, quote, content, escape; +- let escaped, escapePos, prev, n2, currentToken; +- let length = css.length; +- let pos = 0; +- let buffer = []; +- let returned = []; +- function position() { +- return pos; +- } +- function unclosed(what) { +- throw input2.error("Unclosed " + what, pos); +- } +- function endOfFile() { +- return returned.length === 0 && pos >= length; +- } +- function nextToken(opts) { +- if (returned.length) return returned.pop(); +- if (pos >= length) return; +- let ignoreUnclosed = opts ? opts.ignoreUnclosed : false; +- code = css.charCodeAt(pos); +- switch (code) { +- case NEWLINE: +- case SPACE: +- case TAB: +- case CR: +- case FEED: { +- next = pos; +- do { +- next += 1; +- code = css.charCodeAt(next); +- } while (code === SPACE || code === NEWLINE || code === TAB || code === CR || code === FEED); +- currentToken = ["space", css.slice(pos, next)]; +- pos = next - 1; +- break; +- } +- case OPEN_SQUARE: +- case CLOSE_SQUARE: +- case OPEN_CURLY: +- case CLOSE_CURLY: +- case COLON: +- case SEMICOLON: +- case CLOSE_PARENTHESES: { +- let controlChar = String.fromCharCode(code); +- currentToken = [controlChar, controlChar, pos]; +- break; +- } +- case OPEN_PARENTHESES: { +- prev = buffer.length ? buffer.pop()[1] : ""; +- n2 = css.charCodeAt(pos + 1); +- if (prev === "url" && n2 !== SINGLE_QUOTE && n2 !== DOUBLE_QUOTE && n2 !== SPACE && n2 !== NEWLINE && n2 !== TAB && n2 !== FEED && n2 !== CR) { +- next = pos; +- do { +- escaped = false; +- next = css.indexOf(")", next + 1); +- if (next === -1) { +- if (ignore || ignoreUnclosed) { +- next = pos; +- break; +- } else { +- unclosed("bracket"); +- } +- } +- escapePos = next; +- while (css.charCodeAt(escapePos - 1) === BACKSLASH) { +- escapePos -= 1; +- escaped = !escaped; +- } +- } while (escaped); +- currentToken = ["brackets", css.slice(pos, next + 1), pos, next]; +- pos = next; +- } else { +- next = css.indexOf(")", pos + 1); +- content = css.slice(pos, next + 1); +- if (next === -1 || RE_BAD_BRACKET.test(content)) { +- currentToken = ["(", "(", pos]; +- } else { +- currentToken = ["brackets", content, pos, next]; +- pos = next; +- } +- } +- break; +- } +- case SINGLE_QUOTE: +- case DOUBLE_QUOTE: { +- quote = code === SINGLE_QUOTE ? "'" : '"'; +- next = pos; +- do { +- escaped = false; +- next = css.indexOf(quote, next + 1); +- if (next === -1) { +- if (ignore || ignoreUnclosed) { +- next = pos + 1; +- break; +- } else { +- unclosed("string"); +- } +- } +- escapePos = next; +- while (css.charCodeAt(escapePos - 1) === BACKSLASH) { +- escapePos -= 1; +- escaped = !escaped; +- } +- } while (escaped); +- currentToken = ["string", css.slice(pos, next + 1), pos, next]; +- pos = next; +- break; +- } +- case AT: { +- RE_AT_END.lastIndex = pos + 1; +- RE_AT_END.test(css); +- if (RE_AT_END.lastIndex === 0) { +- next = css.length - 1; +- } else { +- next = RE_AT_END.lastIndex - 2; +- } +- currentToken = ["at-word", css.slice(pos, next + 1), pos, next]; +- pos = next; +- break; +- } +- case BACKSLASH: { +- next = pos; +- escape = true; +- while (css.charCodeAt(next + 1) === BACKSLASH) { +- next += 1; +- escape = !escape; +- } +- code = css.charCodeAt(next + 1); +- if (escape && code !== SLASH && code !== SPACE && code !== NEWLINE && code !== TAB && code !== CR && code !== FEED) { +- next += 1; +- if (RE_HEX_ESCAPE.test(css.charAt(next))) { +- while (RE_HEX_ESCAPE.test(css.charAt(next + 1))) { +- next += 1; +- } +- if (css.charCodeAt(next + 1) === SPACE) { +- next += 1; +- } +- } +- } +- currentToken = ["word", css.slice(pos, next + 1), pos, next]; +- pos = next; +- break; +- } +- default: { +- if (code === SLASH && css.charCodeAt(pos + 1) === ASTERISK) { +- next = css.indexOf("*/", pos + 2) + 1; +- if (next === 0) { +- if (ignore || ignoreUnclosed) { +- next = css.length; +- } else { +- unclosed("comment"); +- } +- } +- currentToken = ["comment", css.slice(pos, next + 1), pos, next]; +- pos = next; +- } else { +- RE_WORD_END.lastIndex = pos + 1; +- RE_WORD_END.test(css); +- if (RE_WORD_END.lastIndex === 0) { +- next = css.length - 1; +- } else { +- next = RE_WORD_END.lastIndex - 2; +- } +- currentToken = ["word", css.slice(pos, next + 1), pos, next]; +- buffer.push(currentToken); +- pos = next; +- } +- break; +- } +- } +- pos++; +- return currentToken; +- } +- function back(token) { +- returned.push(token); +- } +- return { +- back, +- endOfFile, +- nextToken, +- position +- }; +-}; +-let Container$5 = container; +-let AtRule$3 = class AtRule2 extends Container$5 { +- constructor(defaults) { +- super(defaults); +- this.type = "atrule"; +- } +- append(...children) { +- if (!this.proxyOf.nodes) this.nodes = []; +- return super.append(...children); +- } +- prepend(...children) { +- if (!this.proxyOf.nodes) this.nodes = []; +- return super.prepend(...children); +- } +-}; +-var atRule = AtRule$3; +-AtRule$3.default = AtRule$3; +-Container$5.registerAtRule(AtRule$3); +-let Container$4 = container; +-let LazyResult$3, Processor$2; +-let Root$5 = class Root2 extends Container$4 { +- constructor(defaults) { +- super(defaults); +- this.type = "root"; +- if (!this.nodes) this.nodes = []; +- } +- normalize(child, sample, type) { +- let nodes = super.normalize(child); +- if (sample) { +- if (type === "prepend") { +- if (this.nodes.length > 1) { +- sample.raws.before = this.nodes[1].raws.before; +- } else { +- delete sample.raws.before; +- } +- } else if (this.first !== sample) { +- for (let node2 of nodes) { +- node2.raws.before = sample.raws.before; +- } +- } +- } +- return nodes; +- } +- removeChild(child, ignore) { +- let index2 = this.index(child); +- if (!ignore && index2 === 0 && this.nodes.length > 1) { +- this.nodes[1].raws.before = this.nodes[index2].raws.before; +- } +- return super.removeChild(child); +- } +- toResult(opts = {}) { +- let lazy = new LazyResult$3(new Processor$2(), this, opts); +- return lazy.stringify(); +- } +-}; +-Root$5.registerLazyResult = (dependant) => { +- LazyResult$3 = dependant; +-}; +-Root$5.registerProcessor = (dependant) => { +- Processor$2 = dependant; +-}; +-var root = Root$5; +-Root$5.default = Root$5; +-Container$4.registerRoot(Root$5); +-let list$2 = { +- comma(string) { +- return list$2.split(string, [","], true); +- }, +- space(string) { +- let spaces = [" ", "\n", " "]; +- return list$2.split(string, spaces); +- }, +- split(string, separators, last) { +- let array = []; +- let current = ""; +- let split = false; +- let func = 0; +- let inQuote = false; +- let prevQuote = ""; +- let escape = false; +- for (let letter of string) { +- if (escape) { +- escape = false; +- } else if (letter === "\\") { +- escape = true; +- } else if (inQuote) { +- if (letter === prevQuote) { +- inQuote = false; +- } +- } else if (letter === '"' || letter === "'") { +- inQuote = true; +- prevQuote = letter; +- } else if (letter === "(") { +- func += 1; +- } else if (letter === ")") { +- if (func > 0) func -= 1; +- } else if (func === 0) { +- if (separators.includes(letter)) split = true; +- } +- if (split) { +- if (current !== "") array.push(current.trim()); +- current = ""; +- split = false; +- } else { +- current += letter; +- } +- } +- if (last || current !== "") array.push(current.trim()); +- return array; +- } +-}; +-var list_1 = list$2; +-list$2.default = list$2; +-let Container$3 = container; +-let list$1 = list_1; +-let Rule$3 = class Rule2 extends Container$3 { +- constructor(defaults) { +- super(defaults); +- this.type = "rule"; +- if (!this.nodes) this.nodes = []; +- } +- get selectors() { +- return list$1.comma(this.selector); +- } +- set selectors(values) { +- let match = this.selector ? this.selector.match(/,\s*/) : null; +- let sep2 = match ? match[0] : "," + this.raw("between", "beforeOpen"); +- this.selector = values.join(sep2); +- } +-}; +-var rule = Rule$3; +-Rule$3.default = Rule$3; +-Container$3.registerRule(Rule$3); +-let Declaration$2 = declaration; +-let tokenizer22 = tokenize; +-let Comment$2 = comment; +-let AtRule$2 = atRule; +-let Root$4 = root; +-let Rule$2 = rule; +-const SAFE_COMMENT_NEIGHBOR = { +- empty: true, +- space: true +-}; +-function findLastWithPosition(tokens) { +- for (let i2 = tokens.length - 1; i2 >= 0; i2--) { +- let token = tokens[i2]; +- let pos = token[3] || token[2]; +- if (pos) return pos; +- } +-} +-let Parser$1 = class Parser2 { +- constructor(input2) { +- this.input = input2; +- this.root = new Root$4(); +- this.current = this.root; +- this.spaces = ""; +- this.semicolon = false; +- this.createTokenizer(); +- this.root.source = { input: input2, start: { column: 1, line: 1, offset: 0 } }; +- } +- atrule(token) { +- let node2 = new AtRule$2(); +- node2.name = token[1].slice(1); +- if (node2.name === "") { +- this.unnamedAtrule(node2, token); +- } +- this.init(node2, token[2]); +- let type; +- let prev; +- let shift; +- let last = false; +- let open = false; +- let params = []; +- let brackets = []; +- while (!this.tokenizer.endOfFile()) { +- token = this.tokenizer.nextToken(); +- type = token[0]; +- if (type === "(" || type === "[") { +- brackets.push(type === "(" ? ")" : "]"); +- } else if (type === "{" && brackets.length > 0) { +- brackets.push("}"); +- } else if (type === brackets[brackets.length - 1]) { +- brackets.pop(); +- } +- if (brackets.length === 0) { +- if (type === ";") { +- node2.source.end = this.getPosition(token[2]); +- node2.source.end.offset++; +- this.semicolon = true; +- break; +- } else if (type === "{") { +- open = true; +- break; +- } else if (type === "}") { +- if (params.length > 0) { +- shift = params.length - 1; +- prev = params[shift]; +- while (prev && prev[0] === "space") { +- prev = params[--shift]; +- } +- if (prev) { +- node2.source.end = this.getPosition(prev[3] || prev[2]); +- node2.source.end.offset++; +- } +- } +- this.end(token); +- break; +- } else { +- params.push(token); +- } +- } else { +- params.push(token); +- } +- if (this.tokenizer.endOfFile()) { +- last = true; +- break; +- } +- } +- node2.raws.between = this.spacesAndCommentsFromEnd(params); +- if (params.length) { +- node2.raws.afterName = this.spacesAndCommentsFromStart(params); +- this.raw(node2, "params", params); +- if (last) { +- token = params[params.length - 1]; +- node2.source.end = this.getPosition(token[3] || token[2]); +- node2.source.end.offset++; +- this.spaces = node2.raws.between; +- node2.raws.between = ""; +- } +- } else { +- node2.raws.afterName = ""; +- node2.params = ""; +- } +- if (open) { +- node2.nodes = []; +- this.current = node2; +- } +- } +- checkMissedSemicolon(tokens) { +- let colon = this.colon(tokens); +- if (colon === false) return; +- let founded = 0; +- let token; +- for (let j = colon - 1; j >= 0; j--) { +- token = tokens[j]; +- if (token[0] !== "space") { +- founded += 1; +- if (founded === 2) break; +- } +- } +- throw this.input.error( +- "Missed semicolon", +- token[0] === "word" ? token[3] + 1 : token[2] +- ); +- } +- colon(tokens) { +- let brackets = 0; +- let token, type, prev; +- for (let [i2, element] of tokens.entries()) { +- token = element; +- type = token[0]; +- if (type === "(") { +- brackets += 1; +- } +- if (type === ")") { +- brackets -= 1; +- } +- if (brackets === 0 && type === ":") { +- if (!prev) { +- this.doubleColon(token); +- } else if (prev[0] === "word" && prev[1] === "progid") { +- continue; +- } else { +- return i2; +- } +- } +- prev = token; +- } +- return false; +- } +- comment(token) { +- let node2 = new Comment$2(); +- this.init(node2, token[2]); +- node2.source.end = this.getPosition(token[3] || token[2]); +- node2.source.end.offset++; +- let text = token[1].slice(2, -2); +- if (/^\s*$/.test(text)) { +- node2.text = ""; +- node2.raws.left = text; +- node2.raws.right = ""; +- } else { +- let match = text.match(/^(\s*)([^]*\S)(\s*)$/); +- node2.text = match[2]; +- node2.raws.left = match[1]; +- node2.raws.right = match[3]; +- } +- } +- createTokenizer() { +- this.tokenizer = tokenizer22(this.input); +- } +- decl(tokens, customProperty) { +- let node2 = new Declaration$2(); +- this.init(node2, tokens[0][2]); +- let last = tokens[tokens.length - 1]; +- if (last[0] === ";") { +- this.semicolon = true; +- tokens.pop(); +- } +- node2.source.end = this.getPosition( +- last[3] || last[2] || findLastWithPosition(tokens) +- ); +- node2.source.end.offset++; +- while (tokens[0][0] !== "word") { +- if (tokens.length === 1) this.unknownWord(tokens); +- node2.raws.before += tokens.shift()[1]; +- } +- node2.source.start = this.getPosition(tokens[0][2]); +- node2.prop = ""; +- while (tokens.length) { +- let type = tokens[0][0]; +- if (type === ":" || type === "space" || type === "comment") { +- break; +- } +- node2.prop += tokens.shift()[1]; +- } +- node2.raws.between = ""; +- let token; +- while (tokens.length) { +- token = tokens.shift(); +- if (token[0] === ":") { +- node2.raws.between += token[1]; +- break; +- } else { +- if (token[0] === "word" && /\w/.test(token[1])) { +- this.unknownWord([token]); +- } +- node2.raws.between += token[1]; +- } +- } +- if (node2.prop[0] === "_" || node2.prop[0] === "*") { +- node2.raws.before += node2.prop[0]; +- node2.prop = node2.prop.slice(1); +- } +- let firstSpaces = []; +- let next; +- while (tokens.length) { +- next = tokens[0][0]; +- if (next !== "space" && next !== "comment") break; +- firstSpaces.push(tokens.shift()); +- } +- this.precheckMissedSemicolon(tokens); +- for (let i2 = tokens.length - 1; i2 >= 0; i2--) { +- token = tokens[i2]; +- if (token[1].toLowerCase() === "!important") { +- node2.important = true; +- let string = this.stringFrom(tokens, i2); +- string = this.spacesFromEnd(tokens) + string; +- if (string !== " !important") node2.raws.important = string; +- break; +- } else if (token[1].toLowerCase() === "important") { +- let cache = tokens.slice(0); +- let str = ""; +- for (let j = i2; j > 0; j--) { +- let type = cache[j][0]; +- if (str.trim().indexOf("!") === 0 && type !== "space") { +- break; +- } +- str = cache.pop()[1] + str; +- } +- if (str.trim().indexOf("!") === 0) { +- node2.important = true; +- node2.raws.important = str; +- tokens = cache; +- } +- } +- if (token[0] !== "space" && token[0] !== "comment") { +- break; +- } +- } +- let hasWord = tokens.some((i2) => i2[0] !== "space" && i2[0] !== "comment"); +- if (hasWord) { +- node2.raws.between += firstSpaces.map((i2) => i2[1]).join(""); +- firstSpaces = []; +- } +- this.raw(node2, "value", firstSpaces.concat(tokens), customProperty); +- if (node2.value.includes(":") && !customProperty) { +- this.checkMissedSemicolon(tokens); +- } +- } +- doubleColon(token) { +- throw this.input.error( +- "Double colon", +- { offset: token[2] }, +- { offset: token[2] + token[1].length } +- ); +- } +- emptyRule(token) { +- let node2 = new Rule$2(); +- this.init(node2, token[2]); +- node2.selector = ""; +- node2.raws.between = ""; +- this.current = node2; +- } +- end(token) { +- if (this.current.nodes && this.current.nodes.length) { +- this.current.raws.semicolon = this.semicolon; +- } +- this.semicolon = false; +- this.current.raws.after = (this.current.raws.after || "") + this.spaces; +- this.spaces = ""; +- if (this.current.parent) { +- this.current.source.end = this.getPosition(token[2]); +- this.current.source.end.offset++; +- this.current = this.current.parent; +- } else { +- this.unexpectedClose(token); +- } +- } +- endFile() { +- if (this.current.parent) this.unclosedBlock(); +- if (this.current.nodes && this.current.nodes.length) { +- this.current.raws.semicolon = this.semicolon; +- } +- this.current.raws.after = (this.current.raws.after || "") + this.spaces; +- this.root.source.end = this.getPosition(this.tokenizer.position()); +- } +- freeSemicolon(token) { +- this.spaces += token[1]; +- if (this.current.nodes) { +- let prev = this.current.nodes[this.current.nodes.length - 1]; +- if (prev && prev.type === "rule" && !prev.raws.ownSemicolon) { +- prev.raws.ownSemicolon = this.spaces; +- this.spaces = ""; +- } +- } +- } +- // Helpers +- getPosition(offset) { +- let pos = this.input.fromOffset(offset); +- return { +- column: pos.col, +- line: pos.line, +- offset +- }; +- } +- init(node2, offset) { +- this.current.push(node2); +- node2.source = { +- input: this.input, +- start: this.getPosition(offset) +- }; +- node2.raws.before = this.spaces; +- this.spaces = ""; +- if (node2.type !== "comment") this.semicolon = false; +- } +- other(start) { +- let end = false; +- let type = null; +- let colon = false; +- let bracket = null; +- let brackets = []; +- let customProperty = start[1].startsWith("--"); +- let tokens = []; +- let token = start; +- while (token) { +- type = token[0]; +- tokens.push(token); +- if (type === "(" || type === "[") { +- if (!bracket) bracket = token; +- brackets.push(type === "(" ? ")" : "]"); +- } else if (customProperty && colon && type === "{") { +- if (!bracket) bracket = token; +- brackets.push("}"); +- } else if (brackets.length === 0) { +- if (type === ";") { +- if (colon) { +- this.decl(tokens, customProperty); +- return; +- } else { +- break; +- } +- } else if (type === "{") { +- this.rule(tokens); +- return; +- } else if (type === "}") { +- this.tokenizer.back(tokens.pop()); +- end = true; +- break; +- } else if (type === ":") { +- colon = true; +- } +- } else if (type === brackets[brackets.length - 1]) { +- brackets.pop(); +- if (brackets.length === 0) bracket = null; +- } +- token = this.tokenizer.nextToken(); +- } +- if (this.tokenizer.endOfFile()) end = true; +- if (brackets.length > 0) this.unclosedBracket(bracket); +- if (end && colon) { +- if (!customProperty) { +- while (tokens.length) { +- token = tokens[tokens.length - 1][0]; +- if (token !== "space" && token !== "comment") break; +- this.tokenizer.back(tokens.pop()); +- } +- } +- this.decl(tokens, customProperty); +- } else { +- this.unknownWord(tokens); +- } +- } +- parse() { +- let token; +- while (!this.tokenizer.endOfFile()) { +- token = this.tokenizer.nextToken(); +- switch (token[0]) { +- case "space": +- this.spaces += token[1]; +- break; +- case ";": +- this.freeSemicolon(token); +- break; +- case "}": +- this.end(token); +- break; +- case "comment": +- this.comment(token); +- break; +- case "at-word": +- this.atrule(token); +- break; +- case "{": +- this.emptyRule(token); +- break; +- default: +- this.other(token); +- break; +- } +- } +- this.endFile(); +- } +- precheckMissedSemicolon() { +- } +- raw(node2, prop, tokens, customProperty) { +- let token, type; +- let length = tokens.length; +- let value = ""; +- let clean = true; +- let next, prev; +- for (let i2 = 0; i2 < length; i2 += 1) { +- token = tokens[i2]; +- type = token[0]; +- if (type === "space" && i2 === length - 1 && !customProperty) { +- clean = false; +- } else if (type === "comment") { +- prev = tokens[i2 - 1] ? tokens[i2 - 1][0] : "empty"; +- next = tokens[i2 + 1] ? tokens[i2 + 1][0] : "empty"; +- if (!SAFE_COMMENT_NEIGHBOR[prev] && !SAFE_COMMENT_NEIGHBOR[next]) { +- if (value.slice(-1) === ",") { +- clean = false; +- } else { +- value += token[1]; +- } +- } else { +- clean = false; +- } +- } else { +- value += token[1]; +- } +- } +- if (!clean) { +- let raw = tokens.reduce((all, i2) => all + i2[1], ""); +- node2.raws[prop] = { raw, value }; +- } +- node2[prop] = value; +- } +- rule(tokens) { +- tokens.pop(); +- let node2 = new Rule$2(); +- this.init(node2, tokens[0][2]); +- node2.raws.between = this.spacesAndCommentsFromEnd(tokens); +- this.raw(node2, "selector", tokens); +- this.current = node2; +- } +- spacesAndCommentsFromEnd(tokens) { +- let lastTokenType; +- let spaces = ""; +- while (tokens.length) { +- lastTokenType = tokens[tokens.length - 1][0]; +- if (lastTokenType !== "space" && lastTokenType !== "comment") break; +- spaces = tokens.pop()[1] + spaces; +- } +- return spaces; +- } +- // Errors +- spacesAndCommentsFromStart(tokens) { +- let next; +- let spaces = ""; +- while (tokens.length) { +- next = tokens[0][0]; +- if (next !== "space" && next !== "comment") break; +- spaces += tokens.shift()[1]; +- } +- return spaces; +- } +- spacesFromEnd(tokens) { +- let lastTokenType; +- let spaces = ""; +- while (tokens.length) { +- lastTokenType = tokens[tokens.length - 1][0]; +- if (lastTokenType !== "space") break; +- spaces = tokens.pop()[1] + spaces; +- } +- return spaces; +- } +- stringFrom(tokens, from) { +- let result2 = ""; +- for (let i2 = from; i2 < tokens.length; i2++) { +- result2 += tokens[i2][1]; +- } +- tokens.splice(from, tokens.length - from); +- return result2; +- } +- unclosedBlock() { +- let pos = this.current.source.start; +- throw this.input.error("Unclosed block", pos.line, pos.column); +- } +- unclosedBracket(bracket) { +- throw this.input.error( +- "Unclosed bracket", +- { offset: bracket[2] }, +- { offset: bracket[2] + 1 } +- ); +- } +- unexpectedClose(token) { +- throw this.input.error( +- "Unexpected }", +- { offset: token[2] }, +- { offset: token[2] + 1 } +- ); +- } +- unknownWord(tokens) { +- throw this.input.error( +- "Unknown word", +- { offset: tokens[0][2] }, +- { offset: tokens[0][2] + tokens[0][1].length } +- ); +- } +- unnamedAtrule(node2, token) { +- throw this.input.error( +- "At-rule without name", +- { offset: token[2] }, +- { offset: token[2] + token[1].length } +- ); +- } +-}; +-var parser = Parser$1; +-let Container$2 = container; +-let Parser22 = parser; +-let Input$2 = input; +-function parse$3(css, opts) { +- let input2 = new Input$2(css, opts); +- let parser2 = new Parser22(input2); +- try { +- parser2.parse(); +- } catch (e2) { +- if (process.env.NODE_ENV !== "production") { +- if (e2.name === "CssSyntaxError" && opts && opts.from) { +- if (/\.scss$/i.test(opts.from)) { +- e2.message += "\nYou tried to parse SCSS with the standard CSS parser; try again with the postcss-scss parser"; +- } else if (/\.sass/i.test(opts.from)) { +- e2.message += "\nYou tried to parse Sass with the standard CSS parser; try again with the postcss-sass parser"; +- } else if (/\.less$/i.test(opts.from)) { +- e2.message += "\nYou tried to parse Less with the standard CSS parser; try again with the postcss-less parser"; +- } +- } +- } +- throw e2; +- } +- return parser2.root; +-} +-var parse_1 = parse$3; +-parse$3.default = parse$3; +-Container$2.registerParse(parse$3); +-let { isClean, my } = symbols; +-let MapGenerator$1 = mapGenerator; +-let stringify$2 = stringify_1; +-let Container$1 = container; +-let Document$2 = document$1; +-let warnOnce$1 = warnOnce$2; +-let Result$2 = result; +-let parse$2 = parse_1; +-let Root$3 = root; +-const TYPE_TO_CLASS_NAME = { +- atrule: "AtRule", +- comment: "Comment", +- decl: "Declaration", +- document: "Document", +- root: "Root", +- rule: "Rule" +-}; +-const PLUGIN_PROPS = { +- AtRule: true, +- AtRuleExit: true, +- Comment: true, +- CommentExit: true, +- Declaration: true, +- DeclarationExit: true, +- Document: true, +- DocumentExit: true, +- Once: true, +- OnceExit: true, +- postcssPlugin: true, +- prepare: true, +- Root: true, +- RootExit: true, +- Rule: true, +- RuleExit: true +-}; +-const NOT_VISITORS = { +- Once: true, +- postcssPlugin: true, +- prepare: true +-}; +-const CHILDREN = 0; +-function isPromise(obj) { +- return typeof obj === "object" && typeof obj.then === "function"; +-} +-function getEvents(node2) { +- let key = false; +- let type = TYPE_TO_CLASS_NAME[node2.type]; +- if (node2.type === "decl") { +- key = node2.prop.toLowerCase(); +- } else if (node2.type === "atrule") { +- key = node2.name.toLowerCase(); +- } +- if (key && node2.append) { +- return [ +- type, +- type + "-" + key, +- CHILDREN, +- type + "Exit", +- type + "Exit-" + key +- ]; +- } else if (key) { +- return [type, type + "-" + key, type + "Exit", type + "Exit-" + key]; +- } else if (node2.append) { +- return [type, CHILDREN, type + "Exit"]; +- } else { +- return [type, type + "Exit"]; +- } +-} +-function toStack(node2) { +- let events; +- if (node2.type === "document") { +- events = ["Document", CHILDREN, "DocumentExit"]; +- } else if (node2.type === "root") { +- events = ["Root", CHILDREN, "RootExit"]; +- } else { +- events = getEvents(node2); +- } +- return { +- eventIndex: 0, +- events, +- iterator: 0, +- node: node2, +- visitorIndex: 0, +- visitors: [] +- }; +-} +-function cleanMarks(node2) { +- node2[isClean] = false; +- if (node2.nodes) node2.nodes.forEach((i2) => cleanMarks(i2)); +- return node2; +-} +-let postcss$2 = {}; +-let LazyResult$2 = class LazyResult2 { +- constructor(processor2, css, opts) { +- this.stringified = false; +- this.processed = false; +- let root2; +- if (typeof css === "object" && css !== null && (css.type === "root" || css.type === "document")) { +- root2 = cleanMarks(css); +- } else if (css instanceof LazyResult2 || css instanceof Result$2) { +- root2 = cleanMarks(css.root); +- if (css.map) { +- if (typeof opts.map === "undefined") opts.map = {}; +- if (!opts.map.inline) opts.map.inline = false; +- opts.map.prev = css.map; +- } +- } else { +- let parser2 = parse$2; +- if (opts.syntax) parser2 = opts.syntax.parse; +- if (opts.parser) parser2 = opts.parser; +- if (parser2.parse) parser2 = parser2.parse; +- try { +- root2 = parser2(css, opts); +- } catch (error) { +- this.processed = true; +- this.error = error; +- } +- if (root2 && !root2[my]) { +- Container$1.rebuild(root2); +- } +- } +- this.result = new Result$2(processor2, root2, opts); +- this.helpers = { ...postcss$2, postcss: postcss$2, result: this.result }; +- this.plugins = this.processor.plugins.map((plugin22) => { +- if (typeof plugin22 === "object" && plugin22.prepare) { +- return { ...plugin22, ...plugin22.prepare(this.result) }; +- } else { +- return plugin22; +- } +- }); +- } +- async() { +- if (this.error) return Promise.reject(this.error); +- if (this.processed) return Promise.resolve(this.result); +- if (!this.processing) { +- this.processing = this.runAsync(); +- } +- return this.processing; +- } +- catch(onRejected) { +- return this.async().catch(onRejected); +- } +- finally(onFinally) { +- return this.async().then(onFinally, onFinally); +- } +- getAsyncError() { +- throw new Error("Use process(css).then(cb) to work with async plugins"); +- } +- handleError(error, node2) { +- let plugin22 = this.result.lastPlugin; +- try { +- if (node2) node2.addToError(error); +- this.error = error; +- if (error.name === "CssSyntaxError" && !error.plugin) { +- error.plugin = plugin22.postcssPlugin; +- error.setMessage(); +- } else if (plugin22.postcssVersion) { +- if (process.env.NODE_ENV !== "production") { +- let pluginName = plugin22.postcssPlugin; +- let pluginVer = plugin22.postcssVersion; +- let runtimeVer = this.result.processor.version; +- let a2 = pluginVer.split("."); +- let b = runtimeVer.split("."); +- if (a2[0] !== b[0] || parseInt(a2[1]) > parseInt(b[1])) { +- console.error( +- "Unknown error from PostCSS plugin. Your current PostCSS version is " + runtimeVer + ", but " + pluginName + " uses " + pluginVer + ". Perhaps this is the source of the error below." +- ); +- } +- } +- } +- } catch (err) { +- if (console && console.error) console.error(err); +- } +- return error; +- } +- prepareVisitors() { +- this.listeners = {}; +- let add = (plugin22, type, cb) => { +- if (!this.listeners[type]) this.listeners[type] = []; +- this.listeners[type].push([plugin22, cb]); +- }; +- for (let plugin22 of this.plugins) { +- if (typeof plugin22 === "object") { +- for (let event in plugin22) { +- if (!PLUGIN_PROPS[event] && /^[A-Z]/.test(event)) { +- throw new Error( +- `Unknown event ${event} in ${plugin22.postcssPlugin}. Try to update PostCSS (${this.processor.version} now).` +- ); +- } +- if (!NOT_VISITORS[event]) { +- if (typeof plugin22[event] === "object") { +- for (let filter in plugin22[event]) { +- if (filter === "*") { +- add(plugin22, event, plugin22[event][filter]); +- } else { +- add( +- plugin22, +- event + "-" + filter.toLowerCase(), +- plugin22[event][filter] +- ); +- } +- } +- } else if (typeof plugin22[event] === "function") { +- add(plugin22, event, plugin22[event]); +- } +- } +- } +- } +- } +- this.hasListener = Object.keys(this.listeners).length > 0; +- } +- async runAsync() { +- this.plugin = 0; +- for (let i2 = 0; i2 < this.plugins.length; i2++) { +- let plugin22 = this.plugins[i2]; +- let promise = this.runOnRoot(plugin22); +- if (isPromise(promise)) { +- try { +- await promise; +- } catch (error) { +- throw this.handleError(error); +- } +- } +- } +- this.prepareVisitors(); +- if (this.hasListener) { +- let root2 = this.result.root; +- while (!root2[isClean]) { +- root2[isClean] = true; +- let stack = [toStack(root2)]; +- while (stack.length > 0) { +- let promise = this.visitTick(stack); +- if (isPromise(promise)) { +- try { +- await promise; +- } catch (e2) { +- let node2 = stack[stack.length - 1].node; +- throw this.handleError(e2, node2); +- } +- } +- } +- } +- if (this.listeners.OnceExit) { +- for (let [plugin22, visitor] of this.listeners.OnceExit) { +- this.result.lastPlugin = plugin22; +- try { +- if (root2.type === "document") { +- let roots = root2.nodes.map( +- (subRoot) => visitor(subRoot, this.helpers) +- ); +- await Promise.all(roots); +- } else { +- await visitor(root2, this.helpers); +- } +- } catch (e2) { +- throw this.handleError(e2); +- } +- } +- } +- } +- this.processed = true; +- return this.stringify(); +- } +- runOnRoot(plugin22) { +- this.result.lastPlugin = plugin22; +- try { +- if (typeof plugin22 === "object" && plugin22.Once) { +- if (this.result.root.type === "document") { +- let roots = this.result.root.nodes.map( +- (root2) => plugin22.Once(root2, this.helpers) +- ); +- if (isPromise(roots[0])) { +- return Promise.all(roots); +- } +- return roots; +- } +- return plugin22.Once(this.result.root, this.helpers); +- } else if (typeof plugin22 === "function") { +- return plugin22(this.result.root, this.result); +- } +- } catch (error) { +- throw this.handleError(error); +- } +- } +- stringify() { +- if (this.error) throw this.error; +- if (this.stringified) return this.result; +- this.stringified = true; +- this.sync(); +- let opts = this.result.opts; +- let str = stringify$2; +- if (opts.syntax) str = opts.syntax.stringify; +- if (opts.stringifier) str = opts.stringifier; +- if (str.stringify) str = str.stringify; +- let map = new MapGenerator$1(str, this.result.root, this.result.opts); +- let data = map.generate(); +- this.result.css = data[0]; +- this.result.map = data[1]; +- return this.result; +- } +- sync() { +- if (this.error) throw this.error; +- if (this.processed) return this.result; +- this.processed = true; +- if (this.processing) { +- throw this.getAsyncError(); +- } +- for (let plugin22 of this.plugins) { +- let promise = this.runOnRoot(plugin22); +- if (isPromise(promise)) { +- throw this.getAsyncError(); +- } +- } +- this.prepareVisitors(); +- if (this.hasListener) { +- let root2 = this.result.root; +- while (!root2[isClean]) { +- root2[isClean] = true; +- this.walkSync(root2); +- } +- if (this.listeners.OnceExit) { +- if (root2.type === "document") { +- for (let subRoot of root2.nodes) { +- this.visitSync(this.listeners.OnceExit, subRoot); +- } +- } else { +- this.visitSync(this.listeners.OnceExit, root2); +- } +- } +- } +- return this.result; +- } +- then(onFulfilled, onRejected) { +- if (process.env.NODE_ENV !== "production") { +- if (!("from" in this.opts)) { +- warnOnce$1( +- "Without `from` option PostCSS could generate wrong source map and will not find Browserslist config. Set it to CSS file path or to `undefined` to prevent this warning." +- ); +- } +- } +- return this.async().then(onFulfilled, onRejected); +- } +- toString() { +- return this.css; +- } +- visitSync(visitors, node2) { +- for (let [plugin22, visitor] of visitors) { +- this.result.lastPlugin = plugin22; +- let promise; +- try { +- promise = visitor(node2, this.helpers); +- } catch (e2) { +- throw this.handleError(e2, node2.proxyOf); +- } +- if (node2.type !== "root" && node2.type !== "document" && !node2.parent) { +- return true; +- } +- if (isPromise(promise)) { +- throw this.getAsyncError(); +- } +- } +- } +- visitTick(stack) { +- let visit2 = stack[stack.length - 1]; +- let { node: node2, visitors } = visit2; +- if (node2.type !== "root" && node2.type !== "document" && !node2.parent) { +- stack.pop(); +- return; +- } +- if (visitors.length > 0 && visit2.visitorIndex < visitors.length) { +- let [plugin22, visitor] = visitors[visit2.visitorIndex]; +- visit2.visitorIndex += 1; +- if (visit2.visitorIndex === visitors.length) { +- visit2.visitors = []; +- visit2.visitorIndex = 0; +- } +- this.result.lastPlugin = plugin22; +- try { +- return visitor(node2.toProxy(), this.helpers); +- } catch (e2) { +- throw this.handleError(e2, node2); +- } +- } +- if (visit2.iterator !== 0) { +- let iterator = visit2.iterator; +- let child; +- while (child = node2.nodes[node2.indexes[iterator]]) { +- node2.indexes[iterator] += 1; +- if (!child[isClean]) { +- child[isClean] = true; +- stack.push(toStack(child)); +- return; +- } +- } +- visit2.iterator = 0; +- delete node2.indexes[iterator]; +- } +- let events = visit2.events; +- while (visit2.eventIndex < events.length) { +- let event = events[visit2.eventIndex]; +- visit2.eventIndex += 1; +- if (event === CHILDREN) { +- if (node2.nodes && node2.nodes.length) { +- node2[isClean] = true; +- visit2.iterator = node2.getIterator(); +- } +- return; +- } else if (this.listeners[event]) { +- visit2.visitors = this.listeners[event]; +- return; +- } +- } +- stack.pop(); +- } +- walkSync(node2) { +- node2[isClean] = true; +- let events = getEvents(node2); +- for (let event of events) { +- if (event === CHILDREN) { +- if (node2.nodes) { +- node2.each((child) => { +- if (!child[isClean]) this.walkSync(child); +- }); +- } +- } else { +- let visitors = this.listeners[event]; +- if (visitors) { +- if (this.visitSync(visitors, node2.toProxy())) return; +- } +- } +- } +- } +- warnings() { +- return this.sync().warnings(); +- } +- get content() { +- return this.stringify().content; +- } +- get css() { +- return this.stringify().css; +- } +- get map() { +- return this.stringify().map; +- } +- get messages() { +- return this.sync().messages; +- } +- get opts() { +- return this.result.opts; +- } +- get processor() { +- return this.result.processor; +- } +- get root() { +- return this.sync().root; +- } +- get [Symbol.toStringTag]() { +- return "LazyResult"; +- } +-}; +-LazyResult$2.registerPostcss = (dependant) => { +- postcss$2 = dependant; +-}; +-var lazyResult = LazyResult$2; +-LazyResult$2.default = LazyResult$2; +-Root$3.registerLazyResult(LazyResult$2); +-Document$2.registerLazyResult(LazyResult$2); +-let MapGenerator22 = mapGenerator; +-let stringify$1 = stringify_1; +-let warnOnce22 = warnOnce$2; +-let parse$1 = parse_1; +-const Result$1 = result; +-let NoWorkResult$1 = class NoWorkResult2 { +- constructor(processor2, css, opts) { +- css = css.toString(); +- this.stringified = false; +- this._processor = processor2; +- this._css = css; +- this._opts = opts; +- this._map = void 0; +- let root2; +- let str = stringify$1; +- this.result = new Result$1(this._processor, root2, this._opts); +- this.result.css = css; +- let self = this; +- Object.defineProperty(this.result, "root", { +- get() { +- return self.root; +- } +- }); +- let map = new MapGenerator22(str, root2, this._opts, css); +- if (map.isMap()) { +- let [generatedCSS, generatedMap] = map.generate(); +- if (generatedCSS) { +- this.result.css = generatedCSS; +- } +- if (generatedMap) { +- this.result.map = generatedMap; +- } +- } else { +- map.clearAnnotation(); +- this.result.css = map.css; +- } +- } +- async() { +- if (this.error) return Promise.reject(this.error); +- return Promise.resolve(this.result); +- } +- catch(onRejected) { +- return this.async().catch(onRejected); +- } +- finally(onFinally) { +- return this.async().then(onFinally, onFinally); +- } +- sync() { +- if (this.error) throw this.error; +- return this.result; +- } +- then(onFulfilled, onRejected) { +- if (process.env.NODE_ENV !== "production") { +- if (!("from" in this._opts)) { +- warnOnce22( +- "Without `from` option PostCSS could generate wrong source map and will not find Browserslist config. Set it to CSS file path or to `undefined` to prevent this warning." +- ); +- } +- } +- return this.async().then(onFulfilled, onRejected); +- } +- toString() { +- return this._css; +- } +- warnings() { +- return []; +- } +- get content() { +- return this.result.css; +- } +- get css() { +- return this.result.css; +- } +- get map() { +- return this.result.map; +- } +- get messages() { +- return []; +- } +- get opts() { +- return this.result.opts; +- } +- get processor() { +- return this.result.processor; +- } +- get root() { +- if (this._root) { +- return this._root; +- } +- let root2; +- let parser2 = parse$1; +- try { +- root2 = parser2(this._css, this._opts); +- } catch (error) { +- this.error = error; +- } +- if (this.error) { +- throw this.error; +- } else { +- this._root = root2; +- return root2; +- } +- } +- get [Symbol.toStringTag]() { +- return "NoWorkResult"; +- } +-}; +-var noWorkResult = NoWorkResult$1; +-NoWorkResult$1.default = NoWorkResult$1; +-let NoWorkResult22 = noWorkResult; +-let LazyResult$1 = lazyResult; +-let Document$1 = document$1; +-let Root$2 = root; +-let Processor$1 = class Processor2 { +- constructor(plugins = []) { +- this.version = "8.4.38"; +- this.plugins = this.normalize(plugins); +- } +- normalize(plugins) { +- let normalized = []; +- for (let i2 of plugins) { +- if (i2.postcss === true) { +- i2 = i2(); +- } else if (i2.postcss) { +- i2 = i2.postcss; +- } +- if (typeof i2 === "object" && Array.isArray(i2.plugins)) { +- normalized = normalized.concat(i2.plugins); +- } else if (typeof i2 === "object" && i2.postcssPlugin) { +- normalized.push(i2); +- } else if (typeof i2 === "function") { +- normalized.push(i2); +- } else if (typeof i2 === "object" && (i2.parse || i2.stringify)) { +- if (process.env.NODE_ENV !== "production") { +- throw new Error( +- "PostCSS syntaxes cannot be used as plugins. Instead, please use one of the syntax/parser/stringifier options as outlined in your PostCSS runner documentation." +- ); +- } +- } else { +- throw new Error(i2 + " is not a PostCSS plugin"); +- } +- } +- return normalized; +- } +- process(css, opts = {}) { +- if (!this.plugins.length && !opts.parser && !opts.stringifier && !opts.syntax) { +- return new NoWorkResult22(this, css, opts); +- } else { +- return new LazyResult$1(this, css, opts); +- } +- } +- use(plugin22) { +- this.plugins = this.plugins.concat(this.normalize([plugin22])); +- return this; +- } +-}; +-var processor = Processor$1; +-Processor$1.default = Processor$1; +-Root$2.registerProcessor(Processor$1); +-Document$1.registerProcessor(Processor$1); +-let Declaration$1 = declaration; +-let PreviousMap22 = previousMap; +-let Comment$1 = comment; +-let AtRule$1 = atRule; +-let Input$1 = input; +-let Root$1 = root; +-let Rule$1 = rule; +-function fromJSON$1(json, inputs) { +- if (Array.isArray(json)) return json.map((n2) => fromJSON$1(n2)); +- let { inputs: ownInputs, ...defaults } = json; +- if (ownInputs) { +- inputs = []; +- for (let input2 of ownInputs) { +- let inputHydrated = { ...input2, __proto__: Input$1.prototype }; +- if (inputHydrated.map) { +- inputHydrated.map = { +- ...inputHydrated.map, +- __proto__: PreviousMap22.prototype +- }; +- } +- inputs.push(inputHydrated); +- } +- } +- if (defaults.nodes) { +- defaults.nodes = json.nodes.map((n2) => fromJSON$1(n2, inputs)); +- } +- if (defaults.source) { +- let { inputId, ...source } = defaults.source; +- defaults.source = source; +- if (inputId != null) { +- defaults.source.input = inputs[inputId]; +- } +- } +- if (defaults.type === "root") { +- return new Root$1(defaults); +- } else if (defaults.type === "decl") { +- return new Declaration$1(defaults); +- } else if (defaults.type === "rule") { +- return new Rule$1(defaults); +- } else if (defaults.type === "comment") { +- return new Comment$1(defaults); +- } else if (defaults.type === "atrule") { +- return new AtRule$1(defaults); +- } else { +- throw new Error("Unknown node type: " + json.type); +- } +-} +-var fromJSON_1 = fromJSON$1; +-fromJSON$1.default = fromJSON$1; +-let CssSyntaxError22 = cssSyntaxError; +-let Declaration22 = declaration; +-let LazyResult22 = lazyResult; +-let Container22 = container; +-let Processor22 = processor; +-let stringify$6 = stringify_1; +-let fromJSON = fromJSON_1; +-let Document222 = document$1; +-let Warning22 = warning; +-let Comment22 = comment; +-let AtRule22 = atRule; +-let Result22 = result; +-let Input22 = input; +-let parse = parse_1; +-let list = list_1; +-let Rule22 = rule; +-let Root22 = root; +-let Node22 = node; +-function postcss(...plugins) { +- if (plugins.length === 1 && Array.isArray(plugins[0])) { +- plugins = plugins[0]; +- } +- return new Processor22(plugins); +-} +-postcss.plugin = function plugin2(name, initializer) { +- let warningPrinted = false; +- function creator(...args) { +- if (console && console.warn && !warningPrinted) { +- warningPrinted = true; +- console.warn( +- name + ": postcss.plugin was deprecated. Migration guide:\nhttps://evilmartians.com/chronicles/postcss-8-plugin-migration" +- ); +- if (process.env.LANG && process.env.LANG.startsWith("cn")) { +- console.warn( +- name + ": 里面 postcss.plugin 被弃用. 迁移指南:\nhttps://www.w3ctech.com/topic/2226" +- ); +- } +- } +- let transformer = initializer(...args); +- transformer.postcssPlugin = name; +- transformer.postcssVersion = new Processor22().version; +- return transformer; +- } +- let cache; +- Object.defineProperty(creator, "postcss", { +- get() { +- if (!cache) cache = creator(); +- return cache; +- } +- }); +- creator.process = function(css, processOpts, pluginOpts) { +- return postcss([creator(pluginOpts)]).process(css, processOpts); +- }; +- return creator; +-}; +-postcss.stringify = stringify$6; +-postcss.parse = parse; +-postcss.fromJSON = fromJSON; +-postcss.list = list; +-postcss.comment = (defaults) => new Comment22(defaults); +-postcss.atRule = (defaults) => new AtRule22(defaults); +-postcss.decl = (defaults) => new Declaration22(defaults); +-postcss.rule = (defaults) => new Rule22(defaults); +-postcss.root = (defaults) => new Root22(defaults); +-postcss.document = (defaults) => new Document222(defaults); +-postcss.CssSyntaxError = CssSyntaxError22; +-postcss.Declaration = Declaration22; +-postcss.Container = Container22; +-postcss.Processor = Processor22; +-postcss.Document = Document222; +-postcss.Comment = Comment22; +-postcss.Warning = Warning22; +-postcss.AtRule = AtRule22; +-postcss.Result = Result22; +-postcss.Input = Input22; +-postcss.Rule = Rule22; +-postcss.Root = Root22; +-postcss.Node = Node22; +-LazyResult22.registerPostcss(postcss); +-var postcss_1 = postcss; +-postcss.default = postcss; +-const postcss$1 = /* @__PURE__ */ getDefaultExportFromCjs(postcss_1); +-postcss$1.stringify; +-postcss$1.fromJSON; +-postcss$1.plugin; +-postcss$1.parse; +-postcss$1.list; +-postcss$1.document; +-postcss$1.comment; +-postcss$1.atRule; +-postcss$1.rule; +-postcss$1.decl; +-postcss$1.root; +-postcss$1.CssSyntaxError; +-postcss$1.Declaration; +-postcss$1.Container; +-postcss$1.Processor; +-postcss$1.Document; +-postcss$1.Comment; +-postcss$1.Warning; +-postcss$1.AtRule; +-postcss$1.Result; +-postcss$1.Input; +-postcss$1.Rule; +-postcss$1.Root; +-postcss$1.Node; ++// Removed postcss here + class BaseRRNode { + // eslint-disable-next-line @typescript-eslint/no-unused-vars, @typescript-eslint/no-explicit-any + constructor(..._args) { diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml index ab12253a4..159d8d3ef 100644 --- a/pnpm-lock.yaml +++ b/pnpm-lock.yaml @@ -8,6 +8,9 @@ patchedDependencies: '@rrweb/record@2.0.0-alpha.17': hash: or7biymn4kjyhnfwbz74vqezxa path: patches/@rrweb__record@2.0.0-alpha.17.patch + '@rrweb/rrweb-plugin-console-record@2.0.0-alpha.17': + hash: ytsspyi7p3hvqcq64vqb7wb6bu + path: patches/@rrweb__rrweb-plugin-console-record@2.0.0-alpha.17.patch dependencies: core-js: @@ -71,7 +74,7 @@ devDependencies: version: 2.0.0-alpha.17(patch_hash=or7biymn4kjyhnfwbz74vqezxa) '@rrweb/rrweb-plugin-console-record': specifier: 2.0.0-alpha.17 - version: 2.0.0-alpha.17(rrweb@2.0.0-alpha.17) + version: 2.0.0-alpha.17(patch_hash=ytsspyi7p3hvqcq64vqb7wb6bu)(rrweb@2.0.0-alpha.17) '@rrweb/types': specifier: 2.0.0-alpha.17 version: 2.0.0-alpha.17 @@ -2807,13 +2810,14 @@ packages: dev: true patched: true - /@rrweb/rrweb-plugin-console-record@2.0.0-alpha.17(rrweb@2.0.0-alpha.17): + /@rrweb/rrweb-plugin-console-record@2.0.0-alpha.17(patch_hash=ytsspyi7p3hvqcq64vqb7wb6bu)(rrweb@2.0.0-alpha.17): resolution: {integrity: sha512-tjNJ3wWUDMMf275xr4Rb5tVYF2UR+wXvSxnyS9tRKnRa574PQQvx7sGbqM/O9AytYjnbiTrAMqNR7OFysGCMwQ==} peerDependencies: rrweb: ^2.0.0-alpha.17 dependencies: rrweb: 2.0.0-alpha.17 dev: true + patched: true /@rrweb/types@2.0.0-alpha.17: resolution: {integrity: sha512-AfDTVUuCyCaIG0lTSqYtrZqJX39ZEYzs4fYKnexhQ+id+kbZIpIJtaut5cto6dWZbB3SEe4fW0o90Po3LvTmfg==} From 797350d54e9819322eabbf693f0636699a4e2c68 Mon Sep 17 00:00:00 2001 From: David Newell Date: Mon, 4 Nov 2024 08:54:04 +0100 Subject: [PATCH 18/21] cleanup changes --- rollup.config.js | 2 -- .../replay/mutation-rate-limiter.test.ts | 2 ++ .../replay/sessionrecording-utils.ts | 32 ------------------- 3 files changed, 2 insertions(+), 34 deletions(-) diff --git a/rollup.config.js b/rollup.config.js index 583ce2855..648cdd8bb 100644 --- a/rollup.config.js +++ b/rollup.config.js @@ -81,8 +81,6 @@ const entrypointTargets = entrypoints.map((file) => { }, ], plugins: [...pluginsForThisFile, visualizer({ filename: `bundle-stats-${fileName}.html` })], - // we know that recorder doesn't use postcss, but the bundler can't determine that - external: ['postcss'], } }) diff --git a/src/__tests__/extensions/replay/mutation-rate-limiter.test.ts b/src/__tests__/extensions/replay/mutation-rate-limiter.test.ts index d45595b30..c54a3f4ef 100644 --- a/src/__tests__/extensions/replay/mutation-rate-limiter.test.ts +++ b/src/__tests__/extensions/replay/mutation-rate-limiter.test.ts @@ -71,6 +71,7 @@ describe('MutationRateLimiter', () => { test('returns event if _any_ adds are left', () => { const event = makeEvent({ + // TODO: add serializedNodeWithId type once https://github.com/rrweb-io/rrweb/pull/1593 merges adds: [{ parentId: 0, nextId: 0, node: {} as unknown as any }], attributes: [{ id: 1, attributes: { a: 'ttribute' } }], }) @@ -81,6 +82,7 @@ describe('MutationRateLimiter', () => { expect(result).toStrictEqual( makeEvent({ + // TODO: add serializedNodeWithId type once https://github.com/rrweb-io/rrweb/pull/1593 merges adds: [{ parentId: 0, nextId: 0, node: {} as unknown as any }], attributes: [], }) diff --git a/src/extensions/replay/sessionrecording-utils.ts b/src/extensions/replay/sessionrecording-utils.ts index 86a29df48..0122bae9d 100644 --- a/src/extensions/replay/sessionrecording-utils.ts +++ b/src/extensions/replay/sessionrecording-utils.ts @@ -52,38 +52,6 @@ export type rrwebRecord = { export declare type recordOptions = Exclude>[0], undefined> -// export declare type recordOptions = { -// emit?: (e: T, isCheckout?: boolean) => void -// checkoutEveryNth?: number -// checkoutEveryNms?: number -// blockClass?: blockClass -// blockSelector?: string -// ignoreClass?: string -// maskTextClass?: maskTextClass -// maskTextSelector?: string -// maskAllInputs?: boolean -// maskInputOptions?: MaskInputOptions -// maskInputFn?: MaskInputFn -// maskTextFn?: MaskTextFn -// slimDOMOptions?: SlimDOMOptions | 'all' | true -// ignoreCSSAttributes?: Set -// inlineStylesheet?: boolean -// hooks?: hooksParam -// // packFn?: PackFn -// sampling?: SamplingStrategy -// dataURLOptions?: DataURLOptions -// recordCanvas?: boolean -// recordCrossOriginIframes?: boolean -// recordAfter?: 'DOMContentLoaded' | 'load' -// userTriggeredOnInput?: boolean -// collectFonts?: boolean -// inlineImages?: boolean -// plugins?: RecordPlugin[] -// mousemoveWait?: number -// keepIframeSrcFn?: KeepIframeSrcFn -// // errorHandler?: ErrorHandler -// } - /* * Check whether a data payload is nearing 5mb. If it is, it checks the data for * data URIs (the likely culprit for large payloads). If it finds data URIs, it either replaces From eed55a6b924d83002132c968b48f626b0334d29d Mon Sep 17 00:00:00 2001 From: David Newell Date: Mon, 4 Nov 2024 10:26:37 +0100 Subject: [PATCH 19/21] re-apply patches to @rrweb/record --- patches/@rrweb__record@2.0.0-alpha.17.patch | 537 +++++++++++++++++++- pnpm-lock.yaml | 6 +- 2 files changed, 524 insertions(+), 19 deletions(-) diff --git a/patches/@rrweb__record@2.0.0-alpha.17.patch b/patches/@rrweb__record@2.0.0-alpha.17.patch index bc9a5b25b..0644a1770 100644 --- a/patches/@rrweb__record@2.0.0-alpha.17.patch +++ b/patches/@rrweb__record@2.0.0-alpha.17.patch @@ -1,11 +1,259 @@ diff --git a/dist/record.js b/dist/record.js -index 46ec389fefb698243008b39db65470dbdf0a3857..ab4f489bda64cb992c184b727a9175de7a646f2d 100644 +index 46ec389fefb698243008b39db65470dbdf0a3857..a5e4f58d77096559b51318decdd6bfcd693f7e6e 100644 --- a/dist/record.js +++ b/dist/record.js -@@ -1336,7080 +1336,6 @@ function getAugmentedNamespace$1(n2) { - }); - return a2; +@@ -246,6 +246,9 @@ function isCSSImportRule(rule2) { + function isCSSStyleRule(rule2) { + return "selectorText" in rule2; } ++function findStylesheet(doc, href) { ++ return Array.from(doc.styleSheets).find((s) => s.href === href); ++} + class Mirror { + constructor() { + __publicField$1(this, "idNodeMap", /* @__PURE__ */ new Map()); +@@ -809,9 +812,14 @@ function serializeElementNode(n2, options) { + } + } + if (tagName === "link" && inlineStylesheet) { +- const stylesheet = Array.from(doc.styleSheets).find((s2) => { +- return s2.href === n2.href; +- }); ++ const href = n2.href; ++ let stylesheet = findStylesheet(doc, href); ++ if (!stylesheet && href.includes('.css')) { ++ const rootDomain = window.location.origin; ++ const stylesheetPath = href.replace(window.location.href, ''); ++ const potentialStylesheetHref = rootDomain + '/' + stylesheetPath ++ stylesheet = findStylesheet(doc, potentialStylesheetHref); ++ } + let cssText = null; + if (stylesheet) { + cssText = stringifyStylesheet(stylesheet); +@@ -1116,7300 +1124,226 @@ function serializeNodeWithId(n2, options) { + keepIframeSrcFn + }; + if (serializedNode.type === NodeType$2.Element && serializedNode.tagName === "textarea" && serializedNode.attributes.value !== void 0) ; +- else { +- for (const childN of Array.from(index$1.childNodes(n2))) { +- const serializedChildNode = serializeNodeWithId(childN, bypassOptions); +- if (serializedChildNode) { +- serializedNode.childNodes.push(serializedChildNode); +- } +- } +- } +- let shadowRootEl = null; +- if (isElement(n2) && (shadowRootEl = index$1.shadowRoot(n2))) { +- for (const childN of Array.from(index$1.childNodes(shadowRootEl))) { +- const serializedChildNode = serializeNodeWithId(childN, bypassOptions); +- if (serializedChildNode) { +- isNativeShadowDom(shadowRootEl) && (serializedChildNode.isShadow = true); +- serializedNode.childNodes.push(serializedChildNode); +- } +- } +- } +- } +- const parent = index$1.parentNode(n2); +- if (parent && isShadowRoot(parent) && isNativeShadowDom(parent)) { +- serializedNode.isShadow = true; +- } +- if (serializedNode.type === NodeType$2.Element && serializedNode.tagName === "iframe") { +- onceIframeLoaded( +- n2, +- () => { +- const iframeDoc = n2.contentDocument; +- if (iframeDoc && onIframeLoad) { +- const serializedIframeNode = serializeNodeWithId(iframeDoc, { +- doc: iframeDoc, +- mirror: mirror2, +- blockClass, +- blockSelector, +- needsMask, +- maskTextClass, +- maskTextSelector, +- skipChild: false, +- inlineStylesheet, +- maskInputOptions, +- maskTextFn, +- maskInputFn, +- slimDOMOptions, +- dataURLOptions, +- inlineImages, +- recordCanvas, +- preserveWhiteSpace, +- onSerialize, +- onIframeLoad, +- iframeLoadTimeout, +- onStylesheetLoad, +- stylesheetLoadTimeout, +- keepIframeSrcFn +- }); +- if (serializedIframeNode) { +- onIframeLoad( +- n2, +- serializedIframeNode +- ); +- } +- } +- }, +- iframeLoadTimeout +- ); +- } +- if (serializedNode.type === NodeType$2.Element && serializedNode.tagName === "link" && typeof serializedNode.attributes.rel === "string" && (serializedNode.attributes.rel === "stylesheet" || serializedNode.attributes.rel === "preload" && typeof serializedNode.attributes.href === "string" && extractFileExtension(serializedNode.attributes.href) === "css")) { +- onceStylesheetLoaded( +- n2, +- () => { +- if (onStylesheetLoad) { +- const serializedLinkNode = serializeNodeWithId(n2, { +- doc, +- mirror: mirror2, +- blockClass, +- blockSelector, +- needsMask, +- maskTextClass, +- maskTextSelector, +- skipChild: false, +- inlineStylesheet, +- maskInputOptions, +- maskTextFn, +- maskInputFn, +- slimDOMOptions, +- dataURLOptions, +- inlineImages, +- recordCanvas, +- preserveWhiteSpace, +- onSerialize, +- onIframeLoad, +- iframeLoadTimeout, +- onStylesheetLoad, +- stylesheetLoadTimeout, +- keepIframeSrcFn +- }); +- if (serializedLinkNode) { +- onStylesheetLoad( +- n2, +- serializedLinkNode +- ); +- } +- } +- }, +- stylesheetLoadTimeout +- ); +- } +- return serializedNode; +-} +-function snapshot(n2, options) { +- const { +- mirror: mirror2 = new Mirror(), +- blockClass = "rr-block", +- blockSelector = null, +- maskTextClass = "rr-mask", +- maskTextSelector = null, +- inlineStylesheet = true, +- inlineImages = false, +- recordCanvas = false, +- maskAllInputs = false, +- maskTextFn, +- maskInputFn, +- slimDOM = false, +- dataURLOptions, +- preserveWhiteSpace, +- onSerialize, +- onIframeLoad, +- iframeLoadTimeout, +- onStylesheetLoad, +- stylesheetLoadTimeout, +- keepIframeSrcFn = () => false +- } = options || {}; +- const maskInputOptions = maskAllInputs === true ? { +- color: true, +- date: true, +- "datetime-local": true, +- email: true, +- month: true, +- number: true, +- range: true, +- search: true, +- tel: true, +- text: true, +- time: true, +- url: true, +- week: true, +- textarea: true, +- select: true, +- password: true +- } : maskAllInputs === false ? { +- password: true +- } : maskAllInputs; +- const slimDOMOptions = slimDOM === true || slimDOM === "all" ? ( +- // if true: set of sensible options that should not throw away any information +- { +- script: true, +- comment: true, +- headFavicon: true, +- headWhitespace: true, +- headMetaDescKeywords: slimDOM === "all", +- // destructive +- headMetaSocial: true, +- headMetaRobots: true, +- headMetaHttpEquiv: true, +- headMetaAuthorship: true, +- headMetaVerification: true +- } +- ) : slimDOM === false ? {} : slimDOM; +- return serializeNodeWithId(n2, { +- doc: n2, +- mirror: mirror2, +- blockClass, +- blockSelector, +- maskTextClass, +- maskTextSelector, +- skipChild: false, +- inlineStylesheet, +- maskInputOptions, +- maskTextFn, +- maskInputFn, +- slimDOMOptions, +- dataURLOptions, +- inlineImages, +- recordCanvas, +- preserveWhiteSpace, +- onSerialize, +- onIframeLoad, +- iframeLoadTimeout, +- onStylesheetLoad, +- stylesheetLoadTimeout, +- keepIframeSrcFn, +- newlyAddedElement: false +- }); +-} +-function getDefaultExportFromCjs$1(x2) { +- return x2 && x2.__esModule && Object.prototype.hasOwnProperty.call(x2, "default") ? x2["default"] : x2; +-} +-function getAugmentedNamespace$1(n2) { +- if (n2.__esModule) return n2; +- var f2 = n2.default; +- if (typeof f2 == "function") { +- var a2 = function a22() { +- if (this instanceof a22) { +- return Reflect.construct(f2, arguments, this.constructor); +- } +- return f2.apply(this, arguments); +- }; +- a2.prototype = f2.prototype; +- } else a2 = {}; +- Object.defineProperty(a2, "__esModule", { value: true }); +- Object.keys(n2).forEach(function(k) { +- var d = Object.getOwnPropertyDescriptor(n2, k); +- Object.defineProperty(a2, k, d.get ? d : { +- enumerable: true, +- get: function() { +- return n2[k]; +- } +- }); +- }); +- return a2; +-} -var picocolors_browser$1 = { exports: {} }; -var x$1 = String; -var create$1 = function() { @@ -6822,8 +7070,14 @@ index 46ec389fefb698243008b39db65470dbdf0a3857..ab4f489bda64cb992c184b727a9175de - warnOnce22( - "Without `from` option PostCSS could generate wrong source map and will not find Browserslist config. Set it to CSS file path or to `undefined` to prevent this warning." - ); -- } -- } ++ else { ++ for (const childN of Array.from(index$1.childNodes(n2))) { ++ const serializedChildNode = serializeNodeWithId(childN, bypassOptions); ++ if (serializedChildNode) { ++ serializedNode.childNodes.push(serializedChildNode); ++ } + } + } - return this.async().then(onFulfilled, onRejected); - } - toString() { @@ -6902,11 +7156,18 @@ index 46ec389fefb698243008b39db65470dbdf0a3857..ab4f489bda64cb992c184b727a9175de - throw new Error( - "PostCSS syntaxes cannot be used as plugins. Instead, please use one of the syntax/parser/stringifier options as outlined in your PostCSS runner documentation." - ); -- } ++ let shadowRootEl = null; ++ if (isElement(n2) && (shadowRootEl = index$1.shadowRoot(n2))) { ++ for (const childN of Array.from(index$1.childNodes(shadowRootEl))) { ++ const serializedChildNode = serializeNodeWithId(childN, bypassOptions); ++ if (serializedChildNode) { ++ isNativeShadowDom(shadowRootEl) && (serializedChildNode.isShadow = true); ++ serializedNode.childNodes.push(serializedChildNode); + } - } else { - throw new Error(i2 + " is not a PostCSS plugin"); -- } -- } + } + } - return normalized; - } - process(css, opts = {}) { @@ -6915,11 +7176,14 @@ index 46ec389fefb698243008b39db65470dbdf0a3857..ab4f489bda64cb992c184b727a9175de - } else { - return new LazyResult$1(this, css, opts); - } -- } + } - use(plugin22) { - this.plugins = this.plugins.concat(this.normalize([plugin22])); - return this; -- } ++ const parent = index$1.parentNode(n2); ++ if (parent && isShadowRoot(parent) && isNativeShadowDom(parent)) { ++ serializedNode.isShadow = true; + } -}; -var processor = Processor$1; -Processor$1.default = Processor$1; @@ -6947,16 +7211,156 @@ index 46ec389fefb698243008b39db65470dbdf0a3857..ab4f489bda64cb992c184b727a9175de - } - inputs.push(inputHydrated); - } -- } ++ if (serializedNode.type === NodeType$2.Element && serializedNode.tagName === "iframe") { ++ onceIframeLoaded( ++ n2, ++ () => { ++ const iframeDoc = n2.contentDocument; ++ if (iframeDoc && onIframeLoad) { ++ const serializedIframeNode = serializeNodeWithId(iframeDoc, { ++ doc: iframeDoc, ++ mirror: mirror2, ++ blockClass, ++ blockSelector, ++ needsMask, ++ maskTextClass, ++ maskTextSelector, ++ skipChild: false, ++ inlineStylesheet, ++ maskInputOptions, ++ maskTextFn, ++ maskInputFn, ++ slimDOMOptions, ++ dataURLOptions, ++ inlineImages, ++ recordCanvas, ++ preserveWhiteSpace, ++ onSerialize, ++ onIframeLoad, ++ iframeLoadTimeout, ++ onStylesheetLoad, ++ stylesheetLoadTimeout, ++ keepIframeSrcFn ++ }); ++ if (serializedIframeNode) { ++ onIframeLoad( ++ n2, ++ serializedIframeNode ++ ); ++ } ++ } ++ }, ++ iframeLoadTimeout ++ ); + } - if (defaults.nodes) { - defaults.nodes = json.nodes.map((n2) => fromJSON$1(n2, inputs)); -- } ++ if (serializedNode.type === NodeType$2.Element && serializedNode.tagName === "link" && typeof serializedNode.attributes.rel === "string" && (serializedNode.attributes.rel === "stylesheet" || serializedNode.attributes.rel === "preload" && typeof serializedNode.attributes.href === "string" && extractFileExtension(serializedNode.attributes.href) === "css")) { ++ onceStylesheetLoaded( ++ n2, ++ () => { ++ if (onStylesheetLoad) { ++ const serializedLinkNode = serializeNodeWithId(n2, { ++ doc, ++ mirror: mirror2, ++ blockClass, ++ blockSelector, ++ needsMask, ++ maskTextClass, ++ maskTextSelector, ++ skipChild: false, ++ inlineStylesheet, ++ maskInputOptions, ++ maskTextFn, ++ maskInputFn, ++ slimDOMOptions, ++ dataURLOptions, ++ inlineImages, ++ recordCanvas, ++ preserveWhiteSpace, ++ onSerialize, ++ onIframeLoad, ++ iframeLoadTimeout, ++ onStylesheetLoad, ++ stylesheetLoadTimeout, ++ keepIframeSrcFn ++ }); ++ if (serializedLinkNode) { ++ onStylesheetLoad( ++ n2, ++ serializedLinkNode ++ ); ++ } ++ } ++ }, ++ stylesheetLoadTimeout ++ ); + } - if (defaults.source) { - let { inputId, ...source } = defaults.source; - defaults.source = source; - if (inputId != null) { - defaults.source.input = inputs[inputId]; -- } ++ return serializedNode; ++} ++function snapshot(n2, options) { ++ const { ++ mirror: mirror2 = new Mirror(), ++ blockClass = "rr-block", ++ blockSelector = null, ++ maskTextClass = "rr-mask", ++ maskTextSelector = null, ++ inlineStylesheet = true, ++ inlineImages = false, ++ recordCanvas = false, ++ maskAllInputs = false, ++ maskTextFn, ++ maskInputFn, ++ slimDOM = false, ++ dataURLOptions, ++ preserveWhiteSpace, ++ onSerialize, ++ onIframeLoad, ++ iframeLoadTimeout, ++ onStylesheetLoad, ++ stylesheetLoadTimeout, ++ keepIframeSrcFn = () => false ++ } = options || {}; ++ const maskInputOptions = maskAllInputs === true ? { ++ color: true, ++ date: true, ++ "datetime-local": true, ++ email: true, ++ month: true, ++ number: true, ++ range: true, ++ search: true, ++ tel: true, ++ text: true, ++ time: true, ++ url: true, ++ week: true, ++ textarea: true, ++ select: true, ++ password: true ++ } : maskAllInputs === false ? { ++ password: true ++ } : maskAllInputs; ++ const slimDOMOptions = slimDOM === true || slimDOM === "all" ? ( ++ // if true: set of sensible options that should not throw away any information ++ { ++ script: true, ++ comment: true, ++ headFavicon: true, ++ headWhitespace: true, ++ headMetaDescKeywords: slimDOM === "all", ++ // destructive ++ headMetaSocial: true, ++ headMetaRobots: true, ++ headMetaHttpEquiv: true, ++ headMetaAuthorship: true, ++ headMetaVerification: true + } - } - if (defaults.type === "root") { - return new Root$1(defaults); @@ -7010,7 +7414,44 @@ index 46ec389fefb698243008b39db65470dbdf0a3857..ab4f489bda64cb992c184b727a9175de - console.warn( - name + ": 里面 postcss.plugin 被弃用. 迁移指南:\nhttps://www.w3ctech.com/topic/2226" - ); -- } ++ ) : slimDOM === false ? {} : slimDOM; ++ return serializeNodeWithId(n2, { ++ doc: n2, ++ mirror: mirror2, ++ blockClass, ++ blockSelector, ++ maskTextClass, ++ maskTextSelector, ++ skipChild: false, ++ inlineStylesheet, ++ maskInputOptions, ++ maskTextFn, ++ maskInputFn, ++ slimDOMOptions, ++ dataURLOptions, ++ inlineImages, ++ recordCanvas, ++ preserveWhiteSpace, ++ onSerialize, ++ onIframeLoad, ++ iframeLoadTimeout, ++ onStylesheetLoad, ++ stylesheetLoadTimeout, ++ keepIframeSrcFn, ++ newlyAddedElement: false ++ }); ++} ++function getDefaultExportFromCjs$1(x2) { ++ return x2 && x2.__esModule && Object.prototype.hasOwnProperty.call(x2, "default") ? x2["default"] : x2; ++} ++function getAugmentedNamespace$1(n2) { ++ if (n2.__esModule) return n2; ++ var f2 = n2.default; ++ if (typeof f2 == "function") { ++ var a2 = function a22() { ++ if (this instanceof a22) { ++ return Reflect.construct(f2, arguments, this.constructor); + } - } - let transformer = initializer(...args); - transformer.postcssPlugin = name; @@ -7023,7 +7464,20 @@ index 46ec389fefb698243008b39db65470dbdf0a3857..ab4f489bda64cb992c184b727a9175de - if (!cache) cache = creator(); - return cache; - } -- }); ++ return f2.apply(this, arguments); ++ }; ++ a2.prototype = f2.prototype; ++ } else a2 = {}; ++ Object.defineProperty(a2, "__esModule", { value: true }); ++ Object.keys(n2).forEach(function(k) { ++ var d = Object.getOwnPropertyDescriptor(n2, k); ++ Object.defineProperty(a2, k, d.get ? d : { ++ enumerable: true, ++ get: function() { ++ return n2[k]; ++ } ++ }); + }); - creator.process = function(css, processOpts, pluginOpts) { - return postcss([creator(pluginOpts)]).process(css, processOpts); - }; @@ -7080,6 +7534,57 @@ index 46ec389fefb698243008b39db65470dbdf0a3857..ab4f489bda64cb992c184b727a9175de -postcss$1.Rule; -postcss$1.Root; -postcss$1.Node; ++ return a2; ++} class BaseRRNode { // eslint-disable-next-line @typescript-eslint/no-unused-vars, @typescript-eslint/no-explicit-any constructor(..._args) { +@@ -11382,11 +4316,19 @@ class CanvasManager { + let rafId; + const getCanvas = () => { + const matchedCanvas = []; +- win.document.querySelectorAll("canvas").forEach((canvas) => { +- if (!isBlocked(canvas, blockClass, blockSelector, true)) { +- matchedCanvas.push(canvas); +- } +- }); ++ const searchCanvas = (root) => { ++ root.querySelectorAll("canvas").forEach((canvas) => { ++ if (!isBlocked(canvas, blockClass, blockSelector, true)) { ++ matchedCanvas.push(canvas); ++ } ++ }); ++ root.querySelectorAll("*").forEach((elem) => { ++ if (elem.shadowRoot) { ++ searchCanvas(elem.shadowRoot); ++ } ++ }); ++ }; ++ searchCanvas(win.document); + return matchedCanvas; + }; + const takeCanvasSnapshots = (timestamp) => { +@@ -11407,13 +4349,20 @@ class CanvasManager { + context.clear(context.COLOR_BUFFER_BIT); + } + } +- const bitmap = await createImageBitmap(canvas); ++ // createImageBitmap throws if resizing to 0 ++ // Fallback to intrinsic size if canvas has not yet rendered ++ const width = canvas.clientWidth || canvas.width; ++ const height = canvas.clientHeight || canvas.height; ++ const bitmap = await createImageBitmap(canvas, { ++ resizeWidth: width, ++ resizeHeight: height ++ }); + worker.postMessage( + { + id, + bitmap, +- width: canvas.width, +- height: canvas.height, ++ width, ++ height, + dataURLOptions: options.dataURLOptions + }, + [bitmap] diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml index 159d8d3ef..3c188c207 100644 --- a/pnpm-lock.yaml +++ b/pnpm-lock.yaml @@ -6,7 +6,7 @@ settings: patchedDependencies: '@rrweb/record@2.0.0-alpha.17': - hash: or7biymn4kjyhnfwbz74vqezxa + hash: wwyxiuzzlj4fuy7by57teumbru path: patches/@rrweb__record@2.0.0-alpha.17.patch '@rrweb/rrweb-plugin-console-record@2.0.0-alpha.17': hash: ytsspyi7p3hvqcq64vqb7wb6bu @@ -71,7 +71,7 @@ devDependencies: version: 12.1.1(rollup@4.24.0)(tslib@2.5.0)(typescript@5.5.4) '@rrweb/record': specifier: 2.0.0-alpha.17 - version: 2.0.0-alpha.17(patch_hash=or7biymn4kjyhnfwbz74vqezxa) + version: 2.0.0-alpha.17(patch_hash=wwyxiuzzlj4fuy7by57teumbru) '@rrweb/rrweb-plugin-console-record': specifier: 2.0.0-alpha.17 version: 2.0.0-alpha.17(patch_hash=ytsspyi7p3hvqcq64vqb7wb6bu)(rrweb@2.0.0-alpha.17) @@ -2802,7 +2802,7 @@ packages: dev: true optional: true - /@rrweb/record@2.0.0-alpha.17(patch_hash=or7biymn4kjyhnfwbz74vqezxa): + /@rrweb/record@2.0.0-alpha.17(patch_hash=wwyxiuzzlj4fuy7by57teumbru): resolution: {integrity: sha512-Je+lzjeWMF8/I0IDoXFzkGPKT8j7AkaBup5YcwUHlkp18VhLVze416MvI6915teE27uUA2ScXMXzG0Yiu5VTIw==} dependencies: '@rrweb/types': 2.0.0-alpha.17 From a9196a98df296a574ad9a36b694e23576cbf0773 Mon Sep 17 00:00:00 2001 From: David Newell Date: Tue, 5 Nov 2024 00:06:00 +0100 Subject: [PATCH 20/21] remove patch --- package.json | 1 - patches/@rrweb__record@2.0.0-alpha.17.patch | 7590 ------------------- pnpm-lock.yaml | 8 +- 3 files changed, 2 insertions(+), 7597 deletions(-) delete mode 100644 patches/@rrweb__record@2.0.0-alpha.17.patch diff --git a/package.json b/package.json index 7e144bb23..e1b0a6d66 100644 --- a/package.json +++ b/package.json @@ -126,7 +126,6 @@ ], "pnpm": { "patchedDependencies": { - "@rrweb/record@2.0.0-alpha.17": "patches/@rrweb__record@2.0.0-alpha.17.patch", "@rrweb/rrweb-plugin-console-record@2.0.0-alpha.17": "patches/@rrweb__rrweb-plugin-console-record@2.0.0-alpha.17.patch" } } diff --git a/patches/@rrweb__record@2.0.0-alpha.17.patch b/patches/@rrweb__record@2.0.0-alpha.17.patch deleted file mode 100644 index 0644a1770..000000000 --- a/patches/@rrweb__record@2.0.0-alpha.17.patch +++ /dev/null @@ -1,7590 +0,0 @@ -diff --git a/dist/record.js b/dist/record.js -index 46ec389fefb698243008b39db65470dbdf0a3857..a5e4f58d77096559b51318decdd6bfcd693f7e6e 100644 ---- a/dist/record.js -+++ b/dist/record.js -@@ -246,6 +246,9 @@ function isCSSImportRule(rule2) { - function isCSSStyleRule(rule2) { - return "selectorText" in rule2; - } -+function findStylesheet(doc, href) { -+ return Array.from(doc.styleSheets).find((s) => s.href === href); -+} - class Mirror { - constructor() { - __publicField$1(this, "idNodeMap", /* @__PURE__ */ new Map()); -@@ -809,9 +812,14 @@ function serializeElementNode(n2, options) { - } - } - if (tagName === "link" && inlineStylesheet) { -- const stylesheet = Array.from(doc.styleSheets).find((s2) => { -- return s2.href === n2.href; -- }); -+ const href = n2.href; -+ let stylesheet = findStylesheet(doc, href); -+ if (!stylesheet && href.includes('.css')) { -+ const rootDomain = window.location.origin; -+ const stylesheetPath = href.replace(window.location.href, ''); -+ const potentialStylesheetHref = rootDomain + '/' + stylesheetPath -+ stylesheet = findStylesheet(doc, potentialStylesheetHref); -+ } - let cssText = null; - if (stylesheet) { - cssText = stringifyStylesheet(stylesheet); -@@ -1116,7300 +1124,226 @@ function serializeNodeWithId(n2, options) { - keepIframeSrcFn - }; - if (serializedNode.type === NodeType$2.Element && serializedNode.tagName === "textarea" && serializedNode.attributes.value !== void 0) ; -- else { -- for (const childN of Array.from(index$1.childNodes(n2))) { -- const serializedChildNode = serializeNodeWithId(childN, bypassOptions); -- if (serializedChildNode) { -- serializedNode.childNodes.push(serializedChildNode); -- } -- } -- } -- let shadowRootEl = null; -- if (isElement(n2) && (shadowRootEl = index$1.shadowRoot(n2))) { -- for (const childN of Array.from(index$1.childNodes(shadowRootEl))) { -- const serializedChildNode = serializeNodeWithId(childN, bypassOptions); -- if (serializedChildNode) { -- isNativeShadowDom(shadowRootEl) && (serializedChildNode.isShadow = true); -- serializedNode.childNodes.push(serializedChildNode); -- } -- } -- } -- } -- const parent = index$1.parentNode(n2); -- if (parent && isShadowRoot(parent) && isNativeShadowDom(parent)) { -- serializedNode.isShadow = true; -- } -- if (serializedNode.type === NodeType$2.Element && serializedNode.tagName === "iframe") { -- onceIframeLoaded( -- n2, -- () => { -- const iframeDoc = n2.contentDocument; -- if (iframeDoc && onIframeLoad) { -- const serializedIframeNode = serializeNodeWithId(iframeDoc, { -- doc: iframeDoc, -- mirror: mirror2, -- blockClass, -- blockSelector, -- needsMask, -- maskTextClass, -- maskTextSelector, -- skipChild: false, -- inlineStylesheet, -- maskInputOptions, -- maskTextFn, -- maskInputFn, -- slimDOMOptions, -- dataURLOptions, -- inlineImages, -- recordCanvas, -- preserveWhiteSpace, -- onSerialize, -- onIframeLoad, -- iframeLoadTimeout, -- onStylesheetLoad, -- stylesheetLoadTimeout, -- keepIframeSrcFn -- }); -- if (serializedIframeNode) { -- onIframeLoad( -- n2, -- serializedIframeNode -- ); -- } -- } -- }, -- iframeLoadTimeout -- ); -- } -- if (serializedNode.type === NodeType$2.Element && serializedNode.tagName === "link" && typeof serializedNode.attributes.rel === "string" && (serializedNode.attributes.rel === "stylesheet" || serializedNode.attributes.rel === "preload" && typeof serializedNode.attributes.href === "string" && extractFileExtension(serializedNode.attributes.href) === "css")) { -- onceStylesheetLoaded( -- n2, -- () => { -- if (onStylesheetLoad) { -- const serializedLinkNode = serializeNodeWithId(n2, { -- doc, -- mirror: mirror2, -- blockClass, -- blockSelector, -- needsMask, -- maskTextClass, -- maskTextSelector, -- skipChild: false, -- inlineStylesheet, -- maskInputOptions, -- maskTextFn, -- maskInputFn, -- slimDOMOptions, -- dataURLOptions, -- inlineImages, -- recordCanvas, -- preserveWhiteSpace, -- onSerialize, -- onIframeLoad, -- iframeLoadTimeout, -- onStylesheetLoad, -- stylesheetLoadTimeout, -- keepIframeSrcFn -- }); -- if (serializedLinkNode) { -- onStylesheetLoad( -- n2, -- serializedLinkNode -- ); -- } -- } -- }, -- stylesheetLoadTimeout -- ); -- } -- return serializedNode; --} --function snapshot(n2, options) { -- const { -- mirror: mirror2 = new Mirror(), -- blockClass = "rr-block", -- blockSelector = null, -- maskTextClass = "rr-mask", -- maskTextSelector = null, -- inlineStylesheet = true, -- inlineImages = false, -- recordCanvas = false, -- maskAllInputs = false, -- maskTextFn, -- maskInputFn, -- slimDOM = false, -- dataURLOptions, -- preserveWhiteSpace, -- onSerialize, -- onIframeLoad, -- iframeLoadTimeout, -- onStylesheetLoad, -- stylesheetLoadTimeout, -- keepIframeSrcFn = () => false -- } = options || {}; -- const maskInputOptions = maskAllInputs === true ? { -- color: true, -- date: true, -- "datetime-local": true, -- email: true, -- month: true, -- number: true, -- range: true, -- search: true, -- tel: true, -- text: true, -- time: true, -- url: true, -- week: true, -- textarea: true, -- select: true, -- password: true -- } : maskAllInputs === false ? { -- password: true -- } : maskAllInputs; -- const slimDOMOptions = slimDOM === true || slimDOM === "all" ? ( -- // if true: set of sensible options that should not throw away any information -- { -- script: true, -- comment: true, -- headFavicon: true, -- headWhitespace: true, -- headMetaDescKeywords: slimDOM === "all", -- // destructive -- headMetaSocial: true, -- headMetaRobots: true, -- headMetaHttpEquiv: true, -- headMetaAuthorship: true, -- headMetaVerification: true -- } -- ) : slimDOM === false ? {} : slimDOM; -- return serializeNodeWithId(n2, { -- doc: n2, -- mirror: mirror2, -- blockClass, -- blockSelector, -- maskTextClass, -- maskTextSelector, -- skipChild: false, -- inlineStylesheet, -- maskInputOptions, -- maskTextFn, -- maskInputFn, -- slimDOMOptions, -- dataURLOptions, -- inlineImages, -- recordCanvas, -- preserveWhiteSpace, -- onSerialize, -- onIframeLoad, -- iframeLoadTimeout, -- onStylesheetLoad, -- stylesheetLoadTimeout, -- keepIframeSrcFn, -- newlyAddedElement: false -- }); --} --function getDefaultExportFromCjs$1(x2) { -- return x2 && x2.__esModule && Object.prototype.hasOwnProperty.call(x2, "default") ? x2["default"] : x2; --} --function getAugmentedNamespace$1(n2) { -- if (n2.__esModule) return n2; -- var f2 = n2.default; -- if (typeof f2 == "function") { -- var a2 = function a22() { -- if (this instanceof a22) { -- return Reflect.construct(f2, arguments, this.constructor); -- } -- return f2.apply(this, arguments); -- }; -- a2.prototype = f2.prototype; -- } else a2 = {}; -- Object.defineProperty(a2, "__esModule", { value: true }); -- Object.keys(n2).forEach(function(k) { -- var d = Object.getOwnPropertyDescriptor(n2, k); -- Object.defineProperty(a2, k, d.get ? d : { -- enumerable: true, -- get: function() { -- return n2[k]; -- } -- }); -- }); -- return a2; --} --var picocolors_browser$1 = { exports: {} }; --var x$1 = String; --var create$1 = function() { -- return { isColorSupported: false, reset: x$1, bold: x$1, dim: x$1, italic: x$1, underline: x$1, inverse: x$1, hidden: x$1, strikethrough: x$1, black: x$1, red: x$1, green: x$1, yellow: x$1, blue: x$1, magenta: x$1, cyan: x$1, white: x$1, gray: x$1, bgBlack: x$1, bgRed: x$1, bgGreen: x$1, bgYellow: x$1, bgBlue: x$1, bgMagenta: x$1, bgCyan: x$1, bgWhite: x$1 }; --}; --picocolors_browser$1.exports = create$1(); --picocolors_browser$1.exports.createColors = create$1; --var picocolors_browserExports$1 = picocolors_browser$1.exports; --const __viteBrowserExternal$2 = {}; --const __viteBrowserExternal$1$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({ -- __proto__: null, -- default: __viteBrowserExternal$2 --}, Symbol.toStringTag, { value: "Module" })); --const require$$2$1 = /* @__PURE__ */ getAugmentedNamespace$1(__viteBrowserExternal$1$1); --let pico$1 = picocolors_browserExports$1; --let terminalHighlight$1$1 = require$$2$1; --let CssSyntaxError$3$1 = class CssSyntaxError extends Error { -- constructor(message, line, column, source, file, plugin22) { -- super(message); -- this.name = "CssSyntaxError"; -- this.reason = message; -- if (file) { -- this.file = file; -- } -- if (source) { -- this.source = source; -- } -- if (plugin22) { -- this.plugin = plugin22; -- } -- if (typeof line !== "undefined" && typeof column !== "undefined") { -- if (typeof line === "number") { -- this.line = line; -- this.column = column; -- } else { -- this.line = line.line; -- this.column = line.column; -- this.endLine = column.line; -- this.endColumn = column.column; -- } -- } -- this.setMessage(); -- if (Error.captureStackTrace) { -- Error.captureStackTrace(this, CssSyntaxError); -- } -- } -- setMessage() { -- this.message = this.plugin ? this.plugin + ": " : ""; -- this.message += this.file ? this.file : ""; -- if (typeof this.line !== "undefined") { -- this.message += ":" + this.line + ":" + this.column; -- } -- this.message += ": " + this.reason; -- } -- showSourceCode(color) { -- if (!this.source) return ""; -- let css = this.source; -- if (color == null) color = pico$1.isColorSupported; -- if (terminalHighlight$1$1) { -- if (color) css = terminalHighlight$1$1(css); -- } -- let lines = css.split(/\r?\n/); -- let start = Math.max(this.line - 3, 0); -- let end = Math.min(this.line + 2, lines.length); -- let maxWidth = String(end).length; -- let mark, aside; -- if (color) { -- let { bold, gray, red } = pico$1.createColors(true); -- mark = (text) => bold(red(text)); -- aside = (text) => gray(text); -- } else { -- mark = aside = (str) => str; -- } -- return lines.slice(start, end).map((line, index2) => { -- let number = start + 1 + index2; -- let gutter = " " + (" " + number).slice(-maxWidth) + " | "; -- if (number === this.line) { -- let spacing = aside(gutter.replace(/\d/g, " ")) + line.slice(0, this.column - 1).replace(/[^\t]/g, " "); -- return mark(">") + aside(gutter) + line + "\n " + spacing + mark("^"); -- } -- return " " + aside(gutter) + line; -- }).join("\n"); -- } -- toString() { -- let code = this.showSourceCode(); -- if (code) { -- code = "\n\n" + code + "\n"; -- } -- return this.name + ": " + this.message + code; -- } --}; --var cssSyntaxError$1 = CssSyntaxError$3$1; --CssSyntaxError$3$1.default = CssSyntaxError$3$1; --var symbols$1 = {}; --symbols$1.isClean = Symbol("isClean"); --symbols$1.my = Symbol("my"); --const DEFAULT_RAW$1 = { -- after: "\n", -- beforeClose: "\n", -- beforeComment: "\n", -- beforeDecl: "\n", -- beforeOpen: " ", -- beforeRule: "\n", -- colon: ": ", -- commentLeft: " ", -- commentRight: " ", -- emptyBody: "", -- indent: " ", -- semicolon: false --}; --function capitalize$1(str) { -- return str[0].toUpperCase() + str.slice(1); --} --let Stringifier$2$1 = class Stringifier { -- constructor(builder) { -- this.builder = builder; -- } -- atrule(node2, semicolon) { -- let name = "@" + node2.name; -- let params = node2.params ? this.rawValue(node2, "params") : ""; -- if (typeof node2.raws.afterName !== "undefined") { -- name += node2.raws.afterName; -- } else if (params) { -- name += " "; -- } -- if (node2.nodes) { -- this.block(node2, name + params); -- } else { -- let end = (node2.raws.between || "") + (semicolon ? ";" : ""); -- this.builder(name + params + end, node2); -- } -- } -- beforeAfter(node2, detect) { -- let value; -- if (node2.type === "decl") { -- value = this.raw(node2, null, "beforeDecl"); -- } else if (node2.type === "comment") { -- value = this.raw(node2, null, "beforeComment"); -- } else if (detect === "before") { -- value = this.raw(node2, null, "beforeRule"); -- } else { -- value = this.raw(node2, null, "beforeClose"); -- } -- let buf = node2.parent; -- let depth = 0; -- while (buf && buf.type !== "root") { -- depth += 1; -- buf = buf.parent; -- } -- if (value.includes("\n")) { -- let indent = this.raw(node2, null, "indent"); -- if (indent.length) { -- for (let step = 0; step < depth; step++) value += indent; -- } -- } -- return value; -- } -- block(node2, start) { -- let between = this.raw(node2, "between", "beforeOpen"); -- this.builder(start + between + "{", node2, "start"); -- let after; -- if (node2.nodes && node2.nodes.length) { -- this.body(node2); -- after = this.raw(node2, "after"); -- } else { -- after = this.raw(node2, "after", "emptyBody"); -- } -- if (after) this.builder(after); -- this.builder("}", node2, "end"); -- } -- body(node2) { -- let last = node2.nodes.length - 1; -- while (last > 0) { -- if (node2.nodes[last].type !== "comment") break; -- last -= 1; -- } -- let semicolon = this.raw(node2, "semicolon"); -- for (let i2 = 0; i2 < node2.nodes.length; i2++) { -- let child = node2.nodes[i2]; -- let before = this.raw(child, "before"); -- if (before) this.builder(before); -- this.stringify(child, last !== i2 || semicolon); -- } -- } -- comment(node2) { -- let left = this.raw(node2, "left", "commentLeft"); -- let right = this.raw(node2, "right", "commentRight"); -- this.builder("/*" + left + node2.text + right + "*/", node2); -- } -- decl(node2, semicolon) { -- let between = this.raw(node2, "between", "colon"); -- let string = node2.prop + between + this.rawValue(node2, "value"); -- if (node2.important) { -- string += node2.raws.important || " !important"; -- } -- if (semicolon) string += ";"; -- this.builder(string, node2); -- } -- document(node2) { -- this.body(node2); -- } -- raw(node2, own, detect) { -- let value; -- if (!detect) detect = own; -- if (own) { -- value = node2.raws[own]; -- if (typeof value !== "undefined") return value; -- } -- let parent = node2.parent; -- if (detect === "before") { -- if (!parent || parent.type === "root" && parent.first === node2) { -- return ""; -- } -- if (parent && parent.type === "document") { -- return ""; -- } -- } -- if (!parent) return DEFAULT_RAW$1[detect]; -- let root2 = node2.root(); -- if (!root2.rawCache) root2.rawCache = {}; -- if (typeof root2.rawCache[detect] !== "undefined") { -- return root2.rawCache[detect]; -- } -- if (detect === "before" || detect === "after") { -- return this.beforeAfter(node2, detect); -- } else { -- let method = "raw" + capitalize$1(detect); -- if (this[method]) { -- value = this[method](root2, node2); -- } else { -- root2.walk((i2) => { -- value = i2.raws[own]; -- if (typeof value !== "undefined") return false; -- }); -- } -- } -- if (typeof value === "undefined") value = DEFAULT_RAW$1[detect]; -- root2.rawCache[detect] = value; -- return value; -- } -- rawBeforeClose(root2) { -- let value; -- root2.walk((i2) => { -- if (i2.nodes && i2.nodes.length > 0) { -- if (typeof i2.raws.after !== "undefined") { -- value = i2.raws.after; -- if (value.includes("\n")) { -- value = value.replace(/[^\n]+$/, ""); -- } -- return false; -- } -- } -- }); -- if (value) value = value.replace(/\S/g, ""); -- return value; -- } -- rawBeforeComment(root2, node2) { -- let value; -- root2.walkComments((i2) => { -- if (typeof i2.raws.before !== "undefined") { -- value = i2.raws.before; -- if (value.includes("\n")) { -- value = value.replace(/[^\n]+$/, ""); -- } -- return false; -- } -- }); -- if (typeof value === "undefined") { -- value = this.raw(node2, null, "beforeDecl"); -- } else if (value) { -- value = value.replace(/\S/g, ""); -- } -- return value; -- } -- rawBeforeDecl(root2, node2) { -- let value; -- root2.walkDecls((i2) => { -- if (typeof i2.raws.before !== "undefined") { -- value = i2.raws.before; -- if (value.includes("\n")) { -- value = value.replace(/[^\n]+$/, ""); -- } -- return false; -- } -- }); -- if (typeof value === "undefined") { -- value = this.raw(node2, null, "beforeRule"); -- } else if (value) { -- value = value.replace(/\S/g, ""); -- } -- return value; -- } -- rawBeforeOpen(root2) { -- let value; -- root2.walk((i2) => { -- if (i2.type !== "decl") { -- value = i2.raws.between; -- if (typeof value !== "undefined") return false; -- } -- }); -- return value; -- } -- rawBeforeRule(root2) { -- let value; -- root2.walk((i2) => { -- if (i2.nodes && (i2.parent !== root2 || root2.first !== i2)) { -- if (typeof i2.raws.before !== "undefined") { -- value = i2.raws.before; -- if (value.includes("\n")) { -- value = value.replace(/[^\n]+$/, ""); -- } -- return false; -- } -- } -- }); -- if (value) value = value.replace(/\S/g, ""); -- return value; -- } -- rawColon(root2) { -- let value; -- root2.walkDecls((i2) => { -- if (typeof i2.raws.between !== "undefined") { -- value = i2.raws.between.replace(/[^\s:]/g, ""); -- return false; -- } -- }); -- return value; -- } -- rawEmptyBody(root2) { -- let value; -- root2.walk((i2) => { -- if (i2.nodes && i2.nodes.length === 0) { -- value = i2.raws.after; -- if (typeof value !== "undefined") return false; -- } -- }); -- return value; -- } -- rawIndent(root2) { -- if (root2.raws.indent) return root2.raws.indent; -- let value; -- root2.walk((i2) => { -- let p = i2.parent; -- if (p && p !== root2 && p.parent && p.parent === root2) { -- if (typeof i2.raws.before !== "undefined") { -- let parts = i2.raws.before.split("\n"); -- value = parts[parts.length - 1]; -- value = value.replace(/\S/g, ""); -- return false; -- } -- } -- }); -- return value; -- } -- rawSemicolon(root2) { -- let value; -- root2.walk((i2) => { -- if (i2.nodes && i2.nodes.length && i2.last.type === "decl") { -- value = i2.raws.semicolon; -- if (typeof value !== "undefined") return false; -- } -- }); -- return value; -- } -- rawValue(node2, prop) { -- let value = node2[prop]; -- let raw = node2.raws[prop]; -- if (raw && raw.value === value) { -- return raw.raw; -- } -- return value; -- } -- root(node2) { -- this.body(node2); -- if (node2.raws.after) this.builder(node2.raws.after); -- } -- rule(node2) { -- this.block(node2, this.rawValue(node2, "selector")); -- if (node2.raws.ownSemicolon) { -- this.builder(node2.raws.ownSemicolon, node2, "end"); -- } -- } -- stringify(node2, semicolon) { -- if (!this[node2.type]) { -- throw new Error( -- "Unknown AST node type " + node2.type + ". Maybe you need to change PostCSS stringifier." -- ); -- } -- this[node2.type](node2, semicolon); -- } --}; --var stringifier$1 = Stringifier$2$1; --Stringifier$2$1.default = Stringifier$2$1; --let Stringifier$1$1 = stringifier$1; --function stringify$4$1(node2, builder) { -- let str = new Stringifier$1$1(builder); -- str.stringify(node2); --} --var stringify_1$1 = stringify$4$1; --stringify$4$1.default = stringify$4$1; --let { isClean: isClean$2$1, my: my$2$1 } = symbols$1; --let CssSyntaxError$2$1 = cssSyntaxError$1; --let Stringifier2$1 = stringifier$1; --let stringify$3$1 = stringify_1$1; --function cloneNode$1(obj, parent) { -- let cloned = new obj.constructor(); -- for (let i2 in obj) { -- if (!Object.prototype.hasOwnProperty.call(obj, i2)) { -- continue; -- } -- if (i2 === "proxyCache") continue; -- let value = obj[i2]; -- let type = typeof value; -- if (i2 === "parent" && type === "object") { -- if (parent) cloned[i2] = parent; -- } else if (i2 === "source") { -- cloned[i2] = value; -- } else if (Array.isArray(value)) { -- cloned[i2] = value.map((j) => cloneNode$1(j, cloned)); -- } else { -- if (type === "object" && value !== null) value = cloneNode$1(value); -- cloned[i2] = value; -- } -- } -- return cloned; --} --let Node$4$1 = class Node2 { -- constructor(defaults = {}) { -- this.raws = {}; -- this[isClean$2$1] = false; -- this[my$2$1] = true; -- for (let name in defaults) { -- if (name === "nodes") { -- this.nodes = []; -- for (let node2 of defaults[name]) { -- if (typeof node2.clone === "function") { -- this.append(node2.clone()); -- } else { -- this.append(node2); -- } -- } -- } else { -- this[name] = defaults[name]; -- } -- } -- } -- addToError(error) { -- error.postcssNode = this; -- if (error.stack && this.source && /\n\s{4}at /.test(error.stack)) { -- let s2 = this.source; -- error.stack = error.stack.replace( -- /\n\s{4}at /, -- `$&${s2.input.from}:${s2.start.line}:${s2.start.column}$&` -- ); -- } -- return error; -- } -- after(add) { -- this.parent.insertAfter(this, add); -- return this; -- } -- assign(overrides = {}) { -- for (let name in overrides) { -- this[name] = overrides[name]; -- } -- return this; -- } -- before(add) { -- this.parent.insertBefore(this, add); -- return this; -- } -- cleanRaws(keepBetween) { -- delete this.raws.before; -- delete this.raws.after; -- if (!keepBetween) delete this.raws.between; -- } -- clone(overrides = {}) { -- let cloned = cloneNode$1(this); -- for (let name in overrides) { -- cloned[name] = overrides[name]; -- } -- return cloned; -- } -- cloneAfter(overrides = {}) { -- let cloned = this.clone(overrides); -- this.parent.insertAfter(this, cloned); -- return cloned; -- } -- cloneBefore(overrides = {}) { -- let cloned = this.clone(overrides); -- this.parent.insertBefore(this, cloned); -- return cloned; -- } -- error(message, opts = {}) { -- if (this.source) { -- let { end, start } = this.rangeBy(opts); -- return this.source.input.error( -- message, -- { column: start.column, line: start.line }, -- { column: end.column, line: end.line }, -- opts -- ); -- } -- return new CssSyntaxError$2$1(message); -- } -- getProxyProcessor() { -- return { -- get(node2, prop) { -- if (prop === "proxyOf") { -- return node2; -- } else if (prop === "root") { -- return () => node2.root().toProxy(); -- } else { -- return node2[prop]; -- } -- }, -- set(node2, prop, value) { -- if (node2[prop] === value) return true; -- node2[prop] = value; -- if (prop === "prop" || prop === "value" || prop === "name" || prop === "params" || prop === "important" || /* c8 ignore next */ -- prop === "text") { -- node2.markDirty(); -- } -- return true; -- } -- }; -- } -- markDirty() { -- if (this[isClean$2$1]) { -- this[isClean$2$1] = false; -- let next = this; -- while (next = next.parent) { -- next[isClean$2$1] = false; -- } -- } -- } -- next() { -- if (!this.parent) return void 0; -- let index2 = this.parent.index(this); -- return this.parent.nodes[index2 + 1]; -- } -- positionBy(opts, stringRepresentation) { -- let pos = this.source.start; -- if (opts.index) { -- pos = this.positionInside(opts.index, stringRepresentation); -- } else if (opts.word) { -- stringRepresentation = this.toString(); -- let index2 = stringRepresentation.indexOf(opts.word); -- if (index2 !== -1) pos = this.positionInside(index2, stringRepresentation); -- } -- return pos; -- } -- positionInside(index2, stringRepresentation) { -- let string = stringRepresentation || this.toString(); -- let column = this.source.start.column; -- let line = this.source.start.line; -- for (let i2 = 0; i2 < index2; i2++) { -- if (string[i2] === "\n") { -- column = 1; -- line += 1; -- } else { -- column += 1; -- } -- } -- return { column, line }; -- } -- prev() { -- if (!this.parent) return void 0; -- let index2 = this.parent.index(this); -- return this.parent.nodes[index2 - 1]; -- } -- rangeBy(opts) { -- let start = { -- column: this.source.start.column, -- line: this.source.start.line -- }; -- let end = this.source.end ? { -- column: this.source.end.column + 1, -- line: this.source.end.line -- } : { -- column: start.column + 1, -- line: start.line -- }; -- if (opts.word) { -- let stringRepresentation = this.toString(); -- let index2 = stringRepresentation.indexOf(opts.word); -- if (index2 !== -1) { -- start = this.positionInside(index2, stringRepresentation); -- end = this.positionInside(index2 + opts.word.length, stringRepresentation); -- } -- } else { -- if (opts.start) { -- start = { -- column: opts.start.column, -- line: opts.start.line -- }; -- } else if (opts.index) { -- start = this.positionInside(opts.index); -- } -- if (opts.end) { -- end = { -- column: opts.end.column, -- line: opts.end.line -- }; -- } else if (typeof opts.endIndex === "number") { -- end = this.positionInside(opts.endIndex); -- } else if (opts.index) { -- end = this.positionInside(opts.index + 1); -- } -- } -- if (end.line < start.line || end.line === start.line && end.column <= start.column) { -- end = { column: start.column + 1, line: start.line }; -- } -- return { end, start }; -- } -- raw(prop, defaultType) { -- let str = new Stringifier2$1(); -- return str.raw(this, prop, defaultType); -- } -- remove() { -- if (this.parent) { -- this.parent.removeChild(this); -- } -- this.parent = void 0; -- return this; -- } -- replaceWith(...nodes) { -- if (this.parent) { -- let bookmark = this; -- let foundSelf = false; -- for (let node2 of nodes) { -- if (node2 === this) { -- foundSelf = true; -- } else if (foundSelf) { -- this.parent.insertAfter(bookmark, node2); -- bookmark = node2; -- } else { -- this.parent.insertBefore(bookmark, node2); -- } -- } -- if (!foundSelf) { -- this.remove(); -- } -- } -- return this; -- } -- root() { -- let result2 = this; -- while (result2.parent && result2.parent.type !== "document") { -- result2 = result2.parent; -- } -- return result2; -- } -- toJSON(_, inputs) { -- let fixed = {}; -- let emitInputs = inputs == null; -- inputs = inputs || /* @__PURE__ */ new Map(); -- let inputsNextIndex = 0; -- for (let name in this) { -- if (!Object.prototype.hasOwnProperty.call(this, name)) { -- continue; -- } -- if (name === "parent" || name === "proxyCache") continue; -- let value = this[name]; -- if (Array.isArray(value)) { -- fixed[name] = value.map((i2) => { -- if (typeof i2 === "object" && i2.toJSON) { -- return i2.toJSON(null, inputs); -- } else { -- return i2; -- } -- }); -- } else if (typeof value === "object" && value.toJSON) { -- fixed[name] = value.toJSON(null, inputs); -- } else if (name === "source") { -- let inputId = inputs.get(value.input); -- if (inputId == null) { -- inputId = inputsNextIndex; -- inputs.set(value.input, inputsNextIndex); -- inputsNextIndex++; -- } -- fixed[name] = { -- end: value.end, -- inputId, -- start: value.start -- }; -- } else { -- fixed[name] = value; -- } -- } -- if (emitInputs) { -- fixed.inputs = [...inputs.keys()].map((input2) => input2.toJSON()); -- } -- return fixed; -- } -- toProxy() { -- if (!this.proxyCache) { -- this.proxyCache = new Proxy(this, this.getProxyProcessor()); -- } -- return this.proxyCache; -- } -- toString(stringifier2 = stringify$3$1) { -- if (stringifier2.stringify) stringifier2 = stringifier2.stringify; -- let result2 = ""; -- stringifier2(this, (i2) => { -- result2 += i2; -- }); -- return result2; -- } -- warn(result2, text, opts) { -- let data = { node: this }; -- for (let i2 in opts) data[i2] = opts[i2]; -- return result2.warn(text, data); -- } -- get proxyOf() { -- return this; -- } --}; --var node$1 = Node$4$1; --Node$4$1.default = Node$4$1; --let Node$3$1 = node$1; --let Declaration$4$1 = class Declaration extends Node$3$1 { -- constructor(defaults) { -- if (defaults && typeof defaults.value !== "undefined" && typeof defaults.value !== "string") { -- defaults = { ...defaults, value: String(defaults.value) }; -- } -- super(defaults); -- this.type = "decl"; -- } -- get variable() { -- return this.prop.startsWith("--") || this.prop[0] === "$"; -- } --}; --var declaration$1 = Declaration$4$1; --Declaration$4$1.default = Declaration$4$1; --let urlAlphabet$1 = "useandom-26T198340PX75pxJACKVERYMINDBUSHWOLF_GQZbfghjklqvwyzrict"; --let customAlphabet$1 = (alphabet, defaultSize = 21) => { -- return (size = defaultSize) => { -- let id = ""; -- let i2 = size; -- while (i2--) { -- id += alphabet[Math.random() * alphabet.length | 0]; -- } -- return id; -- }; --}; --let nanoid$1$1 = (size = 21) => { -- let id = ""; -- let i2 = size; -- while (i2--) { -- id += urlAlphabet$1[Math.random() * 64 | 0]; -- } -- return id; --}; --var nonSecure$1 = { nanoid: nanoid$1$1, customAlphabet: customAlphabet$1 }; --let { SourceMapConsumer: SourceMapConsumer$2$1, SourceMapGenerator: SourceMapGenerator$2$1 } = require$$2$1; --let { existsSync: existsSync$1, readFileSync: readFileSync$1 } = require$$2$1; --let { dirname: dirname$1$1, join: join$1 } = require$$2$1; --function fromBase64$1(str) { -- if (Buffer) { -- return Buffer.from(str, "base64").toString(); -- } else { -- return window.atob(str); -- } --} --let PreviousMap$2$1 = class PreviousMap { -- constructor(css, opts) { -- if (opts.map === false) return; -- this.loadAnnotation(css); -- this.inline = this.startWith(this.annotation, "data:"); -- let prev = opts.map ? opts.map.prev : void 0; -- let text = this.loadMap(opts.from, prev); -- if (!this.mapFile && opts.from) { -- this.mapFile = opts.from; -- } -- if (this.mapFile) this.root = dirname$1$1(this.mapFile); -- if (text) this.text = text; -- } -- consumer() { -- if (!this.consumerCache) { -- this.consumerCache = new SourceMapConsumer$2$1(this.text); -- } -- return this.consumerCache; -- } -- decodeInline(text) { -- let baseCharsetUri = /^data:application\/json;charset=utf-?8;base64,/; -- let baseUri = /^data:application\/json;base64,/; -- let charsetUri = /^data:application\/json;charset=utf-?8,/; -- let uri = /^data:application\/json,/; -- if (charsetUri.test(text) || uri.test(text)) { -- return decodeURIComponent(text.substr(RegExp.lastMatch.length)); -- } -- if (baseCharsetUri.test(text) || baseUri.test(text)) { -- return fromBase64$1(text.substr(RegExp.lastMatch.length)); -- } -- let encoding = text.match(/data:application\/json;([^,]+),/)[1]; -- throw new Error("Unsupported source map encoding " + encoding); -- } -- getAnnotationURL(sourceMapString) { -- return sourceMapString.replace(/^\/\*\s*# sourceMappingURL=/, "").trim(); -- } -- isMap(map) { -- if (typeof map !== "object") return false; -- return typeof map.mappings === "string" || typeof map._mappings === "string" || Array.isArray(map.sections); -- } -- loadAnnotation(css) { -- let comments = css.match(/\/\*\s*# sourceMappingURL=/gm); -- if (!comments) return; -- let start = css.lastIndexOf(comments.pop()); -- let end = css.indexOf("*/", start); -- if (start > -1 && end > -1) { -- this.annotation = this.getAnnotationURL(css.substring(start, end)); -- } -- } -- loadFile(path) { -- this.root = dirname$1$1(path); -- if (existsSync$1(path)) { -- this.mapFile = path; -- return readFileSync$1(path, "utf-8").toString().trim(); -- } -- } -- loadMap(file, prev) { -- if (prev === false) return false; -- if (prev) { -- if (typeof prev === "string") { -- return prev; -- } else if (typeof prev === "function") { -- let prevPath = prev(file); -- if (prevPath) { -- let map = this.loadFile(prevPath); -- if (!map) { -- throw new Error( -- "Unable to load previous source map: " + prevPath.toString() -- ); -- } -- return map; -- } -- } else if (prev instanceof SourceMapConsumer$2$1) { -- return SourceMapGenerator$2$1.fromSourceMap(prev).toString(); -- } else if (prev instanceof SourceMapGenerator$2$1) { -- return prev.toString(); -- } else if (this.isMap(prev)) { -- return JSON.stringify(prev); -- } else { -- throw new Error( -- "Unsupported previous source map format: " + prev.toString() -- ); -- } -- } else if (this.inline) { -- return this.decodeInline(this.annotation); -- } else if (this.annotation) { -- let map = this.annotation; -- if (file) map = join$1(dirname$1$1(file), map); -- return this.loadFile(map); -- } -- } -- startWith(string, start) { -- if (!string) return false; -- return string.substr(0, start.length) === start; -- } -- withContent() { -- return !!(this.consumer().sourcesContent && this.consumer().sourcesContent.length > 0); -- } --}; --var previousMap$1 = PreviousMap$2$1; --PreviousMap$2$1.default = PreviousMap$2$1; --let { SourceMapConsumer: SourceMapConsumer$1$1, SourceMapGenerator: SourceMapGenerator$1$1 } = require$$2$1; --let { fileURLToPath: fileURLToPath$1, pathToFileURL: pathToFileURL$1$1 } = require$$2$1; --let { isAbsolute: isAbsolute$1, resolve: resolve$1$1 } = require$$2$1; --let { nanoid: nanoid$2 } = nonSecure$1; --let terminalHighlight$2 = require$$2$1; --let CssSyntaxError$1$1 = cssSyntaxError$1; --let PreviousMap$1$1 = previousMap$1; --let fromOffsetCache$1 = Symbol("fromOffsetCache"); --let sourceMapAvailable$1$1 = Boolean(SourceMapConsumer$1$1 && SourceMapGenerator$1$1); --let pathAvailable$1$1 = Boolean(resolve$1$1 && isAbsolute$1); --let Input$4$1 = class Input { -- constructor(css, opts = {}) { -- if (css === null || typeof css === "undefined" || typeof css === "object" && !css.toString) { -- throw new Error(`PostCSS received ${css} instead of CSS string`); -- } -- this.css = css.toString(); -- if (this.css[0] === "\uFEFF" || this.css[0] === "￾") { -- this.hasBOM = true; -- this.css = this.css.slice(1); -- } else { -- this.hasBOM = false; -- } -- if (opts.from) { -- if (!pathAvailable$1$1 || /^\w+:\/\//.test(opts.from) || isAbsolute$1(opts.from)) { -- this.file = opts.from; -- } else { -- this.file = resolve$1$1(opts.from); -- } -- } -- if (pathAvailable$1$1 && sourceMapAvailable$1$1) { -- let map = new PreviousMap$1$1(this.css, opts); -- if (map.text) { -- this.map = map; -- let file = map.consumer().file; -- if (!this.file && file) this.file = this.mapResolve(file); -- } -- } -- if (!this.file) { -- this.id = ""; -- } -- if (this.map) this.map.file = this.from; -- } -- error(message, line, column, opts = {}) { -- let result2, endLine, endColumn; -- if (line && typeof line === "object") { -- let start = line; -- let end = column; -- if (typeof start.offset === "number") { -- let pos = this.fromOffset(start.offset); -- line = pos.line; -- column = pos.col; -- } else { -- line = start.line; -- column = start.column; -- } -- if (typeof end.offset === "number") { -- let pos = this.fromOffset(end.offset); -- endLine = pos.line; -- endColumn = pos.col; -- } else { -- endLine = end.line; -- endColumn = end.column; -- } -- } else if (!column) { -- let pos = this.fromOffset(line); -- line = pos.line; -- column = pos.col; -- } -- let origin = this.origin(line, column, endLine, endColumn); -- if (origin) { -- result2 = new CssSyntaxError$1$1( -- message, -- origin.endLine === void 0 ? origin.line : { column: origin.column, line: origin.line }, -- origin.endLine === void 0 ? origin.column : { column: origin.endColumn, line: origin.endLine }, -- origin.source, -- origin.file, -- opts.plugin -- ); -- } else { -- result2 = new CssSyntaxError$1$1( -- message, -- endLine === void 0 ? line : { column, line }, -- endLine === void 0 ? column : { column: endColumn, line: endLine }, -- this.css, -- this.file, -- opts.plugin -- ); -- } -- result2.input = { column, endColumn, endLine, line, source: this.css }; -- if (this.file) { -- if (pathToFileURL$1$1) { -- result2.input.url = pathToFileURL$1$1(this.file).toString(); -- } -- result2.input.file = this.file; -- } -- return result2; -- } -- fromOffset(offset) { -- let lastLine, lineToIndex; -- if (!this[fromOffsetCache$1]) { -- let lines = this.css.split("\n"); -- lineToIndex = new Array(lines.length); -- let prevIndex = 0; -- for (let i2 = 0, l2 = lines.length; i2 < l2; i2++) { -- lineToIndex[i2] = prevIndex; -- prevIndex += lines[i2].length + 1; -- } -- this[fromOffsetCache$1] = lineToIndex; -- } else { -- lineToIndex = this[fromOffsetCache$1]; -- } -- lastLine = lineToIndex[lineToIndex.length - 1]; -- let min = 0; -- if (offset >= lastLine) { -- min = lineToIndex.length - 1; -- } else { -- let max = lineToIndex.length - 2; -- let mid; -- while (min < max) { -- mid = min + (max - min >> 1); -- if (offset < lineToIndex[mid]) { -- max = mid - 1; -- } else if (offset >= lineToIndex[mid + 1]) { -- min = mid + 1; -- } else { -- min = mid; -- break; -- } -- } -- } -- return { -- col: offset - lineToIndex[min] + 1, -- line: min + 1 -- }; -- } -- mapResolve(file) { -- if (/^\w+:\/\//.test(file)) { -- return file; -- } -- return resolve$1$1(this.map.consumer().sourceRoot || this.map.root || ".", file); -- } -- origin(line, column, endLine, endColumn) { -- if (!this.map) return false; -- let consumer = this.map.consumer(); -- let from = consumer.originalPositionFor({ column, line }); -- if (!from.source) return false; -- let to; -- if (typeof endLine === "number") { -- to = consumer.originalPositionFor({ column: endColumn, line: endLine }); -- } -- let fromUrl; -- if (isAbsolute$1(from.source)) { -- fromUrl = pathToFileURL$1$1(from.source); -- } else { -- fromUrl = new URL( -- from.source, -- this.map.consumer().sourceRoot || pathToFileURL$1$1(this.map.mapFile) -- ); -- } -- let result2 = { -- column: from.column, -- endColumn: to && to.column, -- endLine: to && to.line, -- line: from.line, -- url: fromUrl.toString() -- }; -- if (fromUrl.protocol === "file:") { -- if (fileURLToPath$1) { -- result2.file = fileURLToPath$1(fromUrl); -- } else { -- throw new Error(`file: protocol is not available in this PostCSS build`); -- } -- } -- let source = consumer.sourceContentFor(from.source); -- if (source) result2.source = source; -- return result2; -- } -- toJSON() { -- let json = {}; -- for (let name of ["hasBOM", "css", "file", "id"]) { -- if (this[name] != null) { -- json[name] = this[name]; -- } -- } -- if (this.map) { -- json.map = { ...this.map }; -- if (json.map.consumerCache) { -- json.map.consumerCache = void 0; -- } -- } -- return json; -- } -- get from() { -- return this.file || this.id; -- } --}; --var input$1 = Input$4$1; --Input$4$1.default = Input$4$1; --if (terminalHighlight$2 && terminalHighlight$2.registerInput) { -- terminalHighlight$2.registerInput(Input$4$1); --} --let { SourceMapConsumer: SourceMapConsumer$3, SourceMapGenerator: SourceMapGenerator$3 } = require$$2$1; --let { dirname: dirname$2, relative: relative$1, resolve: resolve$2, sep: sep$1 } = require$$2$1; --let { pathToFileURL: pathToFileURL$2 } = require$$2$1; --let Input$3$1 = input$1; --let sourceMapAvailable$2 = Boolean(SourceMapConsumer$3 && SourceMapGenerator$3); --let pathAvailable$2 = Boolean(dirname$2 && resolve$2 && relative$1 && sep$1); --let MapGenerator$2$1 = class MapGenerator { -- constructor(stringify2, root2, opts, cssString) { -- this.stringify = stringify2; -- this.mapOpts = opts.map || {}; -- this.root = root2; -- this.opts = opts; -- this.css = cssString; -- this.originalCSS = cssString; -- this.usesFileUrls = !this.mapOpts.from && this.mapOpts.absolute; -- this.memoizedFileURLs = /* @__PURE__ */ new Map(); -- this.memoizedPaths = /* @__PURE__ */ new Map(); -- this.memoizedURLs = /* @__PURE__ */ new Map(); -- } -- addAnnotation() { -- let content; -- if (this.isInline()) { -- content = "data:application/json;base64," + this.toBase64(this.map.toString()); -- } else if (typeof this.mapOpts.annotation === "string") { -- content = this.mapOpts.annotation; -- } else if (typeof this.mapOpts.annotation === "function") { -- content = this.mapOpts.annotation(this.opts.to, this.root); -- } else { -- content = this.outputFile() + ".map"; -- } -- let eol = "\n"; -- if (this.css.includes("\r\n")) eol = "\r\n"; -- this.css += eol + "/*# sourceMappingURL=" + content + " */"; -- } -- applyPrevMaps() { -- for (let prev of this.previous()) { -- let from = this.toUrl(this.path(prev.file)); -- let root2 = prev.root || dirname$2(prev.file); -- let map; -- if (this.mapOpts.sourcesContent === false) { -- map = new SourceMapConsumer$3(prev.text); -- if (map.sourcesContent) { -- map.sourcesContent = null; -- } -- } else { -- map = prev.consumer(); -- } -- this.map.applySourceMap(map, from, this.toUrl(this.path(root2))); -- } -- } -- clearAnnotation() { -- if (this.mapOpts.annotation === false) return; -- if (this.root) { -- let node2; -- for (let i2 = this.root.nodes.length - 1; i2 >= 0; i2--) { -- node2 = this.root.nodes[i2]; -- if (node2.type !== "comment") continue; -- if (node2.text.indexOf("# sourceMappingURL=") === 0) { -- this.root.removeChild(i2); -- } -- } -- } else if (this.css) { -- this.css = this.css.replace(/\n*?\/\*#[\S\s]*?\*\/$/gm, ""); -- } -- } -- generate() { -- this.clearAnnotation(); -- if (pathAvailable$2 && sourceMapAvailable$2 && this.isMap()) { -- return this.generateMap(); -- } else { -- let result2 = ""; -- this.stringify(this.root, (i2) => { -- result2 += i2; -- }); -- return [result2]; -- } -- } -- generateMap() { -- if (this.root) { -- this.generateString(); -- } else if (this.previous().length === 1) { -- let prev = this.previous()[0].consumer(); -- prev.file = this.outputFile(); -- this.map = SourceMapGenerator$3.fromSourceMap(prev, { -- ignoreInvalidMapping: true -- }); -- } else { -- this.map = new SourceMapGenerator$3({ -- file: this.outputFile(), -- ignoreInvalidMapping: true -- }); -- this.map.addMapping({ -- generated: { column: 0, line: 1 }, -- original: { column: 0, line: 1 }, -- source: this.opts.from ? this.toUrl(this.path(this.opts.from)) : "" -- }); -- } -- if (this.isSourcesContent()) this.setSourcesContent(); -- if (this.root && this.previous().length > 0) this.applyPrevMaps(); -- if (this.isAnnotation()) this.addAnnotation(); -- if (this.isInline()) { -- return [this.css]; -- } else { -- return [this.css, this.map]; -- } -- } -- generateString() { -- this.css = ""; -- this.map = new SourceMapGenerator$3({ -- file: this.outputFile(), -- ignoreInvalidMapping: true -- }); -- let line = 1; -- let column = 1; -- let noSource = ""; -- let mapping = { -- generated: { column: 0, line: 0 }, -- original: { column: 0, line: 0 }, -- source: "" -- }; -- let lines, last; -- this.stringify(this.root, (str, node2, type) => { -- this.css += str; -- if (node2 && type !== "end") { -- mapping.generated.line = line; -- mapping.generated.column = column - 1; -- if (node2.source && node2.source.start) { -- mapping.source = this.sourcePath(node2); -- mapping.original.line = node2.source.start.line; -- mapping.original.column = node2.source.start.column - 1; -- this.map.addMapping(mapping); -- } else { -- mapping.source = noSource; -- mapping.original.line = 1; -- mapping.original.column = 0; -- this.map.addMapping(mapping); -- } -- } -- lines = str.match(/\n/g); -- if (lines) { -- line += lines.length; -- last = str.lastIndexOf("\n"); -- column = str.length - last; -- } else { -- column += str.length; -- } -- if (node2 && type !== "start") { -- let p = node2.parent || { raws: {} }; -- let childless = node2.type === "decl" || node2.type === "atrule" && !node2.nodes; -- if (!childless || node2 !== p.last || p.raws.semicolon) { -- if (node2.source && node2.source.end) { -- mapping.source = this.sourcePath(node2); -- mapping.original.line = node2.source.end.line; -- mapping.original.column = node2.source.end.column - 1; -- mapping.generated.line = line; -- mapping.generated.column = column - 2; -- this.map.addMapping(mapping); -- } else { -- mapping.source = noSource; -- mapping.original.line = 1; -- mapping.original.column = 0; -- mapping.generated.line = line; -- mapping.generated.column = column - 1; -- this.map.addMapping(mapping); -- } -- } -- } -- }); -- } -- isAnnotation() { -- if (this.isInline()) { -- return true; -- } -- if (typeof this.mapOpts.annotation !== "undefined") { -- return this.mapOpts.annotation; -- } -- if (this.previous().length) { -- return this.previous().some((i2) => i2.annotation); -- } -- return true; -- } -- isInline() { -- if (typeof this.mapOpts.inline !== "undefined") { -- return this.mapOpts.inline; -- } -- let annotation = this.mapOpts.annotation; -- if (typeof annotation !== "undefined" && annotation !== true) { -- return false; -- } -- if (this.previous().length) { -- return this.previous().some((i2) => i2.inline); -- } -- return true; -- } -- isMap() { -- if (typeof this.opts.map !== "undefined") { -- return !!this.opts.map; -- } -- return this.previous().length > 0; -- } -- isSourcesContent() { -- if (typeof this.mapOpts.sourcesContent !== "undefined") { -- return this.mapOpts.sourcesContent; -- } -- if (this.previous().length) { -- return this.previous().some((i2) => i2.withContent()); -- } -- return true; -- } -- outputFile() { -- if (this.opts.to) { -- return this.path(this.opts.to); -- } else if (this.opts.from) { -- return this.path(this.opts.from); -- } else { -- return "to.css"; -- } -- } -- path(file) { -- if (this.mapOpts.absolute) return file; -- if (file.charCodeAt(0) === 60) return file; -- if (/^\w+:\/\//.test(file)) return file; -- let cached = this.memoizedPaths.get(file); -- if (cached) return cached; -- let from = this.opts.to ? dirname$2(this.opts.to) : "."; -- if (typeof this.mapOpts.annotation === "string") { -- from = dirname$2(resolve$2(from, this.mapOpts.annotation)); -- } -- let path = relative$1(from, file); -- this.memoizedPaths.set(file, path); -- return path; -- } -- previous() { -- if (!this.previousMaps) { -- this.previousMaps = []; -- if (this.root) { -- this.root.walk((node2) => { -- if (node2.source && node2.source.input.map) { -- let map = node2.source.input.map; -- if (!this.previousMaps.includes(map)) { -- this.previousMaps.push(map); -- } -- } -- }); -- } else { -- let input2 = new Input$3$1(this.originalCSS, this.opts); -- if (input2.map) this.previousMaps.push(input2.map); -- } -- } -- return this.previousMaps; -- } -- setSourcesContent() { -- let already = {}; -- if (this.root) { -- this.root.walk((node2) => { -- if (node2.source) { -- let from = node2.source.input.from; -- if (from && !already[from]) { -- already[from] = true; -- let fromUrl = this.usesFileUrls ? this.toFileUrl(from) : this.toUrl(this.path(from)); -- this.map.setSourceContent(fromUrl, node2.source.input.css); -- } -- } -- }); -- } else if (this.css) { -- let from = this.opts.from ? this.toUrl(this.path(this.opts.from)) : ""; -- this.map.setSourceContent(from, this.css); -- } -- } -- sourcePath(node2) { -- if (this.mapOpts.from) { -- return this.toUrl(this.mapOpts.from); -- } else if (this.usesFileUrls) { -- return this.toFileUrl(node2.source.input.from); -- } else { -- return this.toUrl(this.path(node2.source.input.from)); -- } -- } -- toBase64(str) { -- if (Buffer) { -- return Buffer.from(str).toString("base64"); -- } else { -- return window.btoa(unescape(encodeURIComponent(str))); -- } -- } -- toFileUrl(path) { -- let cached = this.memoizedFileURLs.get(path); -- if (cached) return cached; -- if (pathToFileURL$2) { -- let fileURL = pathToFileURL$2(path).toString(); -- this.memoizedFileURLs.set(path, fileURL); -- return fileURL; -- } else { -- throw new Error( -- "`map.absolute` option is not available in this PostCSS build" -- ); -- } -- } -- toUrl(path) { -- let cached = this.memoizedURLs.get(path); -- if (cached) return cached; -- if (sep$1 === "\\") { -- path = path.replace(/\\/g, "/"); -- } -- let url = encodeURI(path).replace(/[#?]/g, encodeURIComponent); -- this.memoizedURLs.set(path, url); -- return url; -- } --}; --var mapGenerator$1 = MapGenerator$2$1; --let Node$2$1 = node$1; --let Comment$4$1 = class Comment extends Node$2$1 { -- constructor(defaults) { -- super(defaults); -- this.type = "comment"; -- } --}; --var comment$1 = Comment$4$1; --Comment$4$1.default = Comment$4$1; --let { isClean: isClean$1$1, my: my$1$1 } = symbols$1; --let Declaration$3$1 = declaration$1; --let Comment$3$1 = comment$1; --let Node$1$1 = node$1; --let parse$4$1, Rule$4$1, AtRule$4$1, Root$6$1; --function cleanSource$1(nodes) { -- return nodes.map((i2) => { -- if (i2.nodes) i2.nodes = cleanSource$1(i2.nodes); -- delete i2.source; -- return i2; -- }); --} --function markDirtyUp$1(node2) { -- node2[isClean$1$1] = false; -- if (node2.proxyOf.nodes) { -- for (let i2 of node2.proxyOf.nodes) { -- markDirtyUp$1(i2); -- } -- } --} --let Container$7$1 = class Container extends Node$1$1 { -- append(...children) { -- for (let child of children) { -- let nodes = this.normalize(child, this.last); -- for (let node2 of nodes) this.proxyOf.nodes.push(node2); -- } -- this.markDirty(); -- return this; -- } -- cleanRaws(keepBetween) { -- super.cleanRaws(keepBetween); -- if (this.nodes) { -- for (let node2 of this.nodes) node2.cleanRaws(keepBetween); -- } -- } -- each(callback) { -- if (!this.proxyOf.nodes) return void 0; -- let iterator = this.getIterator(); -- let index2, result2; -- while (this.indexes[iterator] < this.proxyOf.nodes.length) { -- index2 = this.indexes[iterator]; -- result2 = callback(this.proxyOf.nodes[index2], index2); -- if (result2 === false) break; -- this.indexes[iterator] += 1; -- } -- delete this.indexes[iterator]; -- return result2; -- } -- every(condition) { -- return this.nodes.every(condition); -- } -- getIterator() { -- if (!this.lastEach) this.lastEach = 0; -- if (!this.indexes) this.indexes = {}; -- this.lastEach += 1; -- let iterator = this.lastEach; -- this.indexes[iterator] = 0; -- return iterator; -- } -- getProxyProcessor() { -- return { -- get(node2, prop) { -- if (prop === "proxyOf") { -- return node2; -- } else if (!node2[prop]) { -- return node2[prop]; -- } else if (prop === "each" || typeof prop === "string" && prop.startsWith("walk")) { -- return (...args) => { -- return node2[prop]( -- ...args.map((i2) => { -- if (typeof i2 === "function") { -- return (child, index2) => i2(child.toProxy(), index2); -- } else { -- return i2; -- } -- }) -- ); -- }; -- } else if (prop === "every" || prop === "some") { -- return (cb) => { -- return node2[prop]( -- (child, ...other) => cb(child.toProxy(), ...other) -- ); -- }; -- } else if (prop === "root") { -- return () => node2.root().toProxy(); -- } else if (prop === "nodes") { -- return node2.nodes.map((i2) => i2.toProxy()); -- } else if (prop === "first" || prop === "last") { -- return node2[prop].toProxy(); -- } else { -- return node2[prop]; -- } -- }, -- set(node2, prop, value) { -- if (node2[prop] === value) return true; -- node2[prop] = value; -- if (prop === "name" || prop === "params" || prop === "selector") { -- node2.markDirty(); -- } -- return true; -- } -- }; -- } -- index(child) { -- if (typeof child === "number") return child; -- if (child.proxyOf) child = child.proxyOf; -- return this.proxyOf.nodes.indexOf(child); -- } -- insertAfter(exist, add) { -- let existIndex = this.index(exist); -- let nodes = this.normalize(add, this.proxyOf.nodes[existIndex]).reverse(); -- existIndex = this.index(exist); -- for (let node2 of nodes) this.proxyOf.nodes.splice(existIndex + 1, 0, node2); -- let index2; -- for (let id in this.indexes) { -- index2 = this.indexes[id]; -- if (existIndex < index2) { -- this.indexes[id] = index2 + nodes.length; -- } -- } -- this.markDirty(); -- return this; -- } -- insertBefore(exist, add) { -- let existIndex = this.index(exist); -- let type = existIndex === 0 ? "prepend" : false; -- let nodes = this.normalize(add, this.proxyOf.nodes[existIndex], type).reverse(); -- existIndex = this.index(exist); -- for (let node2 of nodes) this.proxyOf.nodes.splice(existIndex, 0, node2); -- let index2; -- for (let id in this.indexes) { -- index2 = this.indexes[id]; -- if (existIndex <= index2) { -- this.indexes[id] = index2 + nodes.length; -- } -- } -- this.markDirty(); -- return this; -- } -- normalize(nodes, sample) { -- if (typeof nodes === "string") { -- nodes = cleanSource$1(parse$4$1(nodes).nodes); -- } else if (typeof nodes === "undefined") { -- nodes = []; -- } else if (Array.isArray(nodes)) { -- nodes = nodes.slice(0); -- for (let i2 of nodes) { -- if (i2.parent) i2.parent.removeChild(i2, "ignore"); -- } -- } else if (nodes.type === "root" && this.type !== "document") { -- nodes = nodes.nodes.slice(0); -- for (let i2 of nodes) { -- if (i2.parent) i2.parent.removeChild(i2, "ignore"); -- } -- } else if (nodes.type) { -- nodes = [nodes]; -- } else if (nodes.prop) { -- if (typeof nodes.value === "undefined") { -- throw new Error("Value field is missed in node creation"); -- } else if (typeof nodes.value !== "string") { -- nodes.value = String(nodes.value); -- } -- nodes = [new Declaration$3$1(nodes)]; -- } else if (nodes.selector) { -- nodes = [new Rule$4$1(nodes)]; -- } else if (nodes.name) { -- nodes = [new AtRule$4$1(nodes)]; -- } else if (nodes.text) { -- nodes = [new Comment$3$1(nodes)]; -- } else { -- throw new Error("Unknown node type in node creation"); -- } -- let processed = nodes.map((i2) => { -- if (!i2[my$1$1]) Container.rebuild(i2); -- i2 = i2.proxyOf; -- if (i2.parent) i2.parent.removeChild(i2); -- if (i2[isClean$1$1]) markDirtyUp$1(i2); -- if (typeof i2.raws.before === "undefined") { -- if (sample && typeof sample.raws.before !== "undefined") { -- i2.raws.before = sample.raws.before.replace(/\S/g, ""); -- } -- } -- i2.parent = this.proxyOf; -- return i2; -- }); -- return processed; -- } -- prepend(...children) { -- children = children.reverse(); -- for (let child of children) { -- let nodes = this.normalize(child, this.first, "prepend").reverse(); -- for (let node2 of nodes) this.proxyOf.nodes.unshift(node2); -- for (let id in this.indexes) { -- this.indexes[id] = this.indexes[id] + nodes.length; -- } -- } -- this.markDirty(); -- return this; -- } -- push(child) { -- child.parent = this; -- this.proxyOf.nodes.push(child); -- return this; -- } -- removeAll() { -- for (let node2 of this.proxyOf.nodes) node2.parent = void 0; -- this.proxyOf.nodes = []; -- this.markDirty(); -- return this; -- } -- removeChild(child) { -- child = this.index(child); -- this.proxyOf.nodes[child].parent = void 0; -- this.proxyOf.nodes.splice(child, 1); -- let index2; -- for (let id in this.indexes) { -- index2 = this.indexes[id]; -- if (index2 >= child) { -- this.indexes[id] = index2 - 1; -- } -- } -- this.markDirty(); -- return this; -- } -- replaceValues(pattern, opts, callback) { -- if (!callback) { -- callback = opts; -- opts = {}; -- } -- this.walkDecls((decl) => { -- if (opts.props && !opts.props.includes(decl.prop)) return; -- if (opts.fast && !decl.value.includes(opts.fast)) return; -- decl.value = decl.value.replace(pattern, callback); -- }); -- this.markDirty(); -- return this; -- } -- some(condition) { -- return this.nodes.some(condition); -- } -- walk(callback) { -- return this.each((child, i2) => { -- let result2; -- try { -- result2 = callback(child, i2); -- } catch (e2) { -- throw child.addToError(e2); -- } -- if (result2 !== false && child.walk) { -- result2 = child.walk(callback); -- } -- return result2; -- }); -- } -- walkAtRules(name, callback) { -- if (!callback) { -- callback = name; -- return this.walk((child, i2) => { -- if (child.type === "atrule") { -- return callback(child, i2); -- } -- }); -- } -- if (name instanceof RegExp) { -- return this.walk((child, i2) => { -- if (child.type === "atrule" && name.test(child.name)) { -- return callback(child, i2); -- } -- }); -- } -- return this.walk((child, i2) => { -- if (child.type === "atrule" && child.name === name) { -- return callback(child, i2); -- } -- }); -- } -- walkComments(callback) { -- return this.walk((child, i2) => { -- if (child.type === "comment") { -- return callback(child, i2); -- } -- }); -- } -- walkDecls(prop, callback) { -- if (!callback) { -- callback = prop; -- return this.walk((child, i2) => { -- if (child.type === "decl") { -- return callback(child, i2); -- } -- }); -- } -- if (prop instanceof RegExp) { -- return this.walk((child, i2) => { -- if (child.type === "decl" && prop.test(child.prop)) { -- return callback(child, i2); -- } -- }); -- } -- return this.walk((child, i2) => { -- if (child.type === "decl" && child.prop === prop) { -- return callback(child, i2); -- } -- }); -- } -- walkRules(selector, callback) { -- if (!callback) { -- callback = selector; -- return this.walk((child, i2) => { -- if (child.type === "rule") { -- return callback(child, i2); -- } -- }); -- } -- if (selector instanceof RegExp) { -- return this.walk((child, i2) => { -- if (child.type === "rule" && selector.test(child.selector)) { -- return callback(child, i2); -- } -- }); -- } -- return this.walk((child, i2) => { -- if (child.type === "rule" && child.selector === selector) { -- return callback(child, i2); -- } -- }); -- } -- get first() { -- if (!this.proxyOf.nodes) return void 0; -- return this.proxyOf.nodes[0]; -- } -- get last() { -- if (!this.proxyOf.nodes) return void 0; -- return this.proxyOf.nodes[this.proxyOf.nodes.length - 1]; -- } --}; --Container$7$1.registerParse = (dependant) => { -- parse$4$1 = dependant; --}; --Container$7$1.registerRule = (dependant) => { -- Rule$4$1 = dependant; --}; --Container$7$1.registerAtRule = (dependant) => { -- AtRule$4$1 = dependant; --}; --Container$7$1.registerRoot = (dependant) => { -- Root$6$1 = dependant; --}; --var container$1 = Container$7$1; --Container$7$1.default = Container$7$1; --Container$7$1.rebuild = (node2) => { -- if (node2.type === "atrule") { -- Object.setPrototypeOf(node2, AtRule$4$1.prototype); -- } else if (node2.type === "rule") { -- Object.setPrototypeOf(node2, Rule$4$1.prototype); -- } else if (node2.type === "decl") { -- Object.setPrototypeOf(node2, Declaration$3$1.prototype); -- } else if (node2.type === "comment") { -- Object.setPrototypeOf(node2, Comment$3$1.prototype); -- } else if (node2.type === "root") { -- Object.setPrototypeOf(node2, Root$6$1.prototype); -- } -- node2[my$1$1] = true; -- if (node2.nodes) { -- node2.nodes.forEach((child) => { -- Container$7$1.rebuild(child); -- }); -- } --}; --let Container$6$1 = container$1; --let LazyResult$4$1, Processor$3$1; --let Document$3$1 = class Document2 extends Container$6$1 { -- constructor(defaults) { -- super({ type: "document", ...defaults }); -- if (!this.nodes) { -- this.nodes = []; -- } -- } -- toResult(opts = {}) { -- let lazy = new LazyResult$4$1(new Processor$3$1(), this, opts); -- return lazy.stringify(); -- } --}; --Document$3$1.registerLazyResult = (dependant) => { -- LazyResult$4$1 = dependant; --}; --Document$3$1.registerProcessor = (dependant) => { -- Processor$3$1 = dependant; --}; --var document$1$1 = Document$3$1; --Document$3$1.default = Document$3$1; --let printed$1 = {}; --var warnOnce$2$1 = function warnOnce(message) { -- if (printed$1[message]) return; -- printed$1[message] = true; -- if (typeof console !== "undefined" && console.warn) { -- console.warn(message); -- } --}; --let Warning$2$1 = class Warning { -- constructor(text, opts = {}) { -- this.type = "warning"; -- this.text = text; -- if (opts.node && opts.node.source) { -- let range = opts.node.rangeBy(opts); -- this.line = range.start.line; -- this.column = range.start.column; -- this.endLine = range.end.line; -- this.endColumn = range.end.column; -- } -- for (let opt in opts) this[opt] = opts[opt]; -- } -- toString() { -- if (this.node) { -- return this.node.error(this.text, { -- index: this.index, -- plugin: this.plugin, -- word: this.word -- }).message; -- } -- if (this.plugin) { -- return this.plugin + ": " + this.text; -- } -- return this.text; -- } --}; --var warning$1 = Warning$2$1; --Warning$2$1.default = Warning$2$1; --let Warning$1$1 = warning$1; --let Result$3$1 = class Result { -- constructor(processor2, root2, opts) { -- this.processor = processor2; -- this.messages = []; -- this.root = root2; -- this.opts = opts; -- this.css = void 0; -- this.map = void 0; -- } -- toString() { -- return this.css; -- } -- warn(text, opts = {}) { -- if (!opts.plugin) { -- if (this.lastPlugin && this.lastPlugin.postcssPlugin) { -- opts.plugin = this.lastPlugin.postcssPlugin; -- } -- } -- let warning2 = new Warning$1$1(text, opts); -- this.messages.push(warning2); -- return warning2; -- } -- warnings() { -- return this.messages.filter((i2) => i2.type === "warning"); -- } -- get content() { -- return this.css; -- } --}; --var result$1 = Result$3$1; --Result$3$1.default = Result$3$1; --const SINGLE_QUOTE$1 = "'".charCodeAt(0); --const DOUBLE_QUOTE$1 = '"'.charCodeAt(0); --const BACKSLASH$1 = "\\".charCodeAt(0); --const SLASH$1 = "/".charCodeAt(0); --const NEWLINE$1 = "\n".charCodeAt(0); --const SPACE$1 = " ".charCodeAt(0); --const FEED$1 = "\f".charCodeAt(0); --const TAB$1 = " ".charCodeAt(0); --const CR$1 = "\r".charCodeAt(0); --const OPEN_SQUARE$1 = "[".charCodeAt(0); --const CLOSE_SQUARE$1 = "]".charCodeAt(0); --const OPEN_PARENTHESES$1 = "(".charCodeAt(0); --const CLOSE_PARENTHESES$1 = ")".charCodeAt(0); --const OPEN_CURLY$1 = "{".charCodeAt(0); --const CLOSE_CURLY$1 = "}".charCodeAt(0); --const SEMICOLON$1 = ";".charCodeAt(0); --const ASTERISK$1 = "*".charCodeAt(0); --const COLON$1 = ":".charCodeAt(0); --const AT$1 = "@".charCodeAt(0); --const RE_AT_END$1 = /[\t\n\f\r "#'()/;[\\\]{}]/g; --const RE_WORD_END$1 = /[\t\n\f\r !"#'():;@[\\\]{}]|\/(?=\*)/g; --const RE_BAD_BRACKET$1 = /.[\r\n"'(/\\]/; --const RE_HEX_ESCAPE$1 = /[\da-f]/i; --var tokenize$1 = function tokenizer(input2, options = {}) { -- let css = input2.css.valueOf(); -- let ignore = options.ignoreErrors; -- let code, next, quote, content, escape; -- let escaped, escapePos, prev, n2, currentToken; -- let length = css.length; -- let pos = 0; -- let buffer = []; -- let returned = []; -- function position() { -- return pos; -- } -- function unclosed(what) { -- throw input2.error("Unclosed " + what, pos); -- } -- function endOfFile() { -- return returned.length === 0 && pos >= length; -- } -- function nextToken(opts) { -- if (returned.length) return returned.pop(); -- if (pos >= length) return; -- let ignoreUnclosed = opts ? opts.ignoreUnclosed : false; -- code = css.charCodeAt(pos); -- switch (code) { -- case NEWLINE$1: -- case SPACE$1: -- case TAB$1: -- case CR$1: -- case FEED$1: { -- next = pos; -- do { -- next += 1; -- code = css.charCodeAt(next); -- } while (code === SPACE$1 || code === NEWLINE$1 || code === TAB$1 || code === CR$1 || code === FEED$1); -- currentToken = ["space", css.slice(pos, next)]; -- pos = next - 1; -- break; -- } -- case OPEN_SQUARE$1: -- case CLOSE_SQUARE$1: -- case OPEN_CURLY$1: -- case CLOSE_CURLY$1: -- case COLON$1: -- case SEMICOLON$1: -- case CLOSE_PARENTHESES$1: { -- let controlChar = String.fromCharCode(code); -- currentToken = [controlChar, controlChar, pos]; -- break; -- } -- case OPEN_PARENTHESES$1: { -- prev = buffer.length ? buffer.pop()[1] : ""; -- n2 = css.charCodeAt(pos + 1); -- if (prev === "url" && n2 !== SINGLE_QUOTE$1 && n2 !== DOUBLE_QUOTE$1 && n2 !== SPACE$1 && n2 !== NEWLINE$1 && n2 !== TAB$1 && n2 !== FEED$1 && n2 !== CR$1) { -- next = pos; -- do { -- escaped = false; -- next = css.indexOf(")", next + 1); -- if (next === -1) { -- if (ignore || ignoreUnclosed) { -- next = pos; -- break; -- } else { -- unclosed("bracket"); -- } -- } -- escapePos = next; -- while (css.charCodeAt(escapePos - 1) === BACKSLASH$1) { -- escapePos -= 1; -- escaped = !escaped; -- } -- } while (escaped); -- currentToken = ["brackets", css.slice(pos, next + 1), pos, next]; -- pos = next; -- } else { -- next = css.indexOf(")", pos + 1); -- content = css.slice(pos, next + 1); -- if (next === -1 || RE_BAD_BRACKET$1.test(content)) { -- currentToken = ["(", "(", pos]; -- } else { -- currentToken = ["brackets", content, pos, next]; -- pos = next; -- } -- } -- break; -- } -- case SINGLE_QUOTE$1: -- case DOUBLE_QUOTE$1: { -- quote = code === SINGLE_QUOTE$1 ? "'" : '"'; -- next = pos; -- do { -- escaped = false; -- next = css.indexOf(quote, next + 1); -- if (next === -1) { -- if (ignore || ignoreUnclosed) { -- next = pos + 1; -- break; -- } else { -- unclosed("string"); -- } -- } -- escapePos = next; -- while (css.charCodeAt(escapePos - 1) === BACKSLASH$1) { -- escapePos -= 1; -- escaped = !escaped; -- } -- } while (escaped); -- currentToken = ["string", css.slice(pos, next + 1), pos, next]; -- pos = next; -- break; -- } -- case AT$1: { -- RE_AT_END$1.lastIndex = pos + 1; -- RE_AT_END$1.test(css); -- if (RE_AT_END$1.lastIndex === 0) { -- next = css.length - 1; -- } else { -- next = RE_AT_END$1.lastIndex - 2; -- } -- currentToken = ["at-word", css.slice(pos, next + 1), pos, next]; -- pos = next; -- break; -- } -- case BACKSLASH$1: { -- next = pos; -- escape = true; -- while (css.charCodeAt(next + 1) === BACKSLASH$1) { -- next += 1; -- escape = !escape; -- } -- code = css.charCodeAt(next + 1); -- if (escape && code !== SLASH$1 && code !== SPACE$1 && code !== NEWLINE$1 && code !== TAB$1 && code !== CR$1 && code !== FEED$1) { -- next += 1; -- if (RE_HEX_ESCAPE$1.test(css.charAt(next))) { -- while (RE_HEX_ESCAPE$1.test(css.charAt(next + 1))) { -- next += 1; -- } -- if (css.charCodeAt(next + 1) === SPACE$1) { -- next += 1; -- } -- } -- } -- currentToken = ["word", css.slice(pos, next + 1), pos, next]; -- pos = next; -- break; -- } -- default: { -- if (code === SLASH$1 && css.charCodeAt(pos + 1) === ASTERISK$1) { -- next = css.indexOf("*/", pos + 2) + 1; -- if (next === 0) { -- if (ignore || ignoreUnclosed) { -- next = css.length; -- } else { -- unclosed("comment"); -- } -- } -- currentToken = ["comment", css.slice(pos, next + 1), pos, next]; -- pos = next; -- } else { -- RE_WORD_END$1.lastIndex = pos + 1; -- RE_WORD_END$1.test(css); -- if (RE_WORD_END$1.lastIndex === 0) { -- next = css.length - 1; -- } else { -- next = RE_WORD_END$1.lastIndex - 2; -- } -- currentToken = ["word", css.slice(pos, next + 1), pos, next]; -- buffer.push(currentToken); -- pos = next; -- } -- break; -- } -- } -- pos++; -- return currentToken; -- } -- function back(token) { -- returned.push(token); -- } -- return { -- back, -- endOfFile, -- nextToken, -- position -- }; --}; --let Container$5$1 = container$1; --let AtRule$3$1 = class AtRule extends Container$5$1 { -- constructor(defaults) { -- super(defaults); -- this.type = "atrule"; -- } -- append(...children) { -- if (!this.proxyOf.nodes) this.nodes = []; -- return super.append(...children); -- } -- prepend(...children) { -- if (!this.proxyOf.nodes) this.nodes = []; -- return super.prepend(...children); -- } --}; --var atRule$1 = AtRule$3$1; --AtRule$3$1.default = AtRule$3$1; --Container$5$1.registerAtRule(AtRule$3$1); --let Container$4$1 = container$1; --let LazyResult$3$1, Processor$2$1; --let Root$5$1 = class Root extends Container$4$1 { -- constructor(defaults) { -- super(defaults); -- this.type = "root"; -- if (!this.nodes) this.nodes = []; -- } -- normalize(child, sample, type) { -- let nodes = super.normalize(child); -- if (sample) { -- if (type === "prepend") { -- if (this.nodes.length > 1) { -- sample.raws.before = this.nodes[1].raws.before; -- } else { -- delete sample.raws.before; -- } -- } else if (this.first !== sample) { -- for (let node2 of nodes) { -- node2.raws.before = sample.raws.before; -- } -- } -- } -- return nodes; -- } -- removeChild(child, ignore) { -- let index2 = this.index(child); -- if (!ignore && index2 === 0 && this.nodes.length > 1) { -- this.nodes[1].raws.before = this.nodes[index2].raws.before; -- } -- return super.removeChild(child); -- } -- toResult(opts = {}) { -- let lazy = new LazyResult$3$1(new Processor$2$1(), this, opts); -- return lazy.stringify(); -- } --}; --Root$5$1.registerLazyResult = (dependant) => { -- LazyResult$3$1 = dependant; --}; --Root$5$1.registerProcessor = (dependant) => { -- Processor$2$1 = dependant; --}; --var root$1 = Root$5$1; --Root$5$1.default = Root$5$1; --Container$4$1.registerRoot(Root$5$1); --let list$2$1 = { -- comma(string) { -- return list$2$1.split(string, [","], true); -- }, -- space(string) { -- let spaces = [" ", "\n", " "]; -- return list$2$1.split(string, spaces); -- }, -- split(string, separators, last) { -- let array = []; -- let current = ""; -- let split = false; -- let func = 0; -- let inQuote = false; -- let prevQuote = ""; -- let escape = false; -- for (let letter of string) { -- if (escape) { -- escape = false; -- } else if (letter === "\\") { -- escape = true; -- } else if (inQuote) { -- if (letter === prevQuote) { -- inQuote = false; -- } -- } else if (letter === '"' || letter === "'") { -- inQuote = true; -- prevQuote = letter; -- } else if (letter === "(") { -- func += 1; -- } else if (letter === ")") { -- if (func > 0) func -= 1; -- } else if (func === 0) { -- if (separators.includes(letter)) split = true; -- } -- if (split) { -- if (current !== "") array.push(current.trim()); -- current = ""; -- split = false; -- } else { -- current += letter; -- } -- } -- if (last || current !== "") array.push(current.trim()); -- return array; -- } --}; --var list_1$1 = list$2$1; --list$2$1.default = list$2$1; --let Container$3$1 = container$1; --let list$1$1 = list_1$1; --let Rule$3$1 = class Rule extends Container$3$1 { -- constructor(defaults) { -- super(defaults); -- this.type = "rule"; -- if (!this.nodes) this.nodes = []; -- } -- get selectors() { -- return list$1$1.comma(this.selector); -- } -- set selectors(values) { -- let match = this.selector ? this.selector.match(/,\s*/) : null; -- let sep2 = match ? match[0] : "," + this.raw("between", "beforeOpen"); -- this.selector = values.join(sep2); -- } --}; --var rule$1 = Rule$3$1; --Rule$3$1.default = Rule$3$1; --Container$3$1.registerRule(Rule$3$1); --let Declaration$2$1 = declaration$1; --let tokenizer2$1 = tokenize$1; --let Comment$2$1 = comment$1; --let AtRule$2$1 = atRule$1; --let Root$4$1 = root$1; --let Rule$2$1 = rule$1; --const SAFE_COMMENT_NEIGHBOR$1 = { -- empty: true, -- space: true --}; --function findLastWithPosition$1(tokens) { -- for (let i2 = tokens.length - 1; i2 >= 0; i2--) { -- let token = tokens[i2]; -- let pos = token[3] || token[2]; -- if (pos) return pos; -- } --} --let Parser$1$1 = class Parser { -- constructor(input2) { -- this.input = input2; -- this.root = new Root$4$1(); -- this.current = this.root; -- this.spaces = ""; -- this.semicolon = false; -- this.createTokenizer(); -- this.root.source = { input: input2, start: { column: 1, line: 1, offset: 0 } }; -- } -- atrule(token) { -- let node2 = new AtRule$2$1(); -- node2.name = token[1].slice(1); -- if (node2.name === "") { -- this.unnamedAtrule(node2, token); -- } -- this.init(node2, token[2]); -- let type; -- let prev; -- let shift; -- let last = false; -- let open = false; -- let params = []; -- let brackets = []; -- while (!this.tokenizer.endOfFile()) { -- token = this.tokenizer.nextToken(); -- type = token[0]; -- if (type === "(" || type === "[") { -- brackets.push(type === "(" ? ")" : "]"); -- } else if (type === "{" && brackets.length > 0) { -- brackets.push("}"); -- } else if (type === brackets[brackets.length - 1]) { -- brackets.pop(); -- } -- if (brackets.length === 0) { -- if (type === ";") { -- node2.source.end = this.getPosition(token[2]); -- node2.source.end.offset++; -- this.semicolon = true; -- break; -- } else if (type === "{") { -- open = true; -- break; -- } else if (type === "}") { -- if (params.length > 0) { -- shift = params.length - 1; -- prev = params[shift]; -- while (prev && prev[0] === "space") { -- prev = params[--shift]; -- } -- if (prev) { -- node2.source.end = this.getPosition(prev[3] || prev[2]); -- node2.source.end.offset++; -- } -- } -- this.end(token); -- break; -- } else { -- params.push(token); -- } -- } else { -- params.push(token); -- } -- if (this.tokenizer.endOfFile()) { -- last = true; -- break; -- } -- } -- node2.raws.between = this.spacesAndCommentsFromEnd(params); -- if (params.length) { -- node2.raws.afterName = this.spacesAndCommentsFromStart(params); -- this.raw(node2, "params", params); -- if (last) { -- token = params[params.length - 1]; -- node2.source.end = this.getPosition(token[3] || token[2]); -- node2.source.end.offset++; -- this.spaces = node2.raws.between; -- node2.raws.between = ""; -- } -- } else { -- node2.raws.afterName = ""; -- node2.params = ""; -- } -- if (open) { -- node2.nodes = []; -- this.current = node2; -- } -- } -- checkMissedSemicolon(tokens) { -- let colon = this.colon(tokens); -- if (colon === false) return; -- let founded = 0; -- let token; -- for (let j = colon - 1; j >= 0; j--) { -- token = tokens[j]; -- if (token[0] !== "space") { -- founded += 1; -- if (founded === 2) break; -- } -- } -- throw this.input.error( -- "Missed semicolon", -- token[0] === "word" ? token[3] + 1 : token[2] -- ); -- } -- colon(tokens) { -- let brackets = 0; -- let token, type, prev; -- for (let [i2, element] of tokens.entries()) { -- token = element; -- type = token[0]; -- if (type === "(") { -- brackets += 1; -- } -- if (type === ")") { -- brackets -= 1; -- } -- if (brackets === 0 && type === ":") { -- if (!prev) { -- this.doubleColon(token); -- } else if (prev[0] === "word" && prev[1] === "progid") { -- continue; -- } else { -- return i2; -- } -- } -- prev = token; -- } -- return false; -- } -- comment(token) { -- let node2 = new Comment$2$1(); -- this.init(node2, token[2]); -- node2.source.end = this.getPosition(token[3] || token[2]); -- node2.source.end.offset++; -- let text = token[1].slice(2, -2); -- if (/^\s*$/.test(text)) { -- node2.text = ""; -- node2.raws.left = text; -- node2.raws.right = ""; -- } else { -- let match = text.match(/^(\s*)([^]*\S)(\s*)$/); -- node2.text = match[2]; -- node2.raws.left = match[1]; -- node2.raws.right = match[3]; -- } -- } -- createTokenizer() { -- this.tokenizer = tokenizer2$1(this.input); -- } -- decl(tokens, customProperty) { -- let node2 = new Declaration$2$1(); -- this.init(node2, tokens[0][2]); -- let last = tokens[tokens.length - 1]; -- if (last[0] === ";") { -- this.semicolon = true; -- tokens.pop(); -- } -- node2.source.end = this.getPosition( -- last[3] || last[2] || findLastWithPosition$1(tokens) -- ); -- node2.source.end.offset++; -- while (tokens[0][0] !== "word") { -- if (tokens.length === 1) this.unknownWord(tokens); -- node2.raws.before += tokens.shift()[1]; -- } -- node2.source.start = this.getPosition(tokens[0][2]); -- node2.prop = ""; -- while (tokens.length) { -- let type = tokens[0][0]; -- if (type === ":" || type === "space" || type === "comment") { -- break; -- } -- node2.prop += tokens.shift()[1]; -- } -- node2.raws.between = ""; -- let token; -- while (tokens.length) { -- token = tokens.shift(); -- if (token[0] === ":") { -- node2.raws.between += token[1]; -- break; -- } else { -- if (token[0] === "word" && /\w/.test(token[1])) { -- this.unknownWord([token]); -- } -- node2.raws.between += token[1]; -- } -- } -- if (node2.prop[0] === "_" || node2.prop[0] === "*") { -- node2.raws.before += node2.prop[0]; -- node2.prop = node2.prop.slice(1); -- } -- let firstSpaces = []; -- let next; -- while (tokens.length) { -- next = tokens[0][0]; -- if (next !== "space" && next !== "comment") break; -- firstSpaces.push(tokens.shift()); -- } -- this.precheckMissedSemicolon(tokens); -- for (let i2 = tokens.length - 1; i2 >= 0; i2--) { -- token = tokens[i2]; -- if (token[1].toLowerCase() === "!important") { -- node2.important = true; -- let string = this.stringFrom(tokens, i2); -- string = this.spacesFromEnd(tokens) + string; -- if (string !== " !important") node2.raws.important = string; -- break; -- } else if (token[1].toLowerCase() === "important") { -- let cache = tokens.slice(0); -- let str = ""; -- for (let j = i2; j > 0; j--) { -- let type = cache[j][0]; -- if (str.trim().indexOf("!") === 0 && type !== "space") { -- break; -- } -- str = cache.pop()[1] + str; -- } -- if (str.trim().indexOf("!") === 0) { -- node2.important = true; -- node2.raws.important = str; -- tokens = cache; -- } -- } -- if (token[0] !== "space" && token[0] !== "comment") { -- break; -- } -- } -- let hasWord = tokens.some((i2) => i2[0] !== "space" && i2[0] !== "comment"); -- if (hasWord) { -- node2.raws.between += firstSpaces.map((i2) => i2[1]).join(""); -- firstSpaces = []; -- } -- this.raw(node2, "value", firstSpaces.concat(tokens), customProperty); -- if (node2.value.includes(":") && !customProperty) { -- this.checkMissedSemicolon(tokens); -- } -- } -- doubleColon(token) { -- throw this.input.error( -- "Double colon", -- { offset: token[2] }, -- { offset: token[2] + token[1].length } -- ); -- } -- emptyRule(token) { -- let node2 = new Rule$2$1(); -- this.init(node2, token[2]); -- node2.selector = ""; -- node2.raws.between = ""; -- this.current = node2; -- } -- end(token) { -- if (this.current.nodes && this.current.nodes.length) { -- this.current.raws.semicolon = this.semicolon; -- } -- this.semicolon = false; -- this.current.raws.after = (this.current.raws.after || "") + this.spaces; -- this.spaces = ""; -- if (this.current.parent) { -- this.current.source.end = this.getPosition(token[2]); -- this.current.source.end.offset++; -- this.current = this.current.parent; -- } else { -- this.unexpectedClose(token); -- } -- } -- endFile() { -- if (this.current.parent) this.unclosedBlock(); -- if (this.current.nodes && this.current.nodes.length) { -- this.current.raws.semicolon = this.semicolon; -- } -- this.current.raws.after = (this.current.raws.after || "") + this.spaces; -- this.root.source.end = this.getPosition(this.tokenizer.position()); -- } -- freeSemicolon(token) { -- this.spaces += token[1]; -- if (this.current.nodes) { -- let prev = this.current.nodes[this.current.nodes.length - 1]; -- if (prev && prev.type === "rule" && !prev.raws.ownSemicolon) { -- prev.raws.ownSemicolon = this.spaces; -- this.spaces = ""; -- } -- } -- } -- // Helpers -- getPosition(offset) { -- let pos = this.input.fromOffset(offset); -- return { -- column: pos.col, -- line: pos.line, -- offset -- }; -- } -- init(node2, offset) { -- this.current.push(node2); -- node2.source = { -- input: this.input, -- start: this.getPosition(offset) -- }; -- node2.raws.before = this.spaces; -- this.spaces = ""; -- if (node2.type !== "comment") this.semicolon = false; -- } -- other(start) { -- let end = false; -- let type = null; -- let colon = false; -- let bracket = null; -- let brackets = []; -- let customProperty = start[1].startsWith("--"); -- let tokens = []; -- let token = start; -- while (token) { -- type = token[0]; -- tokens.push(token); -- if (type === "(" || type === "[") { -- if (!bracket) bracket = token; -- brackets.push(type === "(" ? ")" : "]"); -- } else if (customProperty && colon && type === "{") { -- if (!bracket) bracket = token; -- brackets.push("}"); -- } else if (brackets.length === 0) { -- if (type === ";") { -- if (colon) { -- this.decl(tokens, customProperty); -- return; -- } else { -- break; -- } -- } else if (type === "{") { -- this.rule(tokens); -- return; -- } else if (type === "}") { -- this.tokenizer.back(tokens.pop()); -- end = true; -- break; -- } else if (type === ":") { -- colon = true; -- } -- } else if (type === brackets[brackets.length - 1]) { -- brackets.pop(); -- if (brackets.length === 0) bracket = null; -- } -- token = this.tokenizer.nextToken(); -- } -- if (this.tokenizer.endOfFile()) end = true; -- if (brackets.length > 0) this.unclosedBracket(bracket); -- if (end && colon) { -- if (!customProperty) { -- while (tokens.length) { -- token = tokens[tokens.length - 1][0]; -- if (token !== "space" && token !== "comment") break; -- this.tokenizer.back(tokens.pop()); -- } -- } -- this.decl(tokens, customProperty); -- } else { -- this.unknownWord(tokens); -- } -- } -- parse() { -- let token; -- while (!this.tokenizer.endOfFile()) { -- token = this.tokenizer.nextToken(); -- switch (token[0]) { -- case "space": -- this.spaces += token[1]; -- break; -- case ";": -- this.freeSemicolon(token); -- break; -- case "}": -- this.end(token); -- break; -- case "comment": -- this.comment(token); -- break; -- case "at-word": -- this.atrule(token); -- break; -- case "{": -- this.emptyRule(token); -- break; -- default: -- this.other(token); -- break; -- } -- } -- this.endFile(); -- } -- precheckMissedSemicolon() { -- } -- raw(node2, prop, tokens, customProperty) { -- let token, type; -- let length = tokens.length; -- let value = ""; -- let clean = true; -- let next, prev; -- for (let i2 = 0; i2 < length; i2 += 1) { -- token = tokens[i2]; -- type = token[0]; -- if (type === "space" && i2 === length - 1 && !customProperty) { -- clean = false; -- } else if (type === "comment") { -- prev = tokens[i2 - 1] ? tokens[i2 - 1][0] : "empty"; -- next = tokens[i2 + 1] ? tokens[i2 + 1][0] : "empty"; -- if (!SAFE_COMMENT_NEIGHBOR$1[prev] && !SAFE_COMMENT_NEIGHBOR$1[next]) { -- if (value.slice(-1) === ",") { -- clean = false; -- } else { -- value += token[1]; -- } -- } else { -- clean = false; -- } -- } else { -- value += token[1]; -- } -- } -- if (!clean) { -- let raw = tokens.reduce((all, i2) => all + i2[1], ""); -- node2.raws[prop] = { raw, value }; -- } -- node2[prop] = value; -- } -- rule(tokens) { -- tokens.pop(); -- let node2 = new Rule$2$1(); -- this.init(node2, tokens[0][2]); -- node2.raws.between = this.spacesAndCommentsFromEnd(tokens); -- this.raw(node2, "selector", tokens); -- this.current = node2; -- } -- spacesAndCommentsFromEnd(tokens) { -- let lastTokenType; -- let spaces = ""; -- while (tokens.length) { -- lastTokenType = tokens[tokens.length - 1][0]; -- if (lastTokenType !== "space" && lastTokenType !== "comment") break; -- spaces = tokens.pop()[1] + spaces; -- } -- return spaces; -- } -- // Errors -- spacesAndCommentsFromStart(tokens) { -- let next; -- let spaces = ""; -- while (tokens.length) { -- next = tokens[0][0]; -- if (next !== "space" && next !== "comment") break; -- spaces += tokens.shift()[1]; -- } -- return spaces; -- } -- spacesFromEnd(tokens) { -- let lastTokenType; -- let spaces = ""; -- while (tokens.length) { -- lastTokenType = tokens[tokens.length - 1][0]; -- if (lastTokenType !== "space") break; -- spaces = tokens.pop()[1] + spaces; -- } -- return spaces; -- } -- stringFrom(tokens, from) { -- let result2 = ""; -- for (let i2 = from; i2 < tokens.length; i2++) { -- result2 += tokens[i2][1]; -- } -- tokens.splice(from, tokens.length - from); -- return result2; -- } -- unclosedBlock() { -- let pos = this.current.source.start; -- throw this.input.error("Unclosed block", pos.line, pos.column); -- } -- unclosedBracket(bracket) { -- throw this.input.error( -- "Unclosed bracket", -- { offset: bracket[2] }, -- { offset: bracket[2] + 1 } -- ); -- } -- unexpectedClose(token) { -- throw this.input.error( -- "Unexpected }", -- { offset: token[2] }, -- { offset: token[2] + 1 } -- ); -- } -- unknownWord(tokens) { -- throw this.input.error( -- "Unknown word", -- { offset: tokens[0][2] }, -- { offset: tokens[0][2] + tokens[0][1].length } -- ); -- } -- unnamedAtrule(node2, token) { -- throw this.input.error( -- "At-rule without name", -- { offset: token[2] }, -- { offset: token[2] + token[1].length } -- ); -- } --}; --var parser$1 = Parser$1$1; --let Container$2$1 = container$1; --let Parser2$1 = parser$1; --let Input$2$1 = input$1; --function parse$3$1(css, opts) { -- let input2 = new Input$2$1(css, opts); -- let parser2 = new Parser2$1(input2); -- try { -- parser2.parse(); -- } catch (e2) { -- if (process.env.NODE_ENV !== "production") { -- if (e2.name === "CssSyntaxError" && opts && opts.from) { -- if (/\.scss$/i.test(opts.from)) { -- e2.message += "\nYou tried to parse SCSS with the standard CSS parser; try again with the postcss-scss parser"; -- } else if (/\.sass/i.test(opts.from)) { -- e2.message += "\nYou tried to parse Sass with the standard CSS parser; try again with the postcss-sass parser"; -- } else if (/\.less$/i.test(opts.from)) { -- e2.message += "\nYou tried to parse Less with the standard CSS parser; try again with the postcss-less parser"; -- } -- } -- } -- throw e2; -- } -- return parser2.root; --} --var parse_1$1 = parse$3$1; --parse$3$1.default = parse$3$1; --Container$2$1.registerParse(parse$3$1); --let { isClean: isClean$3, my: my$3 } = symbols$1; --let MapGenerator$1$1 = mapGenerator$1; --let stringify$2$1 = stringify_1$1; --let Container$1$1 = container$1; --let Document$2$1 = document$1$1; --let warnOnce$1$1 = warnOnce$2$1; --let Result$2$1 = result$1; --let parse$2$1 = parse_1$1; --let Root$3$1 = root$1; --const TYPE_TO_CLASS_NAME$1 = { -- atrule: "AtRule", -- comment: "Comment", -- decl: "Declaration", -- document: "Document", -- root: "Root", -- rule: "Rule" --}; --const PLUGIN_PROPS$1 = { -- AtRule: true, -- AtRuleExit: true, -- Comment: true, -- CommentExit: true, -- Declaration: true, -- DeclarationExit: true, -- Document: true, -- DocumentExit: true, -- Once: true, -- OnceExit: true, -- postcssPlugin: true, -- prepare: true, -- Root: true, -- RootExit: true, -- Rule: true, -- RuleExit: true --}; --const NOT_VISITORS$1 = { -- Once: true, -- postcssPlugin: true, -- prepare: true --}; --const CHILDREN$1 = 0; --function isPromise$1(obj) { -- return typeof obj === "object" && typeof obj.then === "function"; --} --function getEvents$1(node2) { -- let key = false; -- let type = TYPE_TO_CLASS_NAME$1[node2.type]; -- if (node2.type === "decl") { -- key = node2.prop.toLowerCase(); -- } else if (node2.type === "atrule") { -- key = node2.name.toLowerCase(); -- } -- if (key && node2.append) { -- return [ -- type, -- type + "-" + key, -- CHILDREN$1, -- type + "Exit", -- type + "Exit-" + key -- ]; -- } else if (key) { -- return [type, type + "-" + key, type + "Exit", type + "Exit-" + key]; -- } else if (node2.append) { -- return [type, CHILDREN$1, type + "Exit"]; -- } else { -- return [type, type + "Exit"]; -- } --} --function toStack$1(node2) { -- let events; -- if (node2.type === "document") { -- events = ["Document", CHILDREN$1, "DocumentExit"]; -- } else if (node2.type === "root") { -- events = ["Root", CHILDREN$1, "RootExit"]; -- } else { -- events = getEvents$1(node2); -- } -- return { -- eventIndex: 0, -- events, -- iterator: 0, -- node: node2, -- visitorIndex: 0, -- visitors: [] -- }; --} --function cleanMarks$1(node2) { -- node2[isClean$3] = false; -- if (node2.nodes) node2.nodes.forEach((i2) => cleanMarks$1(i2)); -- return node2; --} --let postcss$2$1 = {}; --let LazyResult$2$1 = class LazyResult { -- constructor(processor2, css, opts) { -- this.stringified = false; -- this.processed = false; -- let root2; -- if (typeof css === "object" && css !== null && (css.type === "root" || css.type === "document")) { -- root2 = cleanMarks$1(css); -- } else if (css instanceof LazyResult || css instanceof Result$2$1) { -- root2 = cleanMarks$1(css.root); -- if (css.map) { -- if (typeof opts.map === "undefined") opts.map = {}; -- if (!opts.map.inline) opts.map.inline = false; -- opts.map.prev = css.map; -- } -- } else { -- let parser2 = parse$2$1; -- if (opts.syntax) parser2 = opts.syntax.parse; -- if (opts.parser) parser2 = opts.parser; -- if (parser2.parse) parser2 = parser2.parse; -- try { -- root2 = parser2(css, opts); -- } catch (error) { -- this.processed = true; -- this.error = error; -- } -- if (root2 && !root2[my$3]) { -- Container$1$1.rebuild(root2); -- } -- } -- this.result = new Result$2$1(processor2, root2, opts); -- this.helpers = { ...postcss$2$1, postcss: postcss$2$1, result: this.result }; -- this.plugins = this.processor.plugins.map((plugin22) => { -- if (typeof plugin22 === "object" && plugin22.prepare) { -- return { ...plugin22, ...plugin22.prepare(this.result) }; -- } else { -- return plugin22; -- } -- }); -- } -- async() { -- if (this.error) return Promise.reject(this.error); -- if (this.processed) return Promise.resolve(this.result); -- if (!this.processing) { -- this.processing = this.runAsync(); -- } -- return this.processing; -- } -- catch(onRejected) { -- return this.async().catch(onRejected); -- } -- finally(onFinally) { -- return this.async().then(onFinally, onFinally); -- } -- getAsyncError() { -- throw new Error("Use process(css).then(cb) to work with async plugins"); -- } -- handleError(error, node2) { -- let plugin22 = this.result.lastPlugin; -- try { -- if (node2) node2.addToError(error); -- this.error = error; -- if (error.name === "CssSyntaxError" && !error.plugin) { -- error.plugin = plugin22.postcssPlugin; -- error.setMessage(); -- } else if (plugin22.postcssVersion) { -- if (process.env.NODE_ENV !== "production") { -- let pluginName = plugin22.postcssPlugin; -- let pluginVer = plugin22.postcssVersion; -- let runtimeVer = this.result.processor.version; -- let a2 = pluginVer.split("."); -- let b = runtimeVer.split("."); -- if (a2[0] !== b[0] || parseInt(a2[1]) > parseInt(b[1])) { -- console.error( -- "Unknown error from PostCSS plugin. Your current PostCSS version is " + runtimeVer + ", but " + pluginName + " uses " + pluginVer + ". Perhaps this is the source of the error below." -- ); -- } -- } -- } -- } catch (err) { -- if (console && console.error) console.error(err); -- } -- return error; -- } -- prepareVisitors() { -- this.listeners = {}; -- let add = (plugin22, type, cb) => { -- if (!this.listeners[type]) this.listeners[type] = []; -- this.listeners[type].push([plugin22, cb]); -- }; -- for (let plugin22 of this.plugins) { -- if (typeof plugin22 === "object") { -- for (let event in plugin22) { -- if (!PLUGIN_PROPS$1[event] && /^[A-Z]/.test(event)) { -- throw new Error( -- `Unknown event ${event} in ${plugin22.postcssPlugin}. Try to update PostCSS (${this.processor.version} now).` -- ); -- } -- if (!NOT_VISITORS$1[event]) { -- if (typeof plugin22[event] === "object") { -- for (let filter in plugin22[event]) { -- if (filter === "*") { -- add(plugin22, event, plugin22[event][filter]); -- } else { -- add( -- plugin22, -- event + "-" + filter.toLowerCase(), -- plugin22[event][filter] -- ); -- } -- } -- } else if (typeof plugin22[event] === "function") { -- add(plugin22, event, plugin22[event]); -- } -- } -- } -- } -- } -- this.hasListener = Object.keys(this.listeners).length > 0; -- } -- async runAsync() { -- this.plugin = 0; -- for (let i2 = 0; i2 < this.plugins.length; i2++) { -- let plugin22 = this.plugins[i2]; -- let promise = this.runOnRoot(plugin22); -- if (isPromise$1(promise)) { -- try { -- await promise; -- } catch (error) { -- throw this.handleError(error); -- } -- } -- } -- this.prepareVisitors(); -- if (this.hasListener) { -- let root2 = this.result.root; -- while (!root2[isClean$3]) { -- root2[isClean$3] = true; -- let stack = [toStack$1(root2)]; -- while (stack.length > 0) { -- let promise = this.visitTick(stack); -- if (isPromise$1(promise)) { -- try { -- await promise; -- } catch (e2) { -- let node2 = stack[stack.length - 1].node; -- throw this.handleError(e2, node2); -- } -- } -- } -- } -- if (this.listeners.OnceExit) { -- for (let [plugin22, visitor] of this.listeners.OnceExit) { -- this.result.lastPlugin = plugin22; -- try { -- if (root2.type === "document") { -- let roots = root2.nodes.map( -- (subRoot) => visitor(subRoot, this.helpers) -- ); -- await Promise.all(roots); -- } else { -- await visitor(root2, this.helpers); -- } -- } catch (e2) { -- throw this.handleError(e2); -- } -- } -- } -- } -- this.processed = true; -- return this.stringify(); -- } -- runOnRoot(plugin22) { -- this.result.lastPlugin = plugin22; -- try { -- if (typeof plugin22 === "object" && plugin22.Once) { -- if (this.result.root.type === "document") { -- let roots = this.result.root.nodes.map( -- (root2) => plugin22.Once(root2, this.helpers) -- ); -- if (isPromise$1(roots[0])) { -- return Promise.all(roots); -- } -- return roots; -- } -- return plugin22.Once(this.result.root, this.helpers); -- } else if (typeof plugin22 === "function") { -- return plugin22(this.result.root, this.result); -- } -- } catch (error) { -- throw this.handleError(error); -- } -- } -- stringify() { -- if (this.error) throw this.error; -- if (this.stringified) return this.result; -- this.stringified = true; -- this.sync(); -- let opts = this.result.opts; -- let str = stringify$2$1; -- if (opts.syntax) str = opts.syntax.stringify; -- if (opts.stringifier) str = opts.stringifier; -- if (str.stringify) str = str.stringify; -- let map = new MapGenerator$1$1(str, this.result.root, this.result.opts); -- let data = map.generate(); -- this.result.css = data[0]; -- this.result.map = data[1]; -- return this.result; -- } -- sync() { -- if (this.error) throw this.error; -- if (this.processed) return this.result; -- this.processed = true; -- if (this.processing) { -- throw this.getAsyncError(); -- } -- for (let plugin22 of this.plugins) { -- let promise = this.runOnRoot(plugin22); -- if (isPromise$1(promise)) { -- throw this.getAsyncError(); -- } -- } -- this.prepareVisitors(); -- if (this.hasListener) { -- let root2 = this.result.root; -- while (!root2[isClean$3]) { -- root2[isClean$3] = true; -- this.walkSync(root2); -- } -- if (this.listeners.OnceExit) { -- if (root2.type === "document") { -- for (let subRoot of root2.nodes) { -- this.visitSync(this.listeners.OnceExit, subRoot); -- } -- } else { -- this.visitSync(this.listeners.OnceExit, root2); -- } -- } -- } -- return this.result; -- } -- then(onFulfilled, onRejected) { -- if (process.env.NODE_ENV !== "production") { -- if (!("from" in this.opts)) { -- warnOnce$1$1( -- "Without `from` option PostCSS could generate wrong source map and will not find Browserslist config. Set it to CSS file path or to `undefined` to prevent this warning." -- ); -- } -- } -- return this.async().then(onFulfilled, onRejected); -- } -- toString() { -- return this.css; -- } -- visitSync(visitors, node2) { -- for (let [plugin22, visitor] of visitors) { -- this.result.lastPlugin = plugin22; -- let promise; -- try { -- promise = visitor(node2, this.helpers); -- } catch (e2) { -- throw this.handleError(e2, node2.proxyOf); -- } -- if (node2.type !== "root" && node2.type !== "document" && !node2.parent) { -- return true; -- } -- if (isPromise$1(promise)) { -- throw this.getAsyncError(); -- } -- } -- } -- visitTick(stack) { -- let visit2 = stack[stack.length - 1]; -- let { node: node2, visitors } = visit2; -- if (node2.type !== "root" && node2.type !== "document" && !node2.parent) { -- stack.pop(); -- return; -- } -- if (visitors.length > 0 && visit2.visitorIndex < visitors.length) { -- let [plugin22, visitor] = visitors[visit2.visitorIndex]; -- visit2.visitorIndex += 1; -- if (visit2.visitorIndex === visitors.length) { -- visit2.visitors = []; -- visit2.visitorIndex = 0; -- } -- this.result.lastPlugin = plugin22; -- try { -- return visitor(node2.toProxy(), this.helpers); -- } catch (e2) { -- throw this.handleError(e2, node2); -- } -- } -- if (visit2.iterator !== 0) { -- let iterator = visit2.iterator; -- let child; -- while (child = node2.nodes[node2.indexes[iterator]]) { -- node2.indexes[iterator] += 1; -- if (!child[isClean$3]) { -- child[isClean$3] = true; -- stack.push(toStack$1(child)); -- return; -- } -- } -- visit2.iterator = 0; -- delete node2.indexes[iterator]; -- } -- let events = visit2.events; -- while (visit2.eventIndex < events.length) { -- let event = events[visit2.eventIndex]; -- visit2.eventIndex += 1; -- if (event === CHILDREN$1) { -- if (node2.nodes && node2.nodes.length) { -- node2[isClean$3] = true; -- visit2.iterator = node2.getIterator(); -- } -- return; -- } else if (this.listeners[event]) { -- visit2.visitors = this.listeners[event]; -- return; -- } -- } -- stack.pop(); -- } -- walkSync(node2) { -- node2[isClean$3] = true; -- let events = getEvents$1(node2); -- for (let event of events) { -- if (event === CHILDREN$1) { -- if (node2.nodes) { -- node2.each((child) => { -- if (!child[isClean$3]) this.walkSync(child); -- }); -- } -- } else { -- let visitors = this.listeners[event]; -- if (visitors) { -- if (this.visitSync(visitors, node2.toProxy())) return; -- } -- } -- } -- } -- warnings() { -- return this.sync().warnings(); -- } -- get content() { -- return this.stringify().content; -- } -- get css() { -- return this.stringify().css; -- } -- get map() { -- return this.stringify().map; -- } -- get messages() { -- return this.sync().messages; -- } -- get opts() { -- return this.result.opts; -- } -- get processor() { -- return this.result.processor; -- } -- get root() { -- return this.sync().root; -- } -- get [Symbol.toStringTag]() { -- return "LazyResult"; -- } --}; --LazyResult$2$1.registerPostcss = (dependant) => { -- postcss$2$1 = dependant; --}; --var lazyResult$1 = LazyResult$2$1; --LazyResult$2$1.default = LazyResult$2$1; --Root$3$1.registerLazyResult(LazyResult$2$1); --Document$2$1.registerLazyResult(LazyResult$2$1); --let MapGenerator2$1 = mapGenerator$1; --let stringify$1$1 = stringify_1$1; --let warnOnce2$1 = warnOnce$2$1; --let parse$1$1 = parse_1$1; --const Result$1$1 = result$1; --let NoWorkResult$1$1 = class NoWorkResult { -- constructor(processor2, css, opts) { -- css = css.toString(); -- this.stringified = false; -- this._processor = processor2; -- this._css = css; -- this._opts = opts; -- this._map = void 0; -- let root2; -- let str = stringify$1$1; -- this.result = new Result$1$1(this._processor, root2, this._opts); -- this.result.css = css; -- let self = this; -- Object.defineProperty(this.result, "root", { -- get() { -- return self.root; -- } -- }); -- let map = new MapGenerator2$1(str, root2, this._opts, css); -- if (map.isMap()) { -- let [generatedCSS, generatedMap] = map.generate(); -- if (generatedCSS) { -- this.result.css = generatedCSS; -- } -- if (generatedMap) { -- this.result.map = generatedMap; -- } -- } else { -- map.clearAnnotation(); -- this.result.css = map.css; -- } -- } -- async() { -- if (this.error) return Promise.reject(this.error); -- return Promise.resolve(this.result); -- } -- catch(onRejected) { -- return this.async().catch(onRejected); -- } -- finally(onFinally) { -- return this.async().then(onFinally, onFinally); -- } -- sync() { -- if (this.error) throw this.error; -- return this.result; -- } -- then(onFulfilled, onRejected) { -- if (process.env.NODE_ENV !== "production") { -- if (!("from" in this._opts)) { -- warnOnce2$1( -- "Without `from` option PostCSS could generate wrong source map and will not find Browserslist config. Set it to CSS file path or to `undefined` to prevent this warning." -- ); -- } -- } -- return this.async().then(onFulfilled, onRejected); -- } -- toString() { -- return this._css; -- } -- warnings() { -- return []; -- } -- get content() { -- return this.result.css; -- } -- get css() { -- return this.result.css; -- } -- get map() { -- return this.result.map; -- } -- get messages() { -- return []; -- } -- get opts() { -- return this.result.opts; -- } -- get processor() { -- return this.result.processor; -- } -- get root() { -- if (this._root) { -- return this._root; -- } -- let root2; -- let parser2 = parse$1$1; -- try { -- root2 = parser2(this._css, this._opts); -- } catch (error) { -- this.error = error; -- } -- if (this.error) { -- throw this.error; -- } else { -- this._root = root2; -- return root2; -- } -- } -- get [Symbol.toStringTag]() { -- return "NoWorkResult"; -- } --}; --var noWorkResult$1 = NoWorkResult$1$1; --NoWorkResult$1$1.default = NoWorkResult$1$1; --let NoWorkResult2$1 = noWorkResult$1; --let LazyResult$1$1 = lazyResult$1; --let Document$1$1 = document$1$1; --let Root$2$1 = root$1; --let Processor$1$1 = class Processor { -- constructor(plugins = []) { -- this.version = "8.4.38"; -- this.plugins = this.normalize(plugins); -- } -- normalize(plugins) { -- let normalized = []; -- for (let i2 of plugins) { -- if (i2.postcss === true) { -- i2 = i2(); -- } else if (i2.postcss) { -- i2 = i2.postcss; -- } -- if (typeof i2 === "object" && Array.isArray(i2.plugins)) { -- normalized = normalized.concat(i2.plugins); -- } else if (typeof i2 === "object" && i2.postcssPlugin) { -- normalized.push(i2); -- } else if (typeof i2 === "function") { -- normalized.push(i2); -- } else if (typeof i2 === "object" && (i2.parse || i2.stringify)) { -- if (process.env.NODE_ENV !== "production") { -- throw new Error( -- "PostCSS syntaxes cannot be used as plugins. Instead, please use one of the syntax/parser/stringifier options as outlined in your PostCSS runner documentation." -- ); -- } -- } else { -- throw new Error(i2 + " is not a PostCSS plugin"); -- } -- } -- return normalized; -- } -- process(css, opts = {}) { -- if (!this.plugins.length && !opts.parser && !opts.stringifier && !opts.syntax) { -- return new NoWorkResult2$1(this, css, opts); -- } else { -- return new LazyResult$1$1(this, css, opts); -- } -- } -- use(plugin22) { -- this.plugins = this.plugins.concat(this.normalize([plugin22])); -- return this; -- } --}; --var processor$1 = Processor$1$1; --Processor$1$1.default = Processor$1$1; --Root$2$1.registerProcessor(Processor$1$1); --Document$1$1.registerProcessor(Processor$1$1); --let Declaration$1$1 = declaration$1; --let PreviousMap2$1 = previousMap$1; --let Comment$1$1 = comment$1; --let AtRule$1$1 = atRule$1; --let Input$1$1 = input$1; --let Root$1$1 = root$1; --let Rule$1$1 = rule$1; --function fromJSON$1$1(json, inputs) { -- if (Array.isArray(json)) return json.map((n2) => fromJSON$1$1(n2)); -- let { inputs: ownInputs, ...defaults } = json; -- if (ownInputs) { -- inputs = []; -- for (let input2 of ownInputs) { -- let inputHydrated = { ...input2, __proto__: Input$1$1.prototype }; -- if (inputHydrated.map) { -- inputHydrated.map = { -- ...inputHydrated.map, -- __proto__: PreviousMap2$1.prototype -- }; -- } -- inputs.push(inputHydrated); -- } -- } -- if (defaults.nodes) { -- defaults.nodes = json.nodes.map((n2) => fromJSON$1$1(n2, inputs)); -- } -- if (defaults.source) { -- let { inputId, ...source } = defaults.source; -- defaults.source = source; -- if (inputId != null) { -- defaults.source.input = inputs[inputId]; -- } -- } -- if (defaults.type === "root") { -- return new Root$1$1(defaults); -- } else if (defaults.type === "decl") { -- return new Declaration$1$1(defaults); -- } else if (defaults.type === "rule") { -- return new Rule$1$1(defaults); -- } else if (defaults.type === "comment") { -- return new Comment$1$1(defaults); -- } else if (defaults.type === "atrule") { -- return new AtRule$1$1(defaults); -- } else { -- throw new Error("Unknown node type: " + json.type); -- } --} --var fromJSON_1$1 = fromJSON$1$1; --fromJSON$1$1.default = fromJSON$1$1; --let CssSyntaxError2$1 = cssSyntaxError$1; --let Declaration2$1 = declaration$1; --let LazyResult2$1 = lazyResult$1; --let Container2$1 = container$1; --let Processor2$1 = processor$1; --let stringify$5 = stringify_1$1; --let fromJSON$2 = fromJSON_1$1; --let Document22 = document$1$1; --let Warning2$1 = warning$1; --let Comment2$1 = comment$1; --let AtRule2$1 = atRule$1; --let Result2$1 = result$1; --let Input2$1 = input$1; --let parse$5 = parse_1$1; --let list$3 = list_1$1; --let Rule2$1 = rule$1; --let Root2$1 = root$1; --let Node2$1 = node$1; --function postcss$3(...plugins) { -- if (plugins.length === 1 && Array.isArray(plugins[0])) { -- plugins = plugins[0]; -- } -- return new Processor2$1(plugins); --} --postcss$3.plugin = function plugin(name, initializer) { -- let warningPrinted = false; -- function creator(...args) { -- if (console && console.warn && !warningPrinted) { -- warningPrinted = true; -- console.warn( -- name + ": postcss.plugin was deprecated. Migration guide:\nhttps://evilmartians.com/chronicles/postcss-8-plugin-migration" -- ); -- if (process.env.LANG && process.env.LANG.startsWith("cn")) { -- console.warn( -- name + ": 里面 postcss.plugin 被弃用. 迁移指南:\nhttps://www.w3ctech.com/topic/2226" -- ); -- } -- } -- let transformer = initializer(...args); -- transformer.postcssPlugin = name; -- transformer.postcssVersion = new Processor2$1().version; -- return transformer; -- } -- let cache; -- Object.defineProperty(creator, "postcss", { -- get() { -- if (!cache) cache = creator(); -- return cache; -- } -- }); -- creator.process = function(css, processOpts, pluginOpts) { -- return postcss$3([creator(pluginOpts)]).process(css, processOpts); -- }; -- return creator; --}; --postcss$3.stringify = stringify$5; --postcss$3.parse = parse$5; --postcss$3.fromJSON = fromJSON$2; --postcss$3.list = list$3; --postcss$3.comment = (defaults) => new Comment2$1(defaults); --postcss$3.atRule = (defaults) => new AtRule2$1(defaults); --postcss$3.decl = (defaults) => new Declaration2$1(defaults); --postcss$3.rule = (defaults) => new Rule2$1(defaults); --postcss$3.root = (defaults) => new Root2$1(defaults); --postcss$3.document = (defaults) => new Document22(defaults); --postcss$3.CssSyntaxError = CssSyntaxError2$1; --postcss$3.Declaration = Declaration2$1; --postcss$3.Container = Container2$1; --postcss$3.Processor = Processor2$1; --postcss$3.Document = Document22; --postcss$3.Comment = Comment2$1; --postcss$3.Warning = Warning2$1; --postcss$3.AtRule = AtRule2$1; --postcss$3.Result = Result2$1; --postcss$3.Input = Input2$1; --postcss$3.Rule = Rule2$1; --postcss$3.Root = Root2$1; --postcss$3.Node = Node2$1; --LazyResult2$1.registerPostcss(postcss$3); --var postcss_1$1 = postcss$3; --postcss$3.default = postcss$3; --const postcss$1$1 = /* @__PURE__ */ getDefaultExportFromCjs$1(postcss_1$1); --postcss$1$1.stringify; --postcss$1$1.fromJSON; --postcss$1$1.plugin; --postcss$1$1.parse; --postcss$1$1.list; --postcss$1$1.document; --postcss$1$1.comment; --postcss$1$1.atRule; --postcss$1$1.rule; --postcss$1$1.decl; --postcss$1$1.root; --postcss$1$1.CssSyntaxError; --postcss$1$1.Declaration; --postcss$1$1.Container; --postcss$1$1.Processor; --postcss$1$1.Document; --postcss$1$1.Comment; --postcss$1$1.Warning; --postcss$1$1.AtRule; --postcss$1$1.Result; --postcss$1$1.Input; --postcss$1$1.Rule; --postcss$1$1.Root; --postcss$1$1.Node; --var __defProp2 = Object.defineProperty; --var __defNormalProp2 = (obj, key, value) => key in obj ? __defProp2(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value; --var __publicField2 = (obj, key, value) => __defNormalProp2(obj, typeof key !== "symbol" ? key + "" : key, value); --function getDefaultExportFromCjs(x2) { -- return x2 && x2.__esModule && Object.prototype.hasOwnProperty.call(x2, "default") ? x2["default"] : x2; --} --function getAugmentedNamespace(n2) { -- if (n2.__esModule) return n2; -- var f2 = n2.default; -- if (typeof f2 == "function") { -- var a2 = function a22() { -- if (this instanceof a22) { -- return Reflect.construct(f2, arguments, this.constructor); -- } -- return f2.apply(this, arguments); -- }; -- a2.prototype = f2.prototype; -- } else a2 = {}; -- Object.defineProperty(a2, "__esModule", { value: true }); -- Object.keys(n2).forEach(function(k) { -- var d = Object.getOwnPropertyDescriptor(n2, k); -- Object.defineProperty(a2, k, d.get ? d : { -- enumerable: true, -- get: function() { -- return n2[k]; -- } -- }); -- }); -- return a2; --} --var picocolors_browser = { exports: {} }; --var x = String; --var create = function() { -- return { isColorSupported: false, reset: x, bold: x, dim: x, italic: x, underline: x, inverse: x, hidden: x, strikethrough: x, black: x, red: x, green: x, yellow: x, blue: x, magenta: x, cyan: x, white: x, gray: x, bgBlack: x, bgRed: x, bgGreen: x, bgYellow: x, bgBlue: x, bgMagenta: x, bgCyan: x, bgWhite: x }; --}; --picocolors_browser.exports = create(); --picocolors_browser.exports.createColors = create; --var picocolors_browserExports = picocolors_browser.exports; --const __viteBrowserExternal = {}; --const __viteBrowserExternal$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({ -- __proto__: null, -- default: __viteBrowserExternal --}, Symbol.toStringTag, { value: "Module" })); --const require$$2 = /* @__PURE__ */ getAugmentedNamespace(__viteBrowserExternal$1); --let pico = picocolors_browserExports; --let terminalHighlight$1 = require$$2; --let CssSyntaxError$3 = class CssSyntaxError2 extends Error { -- constructor(message, line, column, source, file, plugin22) { -- super(message); -- this.name = "CssSyntaxError"; -- this.reason = message; -- if (file) { -- this.file = file; -- } -- if (source) { -- this.source = source; -- } -- if (plugin22) { -- this.plugin = plugin22; -- } -- if (typeof line !== "undefined" && typeof column !== "undefined") { -- if (typeof line === "number") { -- this.line = line; -- this.column = column; -- } else { -- this.line = line.line; -- this.column = line.column; -- this.endLine = column.line; -- this.endColumn = column.column; -- } -- } -- this.setMessage(); -- if (Error.captureStackTrace) { -- Error.captureStackTrace(this, CssSyntaxError2); -- } -- } -- setMessage() { -- this.message = this.plugin ? this.plugin + ": " : ""; -- this.message += this.file ? this.file : ""; -- if (typeof this.line !== "undefined") { -- this.message += ":" + this.line + ":" + this.column; -- } -- this.message += ": " + this.reason; -- } -- showSourceCode(color) { -- if (!this.source) return ""; -- let css = this.source; -- if (color == null) color = pico.isColorSupported; -- if (terminalHighlight$1) { -- if (color) css = terminalHighlight$1(css); -- } -- let lines = css.split(/\r?\n/); -- let start = Math.max(this.line - 3, 0); -- let end = Math.min(this.line + 2, lines.length); -- let maxWidth = String(end).length; -- let mark, aside; -- if (color) { -- let { bold, gray, red } = pico.createColors(true); -- mark = (text) => bold(red(text)); -- aside = (text) => gray(text); -- } else { -- mark = aside = (str) => str; -- } -- return lines.slice(start, end).map((line, index2) => { -- let number = start + 1 + index2; -- let gutter = " " + (" " + number).slice(-maxWidth) + " | "; -- if (number === this.line) { -- let spacing = aside(gutter.replace(/\d/g, " ")) + line.slice(0, this.column - 1).replace(/[^\t]/g, " "); -- return mark(">") + aside(gutter) + line + "\n " + spacing + mark("^"); -- } -- return " " + aside(gutter) + line; -- }).join("\n"); -- } -- toString() { -- let code = this.showSourceCode(); -- if (code) { -- code = "\n\n" + code + "\n"; -- } -- return this.name + ": " + this.message + code; -- } --}; --var cssSyntaxError = CssSyntaxError$3; --CssSyntaxError$3.default = CssSyntaxError$3; --var symbols = {}; --symbols.isClean = Symbol("isClean"); --symbols.my = Symbol("my"); --const DEFAULT_RAW = { -- after: "\n", -- beforeClose: "\n", -- beforeComment: "\n", -- beforeDecl: "\n", -- beforeOpen: " ", -- beforeRule: "\n", -- colon: ": ", -- commentLeft: " ", -- commentRight: " ", -- emptyBody: "", -- indent: " ", -- semicolon: false --}; --function capitalize(str) { -- return str[0].toUpperCase() + str.slice(1); --} --let Stringifier$2 = class Stringifier2 { -- constructor(builder) { -- this.builder = builder; -- } -- atrule(node2, semicolon) { -- let name = "@" + node2.name; -- let params = node2.params ? this.rawValue(node2, "params") : ""; -- if (typeof node2.raws.afterName !== "undefined") { -- name += node2.raws.afterName; -- } else if (params) { -- name += " "; -- } -- if (node2.nodes) { -- this.block(node2, name + params); -- } else { -- let end = (node2.raws.between || "") + (semicolon ? ";" : ""); -- this.builder(name + params + end, node2); -- } -- } -- beforeAfter(node2, detect) { -- let value; -- if (node2.type === "decl") { -- value = this.raw(node2, null, "beforeDecl"); -- } else if (node2.type === "comment") { -- value = this.raw(node2, null, "beforeComment"); -- } else if (detect === "before") { -- value = this.raw(node2, null, "beforeRule"); -- } else { -- value = this.raw(node2, null, "beforeClose"); -- } -- let buf = node2.parent; -- let depth = 0; -- while (buf && buf.type !== "root") { -- depth += 1; -- buf = buf.parent; -- } -- if (value.includes("\n")) { -- let indent = this.raw(node2, null, "indent"); -- if (indent.length) { -- for (let step = 0; step < depth; step++) value += indent; -- } -- } -- return value; -- } -- block(node2, start) { -- let between = this.raw(node2, "between", "beforeOpen"); -- this.builder(start + between + "{", node2, "start"); -- let after; -- if (node2.nodes && node2.nodes.length) { -- this.body(node2); -- after = this.raw(node2, "after"); -- } else { -- after = this.raw(node2, "after", "emptyBody"); -- } -- if (after) this.builder(after); -- this.builder("}", node2, "end"); -- } -- body(node2) { -- let last = node2.nodes.length - 1; -- while (last > 0) { -- if (node2.nodes[last].type !== "comment") break; -- last -= 1; -- } -- let semicolon = this.raw(node2, "semicolon"); -- for (let i2 = 0; i2 < node2.nodes.length; i2++) { -- let child = node2.nodes[i2]; -- let before = this.raw(child, "before"); -- if (before) this.builder(before); -- this.stringify(child, last !== i2 || semicolon); -- } -- } -- comment(node2) { -- let left = this.raw(node2, "left", "commentLeft"); -- let right = this.raw(node2, "right", "commentRight"); -- this.builder("/*" + left + node2.text + right + "*/", node2); -- } -- decl(node2, semicolon) { -- let between = this.raw(node2, "between", "colon"); -- let string = node2.prop + between + this.rawValue(node2, "value"); -- if (node2.important) { -- string += node2.raws.important || " !important"; -- } -- if (semicolon) string += ";"; -- this.builder(string, node2); -- } -- document(node2) { -- this.body(node2); -- } -- raw(node2, own, detect) { -- let value; -- if (!detect) detect = own; -- if (own) { -- value = node2.raws[own]; -- if (typeof value !== "undefined") return value; -- } -- let parent = node2.parent; -- if (detect === "before") { -- if (!parent || parent.type === "root" && parent.first === node2) { -- return ""; -- } -- if (parent && parent.type === "document") { -- return ""; -- } -- } -- if (!parent) return DEFAULT_RAW[detect]; -- let root2 = node2.root(); -- if (!root2.rawCache) root2.rawCache = {}; -- if (typeof root2.rawCache[detect] !== "undefined") { -- return root2.rawCache[detect]; -- } -- if (detect === "before" || detect === "after") { -- return this.beforeAfter(node2, detect); -- } else { -- let method = "raw" + capitalize(detect); -- if (this[method]) { -- value = this[method](root2, node2); -- } else { -- root2.walk((i2) => { -- value = i2.raws[own]; -- if (typeof value !== "undefined") return false; -- }); -- } -- } -- if (typeof value === "undefined") value = DEFAULT_RAW[detect]; -- root2.rawCache[detect] = value; -- return value; -- } -- rawBeforeClose(root2) { -- let value; -- root2.walk((i2) => { -- if (i2.nodes && i2.nodes.length > 0) { -- if (typeof i2.raws.after !== "undefined") { -- value = i2.raws.after; -- if (value.includes("\n")) { -- value = value.replace(/[^\n]+$/, ""); -- } -- return false; -- } -- } -- }); -- if (value) value = value.replace(/\S/g, ""); -- return value; -- } -- rawBeforeComment(root2, node2) { -- let value; -- root2.walkComments((i2) => { -- if (typeof i2.raws.before !== "undefined") { -- value = i2.raws.before; -- if (value.includes("\n")) { -- value = value.replace(/[^\n]+$/, ""); -- } -- return false; -- } -- }); -- if (typeof value === "undefined") { -- value = this.raw(node2, null, "beforeDecl"); -- } else if (value) { -- value = value.replace(/\S/g, ""); -- } -- return value; -- } -- rawBeforeDecl(root2, node2) { -- let value; -- root2.walkDecls((i2) => { -- if (typeof i2.raws.before !== "undefined") { -- value = i2.raws.before; -- if (value.includes("\n")) { -- value = value.replace(/[^\n]+$/, ""); -- } -- return false; -- } -- }); -- if (typeof value === "undefined") { -- value = this.raw(node2, null, "beforeRule"); -- } else if (value) { -- value = value.replace(/\S/g, ""); -- } -- return value; -- } -- rawBeforeOpen(root2) { -- let value; -- root2.walk((i2) => { -- if (i2.type !== "decl") { -- value = i2.raws.between; -- if (typeof value !== "undefined") return false; -- } -- }); -- return value; -- } -- rawBeforeRule(root2) { -- let value; -- root2.walk((i2) => { -- if (i2.nodes && (i2.parent !== root2 || root2.first !== i2)) { -- if (typeof i2.raws.before !== "undefined") { -- value = i2.raws.before; -- if (value.includes("\n")) { -- value = value.replace(/[^\n]+$/, ""); -- } -- return false; -- } -- } -- }); -- if (value) value = value.replace(/\S/g, ""); -- return value; -- } -- rawColon(root2) { -- let value; -- root2.walkDecls((i2) => { -- if (typeof i2.raws.between !== "undefined") { -- value = i2.raws.between.replace(/[^\s:]/g, ""); -- return false; -- } -- }); -- return value; -- } -- rawEmptyBody(root2) { -- let value; -- root2.walk((i2) => { -- if (i2.nodes && i2.nodes.length === 0) { -- value = i2.raws.after; -- if (typeof value !== "undefined") return false; -- } -- }); -- return value; -- } -- rawIndent(root2) { -- if (root2.raws.indent) return root2.raws.indent; -- let value; -- root2.walk((i2) => { -- let p = i2.parent; -- if (p && p !== root2 && p.parent && p.parent === root2) { -- if (typeof i2.raws.before !== "undefined") { -- let parts = i2.raws.before.split("\n"); -- value = parts[parts.length - 1]; -- value = value.replace(/\S/g, ""); -- return false; -- } -- } -- }); -- return value; -- } -- rawSemicolon(root2) { -- let value; -- root2.walk((i2) => { -- if (i2.nodes && i2.nodes.length && i2.last.type === "decl") { -- value = i2.raws.semicolon; -- if (typeof value !== "undefined") return false; -- } -- }); -- return value; -- } -- rawValue(node2, prop) { -- let value = node2[prop]; -- let raw = node2.raws[prop]; -- if (raw && raw.value === value) { -- return raw.raw; -- } -- return value; -- } -- root(node2) { -- this.body(node2); -- if (node2.raws.after) this.builder(node2.raws.after); -- } -- rule(node2) { -- this.block(node2, this.rawValue(node2, "selector")); -- if (node2.raws.ownSemicolon) { -- this.builder(node2.raws.ownSemicolon, node2, "end"); -- } -- } -- stringify(node2, semicolon) { -- if (!this[node2.type]) { -- throw new Error( -- "Unknown AST node type " + node2.type + ". Maybe you need to change PostCSS stringifier." -- ); -- } -- this[node2.type](node2, semicolon); -- } --}; --var stringifier = Stringifier$2; --Stringifier$2.default = Stringifier$2; --let Stringifier$1 = stringifier; --function stringify$4(node2, builder) { -- let str = new Stringifier$1(builder); -- str.stringify(node2); --} --var stringify_1 = stringify$4; --stringify$4.default = stringify$4; --let { isClean: isClean$2, my: my$2 } = symbols; --let CssSyntaxError$2 = cssSyntaxError; --let Stringifier22 = stringifier; --let stringify$3 = stringify_1; --function cloneNode(obj, parent) { -- let cloned = new obj.constructor(); -- for (let i2 in obj) { -- if (!Object.prototype.hasOwnProperty.call(obj, i2)) { -- continue; -- } -- if (i2 === "proxyCache") continue; -- let value = obj[i2]; -- let type = typeof value; -- if (i2 === "parent" && type === "object") { -- if (parent) cloned[i2] = parent; -- } else if (i2 === "source") { -- cloned[i2] = value; -- } else if (Array.isArray(value)) { -- cloned[i2] = value.map((j) => cloneNode(j, cloned)); -- } else { -- if (type === "object" && value !== null) value = cloneNode(value); -- cloned[i2] = value; -- } -- } -- return cloned; --} --let Node$4 = class Node3 { -- constructor(defaults = {}) { -- this.raws = {}; -- this[isClean$2] = false; -- this[my$2] = true; -- for (let name in defaults) { -- if (name === "nodes") { -- this.nodes = []; -- for (let node2 of defaults[name]) { -- if (typeof node2.clone === "function") { -- this.append(node2.clone()); -- } else { -- this.append(node2); -- } -- } -- } else { -- this[name] = defaults[name]; -- } -- } -- } -- addToError(error) { -- error.postcssNode = this; -- if (error.stack && this.source && /\n\s{4}at /.test(error.stack)) { -- let s2 = this.source; -- error.stack = error.stack.replace( -- /\n\s{4}at /, -- `$&${s2.input.from}:${s2.start.line}:${s2.start.column}$&` -- ); -- } -- return error; -- } -- after(add) { -- this.parent.insertAfter(this, add); -- return this; -- } -- assign(overrides = {}) { -- for (let name in overrides) { -- this[name] = overrides[name]; -- } -- return this; -- } -- before(add) { -- this.parent.insertBefore(this, add); -- return this; -- } -- cleanRaws(keepBetween) { -- delete this.raws.before; -- delete this.raws.after; -- if (!keepBetween) delete this.raws.between; -- } -- clone(overrides = {}) { -- let cloned = cloneNode(this); -- for (let name in overrides) { -- cloned[name] = overrides[name]; -- } -- return cloned; -- } -- cloneAfter(overrides = {}) { -- let cloned = this.clone(overrides); -- this.parent.insertAfter(this, cloned); -- return cloned; -- } -- cloneBefore(overrides = {}) { -- let cloned = this.clone(overrides); -- this.parent.insertBefore(this, cloned); -- return cloned; -- } -- error(message, opts = {}) { -- if (this.source) { -- let { end, start } = this.rangeBy(opts); -- return this.source.input.error( -- message, -- { column: start.column, line: start.line }, -- { column: end.column, line: end.line }, -- opts -- ); -- } -- return new CssSyntaxError$2(message); -- } -- getProxyProcessor() { -- return { -- get(node2, prop) { -- if (prop === "proxyOf") { -- return node2; -- } else if (prop === "root") { -- return () => node2.root().toProxy(); -- } else { -- return node2[prop]; -- } -- }, -- set(node2, prop, value) { -- if (node2[prop] === value) return true; -- node2[prop] = value; -- if (prop === "prop" || prop === "value" || prop === "name" || prop === "params" || prop === "important" || /* c8 ignore next */ -- prop === "text") { -- node2.markDirty(); -- } -- return true; -- } -- }; -- } -- markDirty() { -- if (this[isClean$2]) { -- this[isClean$2] = false; -- let next = this; -- while (next = next.parent) { -- next[isClean$2] = false; -- } -- } -- } -- next() { -- if (!this.parent) return void 0; -- let index2 = this.parent.index(this); -- return this.parent.nodes[index2 + 1]; -- } -- positionBy(opts, stringRepresentation) { -- let pos = this.source.start; -- if (opts.index) { -- pos = this.positionInside(opts.index, stringRepresentation); -- } else if (opts.word) { -- stringRepresentation = this.toString(); -- let index2 = stringRepresentation.indexOf(opts.word); -- if (index2 !== -1) pos = this.positionInside(index2, stringRepresentation); -- } -- return pos; -- } -- positionInside(index2, stringRepresentation) { -- let string = stringRepresentation || this.toString(); -- let column = this.source.start.column; -- let line = this.source.start.line; -- for (let i2 = 0; i2 < index2; i2++) { -- if (string[i2] === "\n") { -- column = 1; -- line += 1; -- } else { -- column += 1; -- } -- } -- return { column, line }; -- } -- prev() { -- if (!this.parent) return void 0; -- let index2 = this.parent.index(this); -- return this.parent.nodes[index2 - 1]; -- } -- rangeBy(opts) { -- let start = { -- column: this.source.start.column, -- line: this.source.start.line -- }; -- let end = this.source.end ? { -- column: this.source.end.column + 1, -- line: this.source.end.line -- } : { -- column: start.column + 1, -- line: start.line -- }; -- if (opts.word) { -- let stringRepresentation = this.toString(); -- let index2 = stringRepresentation.indexOf(opts.word); -- if (index2 !== -1) { -- start = this.positionInside(index2, stringRepresentation); -- end = this.positionInside(index2 + opts.word.length, stringRepresentation); -- } -- } else { -- if (opts.start) { -- start = { -- column: opts.start.column, -- line: opts.start.line -- }; -- } else if (opts.index) { -- start = this.positionInside(opts.index); -- } -- if (opts.end) { -- end = { -- column: opts.end.column, -- line: opts.end.line -- }; -- } else if (typeof opts.endIndex === "number") { -- end = this.positionInside(opts.endIndex); -- } else if (opts.index) { -- end = this.positionInside(opts.index + 1); -- } -- } -- if (end.line < start.line || end.line === start.line && end.column <= start.column) { -- end = { column: start.column + 1, line: start.line }; -- } -- return { end, start }; -- } -- raw(prop, defaultType) { -- let str = new Stringifier22(); -- return str.raw(this, prop, defaultType); -- } -- remove() { -- if (this.parent) { -- this.parent.removeChild(this); -- } -- this.parent = void 0; -- return this; -- } -- replaceWith(...nodes) { -- if (this.parent) { -- let bookmark = this; -- let foundSelf = false; -- for (let node2 of nodes) { -- if (node2 === this) { -- foundSelf = true; -- } else if (foundSelf) { -- this.parent.insertAfter(bookmark, node2); -- bookmark = node2; -- } else { -- this.parent.insertBefore(bookmark, node2); -- } -- } -- if (!foundSelf) { -- this.remove(); -- } -- } -- return this; -- } -- root() { -- let result2 = this; -- while (result2.parent && result2.parent.type !== "document") { -- result2 = result2.parent; -- } -- return result2; -- } -- toJSON(_, inputs) { -- let fixed = {}; -- let emitInputs = inputs == null; -- inputs = inputs || /* @__PURE__ */ new Map(); -- let inputsNextIndex = 0; -- for (let name in this) { -- if (!Object.prototype.hasOwnProperty.call(this, name)) { -- continue; -- } -- if (name === "parent" || name === "proxyCache") continue; -- let value = this[name]; -- if (Array.isArray(value)) { -- fixed[name] = value.map((i2) => { -- if (typeof i2 === "object" && i2.toJSON) { -- return i2.toJSON(null, inputs); -- } else { -- return i2; -- } -- }); -- } else if (typeof value === "object" && value.toJSON) { -- fixed[name] = value.toJSON(null, inputs); -- } else if (name === "source") { -- let inputId = inputs.get(value.input); -- if (inputId == null) { -- inputId = inputsNextIndex; -- inputs.set(value.input, inputsNextIndex); -- inputsNextIndex++; -- } -- fixed[name] = { -- end: value.end, -- inputId, -- start: value.start -- }; -- } else { -- fixed[name] = value; -- } -- } -- if (emitInputs) { -- fixed.inputs = [...inputs.keys()].map((input2) => input2.toJSON()); -- } -- return fixed; -- } -- toProxy() { -- if (!this.proxyCache) { -- this.proxyCache = new Proxy(this, this.getProxyProcessor()); -- } -- return this.proxyCache; -- } -- toString(stringifier2 = stringify$3) { -- if (stringifier2.stringify) stringifier2 = stringifier2.stringify; -- let result2 = ""; -- stringifier2(this, (i2) => { -- result2 += i2; -- }); -- return result2; -- } -- warn(result2, text, opts) { -- let data = { node: this }; -- for (let i2 in opts) data[i2] = opts[i2]; -- return result2.warn(text, data); -- } -- get proxyOf() { -- return this; -- } --}; --var node = Node$4; --Node$4.default = Node$4; --let Node$3 = node; --let Declaration$4 = class Declaration2 extends Node$3 { -- constructor(defaults) { -- if (defaults && typeof defaults.value !== "undefined" && typeof defaults.value !== "string") { -- defaults = { ...defaults, value: String(defaults.value) }; -- } -- super(defaults); -- this.type = "decl"; -- } -- get variable() { -- return this.prop.startsWith("--") || this.prop[0] === "$"; -- } --}; --var declaration = Declaration$4; --Declaration$4.default = Declaration$4; --let urlAlphabet = "useandom-26T198340PX75pxJACKVERYMINDBUSHWOLF_GQZbfghjklqvwyzrict"; --let customAlphabet = (alphabet, defaultSize = 21) => { -- return (size = defaultSize) => { -- let id = ""; -- let i2 = size; -- while (i2--) { -- id += alphabet[Math.random() * alphabet.length | 0]; -- } -- return id; -- }; --}; --let nanoid$1 = (size = 21) => { -- let id = ""; -- let i2 = size; -- while (i2--) { -- id += urlAlphabet[Math.random() * 64 | 0]; -- } -- return id; --}; --var nonSecure = { nanoid: nanoid$1, customAlphabet }; --let { SourceMapConsumer: SourceMapConsumer$2, SourceMapGenerator: SourceMapGenerator$2 } = require$$2; --let { existsSync, readFileSync } = require$$2; --let { dirname: dirname$1, join } = require$$2; --function fromBase64(str) { -- if (Buffer) { -- return Buffer.from(str, "base64").toString(); -- } else { -- return window.atob(str); -- } --} --let PreviousMap$2 = class PreviousMap2 { -- constructor(css, opts) { -- if (opts.map === false) return; -- this.loadAnnotation(css); -- this.inline = this.startWith(this.annotation, "data:"); -- let prev = opts.map ? opts.map.prev : void 0; -- let text = this.loadMap(opts.from, prev); -- if (!this.mapFile && opts.from) { -- this.mapFile = opts.from; -- } -- if (this.mapFile) this.root = dirname$1(this.mapFile); -- if (text) this.text = text; -- } -- consumer() { -- if (!this.consumerCache) { -- this.consumerCache = new SourceMapConsumer$2(this.text); -- } -- return this.consumerCache; -- } -- decodeInline(text) { -- let baseCharsetUri = /^data:application\/json;charset=utf-?8;base64,/; -- let baseUri = /^data:application\/json;base64,/; -- let charsetUri = /^data:application\/json;charset=utf-?8,/; -- let uri = /^data:application\/json,/; -- if (charsetUri.test(text) || uri.test(text)) { -- return decodeURIComponent(text.substr(RegExp.lastMatch.length)); -- } -- if (baseCharsetUri.test(text) || baseUri.test(text)) { -- return fromBase64(text.substr(RegExp.lastMatch.length)); -- } -- let encoding = text.match(/data:application\/json;([^,]+),/)[1]; -- throw new Error("Unsupported source map encoding " + encoding); -- } -- getAnnotationURL(sourceMapString) { -- return sourceMapString.replace(/^\/\*\s*# sourceMappingURL=/, "").trim(); -- } -- isMap(map) { -- if (typeof map !== "object") return false; -- return typeof map.mappings === "string" || typeof map._mappings === "string" || Array.isArray(map.sections); -- } -- loadAnnotation(css) { -- let comments = css.match(/\/\*\s*# sourceMappingURL=/gm); -- if (!comments) return; -- let start = css.lastIndexOf(comments.pop()); -- let end = css.indexOf("*/", start); -- if (start > -1 && end > -1) { -- this.annotation = this.getAnnotationURL(css.substring(start, end)); -- } -- } -- loadFile(path) { -- this.root = dirname$1(path); -- if (existsSync(path)) { -- this.mapFile = path; -- return readFileSync(path, "utf-8").toString().trim(); -- } -- } -- loadMap(file, prev) { -- if (prev === false) return false; -- if (prev) { -- if (typeof prev === "string") { -- return prev; -- } else if (typeof prev === "function") { -- let prevPath = prev(file); -- if (prevPath) { -- let map = this.loadFile(prevPath); -- if (!map) { -- throw new Error( -- "Unable to load previous source map: " + prevPath.toString() -- ); -- } -- return map; -- } -- } else if (prev instanceof SourceMapConsumer$2) { -- return SourceMapGenerator$2.fromSourceMap(prev).toString(); -- } else if (prev instanceof SourceMapGenerator$2) { -- return prev.toString(); -- } else if (this.isMap(prev)) { -- return JSON.stringify(prev); -- } else { -- throw new Error( -- "Unsupported previous source map format: " + prev.toString() -- ); -- } -- } else if (this.inline) { -- return this.decodeInline(this.annotation); -- } else if (this.annotation) { -- let map = this.annotation; -- if (file) map = join(dirname$1(file), map); -- return this.loadFile(map); -- } -- } -- startWith(string, start) { -- if (!string) return false; -- return string.substr(0, start.length) === start; -- } -- withContent() { -- return !!(this.consumer().sourcesContent && this.consumer().sourcesContent.length > 0); -- } --}; --var previousMap = PreviousMap$2; --PreviousMap$2.default = PreviousMap$2; --let { SourceMapConsumer: SourceMapConsumer$1, SourceMapGenerator: SourceMapGenerator$1 } = require$$2; --let { fileURLToPath, pathToFileURL: pathToFileURL$1 } = require$$2; --let { isAbsolute, resolve: resolve$1 } = require$$2; --let { nanoid } = nonSecure; --let terminalHighlight = require$$2; --let CssSyntaxError$1 = cssSyntaxError; --let PreviousMap$1 = previousMap; --let fromOffsetCache = Symbol("fromOffsetCache"); --let sourceMapAvailable$1 = Boolean(SourceMapConsumer$1 && SourceMapGenerator$1); --let pathAvailable$1 = Boolean(resolve$1 && isAbsolute); --let Input$4 = class Input2 { -- constructor(css, opts = {}) { -- if (css === null || typeof css === "undefined" || typeof css === "object" && !css.toString) { -- throw new Error(`PostCSS received ${css} instead of CSS string`); -- } -- this.css = css.toString(); -- if (this.css[0] === "\uFEFF" || this.css[0] === "￾") { -- this.hasBOM = true; -- this.css = this.css.slice(1); -- } else { -- this.hasBOM = false; -- } -- if (opts.from) { -- if (!pathAvailable$1 || /^\w+:\/\//.test(opts.from) || isAbsolute(opts.from)) { -- this.file = opts.from; -- } else { -- this.file = resolve$1(opts.from); -- } -- } -- if (pathAvailable$1 && sourceMapAvailable$1) { -- let map = new PreviousMap$1(this.css, opts); -- if (map.text) { -- this.map = map; -- let file = map.consumer().file; -- if (!this.file && file) this.file = this.mapResolve(file); -- } -- } -- if (!this.file) { -- this.id = ""; -- } -- if (this.map) this.map.file = this.from; -- } -- error(message, line, column, opts = {}) { -- let result2, endLine, endColumn; -- if (line && typeof line === "object") { -- let start = line; -- let end = column; -- if (typeof start.offset === "number") { -- let pos = this.fromOffset(start.offset); -- line = pos.line; -- column = pos.col; -- } else { -- line = start.line; -- column = start.column; -- } -- if (typeof end.offset === "number") { -- let pos = this.fromOffset(end.offset); -- endLine = pos.line; -- endColumn = pos.col; -- } else { -- endLine = end.line; -- endColumn = end.column; -- } -- } else if (!column) { -- let pos = this.fromOffset(line); -- line = pos.line; -- column = pos.col; -- } -- let origin = this.origin(line, column, endLine, endColumn); -- if (origin) { -- result2 = new CssSyntaxError$1( -- message, -- origin.endLine === void 0 ? origin.line : { column: origin.column, line: origin.line }, -- origin.endLine === void 0 ? origin.column : { column: origin.endColumn, line: origin.endLine }, -- origin.source, -- origin.file, -- opts.plugin -- ); -- } else { -- result2 = new CssSyntaxError$1( -- message, -- endLine === void 0 ? line : { column, line }, -- endLine === void 0 ? column : { column: endColumn, line: endLine }, -- this.css, -- this.file, -- opts.plugin -- ); -- } -- result2.input = { column, endColumn, endLine, line, source: this.css }; -- if (this.file) { -- if (pathToFileURL$1) { -- result2.input.url = pathToFileURL$1(this.file).toString(); -- } -- result2.input.file = this.file; -- } -- return result2; -- } -- fromOffset(offset) { -- let lastLine, lineToIndex; -- if (!this[fromOffsetCache]) { -- let lines = this.css.split("\n"); -- lineToIndex = new Array(lines.length); -- let prevIndex = 0; -- for (let i2 = 0, l2 = lines.length; i2 < l2; i2++) { -- lineToIndex[i2] = prevIndex; -- prevIndex += lines[i2].length + 1; -- } -- this[fromOffsetCache] = lineToIndex; -- } else { -- lineToIndex = this[fromOffsetCache]; -- } -- lastLine = lineToIndex[lineToIndex.length - 1]; -- let min = 0; -- if (offset >= lastLine) { -- min = lineToIndex.length - 1; -- } else { -- let max = lineToIndex.length - 2; -- let mid; -- while (min < max) { -- mid = min + (max - min >> 1); -- if (offset < lineToIndex[mid]) { -- max = mid - 1; -- } else if (offset >= lineToIndex[mid + 1]) { -- min = mid + 1; -- } else { -- min = mid; -- break; -- } -- } -- } -- return { -- col: offset - lineToIndex[min] + 1, -- line: min + 1 -- }; -- } -- mapResolve(file) { -- if (/^\w+:\/\//.test(file)) { -- return file; -- } -- return resolve$1(this.map.consumer().sourceRoot || this.map.root || ".", file); -- } -- origin(line, column, endLine, endColumn) { -- if (!this.map) return false; -- let consumer = this.map.consumer(); -- let from = consumer.originalPositionFor({ column, line }); -- if (!from.source) return false; -- let to; -- if (typeof endLine === "number") { -- to = consumer.originalPositionFor({ column: endColumn, line: endLine }); -- } -- let fromUrl; -- if (isAbsolute(from.source)) { -- fromUrl = pathToFileURL$1(from.source); -- } else { -- fromUrl = new URL( -- from.source, -- this.map.consumer().sourceRoot || pathToFileURL$1(this.map.mapFile) -- ); -- } -- let result2 = { -- column: from.column, -- endColumn: to && to.column, -- endLine: to && to.line, -- line: from.line, -- url: fromUrl.toString() -- }; -- if (fromUrl.protocol === "file:") { -- if (fileURLToPath) { -- result2.file = fileURLToPath(fromUrl); -- } else { -- throw new Error(`file: protocol is not available in this PostCSS build`); -- } -- } -- let source = consumer.sourceContentFor(from.source); -- if (source) result2.source = source; -- return result2; -- } -- toJSON() { -- let json = {}; -- for (let name of ["hasBOM", "css", "file", "id"]) { -- if (this[name] != null) { -- json[name] = this[name]; -- } -- } -- if (this.map) { -- json.map = { ...this.map }; -- if (json.map.consumerCache) { -- json.map.consumerCache = void 0; -- } -- } -- return json; -- } -- get from() { -- return this.file || this.id; -- } --}; --var input = Input$4; --Input$4.default = Input$4; --if (terminalHighlight && terminalHighlight.registerInput) { -- terminalHighlight.registerInput(Input$4); --} --let { SourceMapConsumer, SourceMapGenerator } = require$$2; --let { dirname, relative, resolve, sep } = require$$2; --let { pathToFileURL } = require$$2; --let Input$3 = input; --let sourceMapAvailable = Boolean(SourceMapConsumer && SourceMapGenerator); --let pathAvailable = Boolean(dirname && resolve && relative && sep); --let MapGenerator$2 = class MapGenerator2 { -- constructor(stringify2, root2, opts, cssString) { -- this.stringify = stringify2; -- this.mapOpts = opts.map || {}; -- this.root = root2; -- this.opts = opts; -- this.css = cssString; -- this.originalCSS = cssString; -- this.usesFileUrls = !this.mapOpts.from && this.mapOpts.absolute; -- this.memoizedFileURLs = /* @__PURE__ */ new Map(); -- this.memoizedPaths = /* @__PURE__ */ new Map(); -- this.memoizedURLs = /* @__PURE__ */ new Map(); -- } -- addAnnotation() { -- let content; -- if (this.isInline()) { -- content = "data:application/json;base64," + this.toBase64(this.map.toString()); -- } else if (typeof this.mapOpts.annotation === "string") { -- content = this.mapOpts.annotation; -- } else if (typeof this.mapOpts.annotation === "function") { -- content = this.mapOpts.annotation(this.opts.to, this.root); -- } else { -- content = this.outputFile() + ".map"; -- } -- let eol = "\n"; -- if (this.css.includes("\r\n")) eol = "\r\n"; -- this.css += eol + "/*# sourceMappingURL=" + content + " */"; -- } -- applyPrevMaps() { -- for (let prev of this.previous()) { -- let from = this.toUrl(this.path(prev.file)); -- let root2 = prev.root || dirname(prev.file); -- let map; -- if (this.mapOpts.sourcesContent === false) { -- map = new SourceMapConsumer(prev.text); -- if (map.sourcesContent) { -- map.sourcesContent = null; -- } -- } else { -- map = prev.consumer(); -- } -- this.map.applySourceMap(map, from, this.toUrl(this.path(root2))); -- } -- } -- clearAnnotation() { -- if (this.mapOpts.annotation === false) return; -- if (this.root) { -- let node2; -- for (let i2 = this.root.nodes.length - 1; i2 >= 0; i2--) { -- node2 = this.root.nodes[i2]; -- if (node2.type !== "comment") continue; -- if (node2.text.indexOf("# sourceMappingURL=") === 0) { -- this.root.removeChild(i2); -- } -- } -- } else if (this.css) { -- this.css = this.css.replace(/\n*?\/\*#[\S\s]*?\*\/$/gm, ""); -- } -- } -- generate() { -- this.clearAnnotation(); -- if (pathAvailable && sourceMapAvailable && this.isMap()) { -- return this.generateMap(); -- } else { -- let result2 = ""; -- this.stringify(this.root, (i2) => { -- result2 += i2; -- }); -- return [result2]; -- } -- } -- generateMap() { -- if (this.root) { -- this.generateString(); -- } else if (this.previous().length === 1) { -- let prev = this.previous()[0].consumer(); -- prev.file = this.outputFile(); -- this.map = SourceMapGenerator.fromSourceMap(prev, { -- ignoreInvalidMapping: true -- }); -- } else { -- this.map = new SourceMapGenerator({ -- file: this.outputFile(), -- ignoreInvalidMapping: true -- }); -- this.map.addMapping({ -- generated: { column: 0, line: 1 }, -- original: { column: 0, line: 1 }, -- source: this.opts.from ? this.toUrl(this.path(this.opts.from)) : "" -- }); -- } -- if (this.isSourcesContent()) this.setSourcesContent(); -- if (this.root && this.previous().length > 0) this.applyPrevMaps(); -- if (this.isAnnotation()) this.addAnnotation(); -- if (this.isInline()) { -- return [this.css]; -- } else { -- return [this.css, this.map]; -- } -- } -- generateString() { -- this.css = ""; -- this.map = new SourceMapGenerator({ -- file: this.outputFile(), -- ignoreInvalidMapping: true -- }); -- let line = 1; -- let column = 1; -- let noSource = ""; -- let mapping = { -- generated: { column: 0, line: 0 }, -- original: { column: 0, line: 0 }, -- source: "" -- }; -- let lines, last; -- this.stringify(this.root, (str, node2, type) => { -- this.css += str; -- if (node2 && type !== "end") { -- mapping.generated.line = line; -- mapping.generated.column = column - 1; -- if (node2.source && node2.source.start) { -- mapping.source = this.sourcePath(node2); -- mapping.original.line = node2.source.start.line; -- mapping.original.column = node2.source.start.column - 1; -- this.map.addMapping(mapping); -- } else { -- mapping.source = noSource; -- mapping.original.line = 1; -- mapping.original.column = 0; -- this.map.addMapping(mapping); -- } -- } -- lines = str.match(/\n/g); -- if (lines) { -- line += lines.length; -- last = str.lastIndexOf("\n"); -- column = str.length - last; -- } else { -- column += str.length; -- } -- if (node2 && type !== "start") { -- let p = node2.parent || { raws: {} }; -- let childless = node2.type === "decl" || node2.type === "atrule" && !node2.nodes; -- if (!childless || node2 !== p.last || p.raws.semicolon) { -- if (node2.source && node2.source.end) { -- mapping.source = this.sourcePath(node2); -- mapping.original.line = node2.source.end.line; -- mapping.original.column = node2.source.end.column - 1; -- mapping.generated.line = line; -- mapping.generated.column = column - 2; -- this.map.addMapping(mapping); -- } else { -- mapping.source = noSource; -- mapping.original.line = 1; -- mapping.original.column = 0; -- mapping.generated.line = line; -- mapping.generated.column = column - 1; -- this.map.addMapping(mapping); -- } -- } -- } -- }); -- } -- isAnnotation() { -- if (this.isInline()) { -- return true; -- } -- if (typeof this.mapOpts.annotation !== "undefined") { -- return this.mapOpts.annotation; -- } -- if (this.previous().length) { -- return this.previous().some((i2) => i2.annotation); -- } -- return true; -- } -- isInline() { -- if (typeof this.mapOpts.inline !== "undefined") { -- return this.mapOpts.inline; -- } -- let annotation = this.mapOpts.annotation; -- if (typeof annotation !== "undefined" && annotation !== true) { -- return false; -- } -- if (this.previous().length) { -- return this.previous().some((i2) => i2.inline); -- } -- return true; -- } -- isMap() { -- if (typeof this.opts.map !== "undefined") { -- return !!this.opts.map; -- } -- return this.previous().length > 0; -- } -- isSourcesContent() { -- if (typeof this.mapOpts.sourcesContent !== "undefined") { -- return this.mapOpts.sourcesContent; -- } -- if (this.previous().length) { -- return this.previous().some((i2) => i2.withContent()); -- } -- return true; -- } -- outputFile() { -- if (this.opts.to) { -- return this.path(this.opts.to); -- } else if (this.opts.from) { -- return this.path(this.opts.from); -- } else { -- return "to.css"; -- } -- } -- path(file) { -- if (this.mapOpts.absolute) return file; -- if (file.charCodeAt(0) === 60) return file; -- if (/^\w+:\/\//.test(file)) return file; -- let cached = this.memoizedPaths.get(file); -- if (cached) return cached; -- let from = this.opts.to ? dirname(this.opts.to) : "."; -- if (typeof this.mapOpts.annotation === "string") { -- from = dirname(resolve(from, this.mapOpts.annotation)); -- } -- let path = relative(from, file); -- this.memoizedPaths.set(file, path); -- return path; -- } -- previous() { -- if (!this.previousMaps) { -- this.previousMaps = []; -- if (this.root) { -- this.root.walk((node2) => { -- if (node2.source && node2.source.input.map) { -- let map = node2.source.input.map; -- if (!this.previousMaps.includes(map)) { -- this.previousMaps.push(map); -- } -- } -- }); -- } else { -- let input2 = new Input$3(this.originalCSS, this.opts); -- if (input2.map) this.previousMaps.push(input2.map); -- } -- } -- return this.previousMaps; -- } -- setSourcesContent() { -- let already = {}; -- if (this.root) { -- this.root.walk((node2) => { -- if (node2.source) { -- let from = node2.source.input.from; -- if (from && !already[from]) { -- already[from] = true; -- let fromUrl = this.usesFileUrls ? this.toFileUrl(from) : this.toUrl(this.path(from)); -- this.map.setSourceContent(fromUrl, node2.source.input.css); -- } -- } -- }); -- } else if (this.css) { -- let from = this.opts.from ? this.toUrl(this.path(this.opts.from)) : ""; -- this.map.setSourceContent(from, this.css); -- } -- } -- sourcePath(node2) { -- if (this.mapOpts.from) { -- return this.toUrl(this.mapOpts.from); -- } else if (this.usesFileUrls) { -- return this.toFileUrl(node2.source.input.from); -- } else { -- return this.toUrl(this.path(node2.source.input.from)); -- } -- } -- toBase64(str) { -- if (Buffer) { -- return Buffer.from(str).toString("base64"); -- } else { -- return window.btoa(unescape(encodeURIComponent(str))); -- } -- } -- toFileUrl(path) { -- let cached = this.memoizedFileURLs.get(path); -- if (cached) return cached; -- if (pathToFileURL) { -- let fileURL = pathToFileURL(path).toString(); -- this.memoizedFileURLs.set(path, fileURL); -- return fileURL; -- } else { -- throw new Error( -- "`map.absolute` option is not available in this PostCSS build" -- ); -- } -- } -- toUrl(path) { -- let cached = this.memoizedURLs.get(path); -- if (cached) return cached; -- if (sep === "\\") { -- path = path.replace(/\\/g, "/"); -- } -- let url = encodeURI(path).replace(/[#?]/g, encodeURIComponent); -- this.memoizedURLs.set(path, url); -- return url; -- } --}; --var mapGenerator = MapGenerator$2; --let Node$2 = node; --let Comment$4 = class Comment2 extends Node$2 { -- constructor(defaults) { -- super(defaults); -- this.type = "comment"; -- } --}; --var comment = Comment$4; --Comment$4.default = Comment$4; --let { isClean: isClean$1, my: my$1 } = symbols; --let Declaration$3 = declaration; --let Comment$3 = comment; --let Node$1 = node; --let parse$4, Rule$4, AtRule$4, Root$6; --function cleanSource(nodes) { -- return nodes.map((i2) => { -- if (i2.nodes) i2.nodes = cleanSource(i2.nodes); -- delete i2.source; -- return i2; -- }); --} --function markDirtyUp(node2) { -- node2[isClean$1] = false; -- if (node2.proxyOf.nodes) { -- for (let i2 of node2.proxyOf.nodes) { -- markDirtyUp(i2); -- } -- } --} --let Container$7 = class Container2 extends Node$1 { -- append(...children) { -- for (let child of children) { -- let nodes = this.normalize(child, this.last); -- for (let node2 of nodes) this.proxyOf.nodes.push(node2); -- } -- this.markDirty(); -- return this; -- } -- cleanRaws(keepBetween) { -- super.cleanRaws(keepBetween); -- if (this.nodes) { -- for (let node2 of this.nodes) node2.cleanRaws(keepBetween); -- } -- } -- each(callback) { -- if (!this.proxyOf.nodes) return void 0; -- let iterator = this.getIterator(); -- let index2, result2; -- while (this.indexes[iterator] < this.proxyOf.nodes.length) { -- index2 = this.indexes[iterator]; -- result2 = callback(this.proxyOf.nodes[index2], index2); -- if (result2 === false) break; -- this.indexes[iterator] += 1; -- } -- delete this.indexes[iterator]; -- return result2; -- } -- every(condition) { -- return this.nodes.every(condition); -- } -- getIterator() { -- if (!this.lastEach) this.lastEach = 0; -- if (!this.indexes) this.indexes = {}; -- this.lastEach += 1; -- let iterator = this.lastEach; -- this.indexes[iterator] = 0; -- return iterator; -- } -- getProxyProcessor() { -- return { -- get(node2, prop) { -- if (prop === "proxyOf") { -- return node2; -- } else if (!node2[prop]) { -- return node2[prop]; -- } else if (prop === "each" || typeof prop === "string" && prop.startsWith("walk")) { -- return (...args) => { -- return node2[prop]( -- ...args.map((i2) => { -- if (typeof i2 === "function") { -- return (child, index2) => i2(child.toProxy(), index2); -- } else { -- return i2; -- } -- }) -- ); -- }; -- } else if (prop === "every" || prop === "some") { -- return (cb) => { -- return node2[prop]( -- (child, ...other) => cb(child.toProxy(), ...other) -- ); -- }; -- } else if (prop === "root") { -- return () => node2.root().toProxy(); -- } else if (prop === "nodes") { -- return node2.nodes.map((i2) => i2.toProxy()); -- } else if (prop === "first" || prop === "last") { -- return node2[prop].toProxy(); -- } else { -- return node2[prop]; -- } -- }, -- set(node2, prop, value) { -- if (node2[prop] === value) return true; -- node2[prop] = value; -- if (prop === "name" || prop === "params" || prop === "selector") { -- node2.markDirty(); -- } -- return true; -- } -- }; -- } -- index(child) { -- if (typeof child === "number") return child; -- if (child.proxyOf) child = child.proxyOf; -- return this.proxyOf.nodes.indexOf(child); -- } -- insertAfter(exist, add) { -- let existIndex = this.index(exist); -- let nodes = this.normalize(add, this.proxyOf.nodes[existIndex]).reverse(); -- existIndex = this.index(exist); -- for (let node2 of nodes) this.proxyOf.nodes.splice(existIndex + 1, 0, node2); -- let index2; -- for (let id in this.indexes) { -- index2 = this.indexes[id]; -- if (existIndex < index2) { -- this.indexes[id] = index2 + nodes.length; -- } -- } -- this.markDirty(); -- return this; -- } -- insertBefore(exist, add) { -- let existIndex = this.index(exist); -- let type = existIndex === 0 ? "prepend" : false; -- let nodes = this.normalize(add, this.proxyOf.nodes[existIndex], type).reverse(); -- existIndex = this.index(exist); -- for (let node2 of nodes) this.proxyOf.nodes.splice(existIndex, 0, node2); -- let index2; -- for (let id in this.indexes) { -- index2 = this.indexes[id]; -- if (existIndex <= index2) { -- this.indexes[id] = index2 + nodes.length; -- } -- } -- this.markDirty(); -- return this; -- } -- normalize(nodes, sample) { -- if (typeof nodes === "string") { -- nodes = cleanSource(parse$4(nodes).nodes); -- } else if (typeof nodes === "undefined") { -- nodes = []; -- } else if (Array.isArray(nodes)) { -- nodes = nodes.slice(0); -- for (let i2 of nodes) { -- if (i2.parent) i2.parent.removeChild(i2, "ignore"); -- } -- } else if (nodes.type === "root" && this.type !== "document") { -- nodes = nodes.nodes.slice(0); -- for (let i2 of nodes) { -- if (i2.parent) i2.parent.removeChild(i2, "ignore"); -- } -- } else if (nodes.type) { -- nodes = [nodes]; -- } else if (nodes.prop) { -- if (typeof nodes.value === "undefined") { -- throw new Error("Value field is missed in node creation"); -- } else if (typeof nodes.value !== "string") { -- nodes.value = String(nodes.value); -- } -- nodes = [new Declaration$3(nodes)]; -- } else if (nodes.selector) { -- nodes = [new Rule$4(nodes)]; -- } else if (nodes.name) { -- nodes = [new AtRule$4(nodes)]; -- } else if (nodes.text) { -- nodes = [new Comment$3(nodes)]; -- } else { -- throw new Error("Unknown node type in node creation"); -- } -- let processed = nodes.map((i2) => { -- if (!i2[my$1]) Container2.rebuild(i2); -- i2 = i2.proxyOf; -- if (i2.parent) i2.parent.removeChild(i2); -- if (i2[isClean$1]) markDirtyUp(i2); -- if (typeof i2.raws.before === "undefined") { -- if (sample && typeof sample.raws.before !== "undefined") { -- i2.raws.before = sample.raws.before.replace(/\S/g, ""); -- } -- } -- i2.parent = this.proxyOf; -- return i2; -- }); -- return processed; -- } -- prepend(...children) { -- children = children.reverse(); -- for (let child of children) { -- let nodes = this.normalize(child, this.first, "prepend").reverse(); -- for (let node2 of nodes) this.proxyOf.nodes.unshift(node2); -- for (let id in this.indexes) { -- this.indexes[id] = this.indexes[id] + nodes.length; -- } -- } -- this.markDirty(); -- return this; -- } -- push(child) { -- child.parent = this; -- this.proxyOf.nodes.push(child); -- return this; -- } -- removeAll() { -- for (let node2 of this.proxyOf.nodes) node2.parent = void 0; -- this.proxyOf.nodes = []; -- this.markDirty(); -- return this; -- } -- removeChild(child) { -- child = this.index(child); -- this.proxyOf.nodes[child].parent = void 0; -- this.proxyOf.nodes.splice(child, 1); -- let index2; -- for (let id in this.indexes) { -- index2 = this.indexes[id]; -- if (index2 >= child) { -- this.indexes[id] = index2 - 1; -- } -- } -- this.markDirty(); -- return this; -- } -- replaceValues(pattern, opts, callback) { -- if (!callback) { -- callback = opts; -- opts = {}; -- } -- this.walkDecls((decl) => { -- if (opts.props && !opts.props.includes(decl.prop)) return; -- if (opts.fast && !decl.value.includes(opts.fast)) return; -- decl.value = decl.value.replace(pattern, callback); -- }); -- this.markDirty(); -- return this; -- } -- some(condition) { -- return this.nodes.some(condition); -- } -- walk(callback) { -- return this.each((child, i2) => { -- let result2; -- try { -- result2 = callback(child, i2); -- } catch (e2) { -- throw child.addToError(e2); -- } -- if (result2 !== false && child.walk) { -- result2 = child.walk(callback); -- } -- return result2; -- }); -- } -- walkAtRules(name, callback) { -- if (!callback) { -- callback = name; -- return this.walk((child, i2) => { -- if (child.type === "atrule") { -- return callback(child, i2); -- } -- }); -- } -- if (name instanceof RegExp) { -- return this.walk((child, i2) => { -- if (child.type === "atrule" && name.test(child.name)) { -- return callback(child, i2); -- } -- }); -- } -- return this.walk((child, i2) => { -- if (child.type === "atrule" && child.name === name) { -- return callback(child, i2); -- } -- }); -- } -- walkComments(callback) { -- return this.walk((child, i2) => { -- if (child.type === "comment") { -- return callback(child, i2); -- } -- }); -- } -- walkDecls(prop, callback) { -- if (!callback) { -- callback = prop; -- return this.walk((child, i2) => { -- if (child.type === "decl") { -- return callback(child, i2); -- } -- }); -- } -- if (prop instanceof RegExp) { -- return this.walk((child, i2) => { -- if (child.type === "decl" && prop.test(child.prop)) { -- return callback(child, i2); -- } -- }); -- } -- return this.walk((child, i2) => { -- if (child.type === "decl" && child.prop === prop) { -- return callback(child, i2); -- } -- }); -- } -- walkRules(selector, callback) { -- if (!callback) { -- callback = selector; -- return this.walk((child, i2) => { -- if (child.type === "rule") { -- return callback(child, i2); -- } -- }); -- } -- if (selector instanceof RegExp) { -- return this.walk((child, i2) => { -- if (child.type === "rule" && selector.test(child.selector)) { -- return callback(child, i2); -- } -- }); -- } -- return this.walk((child, i2) => { -- if (child.type === "rule" && child.selector === selector) { -- return callback(child, i2); -- } -- }); -- } -- get first() { -- if (!this.proxyOf.nodes) return void 0; -- return this.proxyOf.nodes[0]; -- } -- get last() { -- if (!this.proxyOf.nodes) return void 0; -- return this.proxyOf.nodes[this.proxyOf.nodes.length - 1]; -- } --}; --Container$7.registerParse = (dependant) => { -- parse$4 = dependant; --}; --Container$7.registerRule = (dependant) => { -- Rule$4 = dependant; --}; --Container$7.registerAtRule = (dependant) => { -- AtRule$4 = dependant; --}; --Container$7.registerRoot = (dependant) => { -- Root$6 = dependant; --}; --var container = Container$7; --Container$7.default = Container$7; --Container$7.rebuild = (node2) => { -- if (node2.type === "atrule") { -- Object.setPrototypeOf(node2, AtRule$4.prototype); -- } else if (node2.type === "rule") { -- Object.setPrototypeOf(node2, Rule$4.prototype); -- } else if (node2.type === "decl") { -- Object.setPrototypeOf(node2, Declaration$3.prototype); -- } else if (node2.type === "comment") { -- Object.setPrototypeOf(node2, Comment$3.prototype); -- } else if (node2.type === "root") { -- Object.setPrototypeOf(node2, Root$6.prototype); -- } -- node2[my$1] = true; -- if (node2.nodes) { -- node2.nodes.forEach((child) => { -- Container$7.rebuild(child); -- }); -- } --}; --let Container$6 = container; --let LazyResult$4, Processor$3; --let Document$3 = class Document23 extends Container$6 { -- constructor(defaults) { -- super({ type: "document", ...defaults }); -- if (!this.nodes) { -- this.nodes = []; -- } -- } -- toResult(opts = {}) { -- let lazy = new LazyResult$4(new Processor$3(), this, opts); -- return lazy.stringify(); -- } --}; --Document$3.registerLazyResult = (dependant) => { -- LazyResult$4 = dependant; --}; --Document$3.registerProcessor = (dependant) => { -- Processor$3 = dependant; --}; --var document$1 = Document$3; --Document$3.default = Document$3; --let printed = {}; --var warnOnce$2 = function warnOnce2(message) { -- if (printed[message]) return; -- printed[message] = true; -- if (typeof console !== "undefined" && console.warn) { -- console.warn(message); -- } --}; --let Warning$2 = class Warning2 { -- constructor(text, opts = {}) { -- this.type = "warning"; -- this.text = text; -- if (opts.node && opts.node.source) { -- let range = opts.node.rangeBy(opts); -- this.line = range.start.line; -- this.column = range.start.column; -- this.endLine = range.end.line; -- this.endColumn = range.end.column; -- } -- for (let opt in opts) this[opt] = opts[opt]; -- } -- toString() { -- if (this.node) { -- return this.node.error(this.text, { -- index: this.index, -- plugin: this.plugin, -- word: this.word -- }).message; -- } -- if (this.plugin) { -- return this.plugin + ": " + this.text; -- } -- return this.text; -- } --}; --var warning = Warning$2; --Warning$2.default = Warning$2; --let Warning$1 = warning; --let Result$3 = class Result2 { -- constructor(processor2, root2, opts) { -- this.processor = processor2; -- this.messages = []; -- this.root = root2; -- this.opts = opts; -- this.css = void 0; -- this.map = void 0; -- } -- toString() { -- return this.css; -- } -- warn(text, opts = {}) { -- if (!opts.plugin) { -- if (this.lastPlugin && this.lastPlugin.postcssPlugin) { -- opts.plugin = this.lastPlugin.postcssPlugin; -- } -- } -- let warning2 = new Warning$1(text, opts); -- this.messages.push(warning2); -- return warning2; -- } -- warnings() { -- return this.messages.filter((i2) => i2.type === "warning"); -- } -- get content() { -- return this.css; -- } --}; --var result = Result$3; --Result$3.default = Result$3; --const SINGLE_QUOTE = "'".charCodeAt(0); --const DOUBLE_QUOTE = '"'.charCodeAt(0); --const BACKSLASH = "\\".charCodeAt(0); --const SLASH = "/".charCodeAt(0); --const NEWLINE = "\n".charCodeAt(0); --const SPACE = " ".charCodeAt(0); --const FEED = "\f".charCodeAt(0); --const TAB = " ".charCodeAt(0); --const CR = "\r".charCodeAt(0); --const OPEN_SQUARE = "[".charCodeAt(0); --const CLOSE_SQUARE = "]".charCodeAt(0); --const OPEN_PARENTHESES = "(".charCodeAt(0); --const CLOSE_PARENTHESES = ")".charCodeAt(0); --const OPEN_CURLY = "{".charCodeAt(0); --const CLOSE_CURLY = "}".charCodeAt(0); --const SEMICOLON = ";".charCodeAt(0); --const ASTERISK = "*".charCodeAt(0); --const COLON = ":".charCodeAt(0); --const AT = "@".charCodeAt(0); --const RE_AT_END = /[\t\n\f\r "#'()/;[\\\]{}]/g; --const RE_WORD_END = /[\t\n\f\r !"#'():;@[\\\]{}]|\/(?=\*)/g; --const RE_BAD_BRACKET = /.[\r\n"'(/\\]/; --const RE_HEX_ESCAPE = /[\da-f]/i; --var tokenize = function tokenizer2(input2, options = {}) { -- let css = input2.css.valueOf(); -- let ignore = options.ignoreErrors; -- let code, next, quote, content, escape; -- let escaped, escapePos, prev, n2, currentToken; -- let length = css.length; -- let pos = 0; -- let buffer = []; -- let returned = []; -- function position() { -- return pos; -- } -- function unclosed(what) { -- throw input2.error("Unclosed " + what, pos); -- } -- function endOfFile() { -- return returned.length === 0 && pos >= length; -- } -- function nextToken(opts) { -- if (returned.length) return returned.pop(); -- if (pos >= length) return; -- let ignoreUnclosed = opts ? opts.ignoreUnclosed : false; -- code = css.charCodeAt(pos); -- switch (code) { -- case NEWLINE: -- case SPACE: -- case TAB: -- case CR: -- case FEED: { -- next = pos; -- do { -- next += 1; -- code = css.charCodeAt(next); -- } while (code === SPACE || code === NEWLINE || code === TAB || code === CR || code === FEED); -- currentToken = ["space", css.slice(pos, next)]; -- pos = next - 1; -- break; -- } -- case OPEN_SQUARE: -- case CLOSE_SQUARE: -- case OPEN_CURLY: -- case CLOSE_CURLY: -- case COLON: -- case SEMICOLON: -- case CLOSE_PARENTHESES: { -- let controlChar = String.fromCharCode(code); -- currentToken = [controlChar, controlChar, pos]; -- break; -- } -- case OPEN_PARENTHESES: { -- prev = buffer.length ? buffer.pop()[1] : ""; -- n2 = css.charCodeAt(pos + 1); -- if (prev === "url" && n2 !== SINGLE_QUOTE && n2 !== DOUBLE_QUOTE && n2 !== SPACE && n2 !== NEWLINE && n2 !== TAB && n2 !== FEED && n2 !== CR) { -- next = pos; -- do { -- escaped = false; -- next = css.indexOf(")", next + 1); -- if (next === -1) { -- if (ignore || ignoreUnclosed) { -- next = pos; -- break; -- } else { -- unclosed("bracket"); -- } -- } -- escapePos = next; -- while (css.charCodeAt(escapePos - 1) === BACKSLASH) { -- escapePos -= 1; -- escaped = !escaped; -- } -- } while (escaped); -- currentToken = ["brackets", css.slice(pos, next + 1), pos, next]; -- pos = next; -- } else { -- next = css.indexOf(")", pos + 1); -- content = css.slice(pos, next + 1); -- if (next === -1 || RE_BAD_BRACKET.test(content)) { -- currentToken = ["(", "(", pos]; -- } else { -- currentToken = ["brackets", content, pos, next]; -- pos = next; -- } -- } -- break; -- } -- case SINGLE_QUOTE: -- case DOUBLE_QUOTE: { -- quote = code === SINGLE_QUOTE ? "'" : '"'; -- next = pos; -- do { -- escaped = false; -- next = css.indexOf(quote, next + 1); -- if (next === -1) { -- if (ignore || ignoreUnclosed) { -- next = pos + 1; -- break; -- } else { -- unclosed("string"); -- } -- } -- escapePos = next; -- while (css.charCodeAt(escapePos - 1) === BACKSLASH) { -- escapePos -= 1; -- escaped = !escaped; -- } -- } while (escaped); -- currentToken = ["string", css.slice(pos, next + 1), pos, next]; -- pos = next; -- break; -- } -- case AT: { -- RE_AT_END.lastIndex = pos + 1; -- RE_AT_END.test(css); -- if (RE_AT_END.lastIndex === 0) { -- next = css.length - 1; -- } else { -- next = RE_AT_END.lastIndex - 2; -- } -- currentToken = ["at-word", css.slice(pos, next + 1), pos, next]; -- pos = next; -- break; -- } -- case BACKSLASH: { -- next = pos; -- escape = true; -- while (css.charCodeAt(next + 1) === BACKSLASH) { -- next += 1; -- escape = !escape; -- } -- code = css.charCodeAt(next + 1); -- if (escape && code !== SLASH && code !== SPACE && code !== NEWLINE && code !== TAB && code !== CR && code !== FEED) { -- next += 1; -- if (RE_HEX_ESCAPE.test(css.charAt(next))) { -- while (RE_HEX_ESCAPE.test(css.charAt(next + 1))) { -- next += 1; -- } -- if (css.charCodeAt(next + 1) === SPACE) { -- next += 1; -- } -- } -- } -- currentToken = ["word", css.slice(pos, next + 1), pos, next]; -- pos = next; -- break; -- } -- default: { -- if (code === SLASH && css.charCodeAt(pos + 1) === ASTERISK) { -- next = css.indexOf("*/", pos + 2) + 1; -- if (next === 0) { -- if (ignore || ignoreUnclosed) { -- next = css.length; -- } else { -- unclosed("comment"); -- } -- } -- currentToken = ["comment", css.slice(pos, next + 1), pos, next]; -- pos = next; -- } else { -- RE_WORD_END.lastIndex = pos + 1; -- RE_WORD_END.test(css); -- if (RE_WORD_END.lastIndex === 0) { -- next = css.length - 1; -- } else { -- next = RE_WORD_END.lastIndex - 2; -- } -- currentToken = ["word", css.slice(pos, next + 1), pos, next]; -- buffer.push(currentToken); -- pos = next; -- } -- break; -- } -- } -- pos++; -- return currentToken; -- } -- function back(token) { -- returned.push(token); -- } -- return { -- back, -- endOfFile, -- nextToken, -- position -- }; --}; --let Container$5 = container; --let AtRule$3 = class AtRule2 extends Container$5 { -- constructor(defaults) { -- super(defaults); -- this.type = "atrule"; -- } -- append(...children) { -- if (!this.proxyOf.nodes) this.nodes = []; -- return super.append(...children); -- } -- prepend(...children) { -- if (!this.proxyOf.nodes) this.nodes = []; -- return super.prepend(...children); -- } --}; --var atRule = AtRule$3; --AtRule$3.default = AtRule$3; --Container$5.registerAtRule(AtRule$3); --let Container$4 = container; --let LazyResult$3, Processor$2; --let Root$5 = class Root2 extends Container$4 { -- constructor(defaults) { -- super(defaults); -- this.type = "root"; -- if (!this.nodes) this.nodes = []; -- } -- normalize(child, sample, type) { -- let nodes = super.normalize(child); -- if (sample) { -- if (type === "prepend") { -- if (this.nodes.length > 1) { -- sample.raws.before = this.nodes[1].raws.before; -- } else { -- delete sample.raws.before; -- } -- } else if (this.first !== sample) { -- for (let node2 of nodes) { -- node2.raws.before = sample.raws.before; -- } -- } -- } -- return nodes; -- } -- removeChild(child, ignore) { -- let index2 = this.index(child); -- if (!ignore && index2 === 0 && this.nodes.length > 1) { -- this.nodes[1].raws.before = this.nodes[index2].raws.before; -- } -- return super.removeChild(child); -- } -- toResult(opts = {}) { -- let lazy = new LazyResult$3(new Processor$2(), this, opts); -- return lazy.stringify(); -- } --}; --Root$5.registerLazyResult = (dependant) => { -- LazyResult$3 = dependant; --}; --Root$5.registerProcessor = (dependant) => { -- Processor$2 = dependant; --}; --var root = Root$5; --Root$5.default = Root$5; --Container$4.registerRoot(Root$5); --let list$2 = { -- comma(string) { -- return list$2.split(string, [","], true); -- }, -- space(string) { -- let spaces = [" ", "\n", " "]; -- return list$2.split(string, spaces); -- }, -- split(string, separators, last) { -- let array = []; -- let current = ""; -- let split = false; -- let func = 0; -- let inQuote = false; -- let prevQuote = ""; -- let escape = false; -- for (let letter of string) { -- if (escape) { -- escape = false; -- } else if (letter === "\\") { -- escape = true; -- } else if (inQuote) { -- if (letter === prevQuote) { -- inQuote = false; -- } -- } else if (letter === '"' || letter === "'") { -- inQuote = true; -- prevQuote = letter; -- } else if (letter === "(") { -- func += 1; -- } else if (letter === ")") { -- if (func > 0) func -= 1; -- } else if (func === 0) { -- if (separators.includes(letter)) split = true; -- } -- if (split) { -- if (current !== "") array.push(current.trim()); -- current = ""; -- split = false; -- } else { -- current += letter; -- } -- } -- if (last || current !== "") array.push(current.trim()); -- return array; -- } --}; --var list_1 = list$2; --list$2.default = list$2; --let Container$3 = container; --let list$1 = list_1; --let Rule$3 = class Rule2 extends Container$3 { -- constructor(defaults) { -- super(defaults); -- this.type = "rule"; -- if (!this.nodes) this.nodes = []; -- } -- get selectors() { -- return list$1.comma(this.selector); -- } -- set selectors(values) { -- let match = this.selector ? this.selector.match(/,\s*/) : null; -- let sep2 = match ? match[0] : "," + this.raw("between", "beforeOpen"); -- this.selector = values.join(sep2); -- } --}; --var rule = Rule$3; --Rule$3.default = Rule$3; --Container$3.registerRule(Rule$3); --let Declaration$2 = declaration; --let tokenizer22 = tokenize; --let Comment$2 = comment; --let AtRule$2 = atRule; --let Root$4 = root; --let Rule$2 = rule; --const SAFE_COMMENT_NEIGHBOR = { -- empty: true, -- space: true --}; --function findLastWithPosition(tokens) { -- for (let i2 = tokens.length - 1; i2 >= 0; i2--) { -- let token = tokens[i2]; -- let pos = token[3] || token[2]; -- if (pos) return pos; -- } --} --let Parser$1 = class Parser2 { -- constructor(input2) { -- this.input = input2; -- this.root = new Root$4(); -- this.current = this.root; -- this.spaces = ""; -- this.semicolon = false; -- this.createTokenizer(); -- this.root.source = { input: input2, start: { column: 1, line: 1, offset: 0 } }; -- } -- atrule(token) { -- let node2 = new AtRule$2(); -- node2.name = token[1].slice(1); -- if (node2.name === "") { -- this.unnamedAtrule(node2, token); -- } -- this.init(node2, token[2]); -- let type; -- let prev; -- let shift; -- let last = false; -- let open = false; -- let params = []; -- let brackets = []; -- while (!this.tokenizer.endOfFile()) { -- token = this.tokenizer.nextToken(); -- type = token[0]; -- if (type === "(" || type === "[") { -- brackets.push(type === "(" ? ")" : "]"); -- } else if (type === "{" && brackets.length > 0) { -- brackets.push("}"); -- } else if (type === brackets[brackets.length - 1]) { -- brackets.pop(); -- } -- if (brackets.length === 0) { -- if (type === ";") { -- node2.source.end = this.getPosition(token[2]); -- node2.source.end.offset++; -- this.semicolon = true; -- break; -- } else if (type === "{") { -- open = true; -- break; -- } else if (type === "}") { -- if (params.length > 0) { -- shift = params.length - 1; -- prev = params[shift]; -- while (prev && prev[0] === "space") { -- prev = params[--shift]; -- } -- if (prev) { -- node2.source.end = this.getPosition(prev[3] || prev[2]); -- node2.source.end.offset++; -- } -- } -- this.end(token); -- break; -- } else { -- params.push(token); -- } -- } else { -- params.push(token); -- } -- if (this.tokenizer.endOfFile()) { -- last = true; -- break; -- } -- } -- node2.raws.between = this.spacesAndCommentsFromEnd(params); -- if (params.length) { -- node2.raws.afterName = this.spacesAndCommentsFromStart(params); -- this.raw(node2, "params", params); -- if (last) { -- token = params[params.length - 1]; -- node2.source.end = this.getPosition(token[3] || token[2]); -- node2.source.end.offset++; -- this.spaces = node2.raws.between; -- node2.raws.between = ""; -- } -- } else { -- node2.raws.afterName = ""; -- node2.params = ""; -- } -- if (open) { -- node2.nodes = []; -- this.current = node2; -- } -- } -- checkMissedSemicolon(tokens) { -- let colon = this.colon(tokens); -- if (colon === false) return; -- let founded = 0; -- let token; -- for (let j = colon - 1; j >= 0; j--) { -- token = tokens[j]; -- if (token[0] !== "space") { -- founded += 1; -- if (founded === 2) break; -- } -- } -- throw this.input.error( -- "Missed semicolon", -- token[0] === "word" ? token[3] + 1 : token[2] -- ); -- } -- colon(tokens) { -- let brackets = 0; -- let token, type, prev; -- for (let [i2, element] of tokens.entries()) { -- token = element; -- type = token[0]; -- if (type === "(") { -- brackets += 1; -- } -- if (type === ")") { -- brackets -= 1; -- } -- if (brackets === 0 && type === ":") { -- if (!prev) { -- this.doubleColon(token); -- } else if (prev[0] === "word" && prev[1] === "progid") { -- continue; -- } else { -- return i2; -- } -- } -- prev = token; -- } -- return false; -- } -- comment(token) { -- let node2 = new Comment$2(); -- this.init(node2, token[2]); -- node2.source.end = this.getPosition(token[3] || token[2]); -- node2.source.end.offset++; -- let text = token[1].slice(2, -2); -- if (/^\s*$/.test(text)) { -- node2.text = ""; -- node2.raws.left = text; -- node2.raws.right = ""; -- } else { -- let match = text.match(/^(\s*)([^]*\S)(\s*)$/); -- node2.text = match[2]; -- node2.raws.left = match[1]; -- node2.raws.right = match[3]; -- } -- } -- createTokenizer() { -- this.tokenizer = tokenizer22(this.input); -- } -- decl(tokens, customProperty) { -- let node2 = new Declaration$2(); -- this.init(node2, tokens[0][2]); -- let last = tokens[tokens.length - 1]; -- if (last[0] === ";") { -- this.semicolon = true; -- tokens.pop(); -- } -- node2.source.end = this.getPosition( -- last[3] || last[2] || findLastWithPosition(tokens) -- ); -- node2.source.end.offset++; -- while (tokens[0][0] !== "word") { -- if (tokens.length === 1) this.unknownWord(tokens); -- node2.raws.before += tokens.shift()[1]; -- } -- node2.source.start = this.getPosition(tokens[0][2]); -- node2.prop = ""; -- while (tokens.length) { -- let type = tokens[0][0]; -- if (type === ":" || type === "space" || type === "comment") { -- break; -- } -- node2.prop += tokens.shift()[1]; -- } -- node2.raws.between = ""; -- let token; -- while (tokens.length) { -- token = tokens.shift(); -- if (token[0] === ":") { -- node2.raws.between += token[1]; -- break; -- } else { -- if (token[0] === "word" && /\w/.test(token[1])) { -- this.unknownWord([token]); -- } -- node2.raws.between += token[1]; -- } -- } -- if (node2.prop[0] === "_" || node2.prop[0] === "*") { -- node2.raws.before += node2.prop[0]; -- node2.prop = node2.prop.slice(1); -- } -- let firstSpaces = []; -- let next; -- while (tokens.length) { -- next = tokens[0][0]; -- if (next !== "space" && next !== "comment") break; -- firstSpaces.push(tokens.shift()); -- } -- this.precheckMissedSemicolon(tokens); -- for (let i2 = tokens.length - 1; i2 >= 0; i2--) { -- token = tokens[i2]; -- if (token[1].toLowerCase() === "!important") { -- node2.important = true; -- let string = this.stringFrom(tokens, i2); -- string = this.spacesFromEnd(tokens) + string; -- if (string !== " !important") node2.raws.important = string; -- break; -- } else if (token[1].toLowerCase() === "important") { -- let cache = tokens.slice(0); -- let str = ""; -- for (let j = i2; j > 0; j--) { -- let type = cache[j][0]; -- if (str.trim().indexOf("!") === 0 && type !== "space") { -- break; -- } -- str = cache.pop()[1] + str; -- } -- if (str.trim().indexOf("!") === 0) { -- node2.important = true; -- node2.raws.important = str; -- tokens = cache; -- } -- } -- if (token[0] !== "space" && token[0] !== "comment") { -- break; -- } -- } -- let hasWord = tokens.some((i2) => i2[0] !== "space" && i2[0] !== "comment"); -- if (hasWord) { -- node2.raws.between += firstSpaces.map((i2) => i2[1]).join(""); -- firstSpaces = []; -- } -- this.raw(node2, "value", firstSpaces.concat(tokens), customProperty); -- if (node2.value.includes(":") && !customProperty) { -- this.checkMissedSemicolon(tokens); -- } -- } -- doubleColon(token) { -- throw this.input.error( -- "Double colon", -- { offset: token[2] }, -- { offset: token[2] + token[1].length } -- ); -- } -- emptyRule(token) { -- let node2 = new Rule$2(); -- this.init(node2, token[2]); -- node2.selector = ""; -- node2.raws.between = ""; -- this.current = node2; -- } -- end(token) { -- if (this.current.nodes && this.current.nodes.length) { -- this.current.raws.semicolon = this.semicolon; -- } -- this.semicolon = false; -- this.current.raws.after = (this.current.raws.after || "") + this.spaces; -- this.spaces = ""; -- if (this.current.parent) { -- this.current.source.end = this.getPosition(token[2]); -- this.current.source.end.offset++; -- this.current = this.current.parent; -- } else { -- this.unexpectedClose(token); -- } -- } -- endFile() { -- if (this.current.parent) this.unclosedBlock(); -- if (this.current.nodes && this.current.nodes.length) { -- this.current.raws.semicolon = this.semicolon; -- } -- this.current.raws.after = (this.current.raws.after || "") + this.spaces; -- this.root.source.end = this.getPosition(this.tokenizer.position()); -- } -- freeSemicolon(token) { -- this.spaces += token[1]; -- if (this.current.nodes) { -- let prev = this.current.nodes[this.current.nodes.length - 1]; -- if (prev && prev.type === "rule" && !prev.raws.ownSemicolon) { -- prev.raws.ownSemicolon = this.spaces; -- this.spaces = ""; -- } -- } -- } -- // Helpers -- getPosition(offset) { -- let pos = this.input.fromOffset(offset); -- return { -- column: pos.col, -- line: pos.line, -- offset -- }; -- } -- init(node2, offset) { -- this.current.push(node2); -- node2.source = { -- input: this.input, -- start: this.getPosition(offset) -- }; -- node2.raws.before = this.spaces; -- this.spaces = ""; -- if (node2.type !== "comment") this.semicolon = false; -- } -- other(start) { -- let end = false; -- let type = null; -- let colon = false; -- let bracket = null; -- let brackets = []; -- let customProperty = start[1].startsWith("--"); -- let tokens = []; -- let token = start; -- while (token) { -- type = token[0]; -- tokens.push(token); -- if (type === "(" || type === "[") { -- if (!bracket) bracket = token; -- brackets.push(type === "(" ? ")" : "]"); -- } else if (customProperty && colon && type === "{") { -- if (!bracket) bracket = token; -- brackets.push("}"); -- } else if (brackets.length === 0) { -- if (type === ";") { -- if (colon) { -- this.decl(tokens, customProperty); -- return; -- } else { -- break; -- } -- } else if (type === "{") { -- this.rule(tokens); -- return; -- } else if (type === "}") { -- this.tokenizer.back(tokens.pop()); -- end = true; -- break; -- } else if (type === ":") { -- colon = true; -- } -- } else if (type === brackets[brackets.length - 1]) { -- brackets.pop(); -- if (brackets.length === 0) bracket = null; -- } -- token = this.tokenizer.nextToken(); -- } -- if (this.tokenizer.endOfFile()) end = true; -- if (brackets.length > 0) this.unclosedBracket(bracket); -- if (end && colon) { -- if (!customProperty) { -- while (tokens.length) { -- token = tokens[tokens.length - 1][0]; -- if (token !== "space" && token !== "comment") break; -- this.tokenizer.back(tokens.pop()); -- } -- } -- this.decl(tokens, customProperty); -- } else { -- this.unknownWord(tokens); -- } -- } -- parse() { -- let token; -- while (!this.tokenizer.endOfFile()) { -- token = this.tokenizer.nextToken(); -- switch (token[0]) { -- case "space": -- this.spaces += token[1]; -- break; -- case ";": -- this.freeSemicolon(token); -- break; -- case "}": -- this.end(token); -- break; -- case "comment": -- this.comment(token); -- break; -- case "at-word": -- this.atrule(token); -- break; -- case "{": -- this.emptyRule(token); -- break; -- default: -- this.other(token); -- break; -- } -- } -- this.endFile(); -- } -- precheckMissedSemicolon() { -- } -- raw(node2, prop, tokens, customProperty) { -- let token, type; -- let length = tokens.length; -- let value = ""; -- let clean = true; -- let next, prev; -- for (let i2 = 0; i2 < length; i2 += 1) { -- token = tokens[i2]; -- type = token[0]; -- if (type === "space" && i2 === length - 1 && !customProperty) { -- clean = false; -- } else if (type === "comment") { -- prev = tokens[i2 - 1] ? tokens[i2 - 1][0] : "empty"; -- next = tokens[i2 + 1] ? tokens[i2 + 1][0] : "empty"; -- if (!SAFE_COMMENT_NEIGHBOR[prev] && !SAFE_COMMENT_NEIGHBOR[next]) { -- if (value.slice(-1) === ",") { -- clean = false; -- } else { -- value += token[1]; -- } -- } else { -- clean = false; -- } -- } else { -- value += token[1]; -- } -- } -- if (!clean) { -- let raw = tokens.reduce((all, i2) => all + i2[1], ""); -- node2.raws[prop] = { raw, value }; -- } -- node2[prop] = value; -- } -- rule(tokens) { -- tokens.pop(); -- let node2 = new Rule$2(); -- this.init(node2, tokens[0][2]); -- node2.raws.between = this.spacesAndCommentsFromEnd(tokens); -- this.raw(node2, "selector", tokens); -- this.current = node2; -- } -- spacesAndCommentsFromEnd(tokens) { -- let lastTokenType; -- let spaces = ""; -- while (tokens.length) { -- lastTokenType = tokens[tokens.length - 1][0]; -- if (lastTokenType !== "space" && lastTokenType !== "comment") break; -- spaces = tokens.pop()[1] + spaces; -- } -- return spaces; -- } -- // Errors -- spacesAndCommentsFromStart(tokens) { -- let next; -- let spaces = ""; -- while (tokens.length) { -- next = tokens[0][0]; -- if (next !== "space" && next !== "comment") break; -- spaces += tokens.shift()[1]; -- } -- return spaces; -- } -- spacesFromEnd(tokens) { -- let lastTokenType; -- let spaces = ""; -- while (tokens.length) { -- lastTokenType = tokens[tokens.length - 1][0]; -- if (lastTokenType !== "space") break; -- spaces = tokens.pop()[1] + spaces; -- } -- return spaces; -- } -- stringFrom(tokens, from) { -- let result2 = ""; -- for (let i2 = from; i2 < tokens.length; i2++) { -- result2 += tokens[i2][1]; -- } -- tokens.splice(from, tokens.length - from); -- return result2; -- } -- unclosedBlock() { -- let pos = this.current.source.start; -- throw this.input.error("Unclosed block", pos.line, pos.column); -- } -- unclosedBracket(bracket) { -- throw this.input.error( -- "Unclosed bracket", -- { offset: bracket[2] }, -- { offset: bracket[2] + 1 } -- ); -- } -- unexpectedClose(token) { -- throw this.input.error( -- "Unexpected }", -- { offset: token[2] }, -- { offset: token[2] + 1 } -- ); -- } -- unknownWord(tokens) { -- throw this.input.error( -- "Unknown word", -- { offset: tokens[0][2] }, -- { offset: tokens[0][2] + tokens[0][1].length } -- ); -- } -- unnamedAtrule(node2, token) { -- throw this.input.error( -- "At-rule without name", -- { offset: token[2] }, -- { offset: token[2] + token[1].length } -- ); -- } --}; --var parser = Parser$1; --let Container$2 = container; --let Parser22 = parser; --let Input$2 = input; --function parse$3(css, opts) { -- let input2 = new Input$2(css, opts); -- let parser2 = new Parser22(input2); -- try { -- parser2.parse(); -- } catch (e2) { -- if (process.env.NODE_ENV !== "production") { -- if (e2.name === "CssSyntaxError" && opts && opts.from) { -- if (/\.scss$/i.test(opts.from)) { -- e2.message += "\nYou tried to parse SCSS with the standard CSS parser; try again with the postcss-scss parser"; -- } else if (/\.sass/i.test(opts.from)) { -- e2.message += "\nYou tried to parse Sass with the standard CSS parser; try again with the postcss-sass parser"; -- } else if (/\.less$/i.test(opts.from)) { -- e2.message += "\nYou tried to parse Less with the standard CSS parser; try again with the postcss-less parser"; -- } -- } -- } -- throw e2; -- } -- return parser2.root; --} --var parse_1 = parse$3; --parse$3.default = parse$3; --Container$2.registerParse(parse$3); --let { isClean, my } = symbols; --let MapGenerator$1 = mapGenerator; --let stringify$2 = stringify_1; --let Container$1 = container; --let Document$2 = document$1; --let warnOnce$1 = warnOnce$2; --let Result$2 = result; --let parse$2 = parse_1; --let Root$3 = root; --const TYPE_TO_CLASS_NAME = { -- atrule: "AtRule", -- comment: "Comment", -- decl: "Declaration", -- document: "Document", -- root: "Root", -- rule: "Rule" --}; --const PLUGIN_PROPS = { -- AtRule: true, -- AtRuleExit: true, -- Comment: true, -- CommentExit: true, -- Declaration: true, -- DeclarationExit: true, -- Document: true, -- DocumentExit: true, -- Once: true, -- OnceExit: true, -- postcssPlugin: true, -- prepare: true, -- Root: true, -- RootExit: true, -- Rule: true, -- RuleExit: true --}; --const NOT_VISITORS = { -- Once: true, -- postcssPlugin: true, -- prepare: true --}; --const CHILDREN = 0; --function isPromise(obj) { -- return typeof obj === "object" && typeof obj.then === "function"; --} --function getEvents(node2) { -- let key = false; -- let type = TYPE_TO_CLASS_NAME[node2.type]; -- if (node2.type === "decl") { -- key = node2.prop.toLowerCase(); -- } else if (node2.type === "atrule") { -- key = node2.name.toLowerCase(); -- } -- if (key && node2.append) { -- return [ -- type, -- type + "-" + key, -- CHILDREN, -- type + "Exit", -- type + "Exit-" + key -- ]; -- } else if (key) { -- return [type, type + "-" + key, type + "Exit", type + "Exit-" + key]; -- } else if (node2.append) { -- return [type, CHILDREN, type + "Exit"]; -- } else { -- return [type, type + "Exit"]; -- } --} --function toStack(node2) { -- let events; -- if (node2.type === "document") { -- events = ["Document", CHILDREN, "DocumentExit"]; -- } else if (node2.type === "root") { -- events = ["Root", CHILDREN, "RootExit"]; -- } else { -- events = getEvents(node2); -- } -- return { -- eventIndex: 0, -- events, -- iterator: 0, -- node: node2, -- visitorIndex: 0, -- visitors: [] -- }; --} --function cleanMarks(node2) { -- node2[isClean] = false; -- if (node2.nodes) node2.nodes.forEach((i2) => cleanMarks(i2)); -- return node2; --} --let postcss$2 = {}; --let LazyResult$2 = class LazyResult2 { -- constructor(processor2, css, opts) { -- this.stringified = false; -- this.processed = false; -- let root2; -- if (typeof css === "object" && css !== null && (css.type === "root" || css.type === "document")) { -- root2 = cleanMarks(css); -- } else if (css instanceof LazyResult2 || css instanceof Result$2) { -- root2 = cleanMarks(css.root); -- if (css.map) { -- if (typeof opts.map === "undefined") opts.map = {}; -- if (!opts.map.inline) opts.map.inline = false; -- opts.map.prev = css.map; -- } -- } else { -- let parser2 = parse$2; -- if (opts.syntax) parser2 = opts.syntax.parse; -- if (opts.parser) parser2 = opts.parser; -- if (parser2.parse) parser2 = parser2.parse; -- try { -- root2 = parser2(css, opts); -- } catch (error) { -- this.processed = true; -- this.error = error; -- } -- if (root2 && !root2[my]) { -- Container$1.rebuild(root2); -- } -- } -- this.result = new Result$2(processor2, root2, opts); -- this.helpers = { ...postcss$2, postcss: postcss$2, result: this.result }; -- this.plugins = this.processor.plugins.map((plugin22) => { -- if (typeof plugin22 === "object" && plugin22.prepare) { -- return { ...plugin22, ...plugin22.prepare(this.result) }; -- } else { -- return plugin22; -- } -- }); -- } -- async() { -- if (this.error) return Promise.reject(this.error); -- if (this.processed) return Promise.resolve(this.result); -- if (!this.processing) { -- this.processing = this.runAsync(); -- } -- return this.processing; -- } -- catch(onRejected) { -- return this.async().catch(onRejected); -- } -- finally(onFinally) { -- return this.async().then(onFinally, onFinally); -- } -- getAsyncError() { -- throw new Error("Use process(css).then(cb) to work with async plugins"); -- } -- handleError(error, node2) { -- let plugin22 = this.result.lastPlugin; -- try { -- if (node2) node2.addToError(error); -- this.error = error; -- if (error.name === "CssSyntaxError" && !error.plugin) { -- error.plugin = plugin22.postcssPlugin; -- error.setMessage(); -- } else if (plugin22.postcssVersion) { -- if (process.env.NODE_ENV !== "production") { -- let pluginName = plugin22.postcssPlugin; -- let pluginVer = plugin22.postcssVersion; -- let runtimeVer = this.result.processor.version; -- let a2 = pluginVer.split("."); -- let b = runtimeVer.split("."); -- if (a2[0] !== b[0] || parseInt(a2[1]) > parseInt(b[1])) { -- console.error( -- "Unknown error from PostCSS plugin. Your current PostCSS version is " + runtimeVer + ", but " + pluginName + " uses " + pluginVer + ". Perhaps this is the source of the error below." -- ); -- } -- } -- } -- } catch (err) { -- if (console && console.error) console.error(err); -- } -- return error; -- } -- prepareVisitors() { -- this.listeners = {}; -- let add = (plugin22, type, cb) => { -- if (!this.listeners[type]) this.listeners[type] = []; -- this.listeners[type].push([plugin22, cb]); -- }; -- for (let plugin22 of this.plugins) { -- if (typeof plugin22 === "object") { -- for (let event in plugin22) { -- if (!PLUGIN_PROPS[event] && /^[A-Z]/.test(event)) { -- throw new Error( -- `Unknown event ${event} in ${plugin22.postcssPlugin}. Try to update PostCSS (${this.processor.version} now).` -- ); -- } -- if (!NOT_VISITORS[event]) { -- if (typeof plugin22[event] === "object") { -- for (let filter in plugin22[event]) { -- if (filter === "*") { -- add(plugin22, event, plugin22[event][filter]); -- } else { -- add( -- plugin22, -- event + "-" + filter.toLowerCase(), -- plugin22[event][filter] -- ); -- } -- } -- } else if (typeof plugin22[event] === "function") { -- add(plugin22, event, plugin22[event]); -- } -- } -- } -- } -- } -- this.hasListener = Object.keys(this.listeners).length > 0; -- } -- async runAsync() { -- this.plugin = 0; -- for (let i2 = 0; i2 < this.plugins.length; i2++) { -- let plugin22 = this.plugins[i2]; -- let promise = this.runOnRoot(plugin22); -- if (isPromise(promise)) { -- try { -- await promise; -- } catch (error) { -- throw this.handleError(error); -- } -- } -- } -- this.prepareVisitors(); -- if (this.hasListener) { -- let root2 = this.result.root; -- while (!root2[isClean]) { -- root2[isClean] = true; -- let stack = [toStack(root2)]; -- while (stack.length > 0) { -- let promise = this.visitTick(stack); -- if (isPromise(promise)) { -- try { -- await promise; -- } catch (e2) { -- let node2 = stack[stack.length - 1].node; -- throw this.handleError(e2, node2); -- } -- } -- } -- } -- if (this.listeners.OnceExit) { -- for (let [plugin22, visitor] of this.listeners.OnceExit) { -- this.result.lastPlugin = plugin22; -- try { -- if (root2.type === "document") { -- let roots = root2.nodes.map( -- (subRoot) => visitor(subRoot, this.helpers) -- ); -- await Promise.all(roots); -- } else { -- await visitor(root2, this.helpers); -- } -- } catch (e2) { -- throw this.handleError(e2); -- } -- } -- } -- } -- this.processed = true; -- return this.stringify(); -- } -- runOnRoot(plugin22) { -- this.result.lastPlugin = plugin22; -- try { -- if (typeof plugin22 === "object" && plugin22.Once) { -- if (this.result.root.type === "document") { -- let roots = this.result.root.nodes.map( -- (root2) => plugin22.Once(root2, this.helpers) -- ); -- if (isPromise(roots[0])) { -- return Promise.all(roots); -- } -- return roots; -- } -- return plugin22.Once(this.result.root, this.helpers); -- } else if (typeof plugin22 === "function") { -- return plugin22(this.result.root, this.result); -- } -- } catch (error) { -- throw this.handleError(error); -- } -- } -- stringify() { -- if (this.error) throw this.error; -- if (this.stringified) return this.result; -- this.stringified = true; -- this.sync(); -- let opts = this.result.opts; -- let str = stringify$2; -- if (opts.syntax) str = opts.syntax.stringify; -- if (opts.stringifier) str = opts.stringifier; -- if (str.stringify) str = str.stringify; -- let map = new MapGenerator$1(str, this.result.root, this.result.opts); -- let data = map.generate(); -- this.result.css = data[0]; -- this.result.map = data[1]; -- return this.result; -- } -- sync() { -- if (this.error) throw this.error; -- if (this.processed) return this.result; -- this.processed = true; -- if (this.processing) { -- throw this.getAsyncError(); -- } -- for (let plugin22 of this.plugins) { -- let promise = this.runOnRoot(plugin22); -- if (isPromise(promise)) { -- throw this.getAsyncError(); -- } -- } -- this.prepareVisitors(); -- if (this.hasListener) { -- let root2 = this.result.root; -- while (!root2[isClean]) { -- root2[isClean] = true; -- this.walkSync(root2); -- } -- if (this.listeners.OnceExit) { -- if (root2.type === "document") { -- for (let subRoot of root2.nodes) { -- this.visitSync(this.listeners.OnceExit, subRoot); -- } -- } else { -- this.visitSync(this.listeners.OnceExit, root2); -- } -- } -- } -- return this.result; -- } -- then(onFulfilled, onRejected) { -- if (process.env.NODE_ENV !== "production") { -- if (!("from" in this.opts)) { -- warnOnce$1( -- "Without `from` option PostCSS could generate wrong source map and will not find Browserslist config. Set it to CSS file path or to `undefined` to prevent this warning." -- ); -- } -- } -- return this.async().then(onFulfilled, onRejected); -- } -- toString() { -- return this.css; -- } -- visitSync(visitors, node2) { -- for (let [plugin22, visitor] of visitors) { -- this.result.lastPlugin = plugin22; -- let promise; -- try { -- promise = visitor(node2, this.helpers); -- } catch (e2) { -- throw this.handleError(e2, node2.proxyOf); -- } -- if (node2.type !== "root" && node2.type !== "document" && !node2.parent) { -- return true; -- } -- if (isPromise(promise)) { -- throw this.getAsyncError(); -- } -- } -- } -- visitTick(stack) { -- let visit2 = stack[stack.length - 1]; -- let { node: node2, visitors } = visit2; -- if (node2.type !== "root" && node2.type !== "document" && !node2.parent) { -- stack.pop(); -- return; -- } -- if (visitors.length > 0 && visit2.visitorIndex < visitors.length) { -- let [plugin22, visitor] = visitors[visit2.visitorIndex]; -- visit2.visitorIndex += 1; -- if (visit2.visitorIndex === visitors.length) { -- visit2.visitors = []; -- visit2.visitorIndex = 0; -- } -- this.result.lastPlugin = plugin22; -- try { -- return visitor(node2.toProxy(), this.helpers); -- } catch (e2) { -- throw this.handleError(e2, node2); -- } -- } -- if (visit2.iterator !== 0) { -- let iterator = visit2.iterator; -- let child; -- while (child = node2.nodes[node2.indexes[iterator]]) { -- node2.indexes[iterator] += 1; -- if (!child[isClean]) { -- child[isClean] = true; -- stack.push(toStack(child)); -- return; -- } -- } -- visit2.iterator = 0; -- delete node2.indexes[iterator]; -- } -- let events = visit2.events; -- while (visit2.eventIndex < events.length) { -- let event = events[visit2.eventIndex]; -- visit2.eventIndex += 1; -- if (event === CHILDREN) { -- if (node2.nodes && node2.nodes.length) { -- node2[isClean] = true; -- visit2.iterator = node2.getIterator(); -- } -- return; -- } else if (this.listeners[event]) { -- visit2.visitors = this.listeners[event]; -- return; -- } -- } -- stack.pop(); -- } -- walkSync(node2) { -- node2[isClean] = true; -- let events = getEvents(node2); -- for (let event of events) { -- if (event === CHILDREN) { -- if (node2.nodes) { -- node2.each((child) => { -- if (!child[isClean]) this.walkSync(child); -- }); -- } -- } else { -- let visitors = this.listeners[event]; -- if (visitors) { -- if (this.visitSync(visitors, node2.toProxy())) return; -- } -- } -- } -- } -- warnings() { -- return this.sync().warnings(); -- } -- get content() { -- return this.stringify().content; -- } -- get css() { -- return this.stringify().css; -- } -- get map() { -- return this.stringify().map; -- } -- get messages() { -- return this.sync().messages; -- } -- get opts() { -- return this.result.opts; -- } -- get processor() { -- return this.result.processor; -- } -- get root() { -- return this.sync().root; -- } -- get [Symbol.toStringTag]() { -- return "LazyResult"; -- } --}; --LazyResult$2.registerPostcss = (dependant) => { -- postcss$2 = dependant; --}; --var lazyResult = LazyResult$2; --LazyResult$2.default = LazyResult$2; --Root$3.registerLazyResult(LazyResult$2); --Document$2.registerLazyResult(LazyResult$2); --let MapGenerator22 = mapGenerator; --let stringify$1 = stringify_1; --let warnOnce22 = warnOnce$2; --let parse$1 = parse_1; --const Result$1 = result; --let NoWorkResult$1 = class NoWorkResult2 { -- constructor(processor2, css, opts) { -- css = css.toString(); -- this.stringified = false; -- this._processor = processor2; -- this._css = css; -- this._opts = opts; -- this._map = void 0; -- let root2; -- let str = stringify$1; -- this.result = new Result$1(this._processor, root2, this._opts); -- this.result.css = css; -- let self = this; -- Object.defineProperty(this.result, "root", { -- get() { -- return self.root; -- } -- }); -- let map = new MapGenerator22(str, root2, this._opts, css); -- if (map.isMap()) { -- let [generatedCSS, generatedMap] = map.generate(); -- if (generatedCSS) { -- this.result.css = generatedCSS; -- } -- if (generatedMap) { -- this.result.map = generatedMap; -- } -- } else { -- map.clearAnnotation(); -- this.result.css = map.css; -- } -- } -- async() { -- if (this.error) return Promise.reject(this.error); -- return Promise.resolve(this.result); -- } -- catch(onRejected) { -- return this.async().catch(onRejected); -- } -- finally(onFinally) { -- return this.async().then(onFinally, onFinally); -- } -- sync() { -- if (this.error) throw this.error; -- return this.result; -- } -- then(onFulfilled, onRejected) { -- if (process.env.NODE_ENV !== "production") { -- if (!("from" in this._opts)) { -- warnOnce22( -- "Without `from` option PostCSS could generate wrong source map and will not find Browserslist config. Set it to CSS file path or to `undefined` to prevent this warning." -- ); -+ else { -+ for (const childN of Array.from(index$1.childNodes(n2))) { -+ const serializedChildNode = serializeNodeWithId(childN, bypassOptions); -+ if (serializedChildNode) { -+ serializedNode.childNodes.push(serializedChildNode); -+ } - } - } -- return this.async().then(onFulfilled, onRejected); -- } -- toString() { -- return this._css; -- } -- warnings() { -- return []; -- } -- get content() { -- return this.result.css; -- } -- get css() { -- return this.result.css; -- } -- get map() { -- return this.result.map; -- } -- get messages() { -- return []; -- } -- get opts() { -- return this.result.opts; -- } -- get processor() { -- return this.result.processor; -- } -- get root() { -- if (this._root) { -- return this._root; -- } -- let root2; -- let parser2 = parse$1; -- try { -- root2 = parser2(this._css, this._opts); -- } catch (error) { -- this.error = error; -- } -- if (this.error) { -- throw this.error; -- } else { -- this._root = root2; -- return root2; -- } -- } -- get [Symbol.toStringTag]() { -- return "NoWorkResult"; -- } --}; --var noWorkResult = NoWorkResult$1; --NoWorkResult$1.default = NoWorkResult$1; --let NoWorkResult22 = noWorkResult; --let LazyResult$1 = lazyResult; --let Document$1 = document$1; --let Root$2 = root; --let Processor$1 = class Processor2 { -- constructor(plugins = []) { -- this.version = "8.4.38"; -- this.plugins = this.normalize(plugins); -- } -- normalize(plugins) { -- let normalized = []; -- for (let i2 of plugins) { -- if (i2.postcss === true) { -- i2 = i2(); -- } else if (i2.postcss) { -- i2 = i2.postcss; -- } -- if (typeof i2 === "object" && Array.isArray(i2.plugins)) { -- normalized = normalized.concat(i2.plugins); -- } else if (typeof i2 === "object" && i2.postcssPlugin) { -- normalized.push(i2); -- } else if (typeof i2 === "function") { -- normalized.push(i2); -- } else if (typeof i2 === "object" && (i2.parse || i2.stringify)) { -- if (process.env.NODE_ENV !== "production") { -- throw new Error( -- "PostCSS syntaxes cannot be used as plugins. Instead, please use one of the syntax/parser/stringifier options as outlined in your PostCSS runner documentation." -- ); -+ let shadowRootEl = null; -+ if (isElement(n2) && (shadowRootEl = index$1.shadowRoot(n2))) { -+ for (const childN of Array.from(index$1.childNodes(shadowRootEl))) { -+ const serializedChildNode = serializeNodeWithId(childN, bypassOptions); -+ if (serializedChildNode) { -+ isNativeShadowDom(shadowRootEl) && (serializedChildNode.isShadow = true); -+ serializedNode.childNodes.push(serializedChildNode); - } -- } else { -- throw new Error(i2 + " is not a PostCSS plugin"); - } - } -- return normalized; -- } -- process(css, opts = {}) { -- if (!this.plugins.length && !opts.parser && !opts.stringifier && !opts.syntax) { -- return new NoWorkResult22(this, css, opts); -- } else { -- return new LazyResult$1(this, css, opts); -- } - } -- use(plugin22) { -- this.plugins = this.plugins.concat(this.normalize([plugin22])); -- return this; -+ const parent = index$1.parentNode(n2); -+ if (parent && isShadowRoot(parent) && isNativeShadowDom(parent)) { -+ serializedNode.isShadow = true; - } --}; --var processor = Processor$1; --Processor$1.default = Processor$1; --Root$2.registerProcessor(Processor$1); --Document$1.registerProcessor(Processor$1); --let Declaration$1 = declaration; --let PreviousMap22 = previousMap; --let Comment$1 = comment; --let AtRule$1 = atRule; --let Input$1 = input; --let Root$1 = root; --let Rule$1 = rule; --function fromJSON$1(json, inputs) { -- if (Array.isArray(json)) return json.map((n2) => fromJSON$1(n2)); -- let { inputs: ownInputs, ...defaults } = json; -- if (ownInputs) { -- inputs = []; -- for (let input2 of ownInputs) { -- let inputHydrated = { ...input2, __proto__: Input$1.prototype }; -- if (inputHydrated.map) { -- inputHydrated.map = { -- ...inputHydrated.map, -- __proto__: PreviousMap22.prototype -- }; -- } -- inputs.push(inputHydrated); -- } -+ if (serializedNode.type === NodeType$2.Element && serializedNode.tagName === "iframe") { -+ onceIframeLoaded( -+ n2, -+ () => { -+ const iframeDoc = n2.contentDocument; -+ if (iframeDoc && onIframeLoad) { -+ const serializedIframeNode = serializeNodeWithId(iframeDoc, { -+ doc: iframeDoc, -+ mirror: mirror2, -+ blockClass, -+ blockSelector, -+ needsMask, -+ maskTextClass, -+ maskTextSelector, -+ skipChild: false, -+ inlineStylesheet, -+ maskInputOptions, -+ maskTextFn, -+ maskInputFn, -+ slimDOMOptions, -+ dataURLOptions, -+ inlineImages, -+ recordCanvas, -+ preserveWhiteSpace, -+ onSerialize, -+ onIframeLoad, -+ iframeLoadTimeout, -+ onStylesheetLoad, -+ stylesheetLoadTimeout, -+ keepIframeSrcFn -+ }); -+ if (serializedIframeNode) { -+ onIframeLoad( -+ n2, -+ serializedIframeNode -+ ); -+ } -+ } -+ }, -+ iframeLoadTimeout -+ ); - } -- if (defaults.nodes) { -- defaults.nodes = json.nodes.map((n2) => fromJSON$1(n2, inputs)); -+ if (serializedNode.type === NodeType$2.Element && serializedNode.tagName === "link" && typeof serializedNode.attributes.rel === "string" && (serializedNode.attributes.rel === "stylesheet" || serializedNode.attributes.rel === "preload" && typeof serializedNode.attributes.href === "string" && extractFileExtension(serializedNode.attributes.href) === "css")) { -+ onceStylesheetLoaded( -+ n2, -+ () => { -+ if (onStylesheetLoad) { -+ const serializedLinkNode = serializeNodeWithId(n2, { -+ doc, -+ mirror: mirror2, -+ blockClass, -+ blockSelector, -+ needsMask, -+ maskTextClass, -+ maskTextSelector, -+ skipChild: false, -+ inlineStylesheet, -+ maskInputOptions, -+ maskTextFn, -+ maskInputFn, -+ slimDOMOptions, -+ dataURLOptions, -+ inlineImages, -+ recordCanvas, -+ preserveWhiteSpace, -+ onSerialize, -+ onIframeLoad, -+ iframeLoadTimeout, -+ onStylesheetLoad, -+ stylesheetLoadTimeout, -+ keepIframeSrcFn -+ }); -+ if (serializedLinkNode) { -+ onStylesheetLoad( -+ n2, -+ serializedLinkNode -+ ); -+ } -+ } -+ }, -+ stylesheetLoadTimeout -+ ); - } -- if (defaults.source) { -- let { inputId, ...source } = defaults.source; -- defaults.source = source; -- if (inputId != null) { -- defaults.source.input = inputs[inputId]; -+ return serializedNode; -+} -+function snapshot(n2, options) { -+ const { -+ mirror: mirror2 = new Mirror(), -+ blockClass = "rr-block", -+ blockSelector = null, -+ maskTextClass = "rr-mask", -+ maskTextSelector = null, -+ inlineStylesheet = true, -+ inlineImages = false, -+ recordCanvas = false, -+ maskAllInputs = false, -+ maskTextFn, -+ maskInputFn, -+ slimDOM = false, -+ dataURLOptions, -+ preserveWhiteSpace, -+ onSerialize, -+ onIframeLoad, -+ iframeLoadTimeout, -+ onStylesheetLoad, -+ stylesheetLoadTimeout, -+ keepIframeSrcFn = () => false -+ } = options || {}; -+ const maskInputOptions = maskAllInputs === true ? { -+ color: true, -+ date: true, -+ "datetime-local": true, -+ email: true, -+ month: true, -+ number: true, -+ range: true, -+ search: true, -+ tel: true, -+ text: true, -+ time: true, -+ url: true, -+ week: true, -+ textarea: true, -+ select: true, -+ password: true -+ } : maskAllInputs === false ? { -+ password: true -+ } : maskAllInputs; -+ const slimDOMOptions = slimDOM === true || slimDOM === "all" ? ( -+ // if true: set of sensible options that should not throw away any information -+ { -+ script: true, -+ comment: true, -+ headFavicon: true, -+ headWhitespace: true, -+ headMetaDescKeywords: slimDOM === "all", -+ // destructive -+ headMetaSocial: true, -+ headMetaRobots: true, -+ headMetaHttpEquiv: true, -+ headMetaAuthorship: true, -+ headMetaVerification: true - } -- } -- if (defaults.type === "root") { -- return new Root$1(defaults); -- } else if (defaults.type === "decl") { -- return new Declaration$1(defaults); -- } else if (defaults.type === "rule") { -- return new Rule$1(defaults); -- } else if (defaults.type === "comment") { -- return new Comment$1(defaults); -- } else if (defaults.type === "atrule") { -- return new AtRule$1(defaults); -- } else { -- throw new Error("Unknown node type: " + json.type); -- } --} --var fromJSON_1 = fromJSON$1; --fromJSON$1.default = fromJSON$1; --let CssSyntaxError22 = cssSyntaxError; --let Declaration22 = declaration; --let LazyResult22 = lazyResult; --let Container22 = container; --let Processor22 = processor; --let stringify = stringify_1; --let fromJSON = fromJSON_1; --let Document222 = document$1; --let Warning22 = warning; --let Comment22 = comment; --let AtRule22 = atRule; --let Result22 = result; --let Input22 = input; --let parse = parse_1; --let list = list_1; --let Rule22 = rule; --let Root22 = root; --let Node22 = node; --function postcss(...plugins) { -- if (plugins.length === 1 && Array.isArray(plugins[0])) { -- plugins = plugins[0]; -- } -- return new Processor22(plugins); --} --postcss.plugin = function plugin2(name, initializer) { -- let warningPrinted = false; -- function creator(...args) { -- if (console && console.warn && !warningPrinted) { -- warningPrinted = true; -- console.warn( -- name + ": postcss.plugin was deprecated. Migration guide:\nhttps://evilmartians.com/chronicles/postcss-8-plugin-migration" -- ); -- if (process.env.LANG && process.env.LANG.startsWith("cn")) { -- console.warn( -- name + ": 里面 postcss.plugin 被弃用. 迁移指南:\nhttps://www.w3ctech.com/topic/2226" -- ); -+ ) : slimDOM === false ? {} : slimDOM; -+ return serializeNodeWithId(n2, { -+ doc: n2, -+ mirror: mirror2, -+ blockClass, -+ blockSelector, -+ maskTextClass, -+ maskTextSelector, -+ skipChild: false, -+ inlineStylesheet, -+ maskInputOptions, -+ maskTextFn, -+ maskInputFn, -+ slimDOMOptions, -+ dataURLOptions, -+ inlineImages, -+ recordCanvas, -+ preserveWhiteSpace, -+ onSerialize, -+ onIframeLoad, -+ iframeLoadTimeout, -+ onStylesheetLoad, -+ stylesheetLoadTimeout, -+ keepIframeSrcFn, -+ newlyAddedElement: false -+ }); -+} -+function getDefaultExportFromCjs$1(x2) { -+ return x2 && x2.__esModule && Object.prototype.hasOwnProperty.call(x2, "default") ? x2["default"] : x2; -+} -+function getAugmentedNamespace$1(n2) { -+ if (n2.__esModule) return n2; -+ var f2 = n2.default; -+ if (typeof f2 == "function") { -+ var a2 = function a22() { -+ if (this instanceof a22) { -+ return Reflect.construct(f2, arguments, this.constructor); - } -- } -- let transformer = initializer(...args); -- transformer.postcssPlugin = name; -- transformer.postcssVersion = new Processor22().version; -- return transformer; -- } -- let cache; -- Object.defineProperty(creator, "postcss", { -- get() { -- if (!cache) cache = creator(); -- return cache; -- } -+ return f2.apply(this, arguments); -+ }; -+ a2.prototype = f2.prototype; -+ } else a2 = {}; -+ Object.defineProperty(a2, "__esModule", { value: true }); -+ Object.keys(n2).forEach(function(k) { -+ var d = Object.getOwnPropertyDescriptor(n2, k); -+ Object.defineProperty(a2, k, d.get ? d : { -+ enumerable: true, -+ get: function() { -+ return n2[k]; -+ } -+ }); - }); -- creator.process = function(css, processOpts, pluginOpts) { -- return postcss([creator(pluginOpts)]).process(css, processOpts); -- }; -- return creator; --}; --postcss.stringify = stringify; --postcss.parse = parse; --postcss.fromJSON = fromJSON; --postcss.list = list; --postcss.comment = (defaults) => new Comment22(defaults); --postcss.atRule = (defaults) => new AtRule22(defaults); --postcss.decl = (defaults) => new Declaration22(defaults); --postcss.rule = (defaults) => new Rule22(defaults); --postcss.root = (defaults) => new Root22(defaults); --postcss.document = (defaults) => new Document222(defaults); --postcss.CssSyntaxError = CssSyntaxError22; --postcss.Declaration = Declaration22; --postcss.Container = Container22; --postcss.Processor = Processor22; --postcss.Document = Document222; --postcss.Comment = Comment22; --postcss.Warning = Warning22; --postcss.AtRule = AtRule22; --postcss.Result = Result22; --postcss.Input = Input22; --postcss.Rule = Rule22; --postcss.Root = Root22; --postcss.Node = Node22; --LazyResult22.registerPostcss(postcss); --var postcss_1 = postcss; --postcss.default = postcss; --const postcss$1 = /* @__PURE__ */ getDefaultExportFromCjs(postcss_1); --postcss$1.stringify; --postcss$1.fromJSON; --postcss$1.plugin; --postcss$1.parse; --postcss$1.list; --postcss$1.document; --postcss$1.comment; --postcss$1.atRule; --postcss$1.rule; --postcss$1.decl; --postcss$1.root; --postcss$1.CssSyntaxError; --postcss$1.Declaration; --postcss$1.Container; --postcss$1.Processor; --postcss$1.Document; --postcss$1.Comment; --postcss$1.Warning; --postcss$1.AtRule; --postcss$1.Result; --postcss$1.Input; --postcss$1.Rule; --postcss$1.Root; --postcss$1.Node; -+ return a2; -+} - class BaseRRNode { - // eslint-disable-next-line @typescript-eslint/no-unused-vars, @typescript-eslint/no-explicit-any - constructor(..._args) { -@@ -11382,11 +4316,19 @@ class CanvasManager { - let rafId; - const getCanvas = () => { - const matchedCanvas = []; -- win.document.querySelectorAll("canvas").forEach((canvas) => { -- if (!isBlocked(canvas, blockClass, blockSelector, true)) { -- matchedCanvas.push(canvas); -- } -- }); -+ const searchCanvas = (root) => { -+ root.querySelectorAll("canvas").forEach((canvas) => { -+ if (!isBlocked(canvas, blockClass, blockSelector, true)) { -+ matchedCanvas.push(canvas); -+ } -+ }); -+ root.querySelectorAll("*").forEach((elem) => { -+ if (elem.shadowRoot) { -+ searchCanvas(elem.shadowRoot); -+ } -+ }); -+ }; -+ searchCanvas(win.document); - return matchedCanvas; - }; - const takeCanvasSnapshots = (timestamp) => { -@@ -11407,13 +4349,20 @@ class CanvasManager { - context.clear(context.COLOR_BUFFER_BIT); - } - } -- const bitmap = await createImageBitmap(canvas); -+ // createImageBitmap throws if resizing to 0 -+ // Fallback to intrinsic size if canvas has not yet rendered -+ const width = canvas.clientWidth || canvas.width; -+ const height = canvas.clientHeight || canvas.height; -+ const bitmap = await createImageBitmap(canvas, { -+ resizeWidth: width, -+ resizeHeight: height -+ }); - worker.postMessage( - { - id, - bitmap, -- width: canvas.width, -- height: canvas.height, -+ width, -+ height, - dataURLOptions: options.dataURLOptions - }, - [bitmap] diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml index 3c188c207..17fa39ed9 100644 --- a/pnpm-lock.yaml +++ b/pnpm-lock.yaml @@ -5,9 +5,6 @@ settings: excludeLinksFromLockfile: false patchedDependencies: - '@rrweb/record@2.0.0-alpha.17': - hash: wwyxiuzzlj4fuy7by57teumbru - path: patches/@rrweb__record@2.0.0-alpha.17.patch '@rrweb/rrweb-plugin-console-record@2.0.0-alpha.17': hash: ytsspyi7p3hvqcq64vqb7wb6bu path: patches/@rrweb__rrweb-plugin-console-record@2.0.0-alpha.17.patch @@ -71,7 +68,7 @@ devDependencies: version: 12.1.1(rollup@4.24.0)(tslib@2.5.0)(typescript@5.5.4) '@rrweb/record': specifier: 2.0.0-alpha.17 - version: 2.0.0-alpha.17(patch_hash=wwyxiuzzlj4fuy7by57teumbru) + version: 2.0.0-alpha.17 '@rrweb/rrweb-plugin-console-record': specifier: 2.0.0-alpha.17 version: 2.0.0-alpha.17(patch_hash=ytsspyi7p3hvqcq64vqb7wb6bu)(rrweb@2.0.0-alpha.17) @@ -2802,13 +2799,12 @@ packages: dev: true optional: true - /@rrweb/record@2.0.0-alpha.17(patch_hash=wwyxiuzzlj4fuy7by57teumbru): + /@rrweb/record@2.0.0-alpha.17: resolution: {integrity: sha512-Je+lzjeWMF8/I0IDoXFzkGPKT8j7AkaBup5YcwUHlkp18VhLVze416MvI6915teE27uUA2ScXMXzG0Yiu5VTIw==} dependencies: '@rrweb/types': 2.0.0-alpha.17 rrweb: 2.0.0-alpha.17 dev: true - patched: true /@rrweb/rrweb-plugin-console-record@2.0.0-alpha.17(patch_hash=ytsspyi7p3hvqcq64vqb7wb6bu)(rrweb@2.0.0-alpha.17): resolution: {integrity: sha512-tjNJ3wWUDMMf275xr4Rb5tVYF2UR+wXvSxnyS9tRKnRa574PQQvx7sGbqM/O9AytYjnbiTrAMqNR7OFysGCMwQ==} From a8679f9fd85543adf40c901f510170b8dfc5b986 Mon Sep 17 00:00:00 2001 From: David Newell Date: Tue, 5 Nov 2024 00:13:43 +0100 Subject: [PATCH 21/21] patches --- package.json | 3 +- patches/@rrweb__record@2.0.0-alpha.17.patch | 7591 +++++++++++++++++++ pnpm-lock.yaml | 8 +- 3 files changed, 7599 insertions(+), 3 deletions(-) create mode 100644 patches/@rrweb__record@2.0.0-alpha.17.patch diff --git a/package.json b/package.json index e1b0a6d66..7136d1158 100644 --- a/package.json +++ b/package.json @@ -126,7 +126,8 @@ ], "pnpm": { "patchedDependencies": { - "@rrweb/rrweb-plugin-console-record@2.0.0-alpha.17": "patches/@rrweb__rrweb-plugin-console-record@2.0.0-alpha.17.patch" + "@rrweb/rrweb-plugin-console-record@2.0.0-alpha.17": "patches/@rrweb__rrweb-plugin-console-record@2.0.0-alpha.17.patch", + "@rrweb/record@2.0.0-alpha.17": "patches/@rrweb__record@2.0.0-alpha.17.patch" } } } diff --git a/patches/@rrweb__record@2.0.0-alpha.17.patch b/patches/@rrweb__record@2.0.0-alpha.17.patch new file mode 100644 index 000000000..56ad4aedd --- /dev/null +++ b/patches/@rrweb__record@2.0.0-alpha.17.patch @@ -0,0 +1,7591 @@ +diff --git a/dist/record.js b/dist/record.js +index 46ec389fefb698243008b39db65470dbdf0a3857..39d9ac821fd84f5a1494ac1e00c8d4e0e58c432a 100644 +--- a/dist/record.js ++++ b/dist/record.js +@@ -246,6 +246,9 @@ function isCSSImportRule(rule2) { + function isCSSStyleRule(rule2) { + return "selectorText" in rule2; + } ++function findStylesheet(doc, href) { ++ return Array.from(doc.styleSheets).find((s) => s.href === href); ++} + class Mirror { + constructor() { + __publicField$1(this, "idNodeMap", /* @__PURE__ */ new Map()); +@@ -809,9 +812,14 @@ function serializeElementNode(n2, options) { + } + } + if (tagName === "link" && inlineStylesheet) { +- const stylesheet = Array.from(doc.styleSheets).find((s2) => { +- return s2.href === n2.href; +- }); ++ const href = n2.href; ++ let stylesheet = findStylesheet(doc, href); ++ if (!stylesheet && href.includes('.css')) { ++ const rootDomain = window.location.origin; ++ const stylesheetPath = href.replace(window.location.href, ''); ++ const potentialStylesheetHref = rootDomain + '/' + stylesheetPath; ++ stylesheet = findStylesheet(doc, potentialStylesheetHref); ++ } + let cssText = null; + if (stylesheet) { + cssText = stringifyStylesheet(stylesheet); +@@ -1116,7300 +1124,227 @@ function serializeNodeWithId(n2, options) { + keepIframeSrcFn + }; + if (serializedNode.type === NodeType$2.Element && serializedNode.tagName === "textarea" && serializedNode.attributes.value !== void 0) ; +- else { +- for (const childN of Array.from(index$1.childNodes(n2))) { +- const serializedChildNode = serializeNodeWithId(childN, bypassOptions); +- if (serializedChildNode) { +- serializedNode.childNodes.push(serializedChildNode); +- } +- } +- } +- let shadowRootEl = null; +- if (isElement(n2) && (shadowRootEl = index$1.shadowRoot(n2))) { +- for (const childN of Array.from(index$1.childNodes(shadowRootEl))) { +- const serializedChildNode = serializeNodeWithId(childN, bypassOptions); +- if (serializedChildNode) { +- isNativeShadowDom(shadowRootEl) && (serializedChildNode.isShadow = true); +- serializedNode.childNodes.push(serializedChildNode); +- } +- } +- } +- } +- const parent = index$1.parentNode(n2); +- if (parent && isShadowRoot(parent) && isNativeShadowDom(parent)) { +- serializedNode.isShadow = true; +- } +- if (serializedNode.type === NodeType$2.Element && serializedNode.tagName === "iframe") { +- onceIframeLoaded( +- n2, +- () => { +- const iframeDoc = n2.contentDocument; +- if (iframeDoc && onIframeLoad) { +- const serializedIframeNode = serializeNodeWithId(iframeDoc, { +- doc: iframeDoc, +- mirror: mirror2, +- blockClass, +- blockSelector, +- needsMask, +- maskTextClass, +- maskTextSelector, +- skipChild: false, +- inlineStylesheet, +- maskInputOptions, +- maskTextFn, +- maskInputFn, +- slimDOMOptions, +- dataURLOptions, +- inlineImages, +- recordCanvas, +- preserveWhiteSpace, +- onSerialize, +- onIframeLoad, +- iframeLoadTimeout, +- onStylesheetLoad, +- stylesheetLoadTimeout, +- keepIframeSrcFn +- }); +- if (serializedIframeNode) { +- onIframeLoad( +- n2, +- serializedIframeNode +- ); +- } +- } +- }, +- iframeLoadTimeout +- ); +- } +- if (serializedNode.type === NodeType$2.Element && serializedNode.tagName === "link" && typeof serializedNode.attributes.rel === "string" && (serializedNode.attributes.rel === "stylesheet" || serializedNode.attributes.rel === "preload" && typeof serializedNode.attributes.href === "string" && extractFileExtension(serializedNode.attributes.href) === "css")) { +- onceStylesheetLoaded( +- n2, +- () => { +- if (onStylesheetLoad) { +- const serializedLinkNode = serializeNodeWithId(n2, { +- doc, +- mirror: mirror2, +- blockClass, +- blockSelector, +- needsMask, +- maskTextClass, +- maskTextSelector, +- skipChild: false, +- inlineStylesheet, +- maskInputOptions, +- maskTextFn, +- maskInputFn, +- slimDOMOptions, +- dataURLOptions, +- inlineImages, +- recordCanvas, +- preserveWhiteSpace, +- onSerialize, +- onIframeLoad, +- iframeLoadTimeout, +- onStylesheetLoad, +- stylesheetLoadTimeout, +- keepIframeSrcFn +- }); +- if (serializedLinkNode) { +- onStylesheetLoad( +- n2, +- serializedLinkNode +- ); +- } +- } +- }, +- stylesheetLoadTimeout +- ); +- } +- return serializedNode; +-} +-function snapshot(n2, options) { +- const { +- mirror: mirror2 = new Mirror(), +- blockClass = "rr-block", +- blockSelector = null, +- maskTextClass = "rr-mask", +- maskTextSelector = null, +- inlineStylesheet = true, +- inlineImages = false, +- recordCanvas = false, +- maskAllInputs = false, +- maskTextFn, +- maskInputFn, +- slimDOM = false, +- dataURLOptions, +- preserveWhiteSpace, +- onSerialize, +- onIframeLoad, +- iframeLoadTimeout, +- onStylesheetLoad, +- stylesheetLoadTimeout, +- keepIframeSrcFn = () => false +- } = options || {}; +- const maskInputOptions = maskAllInputs === true ? { +- color: true, +- date: true, +- "datetime-local": true, +- email: true, +- month: true, +- number: true, +- range: true, +- search: true, +- tel: true, +- text: true, +- time: true, +- url: true, +- week: true, +- textarea: true, +- select: true, +- password: true +- } : maskAllInputs === false ? { +- password: true +- } : maskAllInputs; +- const slimDOMOptions = slimDOM === true || slimDOM === "all" ? ( +- // if true: set of sensible options that should not throw away any information +- { +- script: true, +- comment: true, +- headFavicon: true, +- headWhitespace: true, +- headMetaDescKeywords: slimDOM === "all", +- // destructive +- headMetaSocial: true, +- headMetaRobots: true, +- headMetaHttpEquiv: true, +- headMetaAuthorship: true, +- headMetaVerification: true +- } +- ) : slimDOM === false ? {} : slimDOM; +- return serializeNodeWithId(n2, { +- doc: n2, +- mirror: mirror2, +- blockClass, +- blockSelector, +- maskTextClass, +- maskTextSelector, +- skipChild: false, +- inlineStylesheet, +- maskInputOptions, +- maskTextFn, +- maskInputFn, +- slimDOMOptions, +- dataURLOptions, +- inlineImages, +- recordCanvas, +- preserveWhiteSpace, +- onSerialize, +- onIframeLoad, +- iframeLoadTimeout, +- onStylesheetLoad, +- stylesheetLoadTimeout, +- keepIframeSrcFn, +- newlyAddedElement: false +- }); +-} +-function getDefaultExportFromCjs$1(x2) { +- return x2 && x2.__esModule && Object.prototype.hasOwnProperty.call(x2, "default") ? x2["default"] : x2; +-} +-function getAugmentedNamespace$1(n2) { +- if (n2.__esModule) return n2; +- var f2 = n2.default; +- if (typeof f2 == "function") { +- var a2 = function a22() { +- if (this instanceof a22) { +- return Reflect.construct(f2, arguments, this.constructor); +- } +- return f2.apply(this, arguments); +- }; +- a2.prototype = f2.prototype; +- } else a2 = {}; +- Object.defineProperty(a2, "__esModule", { value: true }); +- Object.keys(n2).forEach(function(k) { +- var d = Object.getOwnPropertyDescriptor(n2, k); +- Object.defineProperty(a2, k, d.get ? d : { +- enumerable: true, +- get: function() { +- return n2[k]; +- } +- }); +- }); +- return a2; +-} +-var picocolors_browser$1 = { exports: {} }; +-var x$1 = String; +-var create$1 = function() { +- return { isColorSupported: false, reset: x$1, bold: x$1, dim: x$1, italic: x$1, underline: x$1, inverse: x$1, hidden: x$1, strikethrough: x$1, black: x$1, red: x$1, green: x$1, yellow: x$1, blue: x$1, magenta: x$1, cyan: x$1, white: x$1, gray: x$1, bgBlack: x$1, bgRed: x$1, bgGreen: x$1, bgYellow: x$1, bgBlue: x$1, bgMagenta: x$1, bgCyan: x$1, bgWhite: x$1 }; +-}; +-picocolors_browser$1.exports = create$1(); +-picocolors_browser$1.exports.createColors = create$1; +-var picocolors_browserExports$1 = picocolors_browser$1.exports; +-const __viteBrowserExternal$2 = {}; +-const __viteBrowserExternal$1$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({ +- __proto__: null, +- default: __viteBrowserExternal$2 +-}, Symbol.toStringTag, { value: "Module" })); +-const require$$2$1 = /* @__PURE__ */ getAugmentedNamespace$1(__viteBrowserExternal$1$1); +-let pico$1 = picocolors_browserExports$1; +-let terminalHighlight$1$1 = require$$2$1; +-let CssSyntaxError$3$1 = class CssSyntaxError extends Error { +- constructor(message, line, column, source, file, plugin22) { +- super(message); +- this.name = "CssSyntaxError"; +- this.reason = message; +- if (file) { +- this.file = file; +- } +- if (source) { +- this.source = source; +- } +- if (plugin22) { +- this.plugin = plugin22; +- } +- if (typeof line !== "undefined" && typeof column !== "undefined") { +- if (typeof line === "number") { +- this.line = line; +- this.column = column; +- } else { +- this.line = line.line; +- this.column = line.column; +- this.endLine = column.line; +- this.endColumn = column.column; +- } +- } +- this.setMessage(); +- if (Error.captureStackTrace) { +- Error.captureStackTrace(this, CssSyntaxError); +- } +- } +- setMessage() { +- this.message = this.plugin ? this.plugin + ": " : ""; +- this.message += this.file ? this.file : ""; +- if (typeof this.line !== "undefined") { +- this.message += ":" + this.line + ":" + this.column; +- } +- this.message += ": " + this.reason; +- } +- showSourceCode(color) { +- if (!this.source) return ""; +- let css = this.source; +- if (color == null) color = pico$1.isColorSupported; +- if (terminalHighlight$1$1) { +- if (color) css = terminalHighlight$1$1(css); +- } +- let lines = css.split(/\r?\n/); +- let start = Math.max(this.line - 3, 0); +- let end = Math.min(this.line + 2, lines.length); +- let maxWidth = String(end).length; +- let mark, aside; +- if (color) { +- let { bold, gray, red } = pico$1.createColors(true); +- mark = (text) => bold(red(text)); +- aside = (text) => gray(text); +- } else { +- mark = aside = (str) => str; +- } +- return lines.slice(start, end).map((line, index2) => { +- let number = start + 1 + index2; +- let gutter = " " + (" " + number).slice(-maxWidth) + " | "; +- if (number === this.line) { +- let spacing = aside(gutter.replace(/\d/g, " ")) + line.slice(0, this.column - 1).replace(/[^\t]/g, " "); +- return mark(">") + aside(gutter) + line + "\n " + spacing + mark("^"); +- } +- return " " + aside(gutter) + line; +- }).join("\n"); +- } +- toString() { +- let code = this.showSourceCode(); +- if (code) { +- code = "\n\n" + code + "\n"; +- } +- return this.name + ": " + this.message + code; +- } +-}; +-var cssSyntaxError$1 = CssSyntaxError$3$1; +-CssSyntaxError$3$1.default = CssSyntaxError$3$1; +-var symbols$1 = {}; +-symbols$1.isClean = Symbol("isClean"); +-symbols$1.my = Symbol("my"); +-const DEFAULT_RAW$1 = { +- after: "\n", +- beforeClose: "\n", +- beforeComment: "\n", +- beforeDecl: "\n", +- beforeOpen: " ", +- beforeRule: "\n", +- colon: ": ", +- commentLeft: " ", +- commentRight: " ", +- emptyBody: "", +- indent: " ", +- semicolon: false +-}; +-function capitalize$1(str) { +- return str[0].toUpperCase() + str.slice(1); +-} +-let Stringifier$2$1 = class Stringifier { +- constructor(builder) { +- this.builder = builder; +- } +- atrule(node2, semicolon) { +- let name = "@" + node2.name; +- let params = node2.params ? this.rawValue(node2, "params") : ""; +- if (typeof node2.raws.afterName !== "undefined") { +- name += node2.raws.afterName; +- } else if (params) { +- name += " "; +- } +- if (node2.nodes) { +- this.block(node2, name + params); +- } else { +- let end = (node2.raws.between || "") + (semicolon ? ";" : ""); +- this.builder(name + params + end, node2); +- } +- } +- beforeAfter(node2, detect) { +- let value; +- if (node2.type === "decl") { +- value = this.raw(node2, null, "beforeDecl"); +- } else if (node2.type === "comment") { +- value = this.raw(node2, null, "beforeComment"); +- } else if (detect === "before") { +- value = this.raw(node2, null, "beforeRule"); +- } else { +- value = this.raw(node2, null, "beforeClose"); +- } +- let buf = node2.parent; +- let depth = 0; +- while (buf && buf.type !== "root") { +- depth += 1; +- buf = buf.parent; +- } +- if (value.includes("\n")) { +- let indent = this.raw(node2, null, "indent"); +- if (indent.length) { +- for (let step = 0; step < depth; step++) value += indent; +- } +- } +- return value; +- } +- block(node2, start) { +- let between = this.raw(node2, "between", "beforeOpen"); +- this.builder(start + between + "{", node2, "start"); +- let after; +- if (node2.nodes && node2.nodes.length) { +- this.body(node2); +- after = this.raw(node2, "after"); +- } else { +- after = this.raw(node2, "after", "emptyBody"); +- } +- if (after) this.builder(after); +- this.builder("}", node2, "end"); +- } +- body(node2) { +- let last = node2.nodes.length - 1; +- while (last > 0) { +- if (node2.nodes[last].type !== "comment") break; +- last -= 1; +- } +- let semicolon = this.raw(node2, "semicolon"); +- for (let i2 = 0; i2 < node2.nodes.length; i2++) { +- let child = node2.nodes[i2]; +- let before = this.raw(child, "before"); +- if (before) this.builder(before); +- this.stringify(child, last !== i2 || semicolon); +- } +- } +- comment(node2) { +- let left = this.raw(node2, "left", "commentLeft"); +- let right = this.raw(node2, "right", "commentRight"); +- this.builder("/*" + left + node2.text + right + "*/", node2); +- } +- decl(node2, semicolon) { +- let between = this.raw(node2, "between", "colon"); +- let string = node2.prop + between + this.rawValue(node2, "value"); +- if (node2.important) { +- string += node2.raws.important || " !important"; +- } +- if (semicolon) string += ";"; +- this.builder(string, node2); +- } +- document(node2) { +- this.body(node2); +- } +- raw(node2, own, detect) { +- let value; +- if (!detect) detect = own; +- if (own) { +- value = node2.raws[own]; +- if (typeof value !== "undefined") return value; +- } +- let parent = node2.parent; +- if (detect === "before") { +- if (!parent || parent.type === "root" && parent.first === node2) { +- return ""; +- } +- if (parent && parent.type === "document") { +- return ""; +- } +- } +- if (!parent) return DEFAULT_RAW$1[detect]; +- let root2 = node2.root(); +- if (!root2.rawCache) root2.rawCache = {}; +- if (typeof root2.rawCache[detect] !== "undefined") { +- return root2.rawCache[detect]; +- } +- if (detect === "before" || detect === "after") { +- return this.beforeAfter(node2, detect); +- } else { +- let method = "raw" + capitalize$1(detect); +- if (this[method]) { +- value = this[method](root2, node2); +- } else { +- root2.walk((i2) => { +- value = i2.raws[own]; +- if (typeof value !== "undefined") return false; +- }); +- } +- } +- if (typeof value === "undefined") value = DEFAULT_RAW$1[detect]; +- root2.rawCache[detect] = value; +- return value; +- } +- rawBeforeClose(root2) { +- let value; +- root2.walk((i2) => { +- if (i2.nodes && i2.nodes.length > 0) { +- if (typeof i2.raws.after !== "undefined") { +- value = i2.raws.after; +- if (value.includes("\n")) { +- value = value.replace(/[^\n]+$/, ""); +- } +- return false; +- } +- } +- }); +- if (value) value = value.replace(/\S/g, ""); +- return value; +- } +- rawBeforeComment(root2, node2) { +- let value; +- root2.walkComments((i2) => { +- if (typeof i2.raws.before !== "undefined") { +- value = i2.raws.before; +- if (value.includes("\n")) { +- value = value.replace(/[^\n]+$/, ""); +- } +- return false; +- } +- }); +- if (typeof value === "undefined") { +- value = this.raw(node2, null, "beforeDecl"); +- } else if (value) { +- value = value.replace(/\S/g, ""); +- } +- return value; +- } +- rawBeforeDecl(root2, node2) { +- let value; +- root2.walkDecls((i2) => { +- if (typeof i2.raws.before !== "undefined") { +- value = i2.raws.before; +- if (value.includes("\n")) { +- value = value.replace(/[^\n]+$/, ""); +- } +- return false; +- } +- }); +- if (typeof value === "undefined") { +- value = this.raw(node2, null, "beforeRule"); +- } else if (value) { +- value = value.replace(/\S/g, ""); +- } +- return value; +- } +- rawBeforeOpen(root2) { +- let value; +- root2.walk((i2) => { +- if (i2.type !== "decl") { +- value = i2.raws.between; +- if (typeof value !== "undefined") return false; +- } +- }); +- return value; +- } +- rawBeforeRule(root2) { +- let value; +- root2.walk((i2) => { +- if (i2.nodes && (i2.parent !== root2 || root2.first !== i2)) { +- if (typeof i2.raws.before !== "undefined") { +- value = i2.raws.before; +- if (value.includes("\n")) { +- value = value.replace(/[^\n]+$/, ""); +- } +- return false; +- } +- } +- }); +- if (value) value = value.replace(/\S/g, ""); +- return value; +- } +- rawColon(root2) { +- let value; +- root2.walkDecls((i2) => { +- if (typeof i2.raws.between !== "undefined") { +- value = i2.raws.between.replace(/[^\s:]/g, ""); +- return false; +- } +- }); +- return value; +- } +- rawEmptyBody(root2) { +- let value; +- root2.walk((i2) => { +- if (i2.nodes && i2.nodes.length === 0) { +- value = i2.raws.after; +- if (typeof value !== "undefined") return false; +- } +- }); +- return value; +- } +- rawIndent(root2) { +- if (root2.raws.indent) return root2.raws.indent; +- let value; +- root2.walk((i2) => { +- let p = i2.parent; +- if (p && p !== root2 && p.parent && p.parent === root2) { +- if (typeof i2.raws.before !== "undefined") { +- let parts = i2.raws.before.split("\n"); +- value = parts[parts.length - 1]; +- value = value.replace(/\S/g, ""); +- return false; +- } +- } +- }); +- return value; +- } +- rawSemicolon(root2) { +- let value; +- root2.walk((i2) => { +- if (i2.nodes && i2.nodes.length && i2.last.type === "decl") { +- value = i2.raws.semicolon; +- if (typeof value !== "undefined") return false; +- } +- }); +- return value; +- } +- rawValue(node2, prop) { +- let value = node2[prop]; +- let raw = node2.raws[prop]; +- if (raw && raw.value === value) { +- return raw.raw; +- } +- return value; +- } +- root(node2) { +- this.body(node2); +- if (node2.raws.after) this.builder(node2.raws.after); +- } +- rule(node2) { +- this.block(node2, this.rawValue(node2, "selector")); +- if (node2.raws.ownSemicolon) { +- this.builder(node2.raws.ownSemicolon, node2, "end"); +- } +- } +- stringify(node2, semicolon) { +- if (!this[node2.type]) { +- throw new Error( +- "Unknown AST node type " + node2.type + ". Maybe you need to change PostCSS stringifier." +- ); +- } +- this[node2.type](node2, semicolon); +- } +-}; +-var stringifier$1 = Stringifier$2$1; +-Stringifier$2$1.default = Stringifier$2$1; +-let Stringifier$1$1 = stringifier$1; +-function stringify$4$1(node2, builder) { +- let str = new Stringifier$1$1(builder); +- str.stringify(node2); +-} +-var stringify_1$1 = stringify$4$1; +-stringify$4$1.default = stringify$4$1; +-let { isClean: isClean$2$1, my: my$2$1 } = symbols$1; +-let CssSyntaxError$2$1 = cssSyntaxError$1; +-let Stringifier2$1 = stringifier$1; +-let stringify$3$1 = stringify_1$1; +-function cloneNode$1(obj, parent) { +- let cloned = new obj.constructor(); +- for (let i2 in obj) { +- if (!Object.prototype.hasOwnProperty.call(obj, i2)) { +- continue; +- } +- if (i2 === "proxyCache") continue; +- let value = obj[i2]; +- let type = typeof value; +- if (i2 === "parent" && type === "object") { +- if (parent) cloned[i2] = parent; +- } else if (i2 === "source") { +- cloned[i2] = value; +- } else if (Array.isArray(value)) { +- cloned[i2] = value.map((j) => cloneNode$1(j, cloned)); +- } else { +- if (type === "object" && value !== null) value = cloneNode$1(value); +- cloned[i2] = value; +- } +- } +- return cloned; +-} +-let Node$4$1 = class Node2 { +- constructor(defaults = {}) { +- this.raws = {}; +- this[isClean$2$1] = false; +- this[my$2$1] = true; +- for (let name in defaults) { +- if (name === "nodes") { +- this.nodes = []; +- for (let node2 of defaults[name]) { +- if (typeof node2.clone === "function") { +- this.append(node2.clone()); +- } else { +- this.append(node2); +- } +- } +- } else { +- this[name] = defaults[name]; +- } +- } +- } +- addToError(error) { +- error.postcssNode = this; +- if (error.stack && this.source && /\n\s{4}at /.test(error.stack)) { +- let s2 = this.source; +- error.stack = error.stack.replace( +- /\n\s{4}at /, +- `$&${s2.input.from}:${s2.start.line}:${s2.start.column}$&` +- ); +- } +- return error; +- } +- after(add) { +- this.parent.insertAfter(this, add); +- return this; +- } +- assign(overrides = {}) { +- for (let name in overrides) { +- this[name] = overrides[name]; +- } +- return this; +- } +- before(add) { +- this.parent.insertBefore(this, add); +- return this; +- } +- cleanRaws(keepBetween) { +- delete this.raws.before; +- delete this.raws.after; +- if (!keepBetween) delete this.raws.between; +- } +- clone(overrides = {}) { +- let cloned = cloneNode$1(this); +- for (let name in overrides) { +- cloned[name] = overrides[name]; +- } +- return cloned; +- } +- cloneAfter(overrides = {}) { +- let cloned = this.clone(overrides); +- this.parent.insertAfter(this, cloned); +- return cloned; +- } +- cloneBefore(overrides = {}) { +- let cloned = this.clone(overrides); +- this.parent.insertBefore(this, cloned); +- return cloned; +- } +- error(message, opts = {}) { +- if (this.source) { +- let { end, start } = this.rangeBy(opts); +- return this.source.input.error( +- message, +- { column: start.column, line: start.line }, +- { column: end.column, line: end.line }, +- opts +- ); +- } +- return new CssSyntaxError$2$1(message); +- } +- getProxyProcessor() { +- return { +- get(node2, prop) { +- if (prop === "proxyOf") { +- return node2; +- } else if (prop === "root") { +- return () => node2.root().toProxy(); +- } else { +- return node2[prop]; +- } +- }, +- set(node2, prop, value) { +- if (node2[prop] === value) return true; +- node2[prop] = value; +- if (prop === "prop" || prop === "value" || prop === "name" || prop === "params" || prop === "important" || /* c8 ignore next */ +- prop === "text") { +- node2.markDirty(); +- } +- return true; +- } +- }; +- } +- markDirty() { +- if (this[isClean$2$1]) { +- this[isClean$2$1] = false; +- let next = this; +- while (next = next.parent) { +- next[isClean$2$1] = false; +- } +- } +- } +- next() { +- if (!this.parent) return void 0; +- let index2 = this.parent.index(this); +- return this.parent.nodes[index2 + 1]; +- } +- positionBy(opts, stringRepresentation) { +- let pos = this.source.start; +- if (opts.index) { +- pos = this.positionInside(opts.index, stringRepresentation); +- } else if (opts.word) { +- stringRepresentation = this.toString(); +- let index2 = stringRepresentation.indexOf(opts.word); +- if (index2 !== -1) pos = this.positionInside(index2, stringRepresentation); +- } +- return pos; +- } +- positionInside(index2, stringRepresentation) { +- let string = stringRepresentation || this.toString(); +- let column = this.source.start.column; +- let line = this.source.start.line; +- for (let i2 = 0; i2 < index2; i2++) { +- if (string[i2] === "\n") { +- column = 1; +- line += 1; +- } else { +- column += 1; +- } +- } +- return { column, line }; +- } +- prev() { +- if (!this.parent) return void 0; +- let index2 = this.parent.index(this); +- return this.parent.nodes[index2 - 1]; +- } +- rangeBy(opts) { +- let start = { +- column: this.source.start.column, +- line: this.source.start.line +- }; +- let end = this.source.end ? { +- column: this.source.end.column + 1, +- line: this.source.end.line +- } : { +- column: start.column + 1, +- line: start.line +- }; +- if (opts.word) { +- let stringRepresentation = this.toString(); +- let index2 = stringRepresentation.indexOf(opts.word); +- if (index2 !== -1) { +- start = this.positionInside(index2, stringRepresentation); +- end = this.positionInside(index2 + opts.word.length, stringRepresentation); +- } +- } else { +- if (opts.start) { +- start = { +- column: opts.start.column, +- line: opts.start.line +- }; +- } else if (opts.index) { +- start = this.positionInside(opts.index); +- } +- if (opts.end) { +- end = { +- column: opts.end.column, +- line: opts.end.line +- }; +- } else if (typeof opts.endIndex === "number") { +- end = this.positionInside(opts.endIndex); +- } else if (opts.index) { +- end = this.positionInside(opts.index + 1); +- } +- } +- if (end.line < start.line || end.line === start.line && end.column <= start.column) { +- end = { column: start.column + 1, line: start.line }; +- } +- return { end, start }; +- } +- raw(prop, defaultType) { +- let str = new Stringifier2$1(); +- return str.raw(this, prop, defaultType); +- } +- remove() { +- if (this.parent) { +- this.parent.removeChild(this); +- } +- this.parent = void 0; +- return this; +- } +- replaceWith(...nodes) { +- if (this.parent) { +- let bookmark = this; +- let foundSelf = false; +- for (let node2 of nodes) { +- if (node2 === this) { +- foundSelf = true; +- } else if (foundSelf) { +- this.parent.insertAfter(bookmark, node2); +- bookmark = node2; +- } else { +- this.parent.insertBefore(bookmark, node2); +- } +- } +- if (!foundSelf) { +- this.remove(); +- } +- } +- return this; +- } +- root() { +- let result2 = this; +- while (result2.parent && result2.parent.type !== "document") { +- result2 = result2.parent; +- } +- return result2; +- } +- toJSON(_, inputs) { +- let fixed = {}; +- let emitInputs = inputs == null; +- inputs = inputs || /* @__PURE__ */ new Map(); +- let inputsNextIndex = 0; +- for (let name in this) { +- if (!Object.prototype.hasOwnProperty.call(this, name)) { +- continue; +- } +- if (name === "parent" || name === "proxyCache") continue; +- let value = this[name]; +- if (Array.isArray(value)) { +- fixed[name] = value.map((i2) => { +- if (typeof i2 === "object" && i2.toJSON) { +- return i2.toJSON(null, inputs); +- } else { +- return i2; +- } +- }); +- } else if (typeof value === "object" && value.toJSON) { +- fixed[name] = value.toJSON(null, inputs); +- } else if (name === "source") { +- let inputId = inputs.get(value.input); +- if (inputId == null) { +- inputId = inputsNextIndex; +- inputs.set(value.input, inputsNextIndex); +- inputsNextIndex++; +- } +- fixed[name] = { +- end: value.end, +- inputId, +- start: value.start +- }; +- } else { +- fixed[name] = value; +- } +- } +- if (emitInputs) { +- fixed.inputs = [...inputs.keys()].map((input2) => input2.toJSON()); +- } +- return fixed; +- } +- toProxy() { +- if (!this.proxyCache) { +- this.proxyCache = new Proxy(this, this.getProxyProcessor()); +- } +- return this.proxyCache; +- } +- toString(stringifier2 = stringify$3$1) { +- if (stringifier2.stringify) stringifier2 = stringifier2.stringify; +- let result2 = ""; +- stringifier2(this, (i2) => { +- result2 += i2; +- }); +- return result2; +- } +- warn(result2, text, opts) { +- let data = { node: this }; +- for (let i2 in opts) data[i2] = opts[i2]; +- return result2.warn(text, data); +- } +- get proxyOf() { +- return this; +- } +-}; +-var node$1 = Node$4$1; +-Node$4$1.default = Node$4$1; +-let Node$3$1 = node$1; +-let Declaration$4$1 = class Declaration extends Node$3$1 { +- constructor(defaults) { +- if (defaults && typeof defaults.value !== "undefined" && typeof defaults.value !== "string") { +- defaults = { ...defaults, value: String(defaults.value) }; +- } +- super(defaults); +- this.type = "decl"; +- } +- get variable() { +- return this.prop.startsWith("--") || this.prop[0] === "$"; +- } +-}; +-var declaration$1 = Declaration$4$1; +-Declaration$4$1.default = Declaration$4$1; +-let urlAlphabet$1 = "useandom-26T198340PX75pxJACKVERYMINDBUSHWOLF_GQZbfghjklqvwyzrict"; +-let customAlphabet$1 = (alphabet, defaultSize = 21) => { +- return (size = defaultSize) => { +- let id = ""; +- let i2 = size; +- while (i2--) { +- id += alphabet[Math.random() * alphabet.length | 0]; +- } +- return id; +- }; +-}; +-let nanoid$1$1 = (size = 21) => { +- let id = ""; +- let i2 = size; +- while (i2--) { +- id += urlAlphabet$1[Math.random() * 64 | 0]; +- } +- return id; +-}; +-var nonSecure$1 = { nanoid: nanoid$1$1, customAlphabet: customAlphabet$1 }; +-let { SourceMapConsumer: SourceMapConsumer$2$1, SourceMapGenerator: SourceMapGenerator$2$1 } = require$$2$1; +-let { existsSync: existsSync$1, readFileSync: readFileSync$1 } = require$$2$1; +-let { dirname: dirname$1$1, join: join$1 } = require$$2$1; +-function fromBase64$1(str) { +- if (Buffer) { +- return Buffer.from(str, "base64").toString(); +- } else { +- return window.atob(str); +- } +-} +-let PreviousMap$2$1 = class PreviousMap { +- constructor(css, opts) { +- if (opts.map === false) return; +- this.loadAnnotation(css); +- this.inline = this.startWith(this.annotation, "data:"); +- let prev = opts.map ? opts.map.prev : void 0; +- let text = this.loadMap(opts.from, prev); +- if (!this.mapFile && opts.from) { +- this.mapFile = opts.from; +- } +- if (this.mapFile) this.root = dirname$1$1(this.mapFile); +- if (text) this.text = text; +- } +- consumer() { +- if (!this.consumerCache) { +- this.consumerCache = new SourceMapConsumer$2$1(this.text); +- } +- return this.consumerCache; +- } +- decodeInline(text) { +- let baseCharsetUri = /^data:application\/json;charset=utf-?8;base64,/; +- let baseUri = /^data:application\/json;base64,/; +- let charsetUri = /^data:application\/json;charset=utf-?8,/; +- let uri = /^data:application\/json,/; +- if (charsetUri.test(text) || uri.test(text)) { +- return decodeURIComponent(text.substr(RegExp.lastMatch.length)); +- } +- if (baseCharsetUri.test(text) || baseUri.test(text)) { +- return fromBase64$1(text.substr(RegExp.lastMatch.length)); +- } +- let encoding = text.match(/data:application\/json;([^,]+),/)[1]; +- throw new Error("Unsupported source map encoding " + encoding); +- } +- getAnnotationURL(sourceMapString) { +- return sourceMapString.replace(/^\/\*\s*# sourceMappingURL=/, "").trim(); +- } +- isMap(map) { +- if (typeof map !== "object") return false; +- return typeof map.mappings === "string" || typeof map._mappings === "string" || Array.isArray(map.sections); +- } +- loadAnnotation(css) { +- let comments = css.match(/\/\*\s*# sourceMappingURL=/gm); +- if (!comments) return; +- let start = css.lastIndexOf(comments.pop()); +- let end = css.indexOf("*/", start); +- if (start > -1 && end > -1) { +- this.annotation = this.getAnnotationURL(css.substring(start, end)); +- } +- } +- loadFile(path) { +- this.root = dirname$1$1(path); +- if (existsSync$1(path)) { +- this.mapFile = path; +- return readFileSync$1(path, "utf-8").toString().trim(); +- } +- } +- loadMap(file, prev) { +- if (prev === false) return false; +- if (prev) { +- if (typeof prev === "string") { +- return prev; +- } else if (typeof prev === "function") { +- let prevPath = prev(file); +- if (prevPath) { +- let map = this.loadFile(prevPath); +- if (!map) { +- throw new Error( +- "Unable to load previous source map: " + prevPath.toString() +- ); +- } +- return map; +- } +- } else if (prev instanceof SourceMapConsumer$2$1) { +- return SourceMapGenerator$2$1.fromSourceMap(prev).toString(); +- } else if (prev instanceof SourceMapGenerator$2$1) { +- return prev.toString(); +- } else if (this.isMap(prev)) { +- return JSON.stringify(prev); +- } else { +- throw new Error( +- "Unsupported previous source map format: " + prev.toString() +- ); +- } +- } else if (this.inline) { +- return this.decodeInline(this.annotation); +- } else if (this.annotation) { +- let map = this.annotation; +- if (file) map = join$1(dirname$1$1(file), map); +- return this.loadFile(map); +- } +- } +- startWith(string, start) { +- if (!string) return false; +- return string.substr(0, start.length) === start; +- } +- withContent() { +- return !!(this.consumer().sourcesContent && this.consumer().sourcesContent.length > 0); +- } +-}; +-var previousMap$1 = PreviousMap$2$1; +-PreviousMap$2$1.default = PreviousMap$2$1; +-let { SourceMapConsumer: SourceMapConsumer$1$1, SourceMapGenerator: SourceMapGenerator$1$1 } = require$$2$1; +-let { fileURLToPath: fileURLToPath$1, pathToFileURL: pathToFileURL$1$1 } = require$$2$1; +-let { isAbsolute: isAbsolute$1, resolve: resolve$1$1 } = require$$2$1; +-let { nanoid: nanoid$2 } = nonSecure$1; +-let terminalHighlight$2 = require$$2$1; +-let CssSyntaxError$1$1 = cssSyntaxError$1; +-let PreviousMap$1$1 = previousMap$1; +-let fromOffsetCache$1 = Symbol("fromOffsetCache"); +-let sourceMapAvailable$1$1 = Boolean(SourceMapConsumer$1$1 && SourceMapGenerator$1$1); +-let pathAvailable$1$1 = Boolean(resolve$1$1 && isAbsolute$1); +-let Input$4$1 = class Input { +- constructor(css, opts = {}) { +- if (css === null || typeof css === "undefined" || typeof css === "object" && !css.toString) { +- throw new Error(`PostCSS received ${css} instead of CSS string`); +- } +- this.css = css.toString(); +- if (this.css[0] === "\uFEFF" || this.css[0] === "￾") { +- this.hasBOM = true; +- this.css = this.css.slice(1); +- } else { +- this.hasBOM = false; +- } +- if (opts.from) { +- if (!pathAvailable$1$1 || /^\w+:\/\//.test(opts.from) || isAbsolute$1(opts.from)) { +- this.file = opts.from; +- } else { +- this.file = resolve$1$1(opts.from); +- } +- } +- if (pathAvailable$1$1 && sourceMapAvailable$1$1) { +- let map = new PreviousMap$1$1(this.css, opts); +- if (map.text) { +- this.map = map; +- let file = map.consumer().file; +- if (!this.file && file) this.file = this.mapResolve(file); +- } +- } +- if (!this.file) { +- this.id = ""; +- } +- if (this.map) this.map.file = this.from; +- } +- error(message, line, column, opts = {}) { +- let result2, endLine, endColumn; +- if (line && typeof line === "object") { +- let start = line; +- let end = column; +- if (typeof start.offset === "number") { +- let pos = this.fromOffset(start.offset); +- line = pos.line; +- column = pos.col; +- } else { +- line = start.line; +- column = start.column; +- } +- if (typeof end.offset === "number") { +- let pos = this.fromOffset(end.offset); +- endLine = pos.line; +- endColumn = pos.col; +- } else { +- endLine = end.line; +- endColumn = end.column; +- } +- } else if (!column) { +- let pos = this.fromOffset(line); +- line = pos.line; +- column = pos.col; +- } +- let origin = this.origin(line, column, endLine, endColumn); +- if (origin) { +- result2 = new CssSyntaxError$1$1( +- message, +- origin.endLine === void 0 ? origin.line : { column: origin.column, line: origin.line }, +- origin.endLine === void 0 ? origin.column : { column: origin.endColumn, line: origin.endLine }, +- origin.source, +- origin.file, +- opts.plugin +- ); +- } else { +- result2 = new CssSyntaxError$1$1( +- message, +- endLine === void 0 ? line : { column, line }, +- endLine === void 0 ? column : { column: endColumn, line: endLine }, +- this.css, +- this.file, +- opts.plugin +- ); +- } +- result2.input = { column, endColumn, endLine, line, source: this.css }; +- if (this.file) { +- if (pathToFileURL$1$1) { +- result2.input.url = pathToFileURL$1$1(this.file).toString(); +- } +- result2.input.file = this.file; +- } +- return result2; +- } +- fromOffset(offset) { +- let lastLine, lineToIndex; +- if (!this[fromOffsetCache$1]) { +- let lines = this.css.split("\n"); +- lineToIndex = new Array(lines.length); +- let prevIndex = 0; +- for (let i2 = 0, l2 = lines.length; i2 < l2; i2++) { +- lineToIndex[i2] = prevIndex; +- prevIndex += lines[i2].length + 1; +- } +- this[fromOffsetCache$1] = lineToIndex; +- } else { +- lineToIndex = this[fromOffsetCache$1]; +- } +- lastLine = lineToIndex[lineToIndex.length - 1]; +- let min = 0; +- if (offset >= lastLine) { +- min = lineToIndex.length - 1; +- } else { +- let max = lineToIndex.length - 2; +- let mid; +- while (min < max) { +- mid = min + (max - min >> 1); +- if (offset < lineToIndex[mid]) { +- max = mid - 1; +- } else if (offset >= lineToIndex[mid + 1]) { +- min = mid + 1; +- } else { +- min = mid; +- break; +- } +- } +- } +- return { +- col: offset - lineToIndex[min] + 1, +- line: min + 1 +- }; +- } +- mapResolve(file) { +- if (/^\w+:\/\//.test(file)) { +- return file; +- } +- return resolve$1$1(this.map.consumer().sourceRoot || this.map.root || ".", file); +- } +- origin(line, column, endLine, endColumn) { +- if (!this.map) return false; +- let consumer = this.map.consumer(); +- let from = consumer.originalPositionFor({ column, line }); +- if (!from.source) return false; +- let to; +- if (typeof endLine === "number") { +- to = consumer.originalPositionFor({ column: endColumn, line: endLine }); +- } +- let fromUrl; +- if (isAbsolute$1(from.source)) { +- fromUrl = pathToFileURL$1$1(from.source); +- } else { +- fromUrl = new URL( +- from.source, +- this.map.consumer().sourceRoot || pathToFileURL$1$1(this.map.mapFile) +- ); +- } +- let result2 = { +- column: from.column, +- endColumn: to && to.column, +- endLine: to && to.line, +- line: from.line, +- url: fromUrl.toString() +- }; +- if (fromUrl.protocol === "file:") { +- if (fileURLToPath$1) { +- result2.file = fileURLToPath$1(fromUrl); +- } else { +- throw new Error(`file: protocol is not available in this PostCSS build`); +- } +- } +- let source = consumer.sourceContentFor(from.source); +- if (source) result2.source = source; +- return result2; +- } +- toJSON() { +- let json = {}; +- for (let name of ["hasBOM", "css", "file", "id"]) { +- if (this[name] != null) { +- json[name] = this[name]; +- } +- } +- if (this.map) { +- json.map = { ...this.map }; +- if (json.map.consumerCache) { +- json.map.consumerCache = void 0; +- } +- } +- return json; +- } +- get from() { +- return this.file || this.id; +- } +-}; +-var input$1 = Input$4$1; +-Input$4$1.default = Input$4$1; +-if (terminalHighlight$2 && terminalHighlight$2.registerInput) { +- terminalHighlight$2.registerInput(Input$4$1); +-} +-let { SourceMapConsumer: SourceMapConsumer$3, SourceMapGenerator: SourceMapGenerator$3 } = require$$2$1; +-let { dirname: dirname$2, relative: relative$1, resolve: resolve$2, sep: sep$1 } = require$$2$1; +-let { pathToFileURL: pathToFileURL$2 } = require$$2$1; +-let Input$3$1 = input$1; +-let sourceMapAvailable$2 = Boolean(SourceMapConsumer$3 && SourceMapGenerator$3); +-let pathAvailable$2 = Boolean(dirname$2 && resolve$2 && relative$1 && sep$1); +-let MapGenerator$2$1 = class MapGenerator { +- constructor(stringify2, root2, opts, cssString) { +- this.stringify = stringify2; +- this.mapOpts = opts.map || {}; +- this.root = root2; +- this.opts = opts; +- this.css = cssString; +- this.originalCSS = cssString; +- this.usesFileUrls = !this.mapOpts.from && this.mapOpts.absolute; +- this.memoizedFileURLs = /* @__PURE__ */ new Map(); +- this.memoizedPaths = /* @__PURE__ */ new Map(); +- this.memoizedURLs = /* @__PURE__ */ new Map(); +- } +- addAnnotation() { +- let content; +- if (this.isInline()) { +- content = "data:application/json;base64," + this.toBase64(this.map.toString()); +- } else if (typeof this.mapOpts.annotation === "string") { +- content = this.mapOpts.annotation; +- } else if (typeof this.mapOpts.annotation === "function") { +- content = this.mapOpts.annotation(this.opts.to, this.root); +- } else { +- content = this.outputFile() + ".map"; +- } +- let eol = "\n"; +- if (this.css.includes("\r\n")) eol = "\r\n"; +- this.css += eol + "/*# sourceMappingURL=" + content + " */"; +- } +- applyPrevMaps() { +- for (let prev of this.previous()) { +- let from = this.toUrl(this.path(prev.file)); +- let root2 = prev.root || dirname$2(prev.file); +- let map; +- if (this.mapOpts.sourcesContent === false) { +- map = new SourceMapConsumer$3(prev.text); +- if (map.sourcesContent) { +- map.sourcesContent = null; +- } +- } else { +- map = prev.consumer(); +- } +- this.map.applySourceMap(map, from, this.toUrl(this.path(root2))); +- } +- } +- clearAnnotation() { +- if (this.mapOpts.annotation === false) return; +- if (this.root) { +- let node2; +- for (let i2 = this.root.nodes.length - 1; i2 >= 0; i2--) { +- node2 = this.root.nodes[i2]; +- if (node2.type !== "comment") continue; +- if (node2.text.indexOf("# sourceMappingURL=") === 0) { +- this.root.removeChild(i2); +- } +- } +- } else if (this.css) { +- this.css = this.css.replace(/\n*?\/\*#[\S\s]*?\*\/$/gm, ""); +- } +- } +- generate() { +- this.clearAnnotation(); +- if (pathAvailable$2 && sourceMapAvailable$2 && this.isMap()) { +- return this.generateMap(); +- } else { +- let result2 = ""; +- this.stringify(this.root, (i2) => { +- result2 += i2; +- }); +- return [result2]; +- } +- } +- generateMap() { +- if (this.root) { +- this.generateString(); +- } else if (this.previous().length === 1) { +- let prev = this.previous()[0].consumer(); +- prev.file = this.outputFile(); +- this.map = SourceMapGenerator$3.fromSourceMap(prev, { +- ignoreInvalidMapping: true +- }); +- } else { +- this.map = new SourceMapGenerator$3({ +- file: this.outputFile(), +- ignoreInvalidMapping: true +- }); +- this.map.addMapping({ +- generated: { column: 0, line: 1 }, +- original: { column: 0, line: 1 }, +- source: this.opts.from ? this.toUrl(this.path(this.opts.from)) : "" +- }); +- } +- if (this.isSourcesContent()) this.setSourcesContent(); +- if (this.root && this.previous().length > 0) this.applyPrevMaps(); +- if (this.isAnnotation()) this.addAnnotation(); +- if (this.isInline()) { +- return [this.css]; +- } else { +- return [this.css, this.map]; +- } +- } +- generateString() { +- this.css = ""; +- this.map = new SourceMapGenerator$3({ +- file: this.outputFile(), +- ignoreInvalidMapping: true +- }); +- let line = 1; +- let column = 1; +- let noSource = ""; +- let mapping = { +- generated: { column: 0, line: 0 }, +- original: { column: 0, line: 0 }, +- source: "" +- }; +- let lines, last; +- this.stringify(this.root, (str, node2, type) => { +- this.css += str; +- if (node2 && type !== "end") { +- mapping.generated.line = line; +- mapping.generated.column = column - 1; +- if (node2.source && node2.source.start) { +- mapping.source = this.sourcePath(node2); +- mapping.original.line = node2.source.start.line; +- mapping.original.column = node2.source.start.column - 1; +- this.map.addMapping(mapping); +- } else { +- mapping.source = noSource; +- mapping.original.line = 1; +- mapping.original.column = 0; +- this.map.addMapping(mapping); +- } +- } +- lines = str.match(/\n/g); +- if (lines) { +- line += lines.length; +- last = str.lastIndexOf("\n"); +- column = str.length - last; +- } else { +- column += str.length; +- } +- if (node2 && type !== "start") { +- let p = node2.parent || { raws: {} }; +- let childless = node2.type === "decl" || node2.type === "atrule" && !node2.nodes; +- if (!childless || node2 !== p.last || p.raws.semicolon) { +- if (node2.source && node2.source.end) { +- mapping.source = this.sourcePath(node2); +- mapping.original.line = node2.source.end.line; +- mapping.original.column = node2.source.end.column - 1; +- mapping.generated.line = line; +- mapping.generated.column = column - 2; +- this.map.addMapping(mapping); +- } else { +- mapping.source = noSource; +- mapping.original.line = 1; +- mapping.original.column = 0; +- mapping.generated.line = line; +- mapping.generated.column = column - 1; +- this.map.addMapping(mapping); +- } +- } +- } +- }); +- } +- isAnnotation() { +- if (this.isInline()) { +- return true; +- } +- if (typeof this.mapOpts.annotation !== "undefined") { +- return this.mapOpts.annotation; +- } +- if (this.previous().length) { +- return this.previous().some((i2) => i2.annotation); +- } +- return true; +- } +- isInline() { +- if (typeof this.mapOpts.inline !== "undefined") { +- return this.mapOpts.inline; +- } +- let annotation = this.mapOpts.annotation; +- if (typeof annotation !== "undefined" && annotation !== true) { +- return false; +- } +- if (this.previous().length) { +- return this.previous().some((i2) => i2.inline); +- } +- return true; +- } +- isMap() { +- if (typeof this.opts.map !== "undefined") { +- return !!this.opts.map; +- } +- return this.previous().length > 0; +- } +- isSourcesContent() { +- if (typeof this.mapOpts.sourcesContent !== "undefined") { +- return this.mapOpts.sourcesContent; +- } +- if (this.previous().length) { +- return this.previous().some((i2) => i2.withContent()); +- } +- return true; +- } +- outputFile() { +- if (this.opts.to) { +- return this.path(this.opts.to); +- } else if (this.opts.from) { +- return this.path(this.opts.from); +- } else { +- return "to.css"; +- } +- } +- path(file) { +- if (this.mapOpts.absolute) return file; +- if (file.charCodeAt(0) === 60) return file; +- if (/^\w+:\/\//.test(file)) return file; +- let cached = this.memoizedPaths.get(file); +- if (cached) return cached; +- let from = this.opts.to ? dirname$2(this.opts.to) : "."; +- if (typeof this.mapOpts.annotation === "string") { +- from = dirname$2(resolve$2(from, this.mapOpts.annotation)); +- } +- let path = relative$1(from, file); +- this.memoizedPaths.set(file, path); +- return path; +- } +- previous() { +- if (!this.previousMaps) { +- this.previousMaps = []; +- if (this.root) { +- this.root.walk((node2) => { +- if (node2.source && node2.source.input.map) { +- let map = node2.source.input.map; +- if (!this.previousMaps.includes(map)) { +- this.previousMaps.push(map); +- } +- } +- }); +- } else { +- let input2 = new Input$3$1(this.originalCSS, this.opts); +- if (input2.map) this.previousMaps.push(input2.map); +- } +- } +- return this.previousMaps; +- } +- setSourcesContent() { +- let already = {}; +- if (this.root) { +- this.root.walk((node2) => { +- if (node2.source) { +- let from = node2.source.input.from; +- if (from && !already[from]) { +- already[from] = true; +- let fromUrl = this.usesFileUrls ? this.toFileUrl(from) : this.toUrl(this.path(from)); +- this.map.setSourceContent(fromUrl, node2.source.input.css); +- } +- } +- }); +- } else if (this.css) { +- let from = this.opts.from ? this.toUrl(this.path(this.opts.from)) : ""; +- this.map.setSourceContent(from, this.css); +- } +- } +- sourcePath(node2) { +- if (this.mapOpts.from) { +- return this.toUrl(this.mapOpts.from); +- } else if (this.usesFileUrls) { +- return this.toFileUrl(node2.source.input.from); +- } else { +- return this.toUrl(this.path(node2.source.input.from)); +- } +- } +- toBase64(str) { +- if (Buffer) { +- return Buffer.from(str).toString("base64"); +- } else { +- return window.btoa(unescape(encodeURIComponent(str))); +- } +- } +- toFileUrl(path) { +- let cached = this.memoizedFileURLs.get(path); +- if (cached) return cached; +- if (pathToFileURL$2) { +- let fileURL = pathToFileURL$2(path).toString(); +- this.memoizedFileURLs.set(path, fileURL); +- return fileURL; +- } else { +- throw new Error( +- "`map.absolute` option is not available in this PostCSS build" +- ); +- } +- } +- toUrl(path) { +- let cached = this.memoizedURLs.get(path); +- if (cached) return cached; +- if (sep$1 === "\\") { +- path = path.replace(/\\/g, "/"); +- } +- let url = encodeURI(path).replace(/[#?]/g, encodeURIComponent); +- this.memoizedURLs.set(path, url); +- return url; +- } +-}; +-var mapGenerator$1 = MapGenerator$2$1; +-let Node$2$1 = node$1; +-let Comment$4$1 = class Comment extends Node$2$1 { +- constructor(defaults) { +- super(defaults); +- this.type = "comment"; +- } +-}; +-var comment$1 = Comment$4$1; +-Comment$4$1.default = Comment$4$1; +-let { isClean: isClean$1$1, my: my$1$1 } = symbols$1; +-let Declaration$3$1 = declaration$1; +-let Comment$3$1 = comment$1; +-let Node$1$1 = node$1; +-let parse$4$1, Rule$4$1, AtRule$4$1, Root$6$1; +-function cleanSource$1(nodes) { +- return nodes.map((i2) => { +- if (i2.nodes) i2.nodes = cleanSource$1(i2.nodes); +- delete i2.source; +- return i2; +- }); +-} +-function markDirtyUp$1(node2) { +- node2[isClean$1$1] = false; +- if (node2.proxyOf.nodes) { +- for (let i2 of node2.proxyOf.nodes) { +- markDirtyUp$1(i2); +- } +- } +-} +-let Container$7$1 = class Container extends Node$1$1 { +- append(...children) { +- for (let child of children) { +- let nodes = this.normalize(child, this.last); +- for (let node2 of nodes) this.proxyOf.nodes.push(node2); +- } +- this.markDirty(); +- return this; +- } +- cleanRaws(keepBetween) { +- super.cleanRaws(keepBetween); +- if (this.nodes) { +- for (let node2 of this.nodes) node2.cleanRaws(keepBetween); +- } +- } +- each(callback) { +- if (!this.proxyOf.nodes) return void 0; +- let iterator = this.getIterator(); +- let index2, result2; +- while (this.indexes[iterator] < this.proxyOf.nodes.length) { +- index2 = this.indexes[iterator]; +- result2 = callback(this.proxyOf.nodes[index2], index2); +- if (result2 === false) break; +- this.indexes[iterator] += 1; +- } +- delete this.indexes[iterator]; +- return result2; +- } +- every(condition) { +- return this.nodes.every(condition); +- } +- getIterator() { +- if (!this.lastEach) this.lastEach = 0; +- if (!this.indexes) this.indexes = {}; +- this.lastEach += 1; +- let iterator = this.lastEach; +- this.indexes[iterator] = 0; +- return iterator; +- } +- getProxyProcessor() { +- return { +- get(node2, prop) { +- if (prop === "proxyOf") { +- return node2; +- } else if (!node2[prop]) { +- return node2[prop]; +- } else if (prop === "each" || typeof prop === "string" && prop.startsWith("walk")) { +- return (...args) => { +- return node2[prop]( +- ...args.map((i2) => { +- if (typeof i2 === "function") { +- return (child, index2) => i2(child.toProxy(), index2); +- } else { +- return i2; +- } +- }) +- ); +- }; +- } else if (prop === "every" || prop === "some") { +- return (cb) => { +- return node2[prop]( +- (child, ...other) => cb(child.toProxy(), ...other) +- ); +- }; +- } else if (prop === "root") { +- return () => node2.root().toProxy(); +- } else if (prop === "nodes") { +- return node2.nodes.map((i2) => i2.toProxy()); +- } else if (prop === "first" || prop === "last") { +- return node2[prop].toProxy(); +- } else { +- return node2[prop]; +- } +- }, +- set(node2, prop, value) { +- if (node2[prop] === value) return true; +- node2[prop] = value; +- if (prop === "name" || prop === "params" || prop === "selector") { +- node2.markDirty(); +- } +- return true; +- } +- }; +- } +- index(child) { +- if (typeof child === "number") return child; +- if (child.proxyOf) child = child.proxyOf; +- return this.proxyOf.nodes.indexOf(child); +- } +- insertAfter(exist, add) { +- let existIndex = this.index(exist); +- let nodes = this.normalize(add, this.proxyOf.nodes[existIndex]).reverse(); +- existIndex = this.index(exist); +- for (let node2 of nodes) this.proxyOf.nodes.splice(existIndex + 1, 0, node2); +- let index2; +- for (let id in this.indexes) { +- index2 = this.indexes[id]; +- if (existIndex < index2) { +- this.indexes[id] = index2 + nodes.length; +- } +- } +- this.markDirty(); +- return this; +- } +- insertBefore(exist, add) { +- let existIndex = this.index(exist); +- let type = existIndex === 0 ? "prepend" : false; +- let nodes = this.normalize(add, this.proxyOf.nodes[existIndex], type).reverse(); +- existIndex = this.index(exist); +- for (let node2 of nodes) this.proxyOf.nodes.splice(existIndex, 0, node2); +- let index2; +- for (let id in this.indexes) { +- index2 = this.indexes[id]; +- if (existIndex <= index2) { +- this.indexes[id] = index2 + nodes.length; +- } +- } +- this.markDirty(); +- return this; +- } +- normalize(nodes, sample) { +- if (typeof nodes === "string") { +- nodes = cleanSource$1(parse$4$1(nodes).nodes); +- } else if (typeof nodes === "undefined") { +- nodes = []; +- } else if (Array.isArray(nodes)) { +- nodes = nodes.slice(0); +- for (let i2 of nodes) { +- if (i2.parent) i2.parent.removeChild(i2, "ignore"); +- } +- } else if (nodes.type === "root" && this.type !== "document") { +- nodes = nodes.nodes.slice(0); +- for (let i2 of nodes) { +- if (i2.parent) i2.parent.removeChild(i2, "ignore"); +- } +- } else if (nodes.type) { +- nodes = [nodes]; +- } else if (nodes.prop) { +- if (typeof nodes.value === "undefined") { +- throw new Error("Value field is missed in node creation"); +- } else if (typeof nodes.value !== "string") { +- nodes.value = String(nodes.value); +- } +- nodes = [new Declaration$3$1(nodes)]; +- } else if (nodes.selector) { +- nodes = [new Rule$4$1(nodes)]; +- } else if (nodes.name) { +- nodes = [new AtRule$4$1(nodes)]; +- } else if (nodes.text) { +- nodes = [new Comment$3$1(nodes)]; +- } else { +- throw new Error("Unknown node type in node creation"); +- } +- let processed = nodes.map((i2) => { +- if (!i2[my$1$1]) Container.rebuild(i2); +- i2 = i2.proxyOf; +- if (i2.parent) i2.parent.removeChild(i2); +- if (i2[isClean$1$1]) markDirtyUp$1(i2); +- if (typeof i2.raws.before === "undefined") { +- if (sample && typeof sample.raws.before !== "undefined") { +- i2.raws.before = sample.raws.before.replace(/\S/g, ""); +- } +- } +- i2.parent = this.proxyOf; +- return i2; +- }); +- return processed; +- } +- prepend(...children) { +- children = children.reverse(); +- for (let child of children) { +- let nodes = this.normalize(child, this.first, "prepend").reverse(); +- for (let node2 of nodes) this.proxyOf.nodes.unshift(node2); +- for (let id in this.indexes) { +- this.indexes[id] = this.indexes[id] + nodes.length; +- } +- } +- this.markDirty(); +- return this; +- } +- push(child) { +- child.parent = this; +- this.proxyOf.nodes.push(child); +- return this; +- } +- removeAll() { +- for (let node2 of this.proxyOf.nodes) node2.parent = void 0; +- this.proxyOf.nodes = []; +- this.markDirty(); +- return this; +- } +- removeChild(child) { +- child = this.index(child); +- this.proxyOf.nodes[child].parent = void 0; +- this.proxyOf.nodes.splice(child, 1); +- let index2; +- for (let id in this.indexes) { +- index2 = this.indexes[id]; +- if (index2 >= child) { +- this.indexes[id] = index2 - 1; +- } +- } +- this.markDirty(); +- return this; +- } +- replaceValues(pattern, opts, callback) { +- if (!callback) { +- callback = opts; +- opts = {}; +- } +- this.walkDecls((decl) => { +- if (opts.props && !opts.props.includes(decl.prop)) return; +- if (opts.fast && !decl.value.includes(opts.fast)) return; +- decl.value = decl.value.replace(pattern, callback); +- }); +- this.markDirty(); +- return this; +- } +- some(condition) { +- return this.nodes.some(condition); +- } +- walk(callback) { +- return this.each((child, i2) => { +- let result2; +- try { +- result2 = callback(child, i2); +- } catch (e2) { +- throw child.addToError(e2); +- } +- if (result2 !== false && child.walk) { +- result2 = child.walk(callback); +- } +- return result2; +- }); +- } +- walkAtRules(name, callback) { +- if (!callback) { +- callback = name; +- return this.walk((child, i2) => { +- if (child.type === "atrule") { +- return callback(child, i2); +- } +- }); +- } +- if (name instanceof RegExp) { +- return this.walk((child, i2) => { +- if (child.type === "atrule" && name.test(child.name)) { +- return callback(child, i2); +- } +- }); +- } +- return this.walk((child, i2) => { +- if (child.type === "atrule" && child.name === name) { +- return callback(child, i2); +- } +- }); +- } +- walkComments(callback) { +- return this.walk((child, i2) => { +- if (child.type === "comment") { +- return callback(child, i2); +- } +- }); +- } +- walkDecls(prop, callback) { +- if (!callback) { +- callback = prop; +- return this.walk((child, i2) => { +- if (child.type === "decl") { +- return callback(child, i2); +- } +- }); +- } +- if (prop instanceof RegExp) { +- return this.walk((child, i2) => { +- if (child.type === "decl" && prop.test(child.prop)) { +- return callback(child, i2); +- } +- }); +- } +- return this.walk((child, i2) => { +- if (child.type === "decl" && child.prop === prop) { +- return callback(child, i2); +- } +- }); +- } +- walkRules(selector, callback) { +- if (!callback) { +- callback = selector; +- return this.walk((child, i2) => { +- if (child.type === "rule") { +- return callback(child, i2); +- } +- }); +- } +- if (selector instanceof RegExp) { +- return this.walk((child, i2) => { +- if (child.type === "rule" && selector.test(child.selector)) { +- return callback(child, i2); +- } +- }); +- } +- return this.walk((child, i2) => { +- if (child.type === "rule" && child.selector === selector) { +- return callback(child, i2); +- } +- }); +- } +- get first() { +- if (!this.proxyOf.nodes) return void 0; +- return this.proxyOf.nodes[0]; +- } +- get last() { +- if (!this.proxyOf.nodes) return void 0; +- return this.proxyOf.nodes[this.proxyOf.nodes.length - 1]; +- } +-}; +-Container$7$1.registerParse = (dependant) => { +- parse$4$1 = dependant; +-}; +-Container$7$1.registerRule = (dependant) => { +- Rule$4$1 = dependant; +-}; +-Container$7$1.registerAtRule = (dependant) => { +- AtRule$4$1 = dependant; +-}; +-Container$7$1.registerRoot = (dependant) => { +- Root$6$1 = dependant; +-}; +-var container$1 = Container$7$1; +-Container$7$1.default = Container$7$1; +-Container$7$1.rebuild = (node2) => { +- if (node2.type === "atrule") { +- Object.setPrototypeOf(node2, AtRule$4$1.prototype); +- } else if (node2.type === "rule") { +- Object.setPrototypeOf(node2, Rule$4$1.prototype); +- } else if (node2.type === "decl") { +- Object.setPrototypeOf(node2, Declaration$3$1.prototype); +- } else if (node2.type === "comment") { +- Object.setPrototypeOf(node2, Comment$3$1.prototype); +- } else if (node2.type === "root") { +- Object.setPrototypeOf(node2, Root$6$1.prototype); +- } +- node2[my$1$1] = true; +- if (node2.nodes) { +- node2.nodes.forEach((child) => { +- Container$7$1.rebuild(child); +- }); +- } +-}; +-let Container$6$1 = container$1; +-let LazyResult$4$1, Processor$3$1; +-let Document$3$1 = class Document2 extends Container$6$1 { +- constructor(defaults) { +- super({ type: "document", ...defaults }); +- if (!this.nodes) { +- this.nodes = []; +- } +- } +- toResult(opts = {}) { +- let lazy = new LazyResult$4$1(new Processor$3$1(), this, opts); +- return lazy.stringify(); +- } +-}; +-Document$3$1.registerLazyResult = (dependant) => { +- LazyResult$4$1 = dependant; +-}; +-Document$3$1.registerProcessor = (dependant) => { +- Processor$3$1 = dependant; +-}; +-var document$1$1 = Document$3$1; +-Document$3$1.default = Document$3$1; +-let printed$1 = {}; +-var warnOnce$2$1 = function warnOnce(message) { +- if (printed$1[message]) return; +- printed$1[message] = true; +- if (typeof console !== "undefined" && console.warn) { +- console.warn(message); +- } +-}; +-let Warning$2$1 = class Warning { +- constructor(text, opts = {}) { +- this.type = "warning"; +- this.text = text; +- if (opts.node && opts.node.source) { +- let range = opts.node.rangeBy(opts); +- this.line = range.start.line; +- this.column = range.start.column; +- this.endLine = range.end.line; +- this.endColumn = range.end.column; +- } +- for (let opt in opts) this[opt] = opts[opt]; +- } +- toString() { +- if (this.node) { +- return this.node.error(this.text, { +- index: this.index, +- plugin: this.plugin, +- word: this.word +- }).message; +- } +- if (this.plugin) { +- return this.plugin + ": " + this.text; +- } +- return this.text; +- } +-}; +-var warning$1 = Warning$2$1; +-Warning$2$1.default = Warning$2$1; +-let Warning$1$1 = warning$1; +-let Result$3$1 = class Result { +- constructor(processor2, root2, opts) { +- this.processor = processor2; +- this.messages = []; +- this.root = root2; +- this.opts = opts; +- this.css = void 0; +- this.map = void 0; +- } +- toString() { +- return this.css; +- } +- warn(text, opts = {}) { +- if (!opts.plugin) { +- if (this.lastPlugin && this.lastPlugin.postcssPlugin) { +- opts.plugin = this.lastPlugin.postcssPlugin; +- } +- } +- let warning2 = new Warning$1$1(text, opts); +- this.messages.push(warning2); +- return warning2; +- } +- warnings() { +- return this.messages.filter((i2) => i2.type === "warning"); +- } +- get content() { +- return this.css; +- } +-}; +-var result$1 = Result$3$1; +-Result$3$1.default = Result$3$1; +-const SINGLE_QUOTE$1 = "'".charCodeAt(0); +-const DOUBLE_QUOTE$1 = '"'.charCodeAt(0); +-const BACKSLASH$1 = "\\".charCodeAt(0); +-const SLASH$1 = "/".charCodeAt(0); +-const NEWLINE$1 = "\n".charCodeAt(0); +-const SPACE$1 = " ".charCodeAt(0); +-const FEED$1 = "\f".charCodeAt(0); +-const TAB$1 = " ".charCodeAt(0); +-const CR$1 = "\r".charCodeAt(0); +-const OPEN_SQUARE$1 = "[".charCodeAt(0); +-const CLOSE_SQUARE$1 = "]".charCodeAt(0); +-const OPEN_PARENTHESES$1 = "(".charCodeAt(0); +-const CLOSE_PARENTHESES$1 = ")".charCodeAt(0); +-const OPEN_CURLY$1 = "{".charCodeAt(0); +-const CLOSE_CURLY$1 = "}".charCodeAt(0); +-const SEMICOLON$1 = ";".charCodeAt(0); +-const ASTERISK$1 = "*".charCodeAt(0); +-const COLON$1 = ":".charCodeAt(0); +-const AT$1 = "@".charCodeAt(0); +-const RE_AT_END$1 = /[\t\n\f\r "#'()/;[\\\]{}]/g; +-const RE_WORD_END$1 = /[\t\n\f\r !"#'():;@[\\\]{}]|\/(?=\*)/g; +-const RE_BAD_BRACKET$1 = /.[\r\n"'(/\\]/; +-const RE_HEX_ESCAPE$1 = /[\da-f]/i; +-var tokenize$1 = function tokenizer(input2, options = {}) { +- let css = input2.css.valueOf(); +- let ignore = options.ignoreErrors; +- let code, next, quote, content, escape; +- let escaped, escapePos, prev, n2, currentToken; +- let length = css.length; +- let pos = 0; +- let buffer = []; +- let returned = []; +- function position() { +- return pos; +- } +- function unclosed(what) { +- throw input2.error("Unclosed " + what, pos); +- } +- function endOfFile() { +- return returned.length === 0 && pos >= length; +- } +- function nextToken(opts) { +- if (returned.length) return returned.pop(); +- if (pos >= length) return; +- let ignoreUnclosed = opts ? opts.ignoreUnclosed : false; +- code = css.charCodeAt(pos); +- switch (code) { +- case NEWLINE$1: +- case SPACE$1: +- case TAB$1: +- case CR$1: +- case FEED$1: { +- next = pos; +- do { +- next += 1; +- code = css.charCodeAt(next); +- } while (code === SPACE$1 || code === NEWLINE$1 || code === TAB$1 || code === CR$1 || code === FEED$1); +- currentToken = ["space", css.slice(pos, next)]; +- pos = next - 1; +- break; +- } +- case OPEN_SQUARE$1: +- case CLOSE_SQUARE$1: +- case OPEN_CURLY$1: +- case CLOSE_CURLY$1: +- case COLON$1: +- case SEMICOLON$1: +- case CLOSE_PARENTHESES$1: { +- let controlChar = String.fromCharCode(code); +- currentToken = [controlChar, controlChar, pos]; +- break; +- } +- case OPEN_PARENTHESES$1: { +- prev = buffer.length ? buffer.pop()[1] : ""; +- n2 = css.charCodeAt(pos + 1); +- if (prev === "url" && n2 !== SINGLE_QUOTE$1 && n2 !== DOUBLE_QUOTE$1 && n2 !== SPACE$1 && n2 !== NEWLINE$1 && n2 !== TAB$1 && n2 !== FEED$1 && n2 !== CR$1) { +- next = pos; +- do { +- escaped = false; +- next = css.indexOf(")", next + 1); +- if (next === -1) { +- if (ignore || ignoreUnclosed) { +- next = pos; +- break; +- } else { +- unclosed("bracket"); +- } +- } +- escapePos = next; +- while (css.charCodeAt(escapePos - 1) === BACKSLASH$1) { +- escapePos -= 1; +- escaped = !escaped; +- } +- } while (escaped); +- currentToken = ["brackets", css.slice(pos, next + 1), pos, next]; +- pos = next; +- } else { +- next = css.indexOf(")", pos + 1); +- content = css.slice(pos, next + 1); +- if (next === -1 || RE_BAD_BRACKET$1.test(content)) { +- currentToken = ["(", "(", pos]; +- } else { +- currentToken = ["brackets", content, pos, next]; +- pos = next; +- } +- } +- break; +- } +- case SINGLE_QUOTE$1: +- case DOUBLE_QUOTE$1: { +- quote = code === SINGLE_QUOTE$1 ? "'" : '"'; +- next = pos; +- do { +- escaped = false; +- next = css.indexOf(quote, next + 1); +- if (next === -1) { +- if (ignore || ignoreUnclosed) { +- next = pos + 1; +- break; +- } else { +- unclosed("string"); +- } +- } +- escapePos = next; +- while (css.charCodeAt(escapePos - 1) === BACKSLASH$1) { +- escapePos -= 1; +- escaped = !escaped; +- } +- } while (escaped); +- currentToken = ["string", css.slice(pos, next + 1), pos, next]; +- pos = next; +- break; +- } +- case AT$1: { +- RE_AT_END$1.lastIndex = pos + 1; +- RE_AT_END$1.test(css); +- if (RE_AT_END$1.lastIndex === 0) { +- next = css.length - 1; +- } else { +- next = RE_AT_END$1.lastIndex - 2; +- } +- currentToken = ["at-word", css.slice(pos, next + 1), pos, next]; +- pos = next; +- break; +- } +- case BACKSLASH$1: { +- next = pos; +- escape = true; +- while (css.charCodeAt(next + 1) === BACKSLASH$1) { +- next += 1; +- escape = !escape; +- } +- code = css.charCodeAt(next + 1); +- if (escape && code !== SLASH$1 && code !== SPACE$1 && code !== NEWLINE$1 && code !== TAB$1 && code !== CR$1 && code !== FEED$1) { +- next += 1; +- if (RE_HEX_ESCAPE$1.test(css.charAt(next))) { +- while (RE_HEX_ESCAPE$1.test(css.charAt(next + 1))) { +- next += 1; +- } +- if (css.charCodeAt(next + 1) === SPACE$1) { +- next += 1; +- } +- } +- } +- currentToken = ["word", css.slice(pos, next + 1), pos, next]; +- pos = next; +- break; +- } +- default: { +- if (code === SLASH$1 && css.charCodeAt(pos + 1) === ASTERISK$1) { +- next = css.indexOf("*/", pos + 2) + 1; +- if (next === 0) { +- if (ignore || ignoreUnclosed) { +- next = css.length; +- } else { +- unclosed("comment"); +- } +- } +- currentToken = ["comment", css.slice(pos, next + 1), pos, next]; +- pos = next; +- } else { +- RE_WORD_END$1.lastIndex = pos + 1; +- RE_WORD_END$1.test(css); +- if (RE_WORD_END$1.lastIndex === 0) { +- next = css.length - 1; +- } else { +- next = RE_WORD_END$1.lastIndex - 2; +- } +- currentToken = ["word", css.slice(pos, next + 1), pos, next]; +- buffer.push(currentToken); +- pos = next; +- } +- break; +- } +- } +- pos++; +- return currentToken; +- } +- function back(token) { +- returned.push(token); +- } +- return { +- back, +- endOfFile, +- nextToken, +- position +- }; +-}; +-let Container$5$1 = container$1; +-let AtRule$3$1 = class AtRule extends Container$5$1 { +- constructor(defaults) { +- super(defaults); +- this.type = "atrule"; +- } +- append(...children) { +- if (!this.proxyOf.nodes) this.nodes = []; +- return super.append(...children); +- } +- prepend(...children) { +- if (!this.proxyOf.nodes) this.nodes = []; +- return super.prepend(...children); +- } +-}; +-var atRule$1 = AtRule$3$1; +-AtRule$3$1.default = AtRule$3$1; +-Container$5$1.registerAtRule(AtRule$3$1); +-let Container$4$1 = container$1; +-let LazyResult$3$1, Processor$2$1; +-let Root$5$1 = class Root extends Container$4$1 { +- constructor(defaults) { +- super(defaults); +- this.type = "root"; +- if (!this.nodes) this.nodes = []; +- } +- normalize(child, sample, type) { +- let nodes = super.normalize(child); +- if (sample) { +- if (type === "prepend") { +- if (this.nodes.length > 1) { +- sample.raws.before = this.nodes[1].raws.before; +- } else { +- delete sample.raws.before; +- } +- } else if (this.first !== sample) { +- for (let node2 of nodes) { +- node2.raws.before = sample.raws.before; +- } +- } +- } +- return nodes; +- } +- removeChild(child, ignore) { +- let index2 = this.index(child); +- if (!ignore && index2 === 0 && this.nodes.length > 1) { +- this.nodes[1].raws.before = this.nodes[index2].raws.before; +- } +- return super.removeChild(child); +- } +- toResult(opts = {}) { +- let lazy = new LazyResult$3$1(new Processor$2$1(), this, opts); +- return lazy.stringify(); +- } +-}; +-Root$5$1.registerLazyResult = (dependant) => { +- LazyResult$3$1 = dependant; +-}; +-Root$5$1.registerProcessor = (dependant) => { +- Processor$2$1 = dependant; +-}; +-var root$1 = Root$5$1; +-Root$5$1.default = Root$5$1; +-Container$4$1.registerRoot(Root$5$1); +-let list$2$1 = { +- comma(string) { +- return list$2$1.split(string, [","], true); +- }, +- space(string) { +- let spaces = [" ", "\n", " "]; +- return list$2$1.split(string, spaces); +- }, +- split(string, separators, last) { +- let array = []; +- let current = ""; +- let split = false; +- let func = 0; +- let inQuote = false; +- let prevQuote = ""; +- let escape = false; +- for (let letter of string) { +- if (escape) { +- escape = false; +- } else if (letter === "\\") { +- escape = true; +- } else if (inQuote) { +- if (letter === prevQuote) { +- inQuote = false; +- } +- } else if (letter === '"' || letter === "'") { +- inQuote = true; +- prevQuote = letter; +- } else if (letter === "(") { +- func += 1; +- } else if (letter === ")") { +- if (func > 0) func -= 1; +- } else if (func === 0) { +- if (separators.includes(letter)) split = true; +- } +- if (split) { +- if (current !== "") array.push(current.trim()); +- current = ""; +- split = false; +- } else { +- current += letter; +- } +- } +- if (last || current !== "") array.push(current.trim()); +- return array; +- } +-}; +-var list_1$1 = list$2$1; +-list$2$1.default = list$2$1; +-let Container$3$1 = container$1; +-let list$1$1 = list_1$1; +-let Rule$3$1 = class Rule extends Container$3$1 { +- constructor(defaults) { +- super(defaults); +- this.type = "rule"; +- if (!this.nodes) this.nodes = []; +- } +- get selectors() { +- return list$1$1.comma(this.selector); +- } +- set selectors(values) { +- let match = this.selector ? this.selector.match(/,\s*/) : null; +- let sep2 = match ? match[0] : "," + this.raw("between", "beforeOpen"); +- this.selector = values.join(sep2); +- } +-}; +-var rule$1 = Rule$3$1; +-Rule$3$1.default = Rule$3$1; +-Container$3$1.registerRule(Rule$3$1); +-let Declaration$2$1 = declaration$1; +-let tokenizer2$1 = tokenize$1; +-let Comment$2$1 = comment$1; +-let AtRule$2$1 = atRule$1; +-let Root$4$1 = root$1; +-let Rule$2$1 = rule$1; +-const SAFE_COMMENT_NEIGHBOR$1 = { +- empty: true, +- space: true +-}; +-function findLastWithPosition$1(tokens) { +- for (let i2 = tokens.length - 1; i2 >= 0; i2--) { +- let token = tokens[i2]; +- let pos = token[3] || token[2]; +- if (pos) return pos; +- } +-} +-let Parser$1$1 = class Parser { +- constructor(input2) { +- this.input = input2; +- this.root = new Root$4$1(); +- this.current = this.root; +- this.spaces = ""; +- this.semicolon = false; +- this.createTokenizer(); +- this.root.source = { input: input2, start: { column: 1, line: 1, offset: 0 } }; +- } +- atrule(token) { +- let node2 = new AtRule$2$1(); +- node2.name = token[1].slice(1); +- if (node2.name === "") { +- this.unnamedAtrule(node2, token); +- } +- this.init(node2, token[2]); +- let type; +- let prev; +- let shift; +- let last = false; +- let open = false; +- let params = []; +- let brackets = []; +- while (!this.tokenizer.endOfFile()) { +- token = this.tokenizer.nextToken(); +- type = token[0]; +- if (type === "(" || type === "[") { +- brackets.push(type === "(" ? ")" : "]"); +- } else if (type === "{" && brackets.length > 0) { +- brackets.push("}"); +- } else if (type === brackets[brackets.length - 1]) { +- brackets.pop(); +- } +- if (brackets.length === 0) { +- if (type === ";") { +- node2.source.end = this.getPosition(token[2]); +- node2.source.end.offset++; +- this.semicolon = true; +- break; +- } else if (type === "{") { +- open = true; +- break; +- } else if (type === "}") { +- if (params.length > 0) { +- shift = params.length - 1; +- prev = params[shift]; +- while (prev && prev[0] === "space") { +- prev = params[--shift]; +- } +- if (prev) { +- node2.source.end = this.getPosition(prev[3] || prev[2]); +- node2.source.end.offset++; +- } +- } +- this.end(token); +- break; +- } else { +- params.push(token); +- } +- } else { +- params.push(token); +- } +- if (this.tokenizer.endOfFile()) { +- last = true; +- break; +- } +- } +- node2.raws.between = this.spacesAndCommentsFromEnd(params); +- if (params.length) { +- node2.raws.afterName = this.spacesAndCommentsFromStart(params); +- this.raw(node2, "params", params); +- if (last) { +- token = params[params.length - 1]; +- node2.source.end = this.getPosition(token[3] || token[2]); +- node2.source.end.offset++; +- this.spaces = node2.raws.between; +- node2.raws.between = ""; +- } +- } else { +- node2.raws.afterName = ""; +- node2.params = ""; +- } +- if (open) { +- node2.nodes = []; +- this.current = node2; +- } +- } +- checkMissedSemicolon(tokens) { +- let colon = this.colon(tokens); +- if (colon === false) return; +- let founded = 0; +- let token; +- for (let j = colon - 1; j >= 0; j--) { +- token = tokens[j]; +- if (token[0] !== "space") { +- founded += 1; +- if (founded === 2) break; +- } +- } +- throw this.input.error( +- "Missed semicolon", +- token[0] === "word" ? token[3] + 1 : token[2] +- ); +- } +- colon(tokens) { +- let brackets = 0; +- let token, type, prev; +- for (let [i2, element] of tokens.entries()) { +- token = element; +- type = token[0]; +- if (type === "(") { +- brackets += 1; +- } +- if (type === ")") { +- brackets -= 1; +- } +- if (brackets === 0 && type === ":") { +- if (!prev) { +- this.doubleColon(token); +- } else if (prev[0] === "word" && prev[1] === "progid") { +- continue; +- } else { +- return i2; +- } +- } +- prev = token; +- } +- return false; +- } +- comment(token) { +- let node2 = new Comment$2$1(); +- this.init(node2, token[2]); +- node2.source.end = this.getPosition(token[3] || token[2]); +- node2.source.end.offset++; +- let text = token[1].slice(2, -2); +- if (/^\s*$/.test(text)) { +- node2.text = ""; +- node2.raws.left = text; +- node2.raws.right = ""; +- } else { +- let match = text.match(/^(\s*)([^]*\S)(\s*)$/); +- node2.text = match[2]; +- node2.raws.left = match[1]; +- node2.raws.right = match[3]; +- } +- } +- createTokenizer() { +- this.tokenizer = tokenizer2$1(this.input); +- } +- decl(tokens, customProperty) { +- let node2 = new Declaration$2$1(); +- this.init(node2, tokens[0][2]); +- let last = tokens[tokens.length - 1]; +- if (last[0] === ";") { +- this.semicolon = true; +- tokens.pop(); +- } +- node2.source.end = this.getPosition( +- last[3] || last[2] || findLastWithPosition$1(tokens) +- ); +- node2.source.end.offset++; +- while (tokens[0][0] !== "word") { +- if (tokens.length === 1) this.unknownWord(tokens); +- node2.raws.before += tokens.shift()[1]; +- } +- node2.source.start = this.getPosition(tokens[0][2]); +- node2.prop = ""; +- while (tokens.length) { +- let type = tokens[0][0]; +- if (type === ":" || type === "space" || type === "comment") { +- break; +- } +- node2.prop += tokens.shift()[1]; +- } +- node2.raws.between = ""; +- let token; +- while (tokens.length) { +- token = tokens.shift(); +- if (token[0] === ":") { +- node2.raws.between += token[1]; +- break; +- } else { +- if (token[0] === "word" && /\w/.test(token[1])) { +- this.unknownWord([token]); +- } +- node2.raws.between += token[1]; +- } +- } +- if (node2.prop[0] === "_" || node2.prop[0] === "*") { +- node2.raws.before += node2.prop[0]; +- node2.prop = node2.prop.slice(1); +- } +- let firstSpaces = []; +- let next; +- while (tokens.length) { +- next = tokens[0][0]; +- if (next !== "space" && next !== "comment") break; +- firstSpaces.push(tokens.shift()); +- } +- this.precheckMissedSemicolon(tokens); +- for (let i2 = tokens.length - 1; i2 >= 0; i2--) { +- token = tokens[i2]; +- if (token[1].toLowerCase() === "!important") { +- node2.important = true; +- let string = this.stringFrom(tokens, i2); +- string = this.spacesFromEnd(tokens) + string; +- if (string !== " !important") node2.raws.important = string; +- break; +- } else if (token[1].toLowerCase() === "important") { +- let cache = tokens.slice(0); +- let str = ""; +- for (let j = i2; j > 0; j--) { +- let type = cache[j][0]; +- if (str.trim().indexOf("!") === 0 && type !== "space") { +- break; +- } +- str = cache.pop()[1] + str; +- } +- if (str.trim().indexOf("!") === 0) { +- node2.important = true; +- node2.raws.important = str; +- tokens = cache; +- } +- } +- if (token[0] !== "space" && token[0] !== "comment") { +- break; +- } +- } +- let hasWord = tokens.some((i2) => i2[0] !== "space" && i2[0] !== "comment"); +- if (hasWord) { +- node2.raws.between += firstSpaces.map((i2) => i2[1]).join(""); +- firstSpaces = []; +- } +- this.raw(node2, "value", firstSpaces.concat(tokens), customProperty); +- if (node2.value.includes(":") && !customProperty) { +- this.checkMissedSemicolon(tokens); +- } +- } +- doubleColon(token) { +- throw this.input.error( +- "Double colon", +- { offset: token[2] }, +- { offset: token[2] + token[1].length } +- ); +- } +- emptyRule(token) { +- let node2 = new Rule$2$1(); +- this.init(node2, token[2]); +- node2.selector = ""; +- node2.raws.between = ""; +- this.current = node2; +- } +- end(token) { +- if (this.current.nodes && this.current.nodes.length) { +- this.current.raws.semicolon = this.semicolon; +- } +- this.semicolon = false; +- this.current.raws.after = (this.current.raws.after || "") + this.spaces; +- this.spaces = ""; +- if (this.current.parent) { +- this.current.source.end = this.getPosition(token[2]); +- this.current.source.end.offset++; +- this.current = this.current.parent; +- } else { +- this.unexpectedClose(token); +- } +- } +- endFile() { +- if (this.current.parent) this.unclosedBlock(); +- if (this.current.nodes && this.current.nodes.length) { +- this.current.raws.semicolon = this.semicolon; +- } +- this.current.raws.after = (this.current.raws.after || "") + this.spaces; +- this.root.source.end = this.getPosition(this.tokenizer.position()); +- } +- freeSemicolon(token) { +- this.spaces += token[1]; +- if (this.current.nodes) { +- let prev = this.current.nodes[this.current.nodes.length - 1]; +- if (prev && prev.type === "rule" && !prev.raws.ownSemicolon) { +- prev.raws.ownSemicolon = this.spaces; +- this.spaces = ""; +- } +- } +- } +- // Helpers +- getPosition(offset) { +- let pos = this.input.fromOffset(offset); +- return { +- column: pos.col, +- line: pos.line, +- offset +- }; +- } +- init(node2, offset) { +- this.current.push(node2); +- node2.source = { +- input: this.input, +- start: this.getPosition(offset) +- }; +- node2.raws.before = this.spaces; +- this.spaces = ""; +- if (node2.type !== "comment") this.semicolon = false; +- } +- other(start) { +- let end = false; +- let type = null; +- let colon = false; +- let bracket = null; +- let brackets = []; +- let customProperty = start[1].startsWith("--"); +- let tokens = []; +- let token = start; +- while (token) { +- type = token[0]; +- tokens.push(token); +- if (type === "(" || type === "[") { +- if (!bracket) bracket = token; +- brackets.push(type === "(" ? ")" : "]"); +- } else if (customProperty && colon && type === "{") { +- if (!bracket) bracket = token; +- brackets.push("}"); +- } else if (brackets.length === 0) { +- if (type === ";") { +- if (colon) { +- this.decl(tokens, customProperty); +- return; +- } else { +- break; +- } +- } else if (type === "{") { +- this.rule(tokens); +- return; +- } else if (type === "}") { +- this.tokenizer.back(tokens.pop()); +- end = true; +- break; +- } else if (type === ":") { +- colon = true; +- } +- } else if (type === brackets[brackets.length - 1]) { +- brackets.pop(); +- if (brackets.length === 0) bracket = null; +- } +- token = this.tokenizer.nextToken(); +- } +- if (this.tokenizer.endOfFile()) end = true; +- if (brackets.length > 0) this.unclosedBracket(bracket); +- if (end && colon) { +- if (!customProperty) { +- while (tokens.length) { +- token = tokens[tokens.length - 1][0]; +- if (token !== "space" && token !== "comment") break; +- this.tokenizer.back(tokens.pop()); +- } +- } +- this.decl(tokens, customProperty); +- } else { +- this.unknownWord(tokens); +- } +- } +- parse() { +- let token; +- while (!this.tokenizer.endOfFile()) { +- token = this.tokenizer.nextToken(); +- switch (token[0]) { +- case "space": +- this.spaces += token[1]; +- break; +- case ";": +- this.freeSemicolon(token); +- break; +- case "}": +- this.end(token); +- break; +- case "comment": +- this.comment(token); +- break; +- case "at-word": +- this.atrule(token); +- break; +- case "{": +- this.emptyRule(token); +- break; +- default: +- this.other(token); +- break; +- } +- } +- this.endFile(); +- } +- precheckMissedSemicolon() { +- } +- raw(node2, prop, tokens, customProperty) { +- let token, type; +- let length = tokens.length; +- let value = ""; +- let clean = true; +- let next, prev; +- for (let i2 = 0; i2 < length; i2 += 1) { +- token = tokens[i2]; +- type = token[0]; +- if (type === "space" && i2 === length - 1 && !customProperty) { +- clean = false; +- } else if (type === "comment") { +- prev = tokens[i2 - 1] ? tokens[i2 - 1][0] : "empty"; +- next = tokens[i2 + 1] ? tokens[i2 + 1][0] : "empty"; +- if (!SAFE_COMMENT_NEIGHBOR$1[prev] && !SAFE_COMMENT_NEIGHBOR$1[next]) { +- if (value.slice(-1) === ",") { +- clean = false; +- } else { +- value += token[1]; +- } +- } else { +- clean = false; +- } +- } else { +- value += token[1]; +- } +- } +- if (!clean) { +- let raw = tokens.reduce((all, i2) => all + i2[1], ""); +- node2.raws[prop] = { raw, value }; +- } +- node2[prop] = value; +- } +- rule(tokens) { +- tokens.pop(); +- let node2 = new Rule$2$1(); +- this.init(node2, tokens[0][2]); +- node2.raws.between = this.spacesAndCommentsFromEnd(tokens); +- this.raw(node2, "selector", tokens); +- this.current = node2; +- } +- spacesAndCommentsFromEnd(tokens) { +- let lastTokenType; +- let spaces = ""; +- while (tokens.length) { +- lastTokenType = tokens[tokens.length - 1][0]; +- if (lastTokenType !== "space" && lastTokenType !== "comment") break; +- spaces = tokens.pop()[1] + spaces; +- } +- return spaces; +- } +- // Errors +- spacesAndCommentsFromStart(tokens) { +- let next; +- let spaces = ""; +- while (tokens.length) { +- next = tokens[0][0]; +- if (next !== "space" && next !== "comment") break; +- spaces += tokens.shift()[1]; +- } +- return spaces; +- } +- spacesFromEnd(tokens) { +- let lastTokenType; +- let spaces = ""; +- while (tokens.length) { +- lastTokenType = tokens[tokens.length - 1][0]; +- if (lastTokenType !== "space") break; +- spaces = tokens.pop()[1] + spaces; +- } +- return spaces; +- } +- stringFrom(tokens, from) { +- let result2 = ""; +- for (let i2 = from; i2 < tokens.length; i2++) { +- result2 += tokens[i2][1]; +- } +- tokens.splice(from, tokens.length - from); +- return result2; +- } +- unclosedBlock() { +- let pos = this.current.source.start; +- throw this.input.error("Unclosed block", pos.line, pos.column); +- } +- unclosedBracket(bracket) { +- throw this.input.error( +- "Unclosed bracket", +- { offset: bracket[2] }, +- { offset: bracket[2] + 1 } +- ); +- } +- unexpectedClose(token) { +- throw this.input.error( +- "Unexpected }", +- { offset: token[2] }, +- { offset: token[2] + 1 } +- ); +- } +- unknownWord(tokens) { +- throw this.input.error( +- "Unknown word", +- { offset: tokens[0][2] }, +- { offset: tokens[0][2] + tokens[0][1].length } +- ); +- } +- unnamedAtrule(node2, token) { +- throw this.input.error( +- "At-rule without name", +- { offset: token[2] }, +- { offset: token[2] + token[1].length } +- ); +- } +-}; +-var parser$1 = Parser$1$1; +-let Container$2$1 = container$1; +-let Parser2$1 = parser$1; +-let Input$2$1 = input$1; +-function parse$3$1(css, opts) { +- let input2 = new Input$2$1(css, opts); +- let parser2 = new Parser2$1(input2); +- try { +- parser2.parse(); +- } catch (e2) { +- if (process.env.NODE_ENV !== "production") { +- if (e2.name === "CssSyntaxError" && opts && opts.from) { +- if (/\.scss$/i.test(opts.from)) { +- e2.message += "\nYou tried to parse SCSS with the standard CSS parser; try again with the postcss-scss parser"; +- } else if (/\.sass/i.test(opts.from)) { +- e2.message += "\nYou tried to parse Sass with the standard CSS parser; try again with the postcss-sass parser"; +- } else if (/\.less$/i.test(opts.from)) { +- e2.message += "\nYou tried to parse Less with the standard CSS parser; try again with the postcss-less parser"; +- } +- } +- } +- throw e2; +- } +- return parser2.root; +-} +-var parse_1$1 = parse$3$1; +-parse$3$1.default = parse$3$1; +-Container$2$1.registerParse(parse$3$1); +-let { isClean: isClean$3, my: my$3 } = symbols$1; +-let MapGenerator$1$1 = mapGenerator$1; +-let stringify$2$1 = stringify_1$1; +-let Container$1$1 = container$1; +-let Document$2$1 = document$1$1; +-let warnOnce$1$1 = warnOnce$2$1; +-let Result$2$1 = result$1; +-let parse$2$1 = parse_1$1; +-let Root$3$1 = root$1; +-const TYPE_TO_CLASS_NAME$1 = { +- atrule: "AtRule", +- comment: "Comment", +- decl: "Declaration", +- document: "Document", +- root: "Root", +- rule: "Rule" +-}; +-const PLUGIN_PROPS$1 = { +- AtRule: true, +- AtRuleExit: true, +- Comment: true, +- CommentExit: true, +- Declaration: true, +- DeclarationExit: true, +- Document: true, +- DocumentExit: true, +- Once: true, +- OnceExit: true, +- postcssPlugin: true, +- prepare: true, +- Root: true, +- RootExit: true, +- Rule: true, +- RuleExit: true +-}; +-const NOT_VISITORS$1 = { +- Once: true, +- postcssPlugin: true, +- prepare: true +-}; +-const CHILDREN$1 = 0; +-function isPromise$1(obj) { +- return typeof obj === "object" && typeof obj.then === "function"; +-} +-function getEvents$1(node2) { +- let key = false; +- let type = TYPE_TO_CLASS_NAME$1[node2.type]; +- if (node2.type === "decl") { +- key = node2.prop.toLowerCase(); +- } else if (node2.type === "atrule") { +- key = node2.name.toLowerCase(); +- } +- if (key && node2.append) { +- return [ +- type, +- type + "-" + key, +- CHILDREN$1, +- type + "Exit", +- type + "Exit-" + key +- ]; +- } else if (key) { +- return [type, type + "-" + key, type + "Exit", type + "Exit-" + key]; +- } else if (node2.append) { +- return [type, CHILDREN$1, type + "Exit"]; +- } else { +- return [type, type + "Exit"]; +- } +-} +-function toStack$1(node2) { +- let events; +- if (node2.type === "document") { +- events = ["Document", CHILDREN$1, "DocumentExit"]; +- } else if (node2.type === "root") { +- events = ["Root", CHILDREN$1, "RootExit"]; +- } else { +- events = getEvents$1(node2); +- } +- return { +- eventIndex: 0, +- events, +- iterator: 0, +- node: node2, +- visitorIndex: 0, +- visitors: [] +- }; +-} +-function cleanMarks$1(node2) { +- node2[isClean$3] = false; +- if (node2.nodes) node2.nodes.forEach((i2) => cleanMarks$1(i2)); +- return node2; +-} +-let postcss$2$1 = {}; +-let LazyResult$2$1 = class LazyResult { +- constructor(processor2, css, opts) { +- this.stringified = false; +- this.processed = false; +- let root2; +- if (typeof css === "object" && css !== null && (css.type === "root" || css.type === "document")) { +- root2 = cleanMarks$1(css); +- } else if (css instanceof LazyResult || css instanceof Result$2$1) { +- root2 = cleanMarks$1(css.root); +- if (css.map) { +- if (typeof opts.map === "undefined") opts.map = {}; +- if (!opts.map.inline) opts.map.inline = false; +- opts.map.prev = css.map; +- } +- } else { +- let parser2 = parse$2$1; +- if (opts.syntax) parser2 = opts.syntax.parse; +- if (opts.parser) parser2 = opts.parser; +- if (parser2.parse) parser2 = parser2.parse; +- try { +- root2 = parser2(css, opts); +- } catch (error) { +- this.processed = true; +- this.error = error; +- } +- if (root2 && !root2[my$3]) { +- Container$1$1.rebuild(root2); +- } +- } +- this.result = new Result$2$1(processor2, root2, opts); +- this.helpers = { ...postcss$2$1, postcss: postcss$2$1, result: this.result }; +- this.plugins = this.processor.plugins.map((plugin22) => { +- if (typeof plugin22 === "object" && plugin22.prepare) { +- return { ...plugin22, ...plugin22.prepare(this.result) }; +- } else { +- return plugin22; +- } +- }); +- } +- async() { +- if (this.error) return Promise.reject(this.error); +- if (this.processed) return Promise.resolve(this.result); +- if (!this.processing) { +- this.processing = this.runAsync(); +- } +- return this.processing; +- } +- catch(onRejected) { +- return this.async().catch(onRejected); +- } +- finally(onFinally) { +- return this.async().then(onFinally, onFinally); +- } +- getAsyncError() { +- throw new Error("Use process(css).then(cb) to work with async plugins"); +- } +- handleError(error, node2) { +- let plugin22 = this.result.lastPlugin; +- try { +- if (node2) node2.addToError(error); +- this.error = error; +- if (error.name === "CssSyntaxError" && !error.plugin) { +- error.plugin = plugin22.postcssPlugin; +- error.setMessage(); +- } else if (plugin22.postcssVersion) { +- if (process.env.NODE_ENV !== "production") { +- let pluginName = plugin22.postcssPlugin; +- let pluginVer = plugin22.postcssVersion; +- let runtimeVer = this.result.processor.version; +- let a2 = pluginVer.split("."); +- let b = runtimeVer.split("."); +- if (a2[0] !== b[0] || parseInt(a2[1]) > parseInt(b[1])) { +- console.error( +- "Unknown error from PostCSS plugin. Your current PostCSS version is " + runtimeVer + ", but " + pluginName + " uses " + pluginVer + ". Perhaps this is the source of the error below." +- ); +- } +- } +- } +- } catch (err) { +- if (console && console.error) console.error(err); +- } +- return error; +- } +- prepareVisitors() { +- this.listeners = {}; +- let add = (plugin22, type, cb) => { +- if (!this.listeners[type]) this.listeners[type] = []; +- this.listeners[type].push([plugin22, cb]); +- }; +- for (let plugin22 of this.plugins) { +- if (typeof plugin22 === "object") { +- for (let event in plugin22) { +- if (!PLUGIN_PROPS$1[event] && /^[A-Z]/.test(event)) { +- throw new Error( +- `Unknown event ${event} in ${plugin22.postcssPlugin}. Try to update PostCSS (${this.processor.version} now).` +- ); +- } +- if (!NOT_VISITORS$1[event]) { +- if (typeof plugin22[event] === "object") { +- for (let filter in plugin22[event]) { +- if (filter === "*") { +- add(plugin22, event, plugin22[event][filter]); +- } else { +- add( +- plugin22, +- event + "-" + filter.toLowerCase(), +- plugin22[event][filter] +- ); +- } +- } +- } else if (typeof plugin22[event] === "function") { +- add(plugin22, event, plugin22[event]); +- } +- } +- } +- } +- } +- this.hasListener = Object.keys(this.listeners).length > 0; +- } +- async runAsync() { +- this.plugin = 0; +- for (let i2 = 0; i2 < this.plugins.length; i2++) { +- let plugin22 = this.plugins[i2]; +- let promise = this.runOnRoot(plugin22); +- if (isPromise$1(promise)) { +- try { +- await promise; +- } catch (error) { +- throw this.handleError(error); +- } +- } +- } +- this.prepareVisitors(); +- if (this.hasListener) { +- let root2 = this.result.root; +- while (!root2[isClean$3]) { +- root2[isClean$3] = true; +- let stack = [toStack$1(root2)]; +- while (stack.length > 0) { +- let promise = this.visitTick(stack); +- if (isPromise$1(promise)) { +- try { +- await promise; +- } catch (e2) { +- let node2 = stack[stack.length - 1].node; +- throw this.handleError(e2, node2); +- } +- } +- } +- } +- if (this.listeners.OnceExit) { +- for (let [plugin22, visitor] of this.listeners.OnceExit) { +- this.result.lastPlugin = plugin22; +- try { +- if (root2.type === "document") { +- let roots = root2.nodes.map( +- (subRoot) => visitor(subRoot, this.helpers) +- ); +- await Promise.all(roots); +- } else { +- await visitor(root2, this.helpers); +- } +- } catch (e2) { +- throw this.handleError(e2); +- } +- } +- } +- } +- this.processed = true; +- return this.stringify(); +- } +- runOnRoot(plugin22) { +- this.result.lastPlugin = plugin22; +- try { +- if (typeof plugin22 === "object" && plugin22.Once) { +- if (this.result.root.type === "document") { +- let roots = this.result.root.nodes.map( +- (root2) => plugin22.Once(root2, this.helpers) +- ); +- if (isPromise$1(roots[0])) { +- return Promise.all(roots); +- } +- return roots; +- } +- return plugin22.Once(this.result.root, this.helpers); +- } else if (typeof plugin22 === "function") { +- return plugin22(this.result.root, this.result); +- } +- } catch (error) { +- throw this.handleError(error); +- } +- } +- stringify() { +- if (this.error) throw this.error; +- if (this.stringified) return this.result; +- this.stringified = true; +- this.sync(); +- let opts = this.result.opts; +- let str = stringify$2$1; +- if (opts.syntax) str = opts.syntax.stringify; +- if (opts.stringifier) str = opts.stringifier; +- if (str.stringify) str = str.stringify; +- let map = new MapGenerator$1$1(str, this.result.root, this.result.opts); +- let data = map.generate(); +- this.result.css = data[0]; +- this.result.map = data[1]; +- return this.result; +- } +- sync() { +- if (this.error) throw this.error; +- if (this.processed) return this.result; +- this.processed = true; +- if (this.processing) { +- throw this.getAsyncError(); +- } +- for (let plugin22 of this.plugins) { +- let promise = this.runOnRoot(plugin22); +- if (isPromise$1(promise)) { +- throw this.getAsyncError(); +- } +- } +- this.prepareVisitors(); +- if (this.hasListener) { +- let root2 = this.result.root; +- while (!root2[isClean$3]) { +- root2[isClean$3] = true; +- this.walkSync(root2); +- } +- if (this.listeners.OnceExit) { +- if (root2.type === "document") { +- for (let subRoot of root2.nodes) { +- this.visitSync(this.listeners.OnceExit, subRoot); +- } +- } else { +- this.visitSync(this.listeners.OnceExit, root2); +- } +- } +- } +- return this.result; +- } +- then(onFulfilled, onRejected) { +- if (process.env.NODE_ENV !== "production") { +- if (!("from" in this.opts)) { +- warnOnce$1$1( +- "Without `from` option PostCSS could generate wrong source map and will not find Browserslist config. Set it to CSS file path or to `undefined` to prevent this warning." +- ); +- } +- } +- return this.async().then(onFulfilled, onRejected); +- } +- toString() { +- return this.css; +- } +- visitSync(visitors, node2) { +- for (let [plugin22, visitor] of visitors) { +- this.result.lastPlugin = plugin22; +- let promise; +- try { +- promise = visitor(node2, this.helpers); +- } catch (e2) { +- throw this.handleError(e2, node2.proxyOf); +- } +- if (node2.type !== "root" && node2.type !== "document" && !node2.parent) { +- return true; +- } +- if (isPromise$1(promise)) { +- throw this.getAsyncError(); +- } +- } +- } +- visitTick(stack) { +- let visit2 = stack[stack.length - 1]; +- let { node: node2, visitors } = visit2; +- if (node2.type !== "root" && node2.type !== "document" && !node2.parent) { +- stack.pop(); +- return; +- } +- if (visitors.length > 0 && visit2.visitorIndex < visitors.length) { +- let [plugin22, visitor] = visitors[visit2.visitorIndex]; +- visit2.visitorIndex += 1; +- if (visit2.visitorIndex === visitors.length) { +- visit2.visitors = []; +- visit2.visitorIndex = 0; +- } +- this.result.lastPlugin = plugin22; +- try { +- return visitor(node2.toProxy(), this.helpers); +- } catch (e2) { +- throw this.handleError(e2, node2); +- } +- } +- if (visit2.iterator !== 0) { +- let iterator = visit2.iterator; +- let child; +- while (child = node2.nodes[node2.indexes[iterator]]) { +- node2.indexes[iterator] += 1; +- if (!child[isClean$3]) { +- child[isClean$3] = true; +- stack.push(toStack$1(child)); +- return; +- } +- } +- visit2.iterator = 0; +- delete node2.indexes[iterator]; +- } +- let events = visit2.events; +- while (visit2.eventIndex < events.length) { +- let event = events[visit2.eventIndex]; +- visit2.eventIndex += 1; +- if (event === CHILDREN$1) { +- if (node2.nodes && node2.nodes.length) { +- node2[isClean$3] = true; +- visit2.iterator = node2.getIterator(); +- } +- return; +- } else if (this.listeners[event]) { +- visit2.visitors = this.listeners[event]; +- return; +- } +- } +- stack.pop(); +- } +- walkSync(node2) { +- node2[isClean$3] = true; +- let events = getEvents$1(node2); +- for (let event of events) { +- if (event === CHILDREN$1) { +- if (node2.nodes) { +- node2.each((child) => { +- if (!child[isClean$3]) this.walkSync(child); +- }); +- } +- } else { +- let visitors = this.listeners[event]; +- if (visitors) { +- if (this.visitSync(visitors, node2.toProxy())) return; +- } +- } +- } +- } +- warnings() { +- return this.sync().warnings(); +- } +- get content() { +- return this.stringify().content; +- } +- get css() { +- return this.stringify().css; +- } +- get map() { +- return this.stringify().map; +- } +- get messages() { +- return this.sync().messages; +- } +- get opts() { +- return this.result.opts; +- } +- get processor() { +- return this.result.processor; +- } +- get root() { +- return this.sync().root; +- } +- get [Symbol.toStringTag]() { +- return "LazyResult"; +- } +-}; +-LazyResult$2$1.registerPostcss = (dependant) => { +- postcss$2$1 = dependant; +-}; +-var lazyResult$1 = LazyResult$2$1; +-LazyResult$2$1.default = LazyResult$2$1; +-Root$3$1.registerLazyResult(LazyResult$2$1); +-Document$2$1.registerLazyResult(LazyResult$2$1); +-let MapGenerator2$1 = mapGenerator$1; +-let stringify$1$1 = stringify_1$1; +-let warnOnce2$1 = warnOnce$2$1; +-let parse$1$1 = parse_1$1; +-const Result$1$1 = result$1; +-let NoWorkResult$1$1 = class NoWorkResult { +- constructor(processor2, css, opts) { +- css = css.toString(); +- this.stringified = false; +- this._processor = processor2; +- this._css = css; +- this._opts = opts; +- this._map = void 0; +- let root2; +- let str = stringify$1$1; +- this.result = new Result$1$1(this._processor, root2, this._opts); +- this.result.css = css; +- let self = this; +- Object.defineProperty(this.result, "root", { +- get() { +- return self.root; +- } +- }); +- let map = new MapGenerator2$1(str, root2, this._opts, css); +- if (map.isMap()) { +- let [generatedCSS, generatedMap] = map.generate(); +- if (generatedCSS) { +- this.result.css = generatedCSS; +- } +- if (generatedMap) { +- this.result.map = generatedMap; +- } +- } else { +- map.clearAnnotation(); +- this.result.css = map.css; +- } +- } +- async() { +- if (this.error) return Promise.reject(this.error); +- return Promise.resolve(this.result); +- } +- catch(onRejected) { +- return this.async().catch(onRejected); +- } +- finally(onFinally) { +- return this.async().then(onFinally, onFinally); +- } +- sync() { +- if (this.error) throw this.error; +- return this.result; +- } +- then(onFulfilled, onRejected) { +- if (process.env.NODE_ENV !== "production") { +- if (!("from" in this._opts)) { +- warnOnce2$1( +- "Without `from` option PostCSS could generate wrong source map and will not find Browserslist config. Set it to CSS file path or to `undefined` to prevent this warning." +- ); +- } +- } +- return this.async().then(onFulfilled, onRejected); +- } +- toString() { +- return this._css; +- } +- warnings() { +- return []; +- } +- get content() { +- return this.result.css; +- } +- get css() { +- return this.result.css; +- } +- get map() { +- return this.result.map; +- } +- get messages() { +- return []; +- } +- get opts() { +- return this.result.opts; +- } +- get processor() { +- return this.result.processor; +- } +- get root() { +- if (this._root) { +- return this._root; +- } +- let root2; +- let parser2 = parse$1$1; +- try { +- root2 = parser2(this._css, this._opts); +- } catch (error) { +- this.error = error; +- } +- if (this.error) { +- throw this.error; +- } else { +- this._root = root2; +- return root2; +- } +- } +- get [Symbol.toStringTag]() { +- return "NoWorkResult"; +- } +-}; +-var noWorkResult$1 = NoWorkResult$1$1; +-NoWorkResult$1$1.default = NoWorkResult$1$1; +-let NoWorkResult2$1 = noWorkResult$1; +-let LazyResult$1$1 = lazyResult$1; +-let Document$1$1 = document$1$1; +-let Root$2$1 = root$1; +-let Processor$1$1 = class Processor { +- constructor(plugins = []) { +- this.version = "8.4.38"; +- this.plugins = this.normalize(plugins); +- } +- normalize(plugins) { +- let normalized = []; +- for (let i2 of plugins) { +- if (i2.postcss === true) { +- i2 = i2(); +- } else if (i2.postcss) { +- i2 = i2.postcss; +- } +- if (typeof i2 === "object" && Array.isArray(i2.plugins)) { +- normalized = normalized.concat(i2.plugins); +- } else if (typeof i2 === "object" && i2.postcssPlugin) { +- normalized.push(i2); +- } else if (typeof i2 === "function") { +- normalized.push(i2); +- } else if (typeof i2 === "object" && (i2.parse || i2.stringify)) { +- if (process.env.NODE_ENV !== "production") { +- throw new Error( +- "PostCSS syntaxes cannot be used as plugins. Instead, please use one of the syntax/parser/stringifier options as outlined in your PostCSS runner documentation." +- ); +- } +- } else { +- throw new Error(i2 + " is not a PostCSS plugin"); +- } +- } +- return normalized; +- } +- process(css, opts = {}) { +- if (!this.plugins.length && !opts.parser && !opts.stringifier && !opts.syntax) { +- return new NoWorkResult2$1(this, css, opts); +- } else { +- return new LazyResult$1$1(this, css, opts); +- } +- } +- use(plugin22) { +- this.plugins = this.plugins.concat(this.normalize([plugin22])); +- return this; +- } +-}; +-var processor$1 = Processor$1$1; +-Processor$1$1.default = Processor$1$1; +-Root$2$1.registerProcessor(Processor$1$1); +-Document$1$1.registerProcessor(Processor$1$1); +-let Declaration$1$1 = declaration$1; +-let PreviousMap2$1 = previousMap$1; +-let Comment$1$1 = comment$1; +-let AtRule$1$1 = atRule$1; +-let Input$1$1 = input$1; +-let Root$1$1 = root$1; +-let Rule$1$1 = rule$1; +-function fromJSON$1$1(json, inputs) { +- if (Array.isArray(json)) return json.map((n2) => fromJSON$1$1(n2)); +- let { inputs: ownInputs, ...defaults } = json; +- if (ownInputs) { +- inputs = []; +- for (let input2 of ownInputs) { +- let inputHydrated = { ...input2, __proto__: Input$1$1.prototype }; +- if (inputHydrated.map) { +- inputHydrated.map = { +- ...inputHydrated.map, +- __proto__: PreviousMap2$1.prototype +- }; +- } +- inputs.push(inputHydrated); +- } +- } +- if (defaults.nodes) { +- defaults.nodes = json.nodes.map((n2) => fromJSON$1$1(n2, inputs)); +- } +- if (defaults.source) { +- let { inputId, ...source } = defaults.source; +- defaults.source = source; +- if (inputId != null) { +- defaults.source.input = inputs[inputId]; +- } +- } +- if (defaults.type === "root") { +- return new Root$1$1(defaults); +- } else if (defaults.type === "decl") { +- return new Declaration$1$1(defaults); +- } else if (defaults.type === "rule") { +- return new Rule$1$1(defaults); +- } else if (defaults.type === "comment") { +- return new Comment$1$1(defaults); +- } else if (defaults.type === "atrule") { +- return new AtRule$1$1(defaults); +- } else { +- throw new Error("Unknown node type: " + json.type); +- } +-} +-var fromJSON_1$1 = fromJSON$1$1; +-fromJSON$1$1.default = fromJSON$1$1; +-let CssSyntaxError2$1 = cssSyntaxError$1; +-let Declaration2$1 = declaration$1; +-let LazyResult2$1 = lazyResult$1; +-let Container2$1 = container$1; +-let Processor2$1 = processor$1; +-let stringify$5 = stringify_1$1; +-let fromJSON$2 = fromJSON_1$1; +-let Document22 = document$1$1; +-let Warning2$1 = warning$1; +-let Comment2$1 = comment$1; +-let AtRule2$1 = atRule$1; +-let Result2$1 = result$1; +-let Input2$1 = input$1; +-let parse$5 = parse_1$1; +-let list$3 = list_1$1; +-let Rule2$1 = rule$1; +-let Root2$1 = root$1; +-let Node2$1 = node$1; +-function postcss$3(...plugins) { +- if (plugins.length === 1 && Array.isArray(plugins[0])) { +- plugins = plugins[0]; +- } +- return new Processor2$1(plugins); +-} +-postcss$3.plugin = function plugin(name, initializer) { +- let warningPrinted = false; +- function creator(...args) { +- if (console && console.warn && !warningPrinted) { +- warningPrinted = true; +- console.warn( +- name + ": postcss.plugin was deprecated. Migration guide:\nhttps://evilmartians.com/chronicles/postcss-8-plugin-migration" +- ); +- if (process.env.LANG && process.env.LANG.startsWith("cn")) { +- console.warn( +- name + ": 里面 postcss.plugin 被弃用. 迁移指南:\nhttps://www.w3ctech.com/topic/2226" +- ); +- } +- } +- let transformer = initializer(...args); +- transformer.postcssPlugin = name; +- transformer.postcssVersion = new Processor2$1().version; +- return transformer; +- } +- let cache; +- Object.defineProperty(creator, "postcss", { +- get() { +- if (!cache) cache = creator(); +- return cache; +- } +- }); +- creator.process = function(css, processOpts, pluginOpts) { +- return postcss$3([creator(pluginOpts)]).process(css, processOpts); +- }; +- return creator; +-}; +-postcss$3.stringify = stringify$5; +-postcss$3.parse = parse$5; +-postcss$3.fromJSON = fromJSON$2; +-postcss$3.list = list$3; +-postcss$3.comment = (defaults) => new Comment2$1(defaults); +-postcss$3.atRule = (defaults) => new AtRule2$1(defaults); +-postcss$3.decl = (defaults) => new Declaration2$1(defaults); +-postcss$3.rule = (defaults) => new Rule2$1(defaults); +-postcss$3.root = (defaults) => new Root2$1(defaults); +-postcss$3.document = (defaults) => new Document22(defaults); +-postcss$3.CssSyntaxError = CssSyntaxError2$1; +-postcss$3.Declaration = Declaration2$1; +-postcss$3.Container = Container2$1; +-postcss$3.Processor = Processor2$1; +-postcss$3.Document = Document22; +-postcss$3.Comment = Comment2$1; +-postcss$3.Warning = Warning2$1; +-postcss$3.AtRule = AtRule2$1; +-postcss$3.Result = Result2$1; +-postcss$3.Input = Input2$1; +-postcss$3.Rule = Rule2$1; +-postcss$3.Root = Root2$1; +-postcss$3.Node = Node2$1; +-LazyResult2$1.registerPostcss(postcss$3); +-var postcss_1$1 = postcss$3; +-postcss$3.default = postcss$3; +-const postcss$1$1 = /* @__PURE__ */ getDefaultExportFromCjs$1(postcss_1$1); +-postcss$1$1.stringify; +-postcss$1$1.fromJSON; +-postcss$1$1.plugin; +-postcss$1$1.parse; +-postcss$1$1.list; +-postcss$1$1.document; +-postcss$1$1.comment; +-postcss$1$1.atRule; +-postcss$1$1.rule; +-postcss$1$1.decl; +-postcss$1$1.root; +-postcss$1$1.CssSyntaxError; +-postcss$1$1.Declaration; +-postcss$1$1.Container; +-postcss$1$1.Processor; +-postcss$1$1.Document; +-postcss$1$1.Comment; +-postcss$1$1.Warning; +-postcss$1$1.AtRule; +-postcss$1$1.Result; +-postcss$1$1.Input; +-postcss$1$1.Rule; +-postcss$1$1.Root; +-postcss$1$1.Node; +-var __defProp2 = Object.defineProperty; +-var __defNormalProp2 = (obj, key, value) => key in obj ? __defProp2(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value; +-var __publicField2 = (obj, key, value) => __defNormalProp2(obj, typeof key !== "symbol" ? key + "" : key, value); +-function getDefaultExportFromCjs(x2) { +- return x2 && x2.__esModule && Object.prototype.hasOwnProperty.call(x2, "default") ? x2["default"] : x2; +-} +-function getAugmentedNamespace(n2) { +- if (n2.__esModule) return n2; +- var f2 = n2.default; +- if (typeof f2 == "function") { +- var a2 = function a22() { +- if (this instanceof a22) { +- return Reflect.construct(f2, arguments, this.constructor); +- } +- return f2.apply(this, arguments); +- }; +- a2.prototype = f2.prototype; +- } else a2 = {}; +- Object.defineProperty(a2, "__esModule", { value: true }); +- Object.keys(n2).forEach(function(k) { +- var d = Object.getOwnPropertyDescriptor(n2, k); +- Object.defineProperty(a2, k, d.get ? d : { +- enumerable: true, +- get: function() { +- return n2[k]; +- } +- }); +- }); +- return a2; +-} +-var picocolors_browser = { exports: {} }; +-var x = String; +-var create = function() { +- return { isColorSupported: false, reset: x, bold: x, dim: x, italic: x, underline: x, inverse: x, hidden: x, strikethrough: x, black: x, red: x, green: x, yellow: x, blue: x, magenta: x, cyan: x, white: x, gray: x, bgBlack: x, bgRed: x, bgGreen: x, bgYellow: x, bgBlue: x, bgMagenta: x, bgCyan: x, bgWhite: x }; +-}; +-picocolors_browser.exports = create(); +-picocolors_browser.exports.createColors = create; +-var picocolors_browserExports = picocolors_browser.exports; +-const __viteBrowserExternal = {}; +-const __viteBrowserExternal$1 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({ +- __proto__: null, +- default: __viteBrowserExternal +-}, Symbol.toStringTag, { value: "Module" })); +-const require$$2 = /* @__PURE__ */ getAugmentedNamespace(__viteBrowserExternal$1); +-let pico = picocolors_browserExports; +-let terminalHighlight$1 = require$$2; +-let CssSyntaxError$3 = class CssSyntaxError2 extends Error { +- constructor(message, line, column, source, file, plugin22) { +- super(message); +- this.name = "CssSyntaxError"; +- this.reason = message; +- if (file) { +- this.file = file; +- } +- if (source) { +- this.source = source; +- } +- if (plugin22) { +- this.plugin = plugin22; +- } +- if (typeof line !== "undefined" && typeof column !== "undefined") { +- if (typeof line === "number") { +- this.line = line; +- this.column = column; +- } else { +- this.line = line.line; +- this.column = line.column; +- this.endLine = column.line; +- this.endColumn = column.column; +- } +- } +- this.setMessage(); +- if (Error.captureStackTrace) { +- Error.captureStackTrace(this, CssSyntaxError2); +- } +- } +- setMessage() { +- this.message = this.plugin ? this.plugin + ": " : ""; +- this.message += this.file ? this.file : ""; +- if (typeof this.line !== "undefined") { +- this.message += ":" + this.line + ":" + this.column; +- } +- this.message += ": " + this.reason; +- } +- showSourceCode(color) { +- if (!this.source) return ""; +- let css = this.source; +- if (color == null) color = pico.isColorSupported; +- if (terminalHighlight$1) { +- if (color) css = terminalHighlight$1(css); +- } +- let lines = css.split(/\r?\n/); +- let start = Math.max(this.line - 3, 0); +- let end = Math.min(this.line + 2, lines.length); +- let maxWidth = String(end).length; +- let mark, aside; +- if (color) { +- let { bold, gray, red } = pico.createColors(true); +- mark = (text) => bold(red(text)); +- aside = (text) => gray(text); +- } else { +- mark = aside = (str) => str; +- } +- return lines.slice(start, end).map((line, index2) => { +- let number = start + 1 + index2; +- let gutter = " " + (" " + number).slice(-maxWidth) + " | "; +- if (number === this.line) { +- let spacing = aside(gutter.replace(/\d/g, " ")) + line.slice(0, this.column - 1).replace(/[^\t]/g, " "); +- return mark(">") + aside(gutter) + line + "\n " + spacing + mark("^"); +- } +- return " " + aside(gutter) + line; +- }).join("\n"); +- } +- toString() { +- let code = this.showSourceCode(); +- if (code) { +- code = "\n\n" + code + "\n"; +- } +- return this.name + ": " + this.message + code; +- } +-}; +-var cssSyntaxError = CssSyntaxError$3; +-CssSyntaxError$3.default = CssSyntaxError$3; +-var symbols = {}; +-symbols.isClean = Symbol("isClean"); +-symbols.my = Symbol("my"); +-const DEFAULT_RAW = { +- after: "\n", +- beforeClose: "\n", +- beforeComment: "\n", +- beforeDecl: "\n", +- beforeOpen: " ", +- beforeRule: "\n", +- colon: ": ", +- commentLeft: " ", +- commentRight: " ", +- emptyBody: "", +- indent: " ", +- semicolon: false +-}; +-function capitalize(str) { +- return str[0].toUpperCase() + str.slice(1); +-} +-let Stringifier$2 = class Stringifier2 { +- constructor(builder) { +- this.builder = builder; +- } +- atrule(node2, semicolon) { +- let name = "@" + node2.name; +- let params = node2.params ? this.rawValue(node2, "params") : ""; +- if (typeof node2.raws.afterName !== "undefined") { +- name += node2.raws.afterName; +- } else if (params) { +- name += " "; +- } +- if (node2.nodes) { +- this.block(node2, name + params); +- } else { +- let end = (node2.raws.between || "") + (semicolon ? ";" : ""); +- this.builder(name + params + end, node2); +- } +- } +- beforeAfter(node2, detect) { +- let value; +- if (node2.type === "decl") { +- value = this.raw(node2, null, "beforeDecl"); +- } else if (node2.type === "comment") { +- value = this.raw(node2, null, "beforeComment"); +- } else if (detect === "before") { +- value = this.raw(node2, null, "beforeRule"); +- } else { +- value = this.raw(node2, null, "beforeClose"); +- } +- let buf = node2.parent; +- let depth = 0; +- while (buf && buf.type !== "root") { +- depth += 1; +- buf = buf.parent; +- } +- if (value.includes("\n")) { +- let indent = this.raw(node2, null, "indent"); +- if (indent.length) { +- for (let step = 0; step < depth; step++) value += indent; +- } +- } +- return value; +- } +- block(node2, start) { +- let between = this.raw(node2, "between", "beforeOpen"); +- this.builder(start + between + "{", node2, "start"); +- let after; +- if (node2.nodes && node2.nodes.length) { +- this.body(node2); +- after = this.raw(node2, "after"); +- } else { +- after = this.raw(node2, "after", "emptyBody"); +- } +- if (after) this.builder(after); +- this.builder("}", node2, "end"); +- } +- body(node2) { +- let last = node2.nodes.length - 1; +- while (last > 0) { +- if (node2.nodes[last].type !== "comment") break; +- last -= 1; +- } +- let semicolon = this.raw(node2, "semicolon"); +- for (let i2 = 0; i2 < node2.nodes.length; i2++) { +- let child = node2.nodes[i2]; +- let before = this.raw(child, "before"); +- if (before) this.builder(before); +- this.stringify(child, last !== i2 || semicolon); +- } +- } +- comment(node2) { +- let left = this.raw(node2, "left", "commentLeft"); +- let right = this.raw(node2, "right", "commentRight"); +- this.builder("/*" + left + node2.text + right + "*/", node2); +- } +- decl(node2, semicolon) { +- let between = this.raw(node2, "between", "colon"); +- let string = node2.prop + between + this.rawValue(node2, "value"); +- if (node2.important) { +- string += node2.raws.important || " !important"; +- } +- if (semicolon) string += ";"; +- this.builder(string, node2); +- } +- document(node2) { +- this.body(node2); +- } +- raw(node2, own, detect) { +- let value; +- if (!detect) detect = own; +- if (own) { +- value = node2.raws[own]; +- if (typeof value !== "undefined") return value; +- } +- let parent = node2.parent; +- if (detect === "before") { +- if (!parent || parent.type === "root" && parent.first === node2) { +- return ""; +- } +- if (parent && parent.type === "document") { +- return ""; +- } +- } +- if (!parent) return DEFAULT_RAW[detect]; +- let root2 = node2.root(); +- if (!root2.rawCache) root2.rawCache = {}; +- if (typeof root2.rawCache[detect] !== "undefined") { +- return root2.rawCache[detect]; +- } +- if (detect === "before" || detect === "after") { +- return this.beforeAfter(node2, detect); +- } else { +- let method = "raw" + capitalize(detect); +- if (this[method]) { +- value = this[method](root2, node2); +- } else { +- root2.walk((i2) => { +- value = i2.raws[own]; +- if (typeof value !== "undefined") return false; +- }); +- } +- } +- if (typeof value === "undefined") value = DEFAULT_RAW[detect]; +- root2.rawCache[detect] = value; +- return value; +- } +- rawBeforeClose(root2) { +- let value; +- root2.walk((i2) => { +- if (i2.nodes && i2.nodes.length > 0) { +- if (typeof i2.raws.after !== "undefined") { +- value = i2.raws.after; +- if (value.includes("\n")) { +- value = value.replace(/[^\n]+$/, ""); +- } +- return false; +- } +- } +- }); +- if (value) value = value.replace(/\S/g, ""); +- return value; +- } +- rawBeforeComment(root2, node2) { +- let value; +- root2.walkComments((i2) => { +- if (typeof i2.raws.before !== "undefined") { +- value = i2.raws.before; +- if (value.includes("\n")) { +- value = value.replace(/[^\n]+$/, ""); +- } +- return false; +- } +- }); +- if (typeof value === "undefined") { +- value = this.raw(node2, null, "beforeDecl"); +- } else if (value) { +- value = value.replace(/\S/g, ""); +- } +- return value; +- } +- rawBeforeDecl(root2, node2) { +- let value; +- root2.walkDecls((i2) => { +- if (typeof i2.raws.before !== "undefined") { +- value = i2.raws.before; +- if (value.includes("\n")) { +- value = value.replace(/[^\n]+$/, ""); +- } +- return false; +- } +- }); +- if (typeof value === "undefined") { +- value = this.raw(node2, null, "beforeRule"); +- } else if (value) { +- value = value.replace(/\S/g, ""); +- } +- return value; +- } +- rawBeforeOpen(root2) { +- let value; +- root2.walk((i2) => { +- if (i2.type !== "decl") { +- value = i2.raws.between; +- if (typeof value !== "undefined") return false; +- } +- }); +- return value; +- } +- rawBeforeRule(root2) { +- let value; +- root2.walk((i2) => { +- if (i2.nodes && (i2.parent !== root2 || root2.first !== i2)) { +- if (typeof i2.raws.before !== "undefined") { +- value = i2.raws.before; +- if (value.includes("\n")) { +- value = value.replace(/[^\n]+$/, ""); +- } +- return false; +- } +- } +- }); +- if (value) value = value.replace(/\S/g, ""); +- return value; +- } +- rawColon(root2) { +- let value; +- root2.walkDecls((i2) => { +- if (typeof i2.raws.between !== "undefined") { +- value = i2.raws.between.replace(/[^\s:]/g, ""); +- return false; +- } +- }); +- return value; +- } +- rawEmptyBody(root2) { +- let value; +- root2.walk((i2) => { +- if (i2.nodes && i2.nodes.length === 0) { +- value = i2.raws.after; +- if (typeof value !== "undefined") return false; +- } +- }); +- return value; +- } +- rawIndent(root2) { +- if (root2.raws.indent) return root2.raws.indent; +- let value; +- root2.walk((i2) => { +- let p = i2.parent; +- if (p && p !== root2 && p.parent && p.parent === root2) { +- if (typeof i2.raws.before !== "undefined") { +- let parts = i2.raws.before.split("\n"); +- value = parts[parts.length - 1]; +- value = value.replace(/\S/g, ""); +- return false; +- } +- } +- }); +- return value; +- } +- rawSemicolon(root2) { +- let value; +- root2.walk((i2) => { +- if (i2.nodes && i2.nodes.length && i2.last.type === "decl") { +- value = i2.raws.semicolon; +- if (typeof value !== "undefined") return false; +- } +- }); +- return value; +- } +- rawValue(node2, prop) { +- let value = node2[prop]; +- let raw = node2.raws[prop]; +- if (raw && raw.value === value) { +- return raw.raw; +- } +- return value; +- } +- root(node2) { +- this.body(node2); +- if (node2.raws.after) this.builder(node2.raws.after); +- } +- rule(node2) { +- this.block(node2, this.rawValue(node2, "selector")); +- if (node2.raws.ownSemicolon) { +- this.builder(node2.raws.ownSemicolon, node2, "end"); +- } +- } +- stringify(node2, semicolon) { +- if (!this[node2.type]) { +- throw new Error( +- "Unknown AST node type " + node2.type + ". Maybe you need to change PostCSS stringifier." +- ); +- } +- this[node2.type](node2, semicolon); +- } +-}; +-var stringifier = Stringifier$2; +-Stringifier$2.default = Stringifier$2; +-let Stringifier$1 = stringifier; +-function stringify$4(node2, builder) { +- let str = new Stringifier$1(builder); +- str.stringify(node2); +-} +-var stringify_1 = stringify$4; +-stringify$4.default = stringify$4; +-let { isClean: isClean$2, my: my$2 } = symbols; +-let CssSyntaxError$2 = cssSyntaxError; +-let Stringifier22 = stringifier; +-let stringify$3 = stringify_1; +-function cloneNode(obj, parent) { +- let cloned = new obj.constructor(); +- for (let i2 in obj) { +- if (!Object.prototype.hasOwnProperty.call(obj, i2)) { +- continue; +- } +- if (i2 === "proxyCache") continue; +- let value = obj[i2]; +- let type = typeof value; +- if (i2 === "parent" && type === "object") { +- if (parent) cloned[i2] = parent; +- } else if (i2 === "source") { +- cloned[i2] = value; +- } else if (Array.isArray(value)) { +- cloned[i2] = value.map((j) => cloneNode(j, cloned)); +- } else { +- if (type === "object" && value !== null) value = cloneNode(value); +- cloned[i2] = value; +- } +- } +- return cloned; +-} +-let Node$4 = class Node3 { +- constructor(defaults = {}) { +- this.raws = {}; +- this[isClean$2] = false; +- this[my$2] = true; +- for (let name in defaults) { +- if (name === "nodes") { +- this.nodes = []; +- for (let node2 of defaults[name]) { +- if (typeof node2.clone === "function") { +- this.append(node2.clone()); +- } else { +- this.append(node2); +- } +- } +- } else { +- this[name] = defaults[name]; +- } +- } +- } +- addToError(error) { +- error.postcssNode = this; +- if (error.stack && this.source && /\n\s{4}at /.test(error.stack)) { +- let s2 = this.source; +- error.stack = error.stack.replace( +- /\n\s{4}at /, +- `$&${s2.input.from}:${s2.start.line}:${s2.start.column}$&` +- ); +- } +- return error; +- } +- after(add) { +- this.parent.insertAfter(this, add); +- return this; +- } +- assign(overrides = {}) { +- for (let name in overrides) { +- this[name] = overrides[name]; +- } +- return this; +- } +- before(add) { +- this.parent.insertBefore(this, add); +- return this; +- } +- cleanRaws(keepBetween) { +- delete this.raws.before; +- delete this.raws.after; +- if (!keepBetween) delete this.raws.between; +- } +- clone(overrides = {}) { +- let cloned = cloneNode(this); +- for (let name in overrides) { +- cloned[name] = overrides[name]; +- } +- return cloned; +- } +- cloneAfter(overrides = {}) { +- let cloned = this.clone(overrides); +- this.parent.insertAfter(this, cloned); +- return cloned; +- } +- cloneBefore(overrides = {}) { +- let cloned = this.clone(overrides); +- this.parent.insertBefore(this, cloned); +- return cloned; +- } +- error(message, opts = {}) { +- if (this.source) { +- let { end, start } = this.rangeBy(opts); +- return this.source.input.error( +- message, +- { column: start.column, line: start.line }, +- { column: end.column, line: end.line }, +- opts +- ); +- } +- return new CssSyntaxError$2(message); +- } +- getProxyProcessor() { +- return { +- get(node2, prop) { +- if (prop === "proxyOf") { +- return node2; +- } else if (prop === "root") { +- return () => node2.root().toProxy(); +- } else { +- return node2[prop]; +- } +- }, +- set(node2, prop, value) { +- if (node2[prop] === value) return true; +- node2[prop] = value; +- if (prop === "prop" || prop === "value" || prop === "name" || prop === "params" || prop === "important" || /* c8 ignore next */ +- prop === "text") { +- node2.markDirty(); +- } +- return true; +- } +- }; +- } +- markDirty() { +- if (this[isClean$2]) { +- this[isClean$2] = false; +- let next = this; +- while (next = next.parent) { +- next[isClean$2] = false; +- } +- } +- } +- next() { +- if (!this.parent) return void 0; +- let index2 = this.parent.index(this); +- return this.parent.nodes[index2 + 1]; +- } +- positionBy(opts, stringRepresentation) { +- let pos = this.source.start; +- if (opts.index) { +- pos = this.positionInside(opts.index, stringRepresentation); +- } else if (opts.word) { +- stringRepresentation = this.toString(); +- let index2 = stringRepresentation.indexOf(opts.word); +- if (index2 !== -1) pos = this.positionInside(index2, stringRepresentation); +- } +- return pos; +- } +- positionInside(index2, stringRepresentation) { +- let string = stringRepresentation || this.toString(); +- let column = this.source.start.column; +- let line = this.source.start.line; +- for (let i2 = 0; i2 < index2; i2++) { +- if (string[i2] === "\n") { +- column = 1; +- line += 1; +- } else { +- column += 1; +- } +- } +- return { column, line }; +- } +- prev() { +- if (!this.parent) return void 0; +- let index2 = this.parent.index(this); +- return this.parent.nodes[index2 - 1]; +- } +- rangeBy(opts) { +- let start = { +- column: this.source.start.column, +- line: this.source.start.line +- }; +- let end = this.source.end ? { +- column: this.source.end.column + 1, +- line: this.source.end.line +- } : { +- column: start.column + 1, +- line: start.line +- }; +- if (opts.word) { +- let stringRepresentation = this.toString(); +- let index2 = stringRepresentation.indexOf(opts.word); +- if (index2 !== -1) { +- start = this.positionInside(index2, stringRepresentation); +- end = this.positionInside(index2 + opts.word.length, stringRepresentation); +- } +- } else { +- if (opts.start) { +- start = { +- column: opts.start.column, +- line: opts.start.line +- }; +- } else if (opts.index) { +- start = this.positionInside(opts.index); +- } +- if (opts.end) { +- end = { +- column: opts.end.column, +- line: opts.end.line +- }; +- } else if (typeof opts.endIndex === "number") { +- end = this.positionInside(opts.endIndex); +- } else if (opts.index) { +- end = this.positionInside(opts.index + 1); +- } +- } +- if (end.line < start.line || end.line === start.line && end.column <= start.column) { +- end = { column: start.column + 1, line: start.line }; +- } +- return { end, start }; +- } +- raw(prop, defaultType) { +- let str = new Stringifier22(); +- return str.raw(this, prop, defaultType); +- } +- remove() { +- if (this.parent) { +- this.parent.removeChild(this); +- } +- this.parent = void 0; +- return this; +- } +- replaceWith(...nodes) { +- if (this.parent) { +- let bookmark = this; +- let foundSelf = false; +- for (let node2 of nodes) { +- if (node2 === this) { +- foundSelf = true; +- } else if (foundSelf) { +- this.parent.insertAfter(bookmark, node2); +- bookmark = node2; +- } else { +- this.parent.insertBefore(bookmark, node2); +- } +- } +- if (!foundSelf) { +- this.remove(); +- } +- } +- return this; +- } +- root() { +- let result2 = this; +- while (result2.parent && result2.parent.type !== "document") { +- result2 = result2.parent; +- } +- return result2; +- } +- toJSON(_, inputs) { +- let fixed = {}; +- let emitInputs = inputs == null; +- inputs = inputs || /* @__PURE__ */ new Map(); +- let inputsNextIndex = 0; +- for (let name in this) { +- if (!Object.prototype.hasOwnProperty.call(this, name)) { +- continue; +- } +- if (name === "parent" || name === "proxyCache") continue; +- let value = this[name]; +- if (Array.isArray(value)) { +- fixed[name] = value.map((i2) => { +- if (typeof i2 === "object" && i2.toJSON) { +- return i2.toJSON(null, inputs); +- } else { +- return i2; +- } +- }); +- } else if (typeof value === "object" && value.toJSON) { +- fixed[name] = value.toJSON(null, inputs); +- } else if (name === "source") { +- let inputId = inputs.get(value.input); +- if (inputId == null) { +- inputId = inputsNextIndex; +- inputs.set(value.input, inputsNextIndex); +- inputsNextIndex++; +- } +- fixed[name] = { +- end: value.end, +- inputId, +- start: value.start +- }; +- } else { +- fixed[name] = value; +- } +- } +- if (emitInputs) { +- fixed.inputs = [...inputs.keys()].map((input2) => input2.toJSON()); +- } +- return fixed; +- } +- toProxy() { +- if (!this.proxyCache) { +- this.proxyCache = new Proxy(this, this.getProxyProcessor()); +- } +- return this.proxyCache; +- } +- toString(stringifier2 = stringify$3) { +- if (stringifier2.stringify) stringifier2 = stringifier2.stringify; +- let result2 = ""; +- stringifier2(this, (i2) => { +- result2 += i2; +- }); +- return result2; +- } +- warn(result2, text, opts) { +- let data = { node: this }; +- for (let i2 in opts) data[i2] = opts[i2]; +- return result2.warn(text, data); +- } +- get proxyOf() { +- return this; +- } +-}; +-var node = Node$4; +-Node$4.default = Node$4; +-let Node$3 = node; +-let Declaration$4 = class Declaration2 extends Node$3 { +- constructor(defaults) { +- if (defaults && typeof defaults.value !== "undefined" && typeof defaults.value !== "string") { +- defaults = { ...defaults, value: String(defaults.value) }; +- } +- super(defaults); +- this.type = "decl"; +- } +- get variable() { +- return this.prop.startsWith("--") || this.prop[0] === "$"; +- } +-}; +-var declaration = Declaration$4; +-Declaration$4.default = Declaration$4; +-let urlAlphabet = "useandom-26T198340PX75pxJACKVERYMINDBUSHWOLF_GQZbfghjklqvwyzrict"; +-let customAlphabet = (alphabet, defaultSize = 21) => { +- return (size = defaultSize) => { +- let id = ""; +- let i2 = size; +- while (i2--) { +- id += alphabet[Math.random() * alphabet.length | 0]; +- } +- return id; +- }; +-}; +-let nanoid$1 = (size = 21) => { +- let id = ""; +- let i2 = size; +- while (i2--) { +- id += urlAlphabet[Math.random() * 64 | 0]; +- } +- return id; +-}; +-var nonSecure = { nanoid: nanoid$1, customAlphabet }; +-let { SourceMapConsumer: SourceMapConsumer$2, SourceMapGenerator: SourceMapGenerator$2 } = require$$2; +-let { existsSync, readFileSync } = require$$2; +-let { dirname: dirname$1, join } = require$$2; +-function fromBase64(str) { +- if (Buffer) { +- return Buffer.from(str, "base64").toString(); +- } else { +- return window.atob(str); +- } +-} +-let PreviousMap$2 = class PreviousMap2 { +- constructor(css, opts) { +- if (opts.map === false) return; +- this.loadAnnotation(css); +- this.inline = this.startWith(this.annotation, "data:"); +- let prev = opts.map ? opts.map.prev : void 0; +- let text = this.loadMap(opts.from, prev); +- if (!this.mapFile && opts.from) { +- this.mapFile = opts.from; +- } +- if (this.mapFile) this.root = dirname$1(this.mapFile); +- if (text) this.text = text; +- } +- consumer() { +- if (!this.consumerCache) { +- this.consumerCache = new SourceMapConsumer$2(this.text); +- } +- return this.consumerCache; +- } +- decodeInline(text) { +- let baseCharsetUri = /^data:application\/json;charset=utf-?8;base64,/; +- let baseUri = /^data:application\/json;base64,/; +- let charsetUri = /^data:application\/json;charset=utf-?8,/; +- let uri = /^data:application\/json,/; +- if (charsetUri.test(text) || uri.test(text)) { +- return decodeURIComponent(text.substr(RegExp.lastMatch.length)); +- } +- if (baseCharsetUri.test(text) || baseUri.test(text)) { +- return fromBase64(text.substr(RegExp.lastMatch.length)); +- } +- let encoding = text.match(/data:application\/json;([^,]+),/)[1]; +- throw new Error("Unsupported source map encoding " + encoding); +- } +- getAnnotationURL(sourceMapString) { +- return sourceMapString.replace(/^\/\*\s*# sourceMappingURL=/, "").trim(); +- } +- isMap(map) { +- if (typeof map !== "object") return false; +- return typeof map.mappings === "string" || typeof map._mappings === "string" || Array.isArray(map.sections); +- } +- loadAnnotation(css) { +- let comments = css.match(/\/\*\s*# sourceMappingURL=/gm); +- if (!comments) return; +- let start = css.lastIndexOf(comments.pop()); +- let end = css.indexOf("*/", start); +- if (start > -1 && end > -1) { +- this.annotation = this.getAnnotationURL(css.substring(start, end)); +- } +- } +- loadFile(path) { +- this.root = dirname$1(path); +- if (existsSync(path)) { +- this.mapFile = path; +- return readFileSync(path, "utf-8").toString().trim(); +- } +- } +- loadMap(file, prev) { +- if (prev === false) return false; +- if (prev) { +- if (typeof prev === "string") { +- return prev; +- } else if (typeof prev === "function") { +- let prevPath = prev(file); +- if (prevPath) { +- let map = this.loadFile(prevPath); +- if (!map) { +- throw new Error( +- "Unable to load previous source map: " + prevPath.toString() +- ); +- } +- return map; +- } +- } else if (prev instanceof SourceMapConsumer$2) { +- return SourceMapGenerator$2.fromSourceMap(prev).toString(); +- } else if (prev instanceof SourceMapGenerator$2) { +- return prev.toString(); +- } else if (this.isMap(prev)) { +- return JSON.stringify(prev); +- } else { +- throw new Error( +- "Unsupported previous source map format: " + prev.toString() +- ); +- } +- } else if (this.inline) { +- return this.decodeInline(this.annotation); +- } else if (this.annotation) { +- let map = this.annotation; +- if (file) map = join(dirname$1(file), map); +- return this.loadFile(map); +- } +- } +- startWith(string, start) { +- if (!string) return false; +- return string.substr(0, start.length) === start; +- } +- withContent() { +- return !!(this.consumer().sourcesContent && this.consumer().sourcesContent.length > 0); +- } +-}; +-var previousMap = PreviousMap$2; +-PreviousMap$2.default = PreviousMap$2; +-let { SourceMapConsumer: SourceMapConsumer$1, SourceMapGenerator: SourceMapGenerator$1 } = require$$2; +-let { fileURLToPath, pathToFileURL: pathToFileURL$1 } = require$$2; +-let { isAbsolute, resolve: resolve$1 } = require$$2; +-let { nanoid } = nonSecure; +-let terminalHighlight = require$$2; +-let CssSyntaxError$1 = cssSyntaxError; +-let PreviousMap$1 = previousMap; +-let fromOffsetCache = Symbol("fromOffsetCache"); +-let sourceMapAvailable$1 = Boolean(SourceMapConsumer$1 && SourceMapGenerator$1); +-let pathAvailable$1 = Boolean(resolve$1 && isAbsolute); +-let Input$4 = class Input2 { +- constructor(css, opts = {}) { +- if (css === null || typeof css === "undefined" || typeof css === "object" && !css.toString) { +- throw new Error(`PostCSS received ${css} instead of CSS string`); +- } +- this.css = css.toString(); +- if (this.css[0] === "\uFEFF" || this.css[0] === "￾") { +- this.hasBOM = true; +- this.css = this.css.slice(1); +- } else { +- this.hasBOM = false; +- } +- if (opts.from) { +- if (!pathAvailable$1 || /^\w+:\/\//.test(opts.from) || isAbsolute(opts.from)) { +- this.file = opts.from; +- } else { +- this.file = resolve$1(opts.from); +- } +- } +- if (pathAvailable$1 && sourceMapAvailable$1) { +- let map = new PreviousMap$1(this.css, opts); +- if (map.text) { +- this.map = map; +- let file = map.consumer().file; +- if (!this.file && file) this.file = this.mapResolve(file); +- } +- } +- if (!this.file) { +- this.id = ""; +- } +- if (this.map) this.map.file = this.from; +- } +- error(message, line, column, opts = {}) { +- let result2, endLine, endColumn; +- if (line && typeof line === "object") { +- let start = line; +- let end = column; +- if (typeof start.offset === "number") { +- let pos = this.fromOffset(start.offset); +- line = pos.line; +- column = pos.col; +- } else { +- line = start.line; +- column = start.column; +- } +- if (typeof end.offset === "number") { +- let pos = this.fromOffset(end.offset); +- endLine = pos.line; +- endColumn = pos.col; +- } else { +- endLine = end.line; +- endColumn = end.column; +- } +- } else if (!column) { +- let pos = this.fromOffset(line); +- line = pos.line; +- column = pos.col; +- } +- let origin = this.origin(line, column, endLine, endColumn); +- if (origin) { +- result2 = new CssSyntaxError$1( +- message, +- origin.endLine === void 0 ? origin.line : { column: origin.column, line: origin.line }, +- origin.endLine === void 0 ? origin.column : { column: origin.endColumn, line: origin.endLine }, +- origin.source, +- origin.file, +- opts.plugin +- ); +- } else { +- result2 = new CssSyntaxError$1( +- message, +- endLine === void 0 ? line : { column, line }, +- endLine === void 0 ? column : { column: endColumn, line: endLine }, +- this.css, +- this.file, +- opts.plugin +- ); +- } +- result2.input = { column, endColumn, endLine, line, source: this.css }; +- if (this.file) { +- if (pathToFileURL$1) { +- result2.input.url = pathToFileURL$1(this.file).toString(); +- } +- result2.input.file = this.file; +- } +- return result2; +- } +- fromOffset(offset) { +- let lastLine, lineToIndex; +- if (!this[fromOffsetCache]) { +- let lines = this.css.split("\n"); +- lineToIndex = new Array(lines.length); +- let prevIndex = 0; +- for (let i2 = 0, l2 = lines.length; i2 < l2; i2++) { +- lineToIndex[i2] = prevIndex; +- prevIndex += lines[i2].length + 1; +- } +- this[fromOffsetCache] = lineToIndex; +- } else { +- lineToIndex = this[fromOffsetCache]; +- } +- lastLine = lineToIndex[lineToIndex.length - 1]; +- let min = 0; +- if (offset >= lastLine) { +- min = lineToIndex.length - 1; +- } else { +- let max = lineToIndex.length - 2; +- let mid; +- while (min < max) { +- mid = min + (max - min >> 1); +- if (offset < lineToIndex[mid]) { +- max = mid - 1; +- } else if (offset >= lineToIndex[mid + 1]) { +- min = mid + 1; +- } else { +- min = mid; +- break; +- } +- } +- } +- return { +- col: offset - lineToIndex[min] + 1, +- line: min + 1 +- }; +- } +- mapResolve(file) { +- if (/^\w+:\/\//.test(file)) { +- return file; +- } +- return resolve$1(this.map.consumer().sourceRoot || this.map.root || ".", file); +- } +- origin(line, column, endLine, endColumn) { +- if (!this.map) return false; +- let consumer = this.map.consumer(); +- let from = consumer.originalPositionFor({ column, line }); +- if (!from.source) return false; +- let to; +- if (typeof endLine === "number") { +- to = consumer.originalPositionFor({ column: endColumn, line: endLine }); +- } +- let fromUrl; +- if (isAbsolute(from.source)) { +- fromUrl = pathToFileURL$1(from.source); +- } else { +- fromUrl = new URL( +- from.source, +- this.map.consumer().sourceRoot || pathToFileURL$1(this.map.mapFile) +- ); +- } +- let result2 = { +- column: from.column, +- endColumn: to && to.column, +- endLine: to && to.line, +- line: from.line, +- url: fromUrl.toString() +- }; +- if (fromUrl.protocol === "file:") { +- if (fileURLToPath) { +- result2.file = fileURLToPath(fromUrl); +- } else { +- throw new Error(`file: protocol is not available in this PostCSS build`); +- } +- } +- let source = consumer.sourceContentFor(from.source); +- if (source) result2.source = source; +- return result2; +- } +- toJSON() { +- let json = {}; +- for (let name of ["hasBOM", "css", "file", "id"]) { +- if (this[name] != null) { +- json[name] = this[name]; +- } +- } +- if (this.map) { +- json.map = { ...this.map }; +- if (json.map.consumerCache) { +- json.map.consumerCache = void 0; +- } +- } +- return json; +- } +- get from() { +- return this.file || this.id; +- } +-}; +-var input = Input$4; +-Input$4.default = Input$4; +-if (terminalHighlight && terminalHighlight.registerInput) { +- terminalHighlight.registerInput(Input$4); +-} +-let { SourceMapConsumer, SourceMapGenerator } = require$$2; +-let { dirname, relative, resolve, sep } = require$$2; +-let { pathToFileURL } = require$$2; +-let Input$3 = input; +-let sourceMapAvailable = Boolean(SourceMapConsumer && SourceMapGenerator); +-let pathAvailable = Boolean(dirname && resolve && relative && sep); +-let MapGenerator$2 = class MapGenerator2 { +- constructor(stringify2, root2, opts, cssString) { +- this.stringify = stringify2; +- this.mapOpts = opts.map || {}; +- this.root = root2; +- this.opts = opts; +- this.css = cssString; +- this.originalCSS = cssString; +- this.usesFileUrls = !this.mapOpts.from && this.mapOpts.absolute; +- this.memoizedFileURLs = /* @__PURE__ */ new Map(); +- this.memoizedPaths = /* @__PURE__ */ new Map(); +- this.memoizedURLs = /* @__PURE__ */ new Map(); +- } +- addAnnotation() { +- let content; +- if (this.isInline()) { +- content = "data:application/json;base64," + this.toBase64(this.map.toString()); +- } else if (typeof this.mapOpts.annotation === "string") { +- content = this.mapOpts.annotation; +- } else if (typeof this.mapOpts.annotation === "function") { +- content = this.mapOpts.annotation(this.opts.to, this.root); +- } else { +- content = this.outputFile() + ".map"; +- } +- let eol = "\n"; +- if (this.css.includes("\r\n")) eol = "\r\n"; +- this.css += eol + "/*# sourceMappingURL=" + content + " */"; +- } +- applyPrevMaps() { +- for (let prev of this.previous()) { +- let from = this.toUrl(this.path(prev.file)); +- let root2 = prev.root || dirname(prev.file); +- let map; +- if (this.mapOpts.sourcesContent === false) { +- map = new SourceMapConsumer(prev.text); +- if (map.sourcesContent) { +- map.sourcesContent = null; +- } +- } else { +- map = prev.consumer(); +- } +- this.map.applySourceMap(map, from, this.toUrl(this.path(root2))); +- } +- } +- clearAnnotation() { +- if (this.mapOpts.annotation === false) return; +- if (this.root) { +- let node2; +- for (let i2 = this.root.nodes.length - 1; i2 >= 0; i2--) { +- node2 = this.root.nodes[i2]; +- if (node2.type !== "comment") continue; +- if (node2.text.indexOf("# sourceMappingURL=") === 0) { +- this.root.removeChild(i2); +- } +- } +- } else if (this.css) { +- this.css = this.css.replace(/\n*?\/\*#[\S\s]*?\*\/$/gm, ""); +- } +- } +- generate() { +- this.clearAnnotation(); +- if (pathAvailable && sourceMapAvailable && this.isMap()) { +- return this.generateMap(); +- } else { +- let result2 = ""; +- this.stringify(this.root, (i2) => { +- result2 += i2; +- }); +- return [result2]; +- } +- } +- generateMap() { +- if (this.root) { +- this.generateString(); +- } else if (this.previous().length === 1) { +- let prev = this.previous()[0].consumer(); +- prev.file = this.outputFile(); +- this.map = SourceMapGenerator.fromSourceMap(prev, { +- ignoreInvalidMapping: true +- }); +- } else { +- this.map = new SourceMapGenerator({ +- file: this.outputFile(), +- ignoreInvalidMapping: true +- }); +- this.map.addMapping({ +- generated: { column: 0, line: 1 }, +- original: { column: 0, line: 1 }, +- source: this.opts.from ? this.toUrl(this.path(this.opts.from)) : "" +- }); +- } +- if (this.isSourcesContent()) this.setSourcesContent(); +- if (this.root && this.previous().length > 0) this.applyPrevMaps(); +- if (this.isAnnotation()) this.addAnnotation(); +- if (this.isInline()) { +- return [this.css]; +- } else { +- return [this.css, this.map]; +- } +- } +- generateString() { +- this.css = ""; +- this.map = new SourceMapGenerator({ +- file: this.outputFile(), +- ignoreInvalidMapping: true +- }); +- let line = 1; +- let column = 1; +- let noSource = ""; +- let mapping = { +- generated: { column: 0, line: 0 }, +- original: { column: 0, line: 0 }, +- source: "" +- }; +- let lines, last; +- this.stringify(this.root, (str, node2, type) => { +- this.css += str; +- if (node2 && type !== "end") { +- mapping.generated.line = line; +- mapping.generated.column = column - 1; +- if (node2.source && node2.source.start) { +- mapping.source = this.sourcePath(node2); +- mapping.original.line = node2.source.start.line; +- mapping.original.column = node2.source.start.column - 1; +- this.map.addMapping(mapping); +- } else { +- mapping.source = noSource; +- mapping.original.line = 1; +- mapping.original.column = 0; +- this.map.addMapping(mapping); +- } +- } +- lines = str.match(/\n/g); +- if (lines) { +- line += lines.length; +- last = str.lastIndexOf("\n"); +- column = str.length - last; +- } else { +- column += str.length; +- } +- if (node2 && type !== "start") { +- let p = node2.parent || { raws: {} }; +- let childless = node2.type === "decl" || node2.type === "atrule" && !node2.nodes; +- if (!childless || node2 !== p.last || p.raws.semicolon) { +- if (node2.source && node2.source.end) { +- mapping.source = this.sourcePath(node2); +- mapping.original.line = node2.source.end.line; +- mapping.original.column = node2.source.end.column - 1; +- mapping.generated.line = line; +- mapping.generated.column = column - 2; +- this.map.addMapping(mapping); +- } else { +- mapping.source = noSource; +- mapping.original.line = 1; +- mapping.original.column = 0; +- mapping.generated.line = line; +- mapping.generated.column = column - 1; +- this.map.addMapping(mapping); +- } +- } +- } +- }); +- } +- isAnnotation() { +- if (this.isInline()) { +- return true; +- } +- if (typeof this.mapOpts.annotation !== "undefined") { +- return this.mapOpts.annotation; +- } +- if (this.previous().length) { +- return this.previous().some((i2) => i2.annotation); +- } +- return true; +- } +- isInline() { +- if (typeof this.mapOpts.inline !== "undefined") { +- return this.mapOpts.inline; +- } +- let annotation = this.mapOpts.annotation; +- if (typeof annotation !== "undefined" && annotation !== true) { +- return false; +- } +- if (this.previous().length) { +- return this.previous().some((i2) => i2.inline); +- } +- return true; +- } +- isMap() { +- if (typeof this.opts.map !== "undefined") { +- return !!this.opts.map; +- } +- return this.previous().length > 0; +- } +- isSourcesContent() { +- if (typeof this.mapOpts.sourcesContent !== "undefined") { +- return this.mapOpts.sourcesContent; +- } +- if (this.previous().length) { +- return this.previous().some((i2) => i2.withContent()); +- } +- return true; +- } +- outputFile() { +- if (this.opts.to) { +- return this.path(this.opts.to); +- } else if (this.opts.from) { +- return this.path(this.opts.from); +- } else { +- return "to.css"; +- } +- } +- path(file) { +- if (this.mapOpts.absolute) return file; +- if (file.charCodeAt(0) === 60) return file; +- if (/^\w+:\/\//.test(file)) return file; +- let cached = this.memoizedPaths.get(file); +- if (cached) return cached; +- let from = this.opts.to ? dirname(this.opts.to) : "."; +- if (typeof this.mapOpts.annotation === "string") { +- from = dirname(resolve(from, this.mapOpts.annotation)); +- } +- let path = relative(from, file); +- this.memoizedPaths.set(file, path); +- return path; +- } +- previous() { +- if (!this.previousMaps) { +- this.previousMaps = []; +- if (this.root) { +- this.root.walk((node2) => { +- if (node2.source && node2.source.input.map) { +- let map = node2.source.input.map; +- if (!this.previousMaps.includes(map)) { +- this.previousMaps.push(map); +- } +- } +- }); +- } else { +- let input2 = new Input$3(this.originalCSS, this.opts); +- if (input2.map) this.previousMaps.push(input2.map); +- } +- } +- return this.previousMaps; +- } +- setSourcesContent() { +- let already = {}; +- if (this.root) { +- this.root.walk((node2) => { +- if (node2.source) { +- let from = node2.source.input.from; +- if (from && !already[from]) { +- already[from] = true; +- let fromUrl = this.usesFileUrls ? this.toFileUrl(from) : this.toUrl(this.path(from)); +- this.map.setSourceContent(fromUrl, node2.source.input.css); +- } +- } +- }); +- } else if (this.css) { +- let from = this.opts.from ? this.toUrl(this.path(this.opts.from)) : ""; +- this.map.setSourceContent(from, this.css); +- } +- } +- sourcePath(node2) { +- if (this.mapOpts.from) { +- return this.toUrl(this.mapOpts.from); +- } else if (this.usesFileUrls) { +- return this.toFileUrl(node2.source.input.from); +- } else { +- return this.toUrl(this.path(node2.source.input.from)); +- } +- } +- toBase64(str) { +- if (Buffer) { +- return Buffer.from(str).toString("base64"); +- } else { +- return window.btoa(unescape(encodeURIComponent(str))); +- } +- } +- toFileUrl(path) { +- let cached = this.memoizedFileURLs.get(path); +- if (cached) return cached; +- if (pathToFileURL) { +- let fileURL = pathToFileURL(path).toString(); +- this.memoizedFileURLs.set(path, fileURL); +- return fileURL; +- } else { +- throw new Error( +- "`map.absolute` option is not available in this PostCSS build" +- ); +- } +- } +- toUrl(path) { +- let cached = this.memoizedURLs.get(path); +- if (cached) return cached; +- if (sep === "\\") { +- path = path.replace(/\\/g, "/"); +- } +- let url = encodeURI(path).replace(/[#?]/g, encodeURIComponent); +- this.memoizedURLs.set(path, url); +- return url; +- } +-}; +-var mapGenerator = MapGenerator$2; +-let Node$2 = node; +-let Comment$4 = class Comment2 extends Node$2 { +- constructor(defaults) { +- super(defaults); +- this.type = "comment"; +- } +-}; +-var comment = Comment$4; +-Comment$4.default = Comment$4; +-let { isClean: isClean$1, my: my$1 } = symbols; +-let Declaration$3 = declaration; +-let Comment$3 = comment; +-let Node$1 = node; +-let parse$4, Rule$4, AtRule$4, Root$6; +-function cleanSource(nodes) { +- return nodes.map((i2) => { +- if (i2.nodes) i2.nodes = cleanSource(i2.nodes); +- delete i2.source; +- return i2; +- }); +-} +-function markDirtyUp(node2) { +- node2[isClean$1] = false; +- if (node2.proxyOf.nodes) { +- for (let i2 of node2.proxyOf.nodes) { +- markDirtyUp(i2); +- } +- } +-} +-let Container$7 = class Container2 extends Node$1 { +- append(...children) { +- for (let child of children) { +- let nodes = this.normalize(child, this.last); +- for (let node2 of nodes) this.proxyOf.nodes.push(node2); +- } +- this.markDirty(); +- return this; +- } +- cleanRaws(keepBetween) { +- super.cleanRaws(keepBetween); +- if (this.nodes) { +- for (let node2 of this.nodes) node2.cleanRaws(keepBetween); +- } +- } +- each(callback) { +- if (!this.proxyOf.nodes) return void 0; +- let iterator = this.getIterator(); +- let index2, result2; +- while (this.indexes[iterator] < this.proxyOf.nodes.length) { +- index2 = this.indexes[iterator]; +- result2 = callback(this.proxyOf.nodes[index2], index2); +- if (result2 === false) break; +- this.indexes[iterator] += 1; +- } +- delete this.indexes[iterator]; +- return result2; +- } +- every(condition) { +- return this.nodes.every(condition); +- } +- getIterator() { +- if (!this.lastEach) this.lastEach = 0; +- if (!this.indexes) this.indexes = {}; +- this.lastEach += 1; +- let iterator = this.lastEach; +- this.indexes[iterator] = 0; +- return iterator; +- } +- getProxyProcessor() { +- return { +- get(node2, prop) { +- if (prop === "proxyOf") { +- return node2; +- } else if (!node2[prop]) { +- return node2[prop]; +- } else if (prop === "each" || typeof prop === "string" && prop.startsWith("walk")) { +- return (...args) => { +- return node2[prop]( +- ...args.map((i2) => { +- if (typeof i2 === "function") { +- return (child, index2) => i2(child.toProxy(), index2); +- } else { +- return i2; +- } +- }) +- ); +- }; +- } else if (prop === "every" || prop === "some") { +- return (cb) => { +- return node2[prop]( +- (child, ...other) => cb(child.toProxy(), ...other) +- ); +- }; +- } else if (prop === "root") { +- return () => node2.root().toProxy(); +- } else if (prop === "nodes") { +- return node2.nodes.map((i2) => i2.toProxy()); +- } else if (prop === "first" || prop === "last") { +- return node2[prop].toProxy(); +- } else { +- return node2[prop]; +- } +- }, +- set(node2, prop, value) { +- if (node2[prop] === value) return true; +- node2[prop] = value; +- if (prop === "name" || prop === "params" || prop === "selector") { +- node2.markDirty(); +- } +- return true; +- } +- }; +- } +- index(child) { +- if (typeof child === "number") return child; +- if (child.proxyOf) child = child.proxyOf; +- return this.proxyOf.nodes.indexOf(child); +- } +- insertAfter(exist, add) { +- let existIndex = this.index(exist); +- let nodes = this.normalize(add, this.proxyOf.nodes[existIndex]).reverse(); +- existIndex = this.index(exist); +- for (let node2 of nodes) this.proxyOf.nodes.splice(existIndex + 1, 0, node2); +- let index2; +- for (let id in this.indexes) { +- index2 = this.indexes[id]; +- if (existIndex < index2) { +- this.indexes[id] = index2 + nodes.length; +- } +- } +- this.markDirty(); +- return this; +- } +- insertBefore(exist, add) { +- let existIndex = this.index(exist); +- let type = existIndex === 0 ? "prepend" : false; +- let nodes = this.normalize(add, this.proxyOf.nodes[existIndex], type).reverse(); +- existIndex = this.index(exist); +- for (let node2 of nodes) this.proxyOf.nodes.splice(existIndex, 0, node2); +- let index2; +- for (let id in this.indexes) { +- index2 = this.indexes[id]; +- if (existIndex <= index2) { +- this.indexes[id] = index2 + nodes.length; +- } +- } +- this.markDirty(); +- return this; +- } +- normalize(nodes, sample) { +- if (typeof nodes === "string") { +- nodes = cleanSource(parse$4(nodes).nodes); +- } else if (typeof nodes === "undefined") { +- nodes = []; +- } else if (Array.isArray(nodes)) { +- nodes = nodes.slice(0); +- for (let i2 of nodes) { +- if (i2.parent) i2.parent.removeChild(i2, "ignore"); +- } +- } else if (nodes.type === "root" && this.type !== "document") { +- nodes = nodes.nodes.slice(0); +- for (let i2 of nodes) { +- if (i2.parent) i2.parent.removeChild(i2, "ignore"); +- } +- } else if (nodes.type) { +- nodes = [nodes]; +- } else if (nodes.prop) { +- if (typeof nodes.value === "undefined") { +- throw new Error("Value field is missed in node creation"); +- } else if (typeof nodes.value !== "string") { +- nodes.value = String(nodes.value); +- } +- nodes = [new Declaration$3(nodes)]; +- } else if (nodes.selector) { +- nodes = [new Rule$4(nodes)]; +- } else if (nodes.name) { +- nodes = [new AtRule$4(nodes)]; +- } else if (nodes.text) { +- nodes = [new Comment$3(nodes)]; +- } else { +- throw new Error("Unknown node type in node creation"); +- } +- let processed = nodes.map((i2) => { +- if (!i2[my$1]) Container2.rebuild(i2); +- i2 = i2.proxyOf; +- if (i2.parent) i2.parent.removeChild(i2); +- if (i2[isClean$1]) markDirtyUp(i2); +- if (typeof i2.raws.before === "undefined") { +- if (sample && typeof sample.raws.before !== "undefined") { +- i2.raws.before = sample.raws.before.replace(/\S/g, ""); +- } +- } +- i2.parent = this.proxyOf; +- return i2; +- }); +- return processed; +- } +- prepend(...children) { +- children = children.reverse(); +- for (let child of children) { +- let nodes = this.normalize(child, this.first, "prepend").reverse(); +- for (let node2 of nodes) this.proxyOf.nodes.unshift(node2); +- for (let id in this.indexes) { +- this.indexes[id] = this.indexes[id] + nodes.length; +- } +- } +- this.markDirty(); +- return this; +- } +- push(child) { +- child.parent = this; +- this.proxyOf.nodes.push(child); +- return this; +- } +- removeAll() { +- for (let node2 of this.proxyOf.nodes) node2.parent = void 0; +- this.proxyOf.nodes = []; +- this.markDirty(); +- return this; +- } +- removeChild(child) { +- child = this.index(child); +- this.proxyOf.nodes[child].parent = void 0; +- this.proxyOf.nodes.splice(child, 1); +- let index2; +- for (let id in this.indexes) { +- index2 = this.indexes[id]; +- if (index2 >= child) { +- this.indexes[id] = index2 - 1; +- } +- } +- this.markDirty(); +- return this; +- } +- replaceValues(pattern, opts, callback) { +- if (!callback) { +- callback = opts; +- opts = {}; +- } +- this.walkDecls((decl) => { +- if (opts.props && !opts.props.includes(decl.prop)) return; +- if (opts.fast && !decl.value.includes(opts.fast)) return; +- decl.value = decl.value.replace(pattern, callback); +- }); +- this.markDirty(); +- return this; +- } +- some(condition) { +- return this.nodes.some(condition); +- } +- walk(callback) { +- return this.each((child, i2) => { +- let result2; +- try { +- result2 = callback(child, i2); +- } catch (e2) { +- throw child.addToError(e2); +- } +- if (result2 !== false && child.walk) { +- result2 = child.walk(callback); +- } +- return result2; +- }); +- } +- walkAtRules(name, callback) { +- if (!callback) { +- callback = name; +- return this.walk((child, i2) => { +- if (child.type === "atrule") { +- return callback(child, i2); +- } +- }); +- } +- if (name instanceof RegExp) { +- return this.walk((child, i2) => { +- if (child.type === "atrule" && name.test(child.name)) { +- return callback(child, i2); +- } +- }); +- } +- return this.walk((child, i2) => { +- if (child.type === "atrule" && child.name === name) { +- return callback(child, i2); +- } +- }); +- } +- walkComments(callback) { +- return this.walk((child, i2) => { +- if (child.type === "comment") { +- return callback(child, i2); +- } +- }); +- } +- walkDecls(prop, callback) { +- if (!callback) { +- callback = prop; +- return this.walk((child, i2) => { +- if (child.type === "decl") { +- return callback(child, i2); +- } +- }); +- } +- if (prop instanceof RegExp) { +- return this.walk((child, i2) => { +- if (child.type === "decl" && prop.test(child.prop)) { +- return callback(child, i2); +- } +- }); +- } +- return this.walk((child, i2) => { +- if (child.type === "decl" && child.prop === prop) { +- return callback(child, i2); +- } +- }); +- } +- walkRules(selector, callback) { +- if (!callback) { +- callback = selector; +- return this.walk((child, i2) => { +- if (child.type === "rule") { +- return callback(child, i2); +- } +- }); +- } +- if (selector instanceof RegExp) { +- return this.walk((child, i2) => { +- if (child.type === "rule" && selector.test(child.selector)) { +- return callback(child, i2); +- } +- }); +- } +- return this.walk((child, i2) => { +- if (child.type === "rule" && child.selector === selector) { +- return callback(child, i2); +- } +- }); +- } +- get first() { +- if (!this.proxyOf.nodes) return void 0; +- return this.proxyOf.nodes[0]; +- } +- get last() { +- if (!this.proxyOf.nodes) return void 0; +- return this.proxyOf.nodes[this.proxyOf.nodes.length - 1]; +- } +-}; +-Container$7.registerParse = (dependant) => { +- parse$4 = dependant; +-}; +-Container$7.registerRule = (dependant) => { +- Rule$4 = dependant; +-}; +-Container$7.registerAtRule = (dependant) => { +- AtRule$4 = dependant; +-}; +-Container$7.registerRoot = (dependant) => { +- Root$6 = dependant; +-}; +-var container = Container$7; +-Container$7.default = Container$7; +-Container$7.rebuild = (node2) => { +- if (node2.type === "atrule") { +- Object.setPrototypeOf(node2, AtRule$4.prototype); +- } else if (node2.type === "rule") { +- Object.setPrototypeOf(node2, Rule$4.prototype); +- } else if (node2.type === "decl") { +- Object.setPrototypeOf(node2, Declaration$3.prototype); +- } else if (node2.type === "comment") { +- Object.setPrototypeOf(node2, Comment$3.prototype); +- } else if (node2.type === "root") { +- Object.setPrototypeOf(node2, Root$6.prototype); +- } +- node2[my$1] = true; +- if (node2.nodes) { +- node2.nodes.forEach((child) => { +- Container$7.rebuild(child); +- }); +- } +-}; +-let Container$6 = container; +-let LazyResult$4, Processor$3; +-let Document$3 = class Document23 extends Container$6 { +- constructor(defaults) { +- super({ type: "document", ...defaults }); +- if (!this.nodes) { +- this.nodes = []; +- } +- } +- toResult(opts = {}) { +- let lazy = new LazyResult$4(new Processor$3(), this, opts); +- return lazy.stringify(); +- } +-}; +-Document$3.registerLazyResult = (dependant) => { +- LazyResult$4 = dependant; +-}; +-Document$3.registerProcessor = (dependant) => { +- Processor$3 = dependant; +-}; +-var document$1 = Document$3; +-Document$3.default = Document$3; +-let printed = {}; +-var warnOnce$2 = function warnOnce2(message) { +- if (printed[message]) return; +- printed[message] = true; +- if (typeof console !== "undefined" && console.warn) { +- console.warn(message); +- } +-}; +-let Warning$2 = class Warning2 { +- constructor(text, opts = {}) { +- this.type = "warning"; +- this.text = text; +- if (opts.node && opts.node.source) { +- let range = opts.node.rangeBy(opts); +- this.line = range.start.line; +- this.column = range.start.column; +- this.endLine = range.end.line; +- this.endColumn = range.end.column; +- } +- for (let opt in opts) this[opt] = opts[opt]; +- } +- toString() { +- if (this.node) { +- return this.node.error(this.text, { +- index: this.index, +- plugin: this.plugin, +- word: this.word +- }).message; +- } +- if (this.plugin) { +- return this.plugin + ": " + this.text; +- } +- return this.text; +- } +-}; +-var warning = Warning$2; +-Warning$2.default = Warning$2; +-let Warning$1 = warning; +-let Result$3 = class Result2 { +- constructor(processor2, root2, opts) { +- this.processor = processor2; +- this.messages = []; +- this.root = root2; +- this.opts = opts; +- this.css = void 0; +- this.map = void 0; +- } +- toString() { +- return this.css; +- } +- warn(text, opts = {}) { +- if (!opts.plugin) { +- if (this.lastPlugin && this.lastPlugin.postcssPlugin) { +- opts.plugin = this.lastPlugin.postcssPlugin; +- } +- } +- let warning2 = new Warning$1(text, opts); +- this.messages.push(warning2); +- return warning2; +- } +- warnings() { +- return this.messages.filter((i2) => i2.type === "warning"); +- } +- get content() { +- return this.css; +- } +-}; +-var result = Result$3; +-Result$3.default = Result$3; +-const SINGLE_QUOTE = "'".charCodeAt(0); +-const DOUBLE_QUOTE = '"'.charCodeAt(0); +-const BACKSLASH = "\\".charCodeAt(0); +-const SLASH = "/".charCodeAt(0); +-const NEWLINE = "\n".charCodeAt(0); +-const SPACE = " ".charCodeAt(0); +-const FEED = "\f".charCodeAt(0); +-const TAB = " ".charCodeAt(0); +-const CR = "\r".charCodeAt(0); +-const OPEN_SQUARE = "[".charCodeAt(0); +-const CLOSE_SQUARE = "]".charCodeAt(0); +-const OPEN_PARENTHESES = "(".charCodeAt(0); +-const CLOSE_PARENTHESES = ")".charCodeAt(0); +-const OPEN_CURLY = "{".charCodeAt(0); +-const CLOSE_CURLY = "}".charCodeAt(0); +-const SEMICOLON = ";".charCodeAt(0); +-const ASTERISK = "*".charCodeAt(0); +-const COLON = ":".charCodeAt(0); +-const AT = "@".charCodeAt(0); +-const RE_AT_END = /[\t\n\f\r "#'()/;[\\\]{}]/g; +-const RE_WORD_END = /[\t\n\f\r !"#'():;@[\\\]{}]|\/(?=\*)/g; +-const RE_BAD_BRACKET = /.[\r\n"'(/\\]/; +-const RE_HEX_ESCAPE = /[\da-f]/i; +-var tokenize = function tokenizer2(input2, options = {}) { +- let css = input2.css.valueOf(); +- let ignore = options.ignoreErrors; +- let code, next, quote, content, escape; +- let escaped, escapePos, prev, n2, currentToken; +- let length = css.length; +- let pos = 0; +- let buffer = []; +- let returned = []; +- function position() { +- return pos; +- } +- function unclosed(what) { +- throw input2.error("Unclosed " + what, pos); +- } +- function endOfFile() { +- return returned.length === 0 && pos >= length; +- } +- function nextToken(opts) { +- if (returned.length) return returned.pop(); +- if (pos >= length) return; +- let ignoreUnclosed = opts ? opts.ignoreUnclosed : false; +- code = css.charCodeAt(pos); +- switch (code) { +- case NEWLINE: +- case SPACE: +- case TAB: +- case CR: +- case FEED: { +- next = pos; +- do { +- next += 1; +- code = css.charCodeAt(next); +- } while (code === SPACE || code === NEWLINE || code === TAB || code === CR || code === FEED); +- currentToken = ["space", css.slice(pos, next)]; +- pos = next - 1; +- break; +- } +- case OPEN_SQUARE: +- case CLOSE_SQUARE: +- case OPEN_CURLY: +- case CLOSE_CURLY: +- case COLON: +- case SEMICOLON: +- case CLOSE_PARENTHESES: { +- let controlChar = String.fromCharCode(code); +- currentToken = [controlChar, controlChar, pos]; +- break; +- } +- case OPEN_PARENTHESES: { +- prev = buffer.length ? buffer.pop()[1] : ""; +- n2 = css.charCodeAt(pos + 1); +- if (prev === "url" && n2 !== SINGLE_QUOTE && n2 !== DOUBLE_QUOTE && n2 !== SPACE && n2 !== NEWLINE && n2 !== TAB && n2 !== FEED && n2 !== CR) { +- next = pos; +- do { +- escaped = false; +- next = css.indexOf(")", next + 1); +- if (next === -1) { +- if (ignore || ignoreUnclosed) { +- next = pos; +- break; +- } else { +- unclosed("bracket"); +- } +- } +- escapePos = next; +- while (css.charCodeAt(escapePos - 1) === BACKSLASH) { +- escapePos -= 1; +- escaped = !escaped; +- } +- } while (escaped); +- currentToken = ["brackets", css.slice(pos, next + 1), pos, next]; +- pos = next; +- } else { +- next = css.indexOf(")", pos + 1); +- content = css.slice(pos, next + 1); +- if (next === -1 || RE_BAD_BRACKET.test(content)) { +- currentToken = ["(", "(", pos]; +- } else { +- currentToken = ["brackets", content, pos, next]; +- pos = next; +- } +- } +- break; +- } +- case SINGLE_QUOTE: +- case DOUBLE_QUOTE: { +- quote = code === SINGLE_QUOTE ? "'" : '"'; +- next = pos; +- do { +- escaped = false; +- next = css.indexOf(quote, next + 1); +- if (next === -1) { +- if (ignore || ignoreUnclosed) { +- next = pos + 1; +- break; +- } else { +- unclosed("string"); +- } +- } +- escapePos = next; +- while (css.charCodeAt(escapePos - 1) === BACKSLASH) { +- escapePos -= 1; +- escaped = !escaped; +- } +- } while (escaped); +- currentToken = ["string", css.slice(pos, next + 1), pos, next]; +- pos = next; +- break; +- } +- case AT: { +- RE_AT_END.lastIndex = pos + 1; +- RE_AT_END.test(css); +- if (RE_AT_END.lastIndex === 0) { +- next = css.length - 1; +- } else { +- next = RE_AT_END.lastIndex - 2; +- } +- currentToken = ["at-word", css.slice(pos, next + 1), pos, next]; +- pos = next; +- break; +- } +- case BACKSLASH: { +- next = pos; +- escape = true; +- while (css.charCodeAt(next + 1) === BACKSLASH) { +- next += 1; +- escape = !escape; +- } +- code = css.charCodeAt(next + 1); +- if (escape && code !== SLASH && code !== SPACE && code !== NEWLINE && code !== TAB && code !== CR && code !== FEED) { +- next += 1; +- if (RE_HEX_ESCAPE.test(css.charAt(next))) { +- while (RE_HEX_ESCAPE.test(css.charAt(next + 1))) { +- next += 1; +- } +- if (css.charCodeAt(next + 1) === SPACE) { +- next += 1; +- } +- } +- } +- currentToken = ["word", css.slice(pos, next + 1), pos, next]; +- pos = next; +- break; +- } +- default: { +- if (code === SLASH && css.charCodeAt(pos + 1) === ASTERISK) { +- next = css.indexOf("*/", pos + 2) + 1; +- if (next === 0) { +- if (ignore || ignoreUnclosed) { +- next = css.length; +- } else { +- unclosed("comment"); +- } +- } +- currentToken = ["comment", css.slice(pos, next + 1), pos, next]; +- pos = next; +- } else { +- RE_WORD_END.lastIndex = pos + 1; +- RE_WORD_END.test(css); +- if (RE_WORD_END.lastIndex === 0) { +- next = css.length - 1; +- } else { +- next = RE_WORD_END.lastIndex - 2; +- } +- currentToken = ["word", css.slice(pos, next + 1), pos, next]; +- buffer.push(currentToken); +- pos = next; +- } +- break; +- } +- } +- pos++; +- return currentToken; +- } +- function back(token) { +- returned.push(token); +- } +- return { +- back, +- endOfFile, +- nextToken, +- position +- }; +-}; +-let Container$5 = container; +-let AtRule$3 = class AtRule2 extends Container$5 { +- constructor(defaults) { +- super(defaults); +- this.type = "atrule"; +- } +- append(...children) { +- if (!this.proxyOf.nodes) this.nodes = []; +- return super.append(...children); +- } +- prepend(...children) { +- if (!this.proxyOf.nodes) this.nodes = []; +- return super.prepend(...children); +- } +-}; +-var atRule = AtRule$3; +-AtRule$3.default = AtRule$3; +-Container$5.registerAtRule(AtRule$3); +-let Container$4 = container; +-let LazyResult$3, Processor$2; +-let Root$5 = class Root2 extends Container$4 { +- constructor(defaults) { +- super(defaults); +- this.type = "root"; +- if (!this.nodes) this.nodes = []; +- } +- normalize(child, sample, type) { +- let nodes = super.normalize(child); +- if (sample) { +- if (type === "prepend") { +- if (this.nodes.length > 1) { +- sample.raws.before = this.nodes[1].raws.before; +- } else { +- delete sample.raws.before; +- } +- } else if (this.first !== sample) { +- for (let node2 of nodes) { +- node2.raws.before = sample.raws.before; +- } +- } +- } +- return nodes; +- } +- removeChild(child, ignore) { +- let index2 = this.index(child); +- if (!ignore && index2 === 0 && this.nodes.length > 1) { +- this.nodes[1].raws.before = this.nodes[index2].raws.before; +- } +- return super.removeChild(child); +- } +- toResult(opts = {}) { +- let lazy = new LazyResult$3(new Processor$2(), this, opts); +- return lazy.stringify(); +- } +-}; +-Root$5.registerLazyResult = (dependant) => { +- LazyResult$3 = dependant; +-}; +-Root$5.registerProcessor = (dependant) => { +- Processor$2 = dependant; +-}; +-var root = Root$5; +-Root$5.default = Root$5; +-Container$4.registerRoot(Root$5); +-let list$2 = { +- comma(string) { +- return list$2.split(string, [","], true); +- }, +- space(string) { +- let spaces = [" ", "\n", " "]; +- return list$2.split(string, spaces); +- }, +- split(string, separators, last) { +- let array = []; +- let current = ""; +- let split = false; +- let func = 0; +- let inQuote = false; +- let prevQuote = ""; +- let escape = false; +- for (let letter of string) { +- if (escape) { +- escape = false; +- } else if (letter === "\\") { +- escape = true; +- } else if (inQuote) { +- if (letter === prevQuote) { +- inQuote = false; +- } +- } else if (letter === '"' || letter === "'") { +- inQuote = true; +- prevQuote = letter; +- } else if (letter === "(") { +- func += 1; +- } else if (letter === ")") { +- if (func > 0) func -= 1; +- } else if (func === 0) { +- if (separators.includes(letter)) split = true; +- } +- if (split) { +- if (current !== "") array.push(current.trim()); +- current = ""; +- split = false; +- } else { +- current += letter; +- } +- } +- if (last || current !== "") array.push(current.trim()); +- return array; +- } +-}; +-var list_1 = list$2; +-list$2.default = list$2; +-let Container$3 = container; +-let list$1 = list_1; +-let Rule$3 = class Rule2 extends Container$3 { +- constructor(defaults) { +- super(defaults); +- this.type = "rule"; +- if (!this.nodes) this.nodes = []; +- } +- get selectors() { +- return list$1.comma(this.selector); +- } +- set selectors(values) { +- let match = this.selector ? this.selector.match(/,\s*/) : null; +- let sep2 = match ? match[0] : "," + this.raw("between", "beforeOpen"); +- this.selector = values.join(sep2); +- } +-}; +-var rule = Rule$3; +-Rule$3.default = Rule$3; +-Container$3.registerRule(Rule$3); +-let Declaration$2 = declaration; +-let tokenizer22 = tokenize; +-let Comment$2 = comment; +-let AtRule$2 = atRule; +-let Root$4 = root; +-let Rule$2 = rule; +-const SAFE_COMMENT_NEIGHBOR = { +- empty: true, +- space: true +-}; +-function findLastWithPosition(tokens) { +- for (let i2 = tokens.length - 1; i2 >= 0; i2--) { +- let token = tokens[i2]; +- let pos = token[3] || token[2]; +- if (pos) return pos; +- } +-} +-let Parser$1 = class Parser2 { +- constructor(input2) { +- this.input = input2; +- this.root = new Root$4(); +- this.current = this.root; +- this.spaces = ""; +- this.semicolon = false; +- this.createTokenizer(); +- this.root.source = { input: input2, start: { column: 1, line: 1, offset: 0 } }; +- } +- atrule(token) { +- let node2 = new AtRule$2(); +- node2.name = token[1].slice(1); +- if (node2.name === "") { +- this.unnamedAtrule(node2, token); +- } +- this.init(node2, token[2]); +- let type; +- let prev; +- let shift; +- let last = false; +- let open = false; +- let params = []; +- let brackets = []; +- while (!this.tokenizer.endOfFile()) { +- token = this.tokenizer.nextToken(); +- type = token[0]; +- if (type === "(" || type === "[") { +- brackets.push(type === "(" ? ")" : "]"); +- } else if (type === "{" && brackets.length > 0) { +- brackets.push("}"); +- } else if (type === brackets[brackets.length - 1]) { +- brackets.pop(); +- } +- if (brackets.length === 0) { +- if (type === ";") { +- node2.source.end = this.getPosition(token[2]); +- node2.source.end.offset++; +- this.semicolon = true; +- break; +- } else if (type === "{") { +- open = true; +- break; +- } else if (type === "}") { +- if (params.length > 0) { +- shift = params.length - 1; +- prev = params[shift]; +- while (prev && prev[0] === "space") { +- prev = params[--shift]; +- } +- if (prev) { +- node2.source.end = this.getPosition(prev[3] || prev[2]); +- node2.source.end.offset++; +- } +- } +- this.end(token); +- break; +- } else { +- params.push(token); +- } +- } else { +- params.push(token); +- } +- if (this.tokenizer.endOfFile()) { +- last = true; +- break; +- } +- } +- node2.raws.between = this.spacesAndCommentsFromEnd(params); +- if (params.length) { +- node2.raws.afterName = this.spacesAndCommentsFromStart(params); +- this.raw(node2, "params", params); +- if (last) { +- token = params[params.length - 1]; +- node2.source.end = this.getPosition(token[3] || token[2]); +- node2.source.end.offset++; +- this.spaces = node2.raws.between; +- node2.raws.between = ""; +- } +- } else { +- node2.raws.afterName = ""; +- node2.params = ""; +- } +- if (open) { +- node2.nodes = []; +- this.current = node2; +- } +- } +- checkMissedSemicolon(tokens) { +- let colon = this.colon(tokens); +- if (colon === false) return; +- let founded = 0; +- let token; +- for (let j = colon - 1; j >= 0; j--) { +- token = tokens[j]; +- if (token[0] !== "space") { +- founded += 1; +- if (founded === 2) break; +- } +- } +- throw this.input.error( +- "Missed semicolon", +- token[0] === "word" ? token[3] + 1 : token[2] +- ); +- } +- colon(tokens) { +- let brackets = 0; +- let token, type, prev; +- for (let [i2, element] of tokens.entries()) { +- token = element; +- type = token[0]; +- if (type === "(") { +- brackets += 1; +- } +- if (type === ")") { +- brackets -= 1; +- } +- if (brackets === 0 && type === ":") { +- if (!prev) { +- this.doubleColon(token); +- } else if (prev[0] === "word" && prev[1] === "progid") { +- continue; +- } else { +- return i2; +- } +- } +- prev = token; +- } +- return false; +- } +- comment(token) { +- let node2 = new Comment$2(); +- this.init(node2, token[2]); +- node2.source.end = this.getPosition(token[3] || token[2]); +- node2.source.end.offset++; +- let text = token[1].slice(2, -2); +- if (/^\s*$/.test(text)) { +- node2.text = ""; +- node2.raws.left = text; +- node2.raws.right = ""; +- } else { +- let match = text.match(/^(\s*)([^]*\S)(\s*)$/); +- node2.text = match[2]; +- node2.raws.left = match[1]; +- node2.raws.right = match[3]; +- } +- } +- createTokenizer() { +- this.tokenizer = tokenizer22(this.input); +- } +- decl(tokens, customProperty) { +- let node2 = new Declaration$2(); +- this.init(node2, tokens[0][2]); +- let last = tokens[tokens.length - 1]; +- if (last[0] === ";") { +- this.semicolon = true; +- tokens.pop(); +- } +- node2.source.end = this.getPosition( +- last[3] || last[2] || findLastWithPosition(tokens) +- ); +- node2.source.end.offset++; +- while (tokens[0][0] !== "word") { +- if (tokens.length === 1) this.unknownWord(tokens); +- node2.raws.before += tokens.shift()[1]; +- } +- node2.source.start = this.getPosition(tokens[0][2]); +- node2.prop = ""; +- while (tokens.length) { +- let type = tokens[0][0]; +- if (type === ":" || type === "space" || type === "comment") { +- break; +- } +- node2.prop += tokens.shift()[1]; +- } +- node2.raws.between = ""; +- let token; +- while (tokens.length) { +- token = tokens.shift(); +- if (token[0] === ":") { +- node2.raws.between += token[1]; +- break; +- } else { +- if (token[0] === "word" && /\w/.test(token[1])) { +- this.unknownWord([token]); +- } +- node2.raws.between += token[1]; +- } +- } +- if (node2.prop[0] === "_" || node2.prop[0] === "*") { +- node2.raws.before += node2.prop[0]; +- node2.prop = node2.prop.slice(1); +- } +- let firstSpaces = []; +- let next; +- while (tokens.length) { +- next = tokens[0][0]; +- if (next !== "space" && next !== "comment") break; +- firstSpaces.push(tokens.shift()); +- } +- this.precheckMissedSemicolon(tokens); +- for (let i2 = tokens.length - 1; i2 >= 0; i2--) { +- token = tokens[i2]; +- if (token[1].toLowerCase() === "!important") { +- node2.important = true; +- let string = this.stringFrom(tokens, i2); +- string = this.spacesFromEnd(tokens) + string; +- if (string !== " !important") node2.raws.important = string; +- break; +- } else if (token[1].toLowerCase() === "important") { +- let cache = tokens.slice(0); +- let str = ""; +- for (let j = i2; j > 0; j--) { +- let type = cache[j][0]; +- if (str.trim().indexOf("!") === 0 && type !== "space") { +- break; +- } +- str = cache.pop()[1] + str; +- } +- if (str.trim().indexOf("!") === 0) { +- node2.important = true; +- node2.raws.important = str; +- tokens = cache; +- } +- } +- if (token[0] !== "space" && token[0] !== "comment") { +- break; +- } +- } +- let hasWord = tokens.some((i2) => i2[0] !== "space" && i2[0] !== "comment"); +- if (hasWord) { +- node2.raws.between += firstSpaces.map((i2) => i2[1]).join(""); +- firstSpaces = []; +- } +- this.raw(node2, "value", firstSpaces.concat(tokens), customProperty); +- if (node2.value.includes(":") && !customProperty) { +- this.checkMissedSemicolon(tokens); +- } +- } +- doubleColon(token) { +- throw this.input.error( +- "Double colon", +- { offset: token[2] }, +- { offset: token[2] + token[1].length } +- ); +- } +- emptyRule(token) { +- let node2 = new Rule$2(); +- this.init(node2, token[2]); +- node2.selector = ""; +- node2.raws.between = ""; +- this.current = node2; +- } +- end(token) { +- if (this.current.nodes && this.current.nodes.length) { +- this.current.raws.semicolon = this.semicolon; +- } +- this.semicolon = false; +- this.current.raws.after = (this.current.raws.after || "") + this.spaces; +- this.spaces = ""; +- if (this.current.parent) { +- this.current.source.end = this.getPosition(token[2]); +- this.current.source.end.offset++; +- this.current = this.current.parent; +- } else { +- this.unexpectedClose(token); +- } +- } +- endFile() { +- if (this.current.parent) this.unclosedBlock(); +- if (this.current.nodes && this.current.nodes.length) { +- this.current.raws.semicolon = this.semicolon; +- } +- this.current.raws.after = (this.current.raws.after || "") + this.spaces; +- this.root.source.end = this.getPosition(this.tokenizer.position()); +- } +- freeSemicolon(token) { +- this.spaces += token[1]; +- if (this.current.nodes) { +- let prev = this.current.nodes[this.current.nodes.length - 1]; +- if (prev && prev.type === "rule" && !prev.raws.ownSemicolon) { +- prev.raws.ownSemicolon = this.spaces; +- this.spaces = ""; +- } +- } +- } +- // Helpers +- getPosition(offset) { +- let pos = this.input.fromOffset(offset); +- return { +- column: pos.col, +- line: pos.line, +- offset +- }; +- } +- init(node2, offset) { +- this.current.push(node2); +- node2.source = { +- input: this.input, +- start: this.getPosition(offset) +- }; +- node2.raws.before = this.spaces; +- this.spaces = ""; +- if (node2.type !== "comment") this.semicolon = false; +- } +- other(start) { +- let end = false; +- let type = null; +- let colon = false; +- let bracket = null; +- let brackets = []; +- let customProperty = start[1].startsWith("--"); +- let tokens = []; +- let token = start; +- while (token) { +- type = token[0]; +- tokens.push(token); +- if (type === "(" || type === "[") { +- if (!bracket) bracket = token; +- brackets.push(type === "(" ? ")" : "]"); +- } else if (customProperty && colon && type === "{") { +- if (!bracket) bracket = token; +- brackets.push("}"); +- } else if (brackets.length === 0) { +- if (type === ";") { +- if (colon) { +- this.decl(tokens, customProperty); +- return; +- } else { +- break; +- } +- } else if (type === "{") { +- this.rule(tokens); +- return; +- } else if (type === "}") { +- this.tokenizer.back(tokens.pop()); +- end = true; +- break; +- } else if (type === ":") { +- colon = true; +- } +- } else if (type === brackets[brackets.length - 1]) { +- brackets.pop(); +- if (brackets.length === 0) bracket = null; +- } +- token = this.tokenizer.nextToken(); +- } +- if (this.tokenizer.endOfFile()) end = true; +- if (brackets.length > 0) this.unclosedBracket(bracket); +- if (end && colon) { +- if (!customProperty) { +- while (tokens.length) { +- token = tokens[tokens.length - 1][0]; +- if (token !== "space" && token !== "comment") break; +- this.tokenizer.back(tokens.pop()); +- } +- } +- this.decl(tokens, customProperty); +- } else { +- this.unknownWord(tokens); +- } +- } +- parse() { +- let token; +- while (!this.tokenizer.endOfFile()) { +- token = this.tokenizer.nextToken(); +- switch (token[0]) { +- case "space": +- this.spaces += token[1]; +- break; +- case ";": +- this.freeSemicolon(token); +- break; +- case "}": +- this.end(token); +- break; +- case "comment": +- this.comment(token); +- break; +- case "at-word": +- this.atrule(token); +- break; +- case "{": +- this.emptyRule(token); +- break; +- default: +- this.other(token); +- break; +- } +- } +- this.endFile(); +- } +- precheckMissedSemicolon() { +- } +- raw(node2, prop, tokens, customProperty) { +- let token, type; +- let length = tokens.length; +- let value = ""; +- let clean = true; +- let next, prev; +- for (let i2 = 0; i2 < length; i2 += 1) { +- token = tokens[i2]; +- type = token[0]; +- if (type === "space" && i2 === length - 1 && !customProperty) { +- clean = false; +- } else if (type === "comment") { +- prev = tokens[i2 - 1] ? tokens[i2 - 1][0] : "empty"; +- next = tokens[i2 + 1] ? tokens[i2 + 1][0] : "empty"; +- if (!SAFE_COMMENT_NEIGHBOR[prev] && !SAFE_COMMENT_NEIGHBOR[next]) { +- if (value.slice(-1) === ",") { +- clean = false; +- } else { +- value += token[1]; +- } +- } else { +- clean = false; +- } +- } else { +- value += token[1]; +- } +- } +- if (!clean) { +- let raw = tokens.reduce((all, i2) => all + i2[1], ""); +- node2.raws[prop] = { raw, value }; +- } +- node2[prop] = value; +- } +- rule(tokens) { +- tokens.pop(); +- let node2 = new Rule$2(); +- this.init(node2, tokens[0][2]); +- node2.raws.between = this.spacesAndCommentsFromEnd(tokens); +- this.raw(node2, "selector", tokens); +- this.current = node2; +- } +- spacesAndCommentsFromEnd(tokens) { +- let lastTokenType; +- let spaces = ""; +- while (tokens.length) { +- lastTokenType = tokens[tokens.length - 1][0]; +- if (lastTokenType !== "space" && lastTokenType !== "comment") break; +- spaces = tokens.pop()[1] + spaces; +- } +- return spaces; +- } +- // Errors +- spacesAndCommentsFromStart(tokens) { +- let next; +- let spaces = ""; +- while (tokens.length) { +- next = tokens[0][0]; +- if (next !== "space" && next !== "comment") break; +- spaces += tokens.shift()[1]; +- } +- return spaces; +- } +- spacesFromEnd(tokens) { +- let lastTokenType; +- let spaces = ""; +- while (tokens.length) { +- lastTokenType = tokens[tokens.length - 1][0]; +- if (lastTokenType !== "space") break; +- spaces = tokens.pop()[1] + spaces; +- } +- return spaces; +- } +- stringFrom(tokens, from) { +- let result2 = ""; +- for (let i2 = from; i2 < tokens.length; i2++) { +- result2 += tokens[i2][1]; +- } +- tokens.splice(from, tokens.length - from); +- return result2; +- } +- unclosedBlock() { +- let pos = this.current.source.start; +- throw this.input.error("Unclosed block", pos.line, pos.column); +- } +- unclosedBracket(bracket) { +- throw this.input.error( +- "Unclosed bracket", +- { offset: bracket[2] }, +- { offset: bracket[2] + 1 } +- ); +- } +- unexpectedClose(token) { +- throw this.input.error( +- "Unexpected }", +- { offset: token[2] }, +- { offset: token[2] + 1 } +- ); +- } +- unknownWord(tokens) { +- throw this.input.error( +- "Unknown word", +- { offset: tokens[0][2] }, +- { offset: tokens[0][2] + tokens[0][1].length } +- ); +- } +- unnamedAtrule(node2, token) { +- throw this.input.error( +- "At-rule without name", +- { offset: token[2] }, +- { offset: token[2] + token[1].length } +- ); +- } +-}; +-var parser = Parser$1; +-let Container$2 = container; +-let Parser22 = parser; +-let Input$2 = input; +-function parse$3(css, opts) { +- let input2 = new Input$2(css, opts); +- let parser2 = new Parser22(input2); +- try { +- parser2.parse(); +- } catch (e2) { +- if (process.env.NODE_ENV !== "production") { +- if (e2.name === "CssSyntaxError" && opts && opts.from) { +- if (/\.scss$/i.test(opts.from)) { +- e2.message += "\nYou tried to parse SCSS with the standard CSS parser; try again with the postcss-scss parser"; +- } else if (/\.sass/i.test(opts.from)) { +- e2.message += "\nYou tried to parse Sass with the standard CSS parser; try again with the postcss-sass parser"; +- } else if (/\.less$/i.test(opts.from)) { +- e2.message += "\nYou tried to parse Less with the standard CSS parser; try again with the postcss-less parser"; +- } +- } +- } +- throw e2; +- } +- return parser2.root; +-} +-var parse_1 = parse$3; +-parse$3.default = parse$3; +-Container$2.registerParse(parse$3); +-let { isClean, my } = symbols; +-let MapGenerator$1 = mapGenerator; +-let stringify$2 = stringify_1; +-let Container$1 = container; +-let Document$2 = document$1; +-let warnOnce$1 = warnOnce$2; +-let Result$2 = result; +-let parse$2 = parse_1; +-let Root$3 = root; +-const TYPE_TO_CLASS_NAME = { +- atrule: "AtRule", +- comment: "Comment", +- decl: "Declaration", +- document: "Document", +- root: "Root", +- rule: "Rule" +-}; +-const PLUGIN_PROPS = { +- AtRule: true, +- AtRuleExit: true, +- Comment: true, +- CommentExit: true, +- Declaration: true, +- DeclarationExit: true, +- Document: true, +- DocumentExit: true, +- Once: true, +- OnceExit: true, +- postcssPlugin: true, +- prepare: true, +- Root: true, +- RootExit: true, +- Rule: true, +- RuleExit: true +-}; +-const NOT_VISITORS = { +- Once: true, +- postcssPlugin: true, +- prepare: true +-}; +-const CHILDREN = 0; +-function isPromise(obj) { +- return typeof obj === "object" && typeof obj.then === "function"; +-} +-function getEvents(node2) { +- let key = false; +- let type = TYPE_TO_CLASS_NAME[node2.type]; +- if (node2.type === "decl") { +- key = node2.prop.toLowerCase(); +- } else if (node2.type === "atrule") { +- key = node2.name.toLowerCase(); +- } +- if (key && node2.append) { +- return [ +- type, +- type + "-" + key, +- CHILDREN, +- type + "Exit", +- type + "Exit-" + key +- ]; +- } else if (key) { +- return [type, type + "-" + key, type + "Exit", type + "Exit-" + key]; +- } else if (node2.append) { +- return [type, CHILDREN, type + "Exit"]; +- } else { +- return [type, type + "Exit"]; +- } +-} +-function toStack(node2) { +- let events; +- if (node2.type === "document") { +- events = ["Document", CHILDREN, "DocumentExit"]; +- } else if (node2.type === "root") { +- events = ["Root", CHILDREN, "RootExit"]; +- } else { +- events = getEvents(node2); +- } +- return { +- eventIndex: 0, +- events, +- iterator: 0, +- node: node2, +- visitorIndex: 0, +- visitors: [] +- }; +-} +-function cleanMarks(node2) { +- node2[isClean] = false; +- if (node2.nodes) node2.nodes.forEach((i2) => cleanMarks(i2)); +- return node2; +-} +-let postcss$2 = {}; +-let LazyResult$2 = class LazyResult2 { +- constructor(processor2, css, opts) { +- this.stringified = false; +- this.processed = false; +- let root2; +- if (typeof css === "object" && css !== null && (css.type === "root" || css.type === "document")) { +- root2 = cleanMarks(css); +- } else if (css instanceof LazyResult2 || css instanceof Result$2) { +- root2 = cleanMarks(css.root); +- if (css.map) { +- if (typeof opts.map === "undefined") opts.map = {}; +- if (!opts.map.inline) opts.map.inline = false; +- opts.map.prev = css.map; +- } +- } else { +- let parser2 = parse$2; +- if (opts.syntax) parser2 = opts.syntax.parse; +- if (opts.parser) parser2 = opts.parser; +- if (parser2.parse) parser2 = parser2.parse; +- try { +- root2 = parser2(css, opts); +- } catch (error) { +- this.processed = true; +- this.error = error; +- } +- if (root2 && !root2[my]) { +- Container$1.rebuild(root2); +- } +- } +- this.result = new Result$2(processor2, root2, opts); +- this.helpers = { ...postcss$2, postcss: postcss$2, result: this.result }; +- this.plugins = this.processor.plugins.map((plugin22) => { +- if (typeof plugin22 === "object" && plugin22.prepare) { +- return { ...plugin22, ...plugin22.prepare(this.result) }; +- } else { +- return plugin22; +- } +- }); +- } +- async() { +- if (this.error) return Promise.reject(this.error); +- if (this.processed) return Promise.resolve(this.result); +- if (!this.processing) { +- this.processing = this.runAsync(); +- } +- return this.processing; +- } +- catch(onRejected) { +- return this.async().catch(onRejected); +- } +- finally(onFinally) { +- return this.async().then(onFinally, onFinally); +- } +- getAsyncError() { +- throw new Error("Use process(css).then(cb) to work with async plugins"); +- } +- handleError(error, node2) { +- let plugin22 = this.result.lastPlugin; +- try { +- if (node2) node2.addToError(error); +- this.error = error; +- if (error.name === "CssSyntaxError" && !error.plugin) { +- error.plugin = plugin22.postcssPlugin; +- error.setMessage(); +- } else if (plugin22.postcssVersion) { +- if (process.env.NODE_ENV !== "production") { +- let pluginName = plugin22.postcssPlugin; +- let pluginVer = plugin22.postcssVersion; +- let runtimeVer = this.result.processor.version; +- let a2 = pluginVer.split("."); +- let b = runtimeVer.split("."); +- if (a2[0] !== b[0] || parseInt(a2[1]) > parseInt(b[1])) { +- console.error( +- "Unknown error from PostCSS plugin. Your current PostCSS version is " + runtimeVer + ", but " + pluginName + " uses " + pluginVer + ". Perhaps this is the source of the error below." +- ); +- } +- } +- } +- } catch (err) { +- if (console && console.error) console.error(err); +- } +- return error; +- } +- prepareVisitors() { +- this.listeners = {}; +- let add = (plugin22, type, cb) => { +- if (!this.listeners[type]) this.listeners[type] = []; +- this.listeners[type].push([plugin22, cb]); +- }; +- for (let plugin22 of this.plugins) { +- if (typeof plugin22 === "object") { +- for (let event in plugin22) { +- if (!PLUGIN_PROPS[event] && /^[A-Z]/.test(event)) { +- throw new Error( +- `Unknown event ${event} in ${plugin22.postcssPlugin}. Try to update PostCSS (${this.processor.version} now).` +- ); +- } +- if (!NOT_VISITORS[event]) { +- if (typeof plugin22[event] === "object") { +- for (let filter in plugin22[event]) { +- if (filter === "*") { +- add(plugin22, event, plugin22[event][filter]); +- } else { +- add( +- plugin22, +- event + "-" + filter.toLowerCase(), +- plugin22[event][filter] +- ); +- } +- } +- } else if (typeof plugin22[event] === "function") { +- add(plugin22, event, plugin22[event]); +- } +- } +- } +- } +- } +- this.hasListener = Object.keys(this.listeners).length > 0; +- } +- async runAsync() { +- this.plugin = 0; +- for (let i2 = 0; i2 < this.plugins.length; i2++) { +- let plugin22 = this.plugins[i2]; +- let promise = this.runOnRoot(plugin22); +- if (isPromise(promise)) { +- try { +- await promise; +- } catch (error) { +- throw this.handleError(error); +- } +- } +- } +- this.prepareVisitors(); +- if (this.hasListener) { +- let root2 = this.result.root; +- while (!root2[isClean]) { +- root2[isClean] = true; +- let stack = [toStack(root2)]; +- while (stack.length > 0) { +- let promise = this.visitTick(stack); +- if (isPromise(promise)) { +- try { +- await promise; +- } catch (e2) { +- let node2 = stack[stack.length - 1].node; +- throw this.handleError(e2, node2); +- } +- } +- } +- } +- if (this.listeners.OnceExit) { +- for (let [plugin22, visitor] of this.listeners.OnceExit) { +- this.result.lastPlugin = plugin22; +- try { +- if (root2.type === "document") { +- let roots = root2.nodes.map( +- (subRoot) => visitor(subRoot, this.helpers) +- ); +- await Promise.all(roots); +- } else { +- await visitor(root2, this.helpers); +- } +- } catch (e2) { +- throw this.handleError(e2); +- } +- } +- } +- } +- this.processed = true; +- return this.stringify(); +- } +- runOnRoot(plugin22) { +- this.result.lastPlugin = plugin22; +- try { +- if (typeof plugin22 === "object" && plugin22.Once) { +- if (this.result.root.type === "document") { +- let roots = this.result.root.nodes.map( +- (root2) => plugin22.Once(root2, this.helpers) +- ); +- if (isPromise(roots[0])) { +- return Promise.all(roots); +- } +- return roots; +- } +- return plugin22.Once(this.result.root, this.helpers); +- } else if (typeof plugin22 === "function") { +- return plugin22(this.result.root, this.result); +- } +- } catch (error) { +- throw this.handleError(error); +- } +- } +- stringify() { +- if (this.error) throw this.error; +- if (this.stringified) return this.result; +- this.stringified = true; +- this.sync(); +- let opts = this.result.opts; +- let str = stringify$2; +- if (opts.syntax) str = opts.syntax.stringify; +- if (opts.stringifier) str = opts.stringifier; +- if (str.stringify) str = str.stringify; +- let map = new MapGenerator$1(str, this.result.root, this.result.opts); +- let data = map.generate(); +- this.result.css = data[0]; +- this.result.map = data[1]; +- return this.result; +- } +- sync() { +- if (this.error) throw this.error; +- if (this.processed) return this.result; +- this.processed = true; +- if (this.processing) { +- throw this.getAsyncError(); +- } +- for (let plugin22 of this.plugins) { +- let promise = this.runOnRoot(plugin22); +- if (isPromise(promise)) { +- throw this.getAsyncError(); +- } +- } +- this.prepareVisitors(); +- if (this.hasListener) { +- let root2 = this.result.root; +- while (!root2[isClean]) { +- root2[isClean] = true; +- this.walkSync(root2); +- } +- if (this.listeners.OnceExit) { +- if (root2.type === "document") { +- for (let subRoot of root2.nodes) { +- this.visitSync(this.listeners.OnceExit, subRoot); +- } +- } else { +- this.visitSync(this.listeners.OnceExit, root2); +- } +- } +- } +- return this.result; +- } +- then(onFulfilled, onRejected) { +- if (process.env.NODE_ENV !== "production") { +- if (!("from" in this.opts)) { +- warnOnce$1( +- "Without `from` option PostCSS could generate wrong source map and will not find Browserslist config. Set it to CSS file path or to `undefined` to prevent this warning." +- ); +- } +- } +- return this.async().then(onFulfilled, onRejected); +- } +- toString() { +- return this.css; +- } +- visitSync(visitors, node2) { +- for (let [plugin22, visitor] of visitors) { +- this.result.lastPlugin = plugin22; +- let promise; +- try { +- promise = visitor(node2, this.helpers); +- } catch (e2) { +- throw this.handleError(e2, node2.proxyOf); +- } +- if (node2.type !== "root" && node2.type !== "document" && !node2.parent) { +- return true; +- } +- if (isPromise(promise)) { +- throw this.getAsyncError(); +- } +- } +- } +- visitTick(stack) { +- let visit2 = stack[stack.length - 1]; +- let { node: node2, visitors } = visit2; +- if (node2.type !== "root" && node2.type !== "document" && !node2.parent) { +- stack.pop(); +- return; +- } +- if (visitors.length > 0 && visit2.visitorIndex < visitors.length) { +- let [plugin22, visitor] = visitors[visit2.visitorIndex]; +- visit2.visitorIndex += 1; +- if (visit2.visitorIndex === visitors.length) { +- visit2.visitors = []; +- visit2.visitorIndex = 0; +- } +- this.result.lastPlugin = plugin22; +- try { +- return visitor(node2.toProxy(), this.helpers); +- } catch (e2) { +- throw this.handleError(e2, node2); +- } +- } +- if (visit2.iterator !== 0) { +- let iterator = visit2.iterator; +- let child; +- while (child = node2.nodes[node2.indexes[iterator]]) { +- node2.indexes[iterator] += 1; +- if (!child[isClean]) { +- child[isClean] = true; +- stack.push(toStack(child)); +- return; +- } +- } +- visit2.iterator = 0; +- delete node2.indexes[iterator]; +- } +- let events = visit2.events; +- while (visit2.eventIndex < events.length) { +- let event = events[visit2.eventIndex]; +- visit2.eventIndex += 1; +- if (event === CHILDREN) { +- if (node2.nodes && node2.nodes.length) { +- node2[isClean] = true; +- visit2.iterator = node2.getIterator(); +- } +- return; +- } else if (this.listeners[event]) { +- visit2.visitors = this.listeners[event]; +- return; +- } +- } +- stack.pop(); +- } +- walkSync(node2) { +- node2[isClean] = true; +- let events = getEvents(node2); +- for (let event of events) { +- if (event === CHILDREN) { +- if (node2.nodes) { +- node2.each((child) => { +- if (!child[isClean]) this.walkSync(child); +- }); +- } +- } else { +- let visitors = this.listeners[event]; +- if (visitors) { +- if (this.visitSync(visitors, node2.toProxy())) return; +- } +- } +- } +- } +- warnings() { +- return this.sync().warnings(); +- } +- get content() { +- return this.stringify().content; +- } +- get css() { +- return this.stringify().css; +- } +- get map() { +- return this.stringify().map; +- } +- get messages() { +- return this.sync().messages; +- } +- get opts() { +- return this.result.opts; +- } +- get processor() { +- return this.result.processor; +- } +- get root() { +- return this.sync().root; +- } +- get [Symbol.toStringTag]() { +- return "LazyResult"; +- } +-}; +-LazyResult$2.registerPostcss = (dependant) => { +- postcss$2 = dependant; +-}; +-var lazyResult = LazyResult$2; +-LazyResult$2.default = LazyResult$2; +-Root$3.registerLazyResult(LazyResult$2); +-Document$2.registerLazyResult(LazyResult$2); +-let MapGenerator22 = mapGenerator; +-let stringify$1 = stringify_1; +-let warnOnce22 = warnOnce$2; +-let parse$1 = parse_1; +-const Result$1 = result; +-let NoWorkResult$1 = class NoWorkResult2 { +- constructor(processor2, css, opts) { +- css = css.toString(); +- this.stringified = false; +- this._processor = processor2; +- this._css = css; +- this._opts = opts; +- this._map = void 0; +- let root2; +- let str = stringify$1; +- this.result = new Result$1(this._processor, root2, this._opts); +- this.result.css = css; +- let self = this; +- Object.defineProperty(this.result, "root", { +- get() { +- return self.root; +- } +- }); +- let map = new MapGenerator22(str, root2, this._opts, css); +- if (map.isMap()) { +- let [generatedCSS, generatedMap] = map.generate(); +- if (generatedCSS) { +- this.result.css = generatedCSS; +- } +- if (generatedMap) { +- this.result.map = generatedMap; +- } +- } else { +- map.clearAnnotation(); +- this.result.css = map.css; +- } +- } +- async() { +- if (this.error) return Promise.reject(this.error); +- return Promise.resolve(this.result); +- } +- catch(onRejected) { +- return this.async().catch(onRejected); +- } +- finally(onFinally) { +- return this.async().then(onFinally, onFinally); +- } +- sync() { +- if (this.error) throw this.error; +- return this.result; +- } +- then(onFulfilled, onRejected) { +- if (process.env.NODE_ENV !== "production") { +- if (!("from" in this._opts)) { +- warnOnce22( +- "Without `from` option PostCSS could generate wrong source map and will not find Browserslist config. Set it to CSS file path or to `undefined` to prevent this warning." +- ); ++ else { ++ for (const childN of Array.from(index$1.childNodes(n2))) { ++ const serializedChildNode = serializeNodeWithId(childN, bypassOptions); ++ if (serializedChildNode) { ++ serializedNode.childNodes.push(serializedChildNode); ++ } + } + } +- return this.async().then(onFulfilled, onRejected); +- } +- toString() { +- return this._css; +- } +- warnings() { +- return []; +- } +- get content() { +- return this.result.css; +- } +- get css() { +- return this.result.css; +- } +- get map() { +- return this.result.map; +- } +- get messages() { +- return []; +- } +- get opts() { +- return this.result.opts; +- } +- get processor() { +- return this.result.processor; +- } +- get root() { +- if (this._root) { +- return this._root; +- } +- let root2; +- let parser2 = parse$1; +- try { +- root2 = parser2(this._css, this._opts); +- } catch (error) { +- this.error = error; +- } +- if (this.error) { +- throw this.error; +- } else { +- this._root = root2; +- return root2; +- } +- } +- get [Symbol.toStringTag]() { +- return "NoWorkResult"; +- } +-}; +-var noWorkResult = NoWorkResult$1; +-NoWorkResult$1.default = NoWorkResult$1; +-let NoWorkResult22 = noWorkResult; +-let LazyResult$1 = lazyResult; +-let Document$1 = document$1; +-let Root$2 = root; +-let Processor$1 = class Processor2 { +- constructor(plugins = []) { +- this.version = "8.4.38"; +- this.plugins = this.normalize(plugins); +- } +- normalize(plugins) { +- let normalized = []; +- for (let i2 of plugins) { +- if (i2.postcss === true) { +- i2 = i2(); +- } else if (i2.postcss) { +- i2 = i2.postcss; +- } +- if (typeof i2 === "object" && Array.isArray(i2.plugins)) { +- normalized = normalized.concat(i2.plugins); +- } else if (typeof i2 === "object" && i2.postcssPlugin) { +- normalized.push(i2); +- } else if (typeof i2 === "function") { +- normalized.push(i2); +- } else if (typeof i2 === "object" && (i2.parse || i2.stringify)) { +- if (process.env.NODE_ENV !== "production") { +- throw new Error( +- "PostCSS syntaxes cannot be used as plugins. Instead, please use one of the syntax/parser/stringifier options as outlined in your PostCSS runner documentation." +- ); ++ let shadowRootEl = null; ++ if (isElement(n2) && (shadowRootEl = index$1.shadowRoot(n2))) { ++ for (const childN of Array.from(index$1.childNodes(shadowRootEl))) { ++ const serializedChildNode = serializeNodeWithId(childN, bypassOptions); ++ if (serializedChildNode) { ++ isNativeShadowDom(shadowRootEl) && (serializedChildNode.isShadow = true); ++ serializedNode.childNodes.push(serializedChildNode); + } +- } else { +- throw new Error(i2 + " is not a PostCSS plugin"); + } + } +- return normalized; +- } +- process(css, opts = {}) { +- if (!this.plugins.length && !opts.parser && !opts.stringifier && !opts.syntax) { +- return new NoWorkResult22(this, css, opts); +- } else { +- return new LazyResult$1(this, css, opts); +- } + } +- use(plugin22) { +- this.plugins = this.plugins.concat(this.normalize([plugin22])); +- return this; ++ const parent = index$1.parentNode(n2); ++ if (parent && isShadowRoot(parent) && isNativeShadowDom(parent)) { ++ serializedNode.isShadow = true; + } +-}; +-var processor = Processor$1; +-Processor$1.default = Processor$1; +-Root$2.registerProcessor(Processor$1); +-Document$1.registerProcessor(Processor$1); +-let Declaration$1 = declaration; +-let PreviousMap22 = previousMap; +-let Comment$1 = comment; +-let AtRule$1 = atRule; +-let Input$1 = input; +-let Root$1 = root; +-let Rule$1 = rule; +-function fromJSON$1(json, inputs) { +- if (Array.isArray(json)) return json.map((n2) => fromJSON$1(n2)); +- let { inputs: ownInputs, ...defaults } = json; +- if (ownInputs) { +- inputs = []; +- for (let input2 of ownInputs) { +- let inputHydrated = { ...input2, __proto__: Input$1.prototype }; +- if (inputHydrated.map) { +- inputHydrated.map = { +- ...inputHydrated.map, +- __proto__: PreviousMap22.prototype +- }; +- } +- inputs.push(inputHydrated); +- } ++ if (serializedNode.type === NodeType$2.Element && serializedNode.tagName === "iframe") { ++ onceIframeLoaded( ++ n2, ++ () => { ++ const iframeDoc = n2.contentDocument; ++ if (iframeDoc && onIframeLoad) { ++ const serializedIframeNode = serializeNodeWithId(iframeDoc, { ++ doc: iframeDoc, ++ mirror: mirror2, ++ blockClass, ++ blockSelector, ++ needsMask, ++ maskTextClass, ++ maskTextSelector, ++ skipChild: false, ++ inlineStylesheet, ++ maskInputOptions, ++ maskTextFn, ++ maskInputFn, ++ slimDOMOptions, ++ dataURLOptions, ++ inlineImages, ++ recordCanvas, ++ preserveWhiteSpace, ++ onSerialize, ++ onIframeLoad, ++ iframeLoadTimeout, ++ onStylesheetLoad, ++ stylesheetLoadTimeout, ++ keepIframeSrcFn ++ }); ++ if (serializedIframeNode) { ++ onIframeLoad( ++ n2, ++ serializedIframeNode ++ ); ++ } ++ } ++ }, ++ iframeLoadTimeout ++ ); + } +- if (defaults.nodes) { +- defaults.nodes = json.nodes.map((n2) => fromJSON$1(n2, inputs)); ++ if (serializedNode.type === NodeType$2.Element && serializedNode.tagName === "link" && typeof serializedNode.attributes.rel === "string" && (serializedNode.attributes.rel === "stylesheet" || serializedNode.attributes.rel === "preload" && typeof serializedNode.attributes.href === "string" && extractFileExtension(serializedNode.attributes.href) === "css")) { ++ onceStylesheetLoaded( ++ n2, ++ () => { ++ if (onStylesheetLoad) { ++ const serializedLinkNode = serializeNodeWithId(n2, { ++ doc, ++ mirror: mirror2, ++ blockClass, ++ blockSelector, ++ needsMask, ++ maskTextClass, ++ maskTextSelector, ++ skipChild: false, ++ inlineStylesheet, ++ maskInputOptions, ++ maskTextFn, ++ maskInputFn, ++ slimDOMOptions, ++ dataURLOptions, ++ inlineImages, ++ recordCanvas, ++ preserveWhiteSpace, ++ onSerialize, ++ onIframeLoad, ++ iframeLoadTimeout, ++ onStylesheetLoad, ++ stylesheetLoadTimeout, ++ keepIframeSrcFn ++ }); ++ if (serializedLinkNode) { ++ onStylesheetLoad( ++ n2, ++ serializedLinkNode ++ ); ++ } ++ } ++ }, ++ stylesheetLoadTimeout ++ ); + } +- if (defaults.source) { +- let { inputId, ...source } = defaults.source; +- defaults.source = source; +- if (inputId != null) { +- defaults.source.input = inputs[inputId]; ++ return serializedNode; ++} ++function snapshot(n2, options) { ++ const { ++ mirror: mirror2 = new Mirror(), ++ blockClass = "rr-block", ++ blockSelector = null, ++ maskTextClass = "rr-mask", ++ maskTextSelector = null, ++ inlineStylesheet = true, ++ inlineImages = false, ++ recordCanvas = false, ++ maskAllInputs = false, ++ maskTextFn, ++ maskInputFn, ++ slimDOM = false, ++ dataURLOptions, ++ preserveWhiteSpace, ++ onSerialize, ++ onIframeLoad, ++ iframeLoadTimeout, ++ onStylesheetLoad, ++ stylesheetLoadTimeout, ++ keepIframeSrcFn = () => false ++ } = options || {}; ++ const maskInputOptions = maskAllInputs === true ? { ++ color: true, ++ date: true, ++ "datetime-local": true, ++ email: true, ++ month: true, ++ number: true, ++ range: true, ++ search: true, ++ tel: true, ++ text: true, ++ time: true, ++ url: true, ++ week: true, ++ textarea: true, ++ select: true, ++ password: true ++ } : maskAllInputs === false ? { ++ password: true ++ } : maskAllInputs; ++ const slimDOMOptions = slimDOM === true || slimDOM === "all" ? ( ++ // if true: set of sensible options that should not throw away any information ++ { ++ script: true, ++ comment: true, ++ headFavicon: true, ++ headWhitespace: true, ++ headMetaDescKeywords: slimDOM === "all", ++ // destructive ++ headMetaSocial: true, ++ headMetaRobots: true, ++ headMetaHttpEquiv: true, ++ headMetaAuthorship: true, ++ headMetaVerification: true + } +- } +- if (defaults.type === "root") { +- return new Root$1(defaults); +- } else if (defaults.type === "decl") { +- return new Declaration$1(defaults); +- } else if (defaults.type === "rule") { +- return new Rule$1(defaults); +- } else if (defaults.type === "comment") { +- return new Comment$1(defaults); +- } else if (defaults.type === "atrule") { +- return new AtRule$1(defaults); +- } else { +- throw new Error("Unknown node type: " + json.type); +- } +-} +-var fromJSON_1 = fromJSON$1; +-fromJSON$1.default = fromJSON$1; +-let CssSyntaxError22 = cssSyntaxError; +-let Declaration22 = declaration; +-let LazyResult22 = lazyResult; +-let Container22 = container; +-let Processor22 = processor; +-let stringify = stringify_1; +-let fromJSON = fromJSON_1; +-let Document222 = document$1; +-let Warning22 = warning; +-let Comment22 = comment; +-let AtRule22 = atRule; +-let Result22 = result; +-let Input22 = input; +-let parse = parse_1; +-let list = list_1; +-let Rule22 = rule; +-let Root22 = root; +-let Node22 = node; +-function postcss(...plugins) { +- if (plugins.length === 1 && Array.isArray(plugins[0])) { +- plugins = plugins[0]; +- } +- return new Processor22(plugins); +-} +-postcss.plugin = function plugin2(name, initializer) { +- let warningPrinted = false; +- function creator(...args) { +- if (console && console.warn && !warningPrinted) { +- warningPrinted = true; +- console.warn( +- name + ": postcss.plugin was deprecated. Migration guide:\nhttps://evilmartians.com/chronicles/postcss-8-plugin-migration" +- ); +- if (process.env.LANG && process.env.LANG.startsWith("cn")) { +- console.warn( +- name + ": 里面 postcss.plugin 被弃用. 迁移指南:\nhttps://www.w3ctech.com/topic/2226" +- ); ++ ) : slimDOM === false ? {} : slimDOM; ++ return serializeNodeWithId(n2, { ++ doc: n2, ++ mirror: mirror2, ++ blockClass, ++ blockSelector, ++ maskTextClass, ++ maskTextSelector, ++ skipChild: false, ++ inlineStylesheet, ++ maskInputOptions, ++ maskTextFn, ++ maskInputFn, ++ slimDOMOptions, ++ dataURLOptions, ++ inlineImages, ++ recordCanvas, ++ preserveWhiteSpace, ++ onSerialize, ++ onIframeLoad, ++ iframeLoadTimeout, ++ onStylesheetLoad, ++ stylesheetLoadTimeout, ++ keepIframeSrcFn, ++ newlyAddedElement: false ++ }); ++} ++function getDefaultExportFromCjs$1(x2) { ++ return x2 && x2.__esModule && Object.prototype.hasOwnProperty.call(x2, "default") ? x2["default"] : x2; ++} ++function getAugmentedNamespace$1(n2) { ++ if (n2.__esModule) return n2; ++ var f2 = n2.default; ++ if (typeof f2 == "function") { ++ var a2 = function a22() { ++ if (this instanceof a22) { ++ return Reflect.construct(f2, arguments, this.constructor); + } +- } +- let transformer = initializer(...args); +- transformer.postcssPlugin = name; +- transformer.postcssVersion = new Processor22().version; +- return transformer; +- } +- let cache; +- Object.defineProperty(creator, "postcss", { +- get() { +- if (!cache) cache = creator(); +- return cache; +- } ++ return f2.apply(this, arguments); ++ }; ++ a2.prototype = f2.prototype; ++ } else a2 = {}; ++ Object.defineProperty(a2, "__esModule", { value: true }); ++ Object.keys(n2).forEach(function(k) { ++ var d = Object.getOwnPropertyDescriptor(n2, k); ++ Object.defineProperty(a2, k, d.get ? d : { ++ enumerable: true, ++ get: function() { ++ return n2[k]; ++ } ++ }); + }); +- creator.process = function(css, processOpts, pluginOpts) { +- return postcss([creator(pluginOpts)]).process(css, processOpts); +- }; +- return creator; +-}; +-postcss.stringify = stringify; +-postcss.parse = parse; +-postcss.fromJSON = fromJSON; +-postcss.list = list; +-postcss.comment = (defaults) => new Comment22(defaults); +-postcss.atRule = (defaults) => new AtRule22(defaults); +-postcss.decl = (defaults) => new Declaration22(defaults); +-postcss.rule = (defaults) => new Rule22(defaults); +-postcss.root = (defaults) => new Root22(defaults); +-postcss.document = (defaults) => new Document222(defaults); +-postcss.CssSyntaxError = CssSyntaxError22; +-postcss.Declaration = Declaration22; +-postcss.Container = Container22; +-postcss.Processor = Processor22; +-postcss.Document = Document222; +-postcss.Comment = Comment22; +-postcss.Warning = Warning22; +-postcss.AtRule = AtRule22; +-postcss.Result = Result22; +-postcss.Input = Input22; +-postcss.Rule = Rule22; +-postcss.Root = Root22; +-postcss.Node = Node22; +-LazyResult22.registerPostcss(postcss); +-var postcss_1 = postcss; +-postcss.default = postcss; +-const postcss$1 = /* @__PURE__ */ getDefaultExportFromCjs(postcss_1); +-postcss$1.stringify; +-postcss$1.fromJSON; +-postcss$1.plugin; +-postcss$1.parse; +-postcss$1.list; +-postcss$1.document; +-postcss$1.comment; +-postcss$1.atRule; +-postcss$1.rule; +-postcss$1.decl; +-postcss$1.root; +-postcss$1.CssSyntaxError; +-postcss$1.Declaration; +-postcss$1.Container; +-postcss$1.Processor; +-postcss$1.Document; +-postcss$1.Comment; +-postcss$1.Warning; +-postcss$1.AtRule; +-postcss$1.Result; +-postcss$1.Input; +-postcss$1.Rule; +-postcss$1.Root; +-postcss$1.Node; ++ return a2; ++} ++// Removed postcss + class BaseRRNode { + // eslint-disable-next-line @typescript-eslint/no-unused-vars, @typescript-eslint/no-explicit-any + constructor(..._args) { +@@ -11382,11 +4317,19 @@ class CanvasManager { + let rafId; + const getCanvas = () => { + const matchedCanvas = []; +- win.document.querySelectorAll("canvas").forEach((canvas) => { +- if (!isBlocked(canvas, blockClass, blockSelector, true)) { +- matchedCanvas.push(canvas); +- } +- }); ++ const searchCanvas = (root) => { ++ root.querySelectorAll("canvas").forEach((canvas) => { ++ if (!isBlocked(canvas, blockClass, blockSelector, true)) { ++ matchedCanvas.push(canvas); ++ } ++ }); ++ root.querySelectorAll("*").forEach((elem) => { ++ if (elem.shadowRoot) { ++ searchCanvas(elem.shadowRoot); ++ } ++ }); ++ }; ++ searchCanvas(win.document); + return matchedCanvas; + }; + const takeCanvasSnapshots = (timestamp) => { +@@ -11407,13 +4350,20 @@ class CanvasManager { + context.clear(context.COLOR_BUFFER_BIT); + } + } +- const bitmap = await createImageBitmap(canvas); ++ // createImageBitmap throws if resizing to 0 ++ // Fallback to intrinsic size if canvas has not yet rendered ++ const width = canvas.clientWidth || canvas.width; ++ const height = canvas.clientHeight || canvas.height; ++ const bitmap = await createImageBitmap(canvas, { ++ resizeWidth: width, ++ resizeHeight: height ++ }); + worker.postMessage( + { + id, + bitmap, +- width: canvas.width, +- height: canvas.height, ++ width: width, ++ height: height, + dataURLOptions: options.dataURLOptions + }, + [bitmap] diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml index 17fa39ed9..78d1a5fc3 100644 --- a/pnpm-lock.yaml +++ b/pnpm-lock.yaml @@ -5,6 +5,9 @@ settings: excludeLinksFromLockfile: false patchedDependencies: + '@rrweb/record@2.0.0-alpha.17': + hash: ds4wzvngpacxicd464fatv6v44 + path: patches/@rrweb__record@2.0.0-alpha.17.patch '@rrweb/rrweb-plugin-console-record@2.0.0-alpha.17': hash: ytsspyi7p3hvqcq64vqb7wb6bu path: patches/@rrweb__rrweb-plugin-console-record@2.0.0-alpha.17.patch @@ -68,7 +71,7 @@ devDependencies: version: 12.1.1(rollup@4.24.0)(tslib@2.5.0)(typescript@5.5.4) '@rrweb/record': specifier: 2.0.0-alpha.17 - version: 2.0.0-alpha.17 + version: 2.0.0-alpha.17(patch_hash=ds4wzvngpacxicd464fatv6v44) '@rrweb/rrweb-plugin-console-record': specifier: 2.0.0-alpha.17 version: 2.0.0-alpha.17(patch_hash=ytsspyi7p3hvqcq64vqb7wb6bu)(rrweb@2.0.0-alpha.17) @@ -2799,12 +2802,13 @@ packages: dev: true optional: true - /@rrweb/record@2.0.0-alpha.17: + /@rrweb/record@2.0.0-alpha.17(patch_hash=ds4wzvngpacxicd464fatv6v44): resolution: {integrity: sha512-Je+lzjeWMF8/I0IDoXFzkGPKT8j7AkaBup5YcwUHlkp18VhLVze416MvI6915teE27uUA2ScXMXzG0Yiu5VTIw==} dependencies: '@rrweb/types': 2.0.0-alpha.17 rrweb: 2.0.0-alpha.17 dev: true + patched: true /@rrweb/rrweb-plugin-console-record@2.0.0-alpha.17(patch_hash=ytsspyi7p3hvqcq64vqb7wb6bu)(rrweb@2.0.0-alpha.17): resolution: {integrity: sha512-tjNJ3wWUDMMf275xr4Rb5tVYF2UR+wXvSxnyS9tRKnRa574PQQvx7sGbqM/O9AytYjnbiTrAMqNR7OFysGCMwQ==}