@anansi/webpack-config 21.0.12 → 21.1.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/CHANGELOG.md CHANGED
@@ -3,6 +3,30 @@
3
3
  All notable changes to this project will be documented in this file.
4
4
  See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
5
5
 
6
+ ## [21.1.1](/github.com/ntucker/anansi/compare/@anansi/webpack-config@21.1.0...@anansi/webpack-config@21.1.1) (2025-11-15)
7
+
8
+ ### 📦 Package
9
+
10
+ * Update `svgo` to v4 ([#2860](/github.com/ntucker/anansi/issues/2860)) ([0112d1c](/github.com/ntucker/anansi/commit/0112d1c561110005fcf5ee340269dee8fc2e39b8))
11
+ * Update all non-major dependencies ([#2866](/github.com/ntucker/anansi/issues/2866)) ([930d19a](/github.com/ntucker/anansi/commit/930d19aa7ff8768fb2ba9f220543374435c25fbf))
12
+
13
+ ## [21.1.0](/github.com/ntucker/anansi/compare/@anansi/webpack-config@21.0.12...@anansi/webpack-config@21.1.0) (2025-11-09)
14
+
15
+ ### 🚀 Features
16
+
17
+ * Storybook 9 compatibility ([#2851](/github.com/ntucker/anansi/issues/2851)) ([a1daa39](/github.com/ntucker/anansi/commit/a1daa394e453eec8b07695d4eac88c648c169596))
18
+ * Support storybook 10 ([#2853](/github.com/ntucker/anansi/issues/2853)) ([a3179e9](/github.com/ntucker/anansi/commit/a3179e90c46afa459779634cae5d4a65fb399540))
19
+
20
+ ### 🐛 Bug Fix
21
+
22
+ * Modern sass compatibility ([72fd5f6](/github.com/ntucker/anansi/commit/72fd5f6ea98e928c403fa07a3ea38ebd44353568))
23
+
24
+ ### 📦 Package
25
+
26
+ * Update all non-major dependencies ([#2858](/github.com/ntucker/anansi/issues/2858)) ([ea62701](/github.com/ntucker/anansi/commit/ea6270186daa1634ef55e2cbd158879bcfc6bbdd))
27
+ * Update webpack packages ([#2828](/github.com/ntucker/anansi/issues/2828)) ([fdbc282](/github.com/ntucker/anansi/commit/fdbc282e43b40afa2c85a650571e9ace4e99ba65))
28
+ * Upgrade @pmmmwh/react-refresh-webpack-plugin@^0.6.1 ([#2854](/github.com/ntucker/anansi/issues/2854)) ([68c5b66](/github.com/ntucker/anansi/commit/68c5b660f48bcc0e89357e58919aab9890094148))
29
+
6
30
  ## [21.0.12](/github.com/ntucker/anansi/compare/@anansi/webpack-config@21.0.11...@anansi/webpack-config@21.0.12) (2025-10-14)
7
31
 
8
32
  ### 📦 Package
@@ -0,0 +1,24 @@
1
+ const {
2
+ makeConfig
3
+ } = require('../../../src/index');
4
+ const fixtureRoot = __dirname;
5
+
6
+ // Wrap makeConfig to inject entrypath into env
7
+ const baseConfig = makeConfig({
8
+ rootPath: fixtureRoot,
9
+ basePath: 'src',
10
+ buildDir: 'dist',
11
+ tsconfigPathsOptions: false,
12
+ babelLoader: {
13
+ rootMode: 'upward'
14
+ }
15
+ });
16
+ module.exports = (env = {}, argv) => {
17
+ // Set explicit entry path relative to rootPath with full extension
18
+ const envWithEntry = {
19
+ ...env,
20
+ entrypath: env.entrypath || './src/index.jsx'
21
+ };
22
+ return baseConfig(envWithEntry, argv);
23
+ };
24
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJtYWtlQ29uZmlnIiwicmVxdWlyZSIsImZpeHR1cmVSb290IiwiX19kaXJuYW1lIiwiYmFzZUNvbmZpZyIsInJvb3RQYXRoIiwiYmFzZVBhdGgiLCJidWlsZERpciIsInRzY29uZmlnUGF0aHNPcHRpb25zIiwiYmFiZWxMb2FkZXIiLCJyb290TW9kZSIsIm1vZHVsZSIsImV4cG9ydHMiLCJlbnYiLCJhcmd2IiwiZW52V2l0aEVudHJ5IiwiZW50cnlwYXRoIl0sInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL19fZml4dHVyZXNfXy9jc3MtbW9kdWxlcy93ZWJwYWNrLmNvbmZpZy5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJjb25zdCB7IG1ha2VDb25maWcgfSA9IHJlcXVpcmUoJy4uLy4uLy4uL3NyYy9pbmRleCcpO1xuXG5jb25zdCBmaXh0dXJlUm9vdCA9IF9fZGlybmFtZTtcblxuLy8gV3JhcCBtYWtlQ29uZmlnIHRvIGluamVjdCBlbnRyeXBhdGggaW50byBlbnZcbmNvbnN0IGJhc2VDb25maWcgPSBtYWtlQ29uZmlnKHtcbiAgcm9vdFBhdGg6IGZpeHR1cmVSb290LFxuICBiYXNlUGF0aDogJ3NyYycsXG4gIGJ1aWxkRGlyOiAnZGlzdCcsXG4gIHRzY29uZmlnUGF0aHNPcHRpb25zOiBmYWxzZSxcbiAgYmFiZWxMb2FkZXI6IHtcbiAgICByb290TW9kZTogJ3Vwd2FyZCcsXG4gIH0sXG59KTtcblxubW9kdWxlLmV4cG9ydHMgPSAoZW52ID0ge30sIGFyZ3YpID0+IHtcbiAgLy8gU2V0IGV4cGxpY2l0IGVudHJ5IHBhdGggcmVsYXRpdmUgdG8gcm9vdFBhdGggd2l0aCBmdWxsIGV4dGVuc2lvblxuICBjb25zdCBlbnZXaXRoRW50cnkgPSB7XG4gICAgLi4uZW52LFxuICAgIGVudHJ5cGF0aDogZW52LmVudHJ5cGF0aCB8fCAnLi9zcmMvaW5kZXguanN4JyxcbiAgfTtcbiAgcmV0dXJuIGJhc2VDb25maWcoZW52V2l0aEVudHJ5LCBhcmd2KTtcbn07XG4iXSwibWFwcGluZ3MiOiJBQUFBLE1BQU07RUFBRUE7QUFBVyxDQUFDLEdBQUdDLE9BQU8sQ0FBQyxvQkFBb0IsQ0FBQztBQUVwRCxNQUFNQyxXQUFXLEdBQUdDLFNBQVM7O0FBRTdCO0FBQ0EsTUFBTUMsVUFBVSxHQUFHSixVQUFVLENBQUM7RUFDNUJLLFFBQVEsRUFBRUgsV0FBVztFQUNyQkksUUFBUSxFQUFFLEtBQUs7RUFDZkMsUUFBUSxFQUFFLE1BQU07RUFDaEJDLG9CQUFvQixFQUFFLEtBQUs7RUFDM0JDLFdBQVcsRUFBRTtJQUNYQyxRQUFRLEVBQUU7RUFDWjtBQUNGLENBQUMsQ0FBQztBQUVGQyxNQUFNLENBQUNDLE9BQU8sR0FBRyxDQUFDQyxHQUFHLEdBQUcsQ0FBQyxDQUFDLEVBQUVDLElBQUksS0FBSztFQUNuQztFQUNBLE1BQU1DLFlBQVksR0FBRztJQUNuQixHQUFHRixHQUFHO0lBQ05HLFNBQVMsRUFBRUgsR0FBRyxDQUFDRyxTQUFTLElBQUk7RUFDOUIsQ0FBQztFQUNELE9BQU9aLFVBQVUsQ0FBQ1csWUFBWSxFQUFFRCxJQUFJLENBQUM7QUFDdkMsQ0FBQyIsImlnbm9yZUxpc3QiOltdfQ==
@@ -0,0 +1,263 @@
1
+ var _jsxFileName = "/home/ntucker/src/anansi/packages/webpack-config-anansi/src/__fixtures__/linaria/src/index.tsx";
2
+ import { css } from '@linaria/core';
3
+ import { styled } from '@linaria/react';
4
+ import React from 'react';
5
+
6
+ // Basic styled component
7
+ import { jsxDEV as _jsxDEV, Fragment as _Fragment } from "react/jsx-dev-runtime";
8
+ const Button = styled.button`
9
+ background-color: blue;
10
+ color: white;
11
+ padding: 8px 16px;
12
+ border: none;
13
+ cursor: pointer;
14
+
15
+ &:hover {
16
+ background-color: darkblue;
17
+ }
18
+ `;
19
+
20
+ // Styled component with props and interpolations
21
+
22
+ const Container = styled.div`
23
+ padding: ${props => props.size || '16px'};
24
+ background-color: ${props => props.color || 'white'};
25
+ display: flex;
26
+ flex-direction: column;
27
+ gap: 8px;
28
+ `;
29
+
30
+ // Base component to be extended
31
+ const Base = styled.div`
32
+ padding: 16px;
33
+ border: 1px solid #ccc;
34
+ `;
35
+
36
+ // Extended styled component
37
+ const Extended = styled(Base)`
38
+ margin: 8px;
39
+ border-width: 2px;
40
+ `;
41
+
42
+ // CSS tagged template with variable interpolations
43
+ const color = 'blue';
44
+ const fontSize = '16px';
45
+ const stylesWithVars = css`
46
+ color: ${color};
47
+ font-size: ${fontSize};
48
+ `;
49
+
50
+ // CSS with nested selectors
51
+ const nestedStyles = css`
52
+ .container {
53
+ display: flex;
54
+ flex-direction: column;
55
+ }
56
+
57
+ .item {
58
+ padding: 8px;
59
+ }
60
+ `;
61
+
62
+ // Styled component with nested selectors including component references
63
+ const StyledContainer = styled.div`
64
+ padding: 16px;
65
+
66
+ ${Button} {
67
+ margin: 8px;
68
+ }
69
+
70
+ .icon {
71
+ margin-right: 8px;
72
+ }
73
+ `;
74
+
75
+ // Styled component with TypeScript props interface
76
+
77
+ const TypedButton = styled.button`
78
+ background-color: ${props => props.primary ? 'blue' : 'gray'};
79
+ color: white;
80
+ padding: 8px 16px;
81
+ `;
82
+
83
+ // Styled component with media queries
84
+ const media = {
85
+ tablet: '768px',
86
+ desktop: '1024px'
87
+ };
88
+ const ResponsiveContainer = styled.div`
89
+ padding: 16px;
90
+
91
+ @media (min-width: ${media.tablet}) {
92
+ padding: 24px;
93
+ }
94
+
95
+ @media (min-width: ${media.desktop}) {
96
+ padding: 32px;
97
+ }
98
+ `;
99
+
100
+ // Styled component with CSS variables
101
+ const CSSVarContainer = styled.div`
102
+ --main-color: blue;
103
+ --padding-size: 16px;
104
+
105
+ color: var(--main-color);
106
+ padding: var(--padding-size);
107
+ `;
108
+
109
+ // Global styles with :global() selector
110
+ const globalStyles = css`
111
+ :global() {
112
+ body {
113
+ margin: 0;
114
+ font-family: sans-serif;
115
+ }
116
+ }
117
+ `;
118
+
119
+ // Styled component with conditional styles
120
+ const ConditionalButton = styled.button`
121
+ padding: 8px 16px;
122
+ border: none;
123
+ cursor: pointer;
124
+
125
+ ${props => props.disabled ? `
126
+ opacity: 0.5;
127
+ cursor: not-allowed;
128
+ ` : ``}
129
+ `;
130
+
131
+ // Header style
132
+ const header = css`
133
+ text-transform: uppercase;
134
+ font-size: 24px;
135
+ margin-bottom: 16px;
136
+ `;
137
+ function App({
138
+ name = 'Linaria'
139
+ }) {
140
+ return /*#__PURE__*/_jsxDEV(_Fragment, {
141
+ children: [/*#__PURE__*/_jsxDEV("div", {
142
+ className: globalStyles
143
+ }, void 0, false, {
144
+ fileName: _jsxFileName,
145
+ lineNumber: 154,
146
+ columnNumber: 7
147
+ }, this), /*#__PURE__*/_jsxDEV(ResponsiveContainer, {
148
+ children: [/*#__PURE__*/_jsxDEV("h1", {
149
+ className: header,
150
+ children: ["Hello from ", name, " fixture"]
151
+ }, void 0, true, {
152
+ fileName: _jsxFileName,
153
+ lineNumber: 156,
154
+ columnNumber: 9
155
+ }, this), /*#__PURE__*/_jsxDEV(Container, {
156
+ size: "24px",
157
+ color: "red",
158
+ children: [/*#__PURE__*/_jsxDEV(Button, {
159
+ children: "Click me"
160
+ }, void 0, false, {
161
+ fileName: _jsxFileName,
162
+ lineNumber: 158,
163
+ columnNumber: 11
164
+ }, this), /*#__PURE__*/_jsxDEV(TypedButton, {
165
+ primary: true,
166
+ children: "Primary Button"
167
+ }, void 0, false, {
168
+ fileName: _jsxFileName,
169
+ lineNumber: 159,
170
+ columnNumber: 11
171
+ }, this), /*#__PURE__*/_jsxDEV(TypedButton, {
172
+ children: "Secondary Button"
173
+ }, void 0, false, {
174
+ fileName: _jsxFileName,
175
+ lineNumber: 160,
176
+ columnNumber: 11
177
+ }, this)]
178
+ }, void 0, true, {
179
+ fileName: _jsxFileName,
180
+ lineNumber: 157,
181
+ columnNumber: 9
182
+ }, this), /*#__PURE__*/_jsxDEV(Extended, {
183
+ children: "Extended Component"
184
+ }, void 0, false, {
185
+ fileName: _jsxFileName,
186
+ lineNumber: 162,
187
+ columnNumber: 9
188
+ }, this), /*#__PURE__*/_jsxDEV("div", {
189
+ className: stylesWithVars,
190
+ children: "CSS with variable interpolations"
191
+ }, void 0, false, {
192
+ fileName: _jsxFileName,
193
+ lineNumber: 163,
194
+ columnNumber: 9
195
+ }, this), /*#__PURE__*/_jsxDEV("div", {
196
+ className: nestedStyles,
197
+ children: /*#__PURE__*/_jsxDEV("div", {
198
+ className: "container",
199
+ children: /*#__PURE__*/_jsxDEV("div", {
200
+ className: "item",
201
+ children: "Nested styles"
202
+ }, void 0, false, {
203
+ fileName: _jsxFileName,
204
+ lineNumber: 166,
205
+ columnNumber: 13
206
+ }, this)
207
+ }, void 0, false, {
208
+ fileName: _jsxFileName,
209
+ lineNumber: 165,
210
+ columnNumber: 11
211
+ }, this)
212
+ }, void 0, false, {
213
+ fileName: _jsxFileName,
214
+ lineNumber: 164,
215
+ columnNumber: 9
216
+ }, this), /*#__PURE__*/_jsxDEV(StyledContainer, {
217
+ children: [/*#__PURE__*/_jsxDEV(Button, {
218
+ children: "Button inside styled container"
219
+ }, void 0, false, {
220
+ fileName: _jsxFileName,
221
+ lineNumber: 170,
222
+ columnNumber: 11
223
+ }, this), /*#__PURE__*/_jsxDEV("span", {
224
+ className: "icon",
225
+ children: "Icon"
226
+ }, void 0, false, {
227
+ fileName: _jsxFileName,
228
+ lineNumber: 171,
229
+ columnNumber: 11
230
+ }, this)]
231
+ }, void 0, true, {
232
+ fileName: _jsxFileName,
233
+ lineNumber: 169,
234
+ columnNumber: 9
235
+ }, this), /*#__PURE__*/_jsxDEV(CSSVarContainer, {
236
+ children: "CSS Variables"
237
+ }, void 0, false, {
238
+ fileName: _jsxFileName,
239
+ lineNumber: 173,
240
+ columnNumber: 9
241
+ }, this), /*#__PURE__*/_jsxDEV(ConditionalButton, {
242
+ children: "Normal Button"
243
+ }, void 0, false, {
244
+ fileName: _jsxFileName,
245
+ lineNumber: 174,
246
+ columnNumber: 9
247
+ }, this), /*#__PURE__*/_jsxDEV(ConditionalButton, {
248
+ disabled: true,
249
+ children: "Disabled Button"
250
+ }, void 0, false, {
251
+ fileName: _jsxFileName,
252
+ lineNumber: 175,
253
+ columnNumber: 9
254
+ }, this)]
255
+ }, void 0, true, {
256
+ fileName: _jsxFileName,
257
+ lineNumber: 155,
258
+ columnNumber: 7
259
+ }, this)]
260
+ }, void 0, true);
261
+ }
262
+ export default App;
263
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["css","styled","React","jsxDEV","_jsxDEV","Fragment","_Fragment","Button","button","Container","div","props","size","color","Base","Extended","fontSize","stylesWithVars","nestedStyles","StyledContainer","TypedButton","primary","media","tablet","desktop","ResponsiveContainer","CSSVarContainer","globalStyles","ConditionalButton","disabled","header","App","name","children","className","fileName","_jsxFileName","lineNumber","columnNumber"],"sources":["../../../../src/__fixtures__/linaria/src/index.tsx"],"sourcesContent":["import { css } from '@linaria/core';\nimport { styled } from '@linaria/react';\nimport React from 'react';\n\n// Basic styled component\nconst Button = styled.button`\n  background-color: blue;\n  color: white;\n  padding: 8px 16px;\n  border: none;\n  cursor: pointer;\n\n  &:hover {\n    background-color: darkblue;\n  }\n`;\n\n// Styled component with props and interpolations\ninterface ContainerProps {\n  size?: string;\n  color?: string;\n}\n\nconst Container = styled.div<ContainerProps>`\n  padding: ${props => props.size || '16px'};\n  background-color: ${props => props.color || 'white'};\n  display: flex;\n  flex-direction: column;\n  gap: 8px;\n`;\n\n// Base component to be extended\nconst Base = styled.div`\n  padding: 16px;\n  border: 1px solid #ccc;\n`;\n\n// Extended styled component\nconst Extended = styled(Base)`\n  margin: 8px;\n  border-width: 2px;\n`;\n\n// CSS tagged template with variable interpolations\nconst color = 'blue';\nconst fontSize = '16px';\nconst stylesWithVars = css`\n  color: ${color};\n  font-size: ${fontSize};\n`;\n\n// CSS with nested selectors\nconst nestedStyles = css`\n  .container {\n    display: flex;\n    flex-direction: column;\n  }\n\n  .item {\n    padding: 8px;\n  }\n`;\n\n// Styled component with nested selectors including component references\nconst StyledContainer = styled.div`\n  padding: 16px;\n\n  ${Button} {\n    margin: 8px;\n  }\n\n  .icon {\n    margin-right: 8px;\n  }\n`;\n\n// Styled component with TypeScript props interface\ninterface ButtonProps {\n  primary?: boolean;\n}\n\nconst TypedButton = styled.button<ButtonProps>`\n  background-color: ${props => (props.primary ? 'blue' : 'gray')};\n  color: white;\n  padding: 8px 16px;\n`;\n\n// Styled component with media queries\nconst media = {\n  tablet: '768px',\n  desktop: '1024px',\n};\n\nconst ResponsiveContainer = styled.div`\n  padding: 16px;\n\n  @media (min-width: ${media.tablet}) {\n    padding: 24px;\n  }\n\n  @media (min-width: ${media.desktop}) {\n    padding: 32px;\n  }\n`;\n\n// Styled component with CSS variables\nconst CSSVarContainer = styled.div`\n  --main-color: blue;\n  --padding-size: 16px;\n\n  color: var(--main-color);\n  padding: var(--padding-size);\n`;\n\n// Global styles with :global() selector\nconst globalStyles = css`\n  :global() {\n    body {\n      margin: 0;\n      font-family: sans-serif;\n    }\n  }\n`;\n\n// Styled component with conditional styles\nconst ConditionalButton = styled.button<{ disabled?: boolean }>`\n  padding: 8px 16px;\n  border: none;\n  cursor: pointer;\n\n  ${props =>\n    props.disabled ?\n      `\n    opacity: 0.5;\n    cursor: not-allowed;\n  `\n    : ``}\n`;\n\n// Header style\nconst header = css`\n  text-transform: uppercase;\n  font-size: 24px;\n  margin-bottom: 16px;\n`;\n\ninterface AppProps {\n  name?: string;\n}\n\nfunction App({ name = 'Linaria' }: AppProps) {\n  return (\n    <>\n      <div className={globalStyles} />\n      <ResponsiveContainer>\n        <h1 className={header}>Hello from {name} fixture</h1>\n        <Container size=\"24px\" color=\"red\">\n          <Button>Click me</Button>\n          <TypedButton primary>Primary Button</TypedButton>\n          <TypedButton>Secondary Button</TypedButton>\n        </Container>\n        <Extended>Extended Component</Extended>\n        <div className={stylesWithVars}>CSS with variable interpolations</div>\n        <div className={nestedStyles}>\n          <div className=\"container\">\n            <div className=\"item\">Nested styles</div>\n          </div>\n        </div>\n        <StyledContainer>\n          <Button>Button inside styled container</Button>\n          <span className=\"icon\">Icon</span>\n        </StyledContainer>\n        <CSSVarContainer>CSS Variables</CSSVarContainer>\n        <ConditionalButton>Normal Button</ConditionalButton>\n        <ConditionalButton disabled>Disabled Button</ConditionalButton>\n      </ResponsiveContainer>\n    </>\n  );\n}\n\nexport default App;\n"],"mappings":"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","ignoreList":[]}
@@ -0,0 +1,25 @@
1
+ const {
2
+ makeConfig
3
+ } = require('../../../src/index');
4
+ const fixtureRoot = __dirname;
5
+
6
+ // Wrap makeConfig to inject entrypath into env
7
+ const baseConfig = makeConfig({
8
+ rootPath: fixtureRoot,
9
+ basePath: 'src',
10
+ buildDir: 'dist',
11
+ tsconfigPathsOptions: false,
12
+ babelLoader: {
13
+ rootMode: 'upward'
14
+ }
15
+ // inJSOptions defaults to enabled (uses @wyw-in-js/webpack-loader for Linaria)
16
+ });
17
+ module.exports = (env = {}, argv) => {
18
+ // Set explicit entry path relative to rootPath with full extension
19
+ const envWithEntry = {
20
+ ...env,
21
+ entrypath: env.entrypath || './src/index.tsx'
22
+ };
23
+ return baseConfig(envWithEntry, argv);
24
+ };
25
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJtYWtlQ29uZmlnIiwicmVxdWlyZSIsImZpeHR1cmVSb290IiwiX19kaXJuYW1lIiwiYmFzZUNvbmZpZyIsInJvb3RQYXRoIiwiYmFzZVBhdGgiLCJidWlsZERpciIsInRzY29uZmlnUGF0aHNPcHRpb25zIiwiYmFiZWxMb2FkZXIiLCJyb290TW9kZSIsIm1vZHVsZSIsImV4cG9ydHMiLCJlbnYiLCJhcmd2IiwiZW52V2l0aEVudHJ5IiwiZW50cnlwYXRoIl0sInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL19fZml4dHVyZXNfXy9saW5hcmlhL3dlYnBhY2suY29uZmlnLmpzIl0sInNvdXJjZXNDb250ZW50IjpbImNvbnN0IHsgbWFrZUNvbmZpZyB9ID0gcmVxdWlyZSgnLi4vLi4vLi4vc3JjL2luZGV4Jyk7XG5cbmNvbnN0IGZpeHR1cmVSb290ID0gX19kaXJuYW1lO1xuXG4vLyBXcmFwIG1ha2VDb25maWcgdG8gaW5qZWN0IGVudHJ5cGF0aCBpbnRvIGVudlxuY29uc3QgYmFzZUNvbmZpZyA9IG1ha2VDb25maWcoe1xuICByb290UGF0aDogZml4dHVyZVJvb3QsXG4gIGJhc2VQYXRoOiAnc3JjJyxcbiAgYnVpbGREaXI6ICdkaXN0JyxcbiAgdHNjb25maWdQYXRoc09wdGlvbnM6IGZhbHNlLFxuICBiYWJlbExvYWRlcjoge1xuICAgIHJvb3RNb2RlOiAndXB3YXJkJyxcbiAgfSxcbiAgLy8gaW5KU09wdGlvbnMgZGVmYXVsdHMgdG8gZW5hYmxlZCAodXNlcyBAd3l3LWluLWpzL3dlYnBhY2stbG9hZGVyIGZvciBMaW5hcmlhKVxufSk7XG5cbm1vZHVsZS5leHBvcnRzID0gKGVudiA9IHt9LCBhcmd2KSA9PiB7XG4gIC8vIFNldCBleHBsaWNpdCBlbnRyeSBwYXRoIHJlbGF0aXZlIHRvIHJvb3RQYXRoIHdpdGggZnVsbCBleHRlbnNpb25cbiAgY29uc3QgZW52V2l0aEVudHJ5ID0ge1xuICAgIC4uLmVudixcbiAgICBlbnRyeXBhdGg6IGVudi5lbnRyeXBhdGggfHwgJy4vc3JjL2luZGV4LnRzeCcsXG4gIH07XG4gIHJldHVybiBiYXNlQ29uZmlnKGVudldpdGhFbnRyeSwgYXJndik7XG59O1xuIl0sIm1hcHBpbmdzIjoiQUFBQSxNQUFNO0VBQUVBO0FBQVcsQ0FBQyxHQUFHQyxPQUFPLENBQUMsb0JBQW9CLENBQUM7QUFFcEQsTUFBTUMsV0FBVyxHQUFHQyxTQUFTOztBQUU3QjtBQUNBLE1BQU1DLFVBQVUsR0FBR0osVUFBVSxDQUFDO0VBQzVCSyxRQUFRLEVBQUVILFdBQVc7RUFDckJJLFFBQVEsRUFBRSxLQUFLO0VBQ2ZDLFFBQVEsRUFBRSxNQUFNO0VBQ2hCQyxvQkFBb0IsRUFBRSxLQUFLO0VBQzNCQyxXQUFXLEVBQUU7SUFDWEMsUUFBUSxFQUFFO0VBQ1o7RUFDQTtBQUNGLENBQUMsQ0FBQztBQUVGQyxNQUFNLENBQUNDLE9BQU8sR0FBRyxDQUFDQyxHQUFHLEdBQUcsQ0FBQyxDQUFDLEVBQUVDLElBQUksS0FBSztFQUNuQztFQUNBLE1BQU1DLFlBQVksR0FBRztJQUNuQixHQUFHRixHQUFHO0lBQ05HLFNBQVMsRUFBRUgsR0FBRyxDQUFDRyxTQUFTLElBQUk7RUFDOUIsQ0FBQztFQUNELE9BQU9aLFVBQVUsQ0FBQ1csWUFBWSxFQUFFRCxJQUFJLENBQUM7QUFDdkMsQ0FBQyIsImlnbm9yZUxpc3QiOltdfQ==
@@ -0,0 +1,22 @@
1
+ var _jsxFileName = "/home/ntucker/src/anansi/packages/webpack-config-anansi/src/__fixtures__/ts/src/index.tsx";
2
+ import React from 'react';
3
+ import { jsxDEV as _jsxDEV } from "react/jsx-dev-runtime";
4
+ function App({
5
+ name = 'TypeScript'
6
+ }) {
7
+ return /*#__PURE__*/_jsxDEV("div", {
8
+ children: /*#__PURE__*/_jsxDEV("h1", {
9
+ children: ["Hello from ", name, " fixture"]
10
+ }, void 0, true, {
11
+ fileName: _jsxFileName,
12
+ lineNumber: 10,
13
+ columnNumber: 7
14
+ }, this)
15
+ }, void 0, false, {
16
+ fileName: _jsxFileName,
17
+ lineNumber: 9,
18
+ columnNumber: 5
19
+ }, this);
20
+ }
21
+ export default App;
22
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJSZWFjdCIsImpzeERFViIsIl9qc3hERVYiLCJBcHAiLCJuYW1lIiwiY2hpbGRyZW4iLCJmaWxlTmFtZSIsIl9qc3hGaWxlTmFtZSIsImxpbmVOdW1iZXIiLCJjb2x1bW5OdW1iZXIiXSwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvX19maXh0dXJlc19fL3RzL3NyYy9pbmRleC50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcblxuaW50ZXJmYWNlIEFwcFByb3BzIHtcbiAgbmFtZT86IHN0cmluZztcbn1cblxuZnVuY3Rpb24gQXBwKHsgbmFtZSA9ICdUeXBlU2NyaXB0JyB9OiBBcHBQcm9wcykge1xuICByZXR1cm4gKFxuICAgIDxkaXY+XG4gICAgICA8aDE+SGVsbG8gZnJvbSB7bmFtZX0gZml4dHVyZTwvaDE+XG4gICAgPC9kaXY+XG4gICk7XG59XG5cbmV4cG9ydCBkZWZhdWx0IEFwcDtcbiJdLCJtYXBwaW5ncyI6IjtBQUFBLE9BQU9BLEtBQUssTUFBTSxPQUFPO0FBQUMsU0FBQUMsTUFBQSxJQUFBQyxPQUFBO0FBTTFCLFNBQVNDLEdBQUdBLENBQUM7RUFBRUMsSUFBSSxHQUFHO0FBQXVCLENBQUMsRUFBRTtFQUM5QyxvQkFDRUYsT0FBQTtJQUFBRyxRQUFBLGVBQ0VILE9BQUE7TUFBQUcsUUFBQSxHQUFJLGFBQVcsRUFBQ0QsSUFBSSxFQUFDLFVBQVE7SUFBQTtNQUFBRSxRQUFBLEVBQUFDLFlBQUE7TUFBQUMsVUFBQTtNQUFBQyxZQUFBO0lBQUEsT0FBSTtFQUFDO0lBQUFILFFBQUEsRUFBQUMsWUFBQTtJQUFBQyxVQUFBO0lBQUFDLFlBQUE7RUFBQSxPQUMvQixDQUFDO0FBRVY7QUFFQSxlQUFlTixHQUFHIiwiaWdub3JlTGlzdCI6W119
@@ -0,0 +1,24 @@
1
+ const {
2
+ makeConfig
3
+ } = require('../../../src/index');
4
+ const fixtureRoot = __dirname;
5
+
6
+ // Wrap makeConfig to inject entrypath into env
7
+ const baseConfig = makeConfig({
8
+ rootPath: fixtureRoot,
9
+ basePath: 'src',
10
+ buildDir: 'dist',
11
+ tsconfigPathsOptions: false,
12
+ babelLoader: {
13
+ rootMode: 'upward'
14
+ }
15
+ });
16
+ module.exports = (env = {}, argv) => {
17
+ // Set explicit entry path relative to rootPath with full extension
18
+ const envWithEntry = {
19
+ ...env,
20
+ entrypath: env.entrypath || './src/index.tsx'
21
+ };
22
+ return baseConfig(envWithEntry, argv);
23
+ };
24
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJtYWtlQ29uZmlnIiwicmVxdWlyZSIsImZpeHR1cmVSb290IiwiX19kaXJuYW1lIiwiYmFzZUNvbmZpZyIsInJvb3RQYXRoIiwiYmFzZVBhdGgiLCJidWlsZERpciIsInRzY29uZmlnUGF0aHNPcHRpb25zIiwiYmFiZWxMb2FkZXIiLCJyb290TW9kZSIsIm1vZHVsZSIsImV4cG9ydHMiLCJlbnYiLCJhcmd2IiwiZW52V2l0aEVudHJ5IiwiZW50cnlwYXRoIl0sInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL19fZml4dHVyZXNfXy90cy93ZWJwYWNrLmNvbmZpZy5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJjb25zdCB7IG1ha2VDb25maWcgfSA9IHJlcXVpcmUoJy4uLy4uLy4uL3NyYy9pbmRleCcpO1xuXG5jb25zdCBmaXh0dXJlUm9vdCA9IF9fZGlybmFtZTtcblxuLy8gV3JhcCBtYWtlQ29uZmlnIHRvIGluamVjdCBlbnRyeXBhdGggaW50byBlbnZcbmNvbnN0IGJhc2VDb25maWcgPSBtYWtlQ29uZmlnKHtcbiAgcm9vdFBhdGg6IGZpeHR1cmVSb290LFxuICBiYXNlUGF0aDogJ3NyYycsXG4gIGJ1aWxkRGlyOiAnZGlzdCcsXG4gIHRzY29uZmlnUGF0aHNPcHRpb25zOiBmYWxzZSxcbiAgYmFiZWxMb2FkZXI6IHtcbiAgICByb290TW9kZTogJ3Vwd2FyZCcsXG4gIH0sXG59KTtcblxubW9kdWxlLmV4cG9ydHMgPSAoZW52ID0ge30sIGFyZ3YpID0+IHtcbiAgLy8gU2V0IGV4cGxpY2l0IGVudHJ5IHBhdGggcmVsYXRpdmUgdG8gcm9vdFBhdGggd2l0aCBmdWxsIGV4dGVuc2lvblxuICBjb25zdCBlbnZXaXRoRW50cnkgPSB7XG4gICAgLi4uZW52LFxuICAgIGVudHJ5cGF0aDogZW52LmVudHJ5cGF0aCB8fCAnLi9zcmMvaW5kZXgudHN4JyxcbiAgfTtcbiAgcmV0dXJuIGJhc2VDb25maWcoZW52V2l0aEVudHJ5LCBhcmd2KTtcbn07XG4iXSwibWFwcGluZ3MiOiJBQUFBLE1BQU07RUFBRUE7QUFBVyxDQUFDLEdBQUdDLE9BQU8sQ0FBQyxvQkFBb0IsQ0FBQztBQUVwRCxNQUFNQyxXQUFXLEdBQUdDLFNBQVM7O0FBRTdCO0FBQ0EsTUFBTUMsVUFBVSxHQUFHSixVQUFVLENBQUM7RUFDNUJLLFFBQVEsRUFBRUgsV0FBVztFQUNyQkksUUFBUSxFQUFFLEtBQUs7RUFDZkMsUUFBUSxFQUFFLE1BQU07RUFDaEJDLG9CQUFvQixFQUFFLEtBQUs7RUFDM0JDLFdBQVcsRUFBRTtJQUNYQyxRQUFRLEVBQUU7RUFDWjtBQUNGLENBQUMsQ0FBQztBQUVGQyxNQUFNLENBQUNDLE9BQU8sR0FBRyxDQUFDQyxHQUFHLEdBQUcsQ0FBQyxDQUFDLEVBQUVDLElBQUksS0FBSztFQUNuQztFQUNBLE1BQU1DLFlBQVksR0FBRztJQUNuQixHQUFHRixHQUFHO0lBQ05HLFNBQVMsRUFBRUgsR0FBRyxDQUFDRyxTQUFTLElBQUk7RUFDOUIsQ0FBQztFQUNELE9BQU9aLFVBQVUsQ0FBQ1csWUFBWSxFQUFFRCxJQUFJLENBQUM7QUFDdkMsQ0FBQyIsImlnbm9yZUxpc3QiOltdfQ==
@@ -0,0 +1,2 @@
1
+ console.log('Hello from webpack-basic fixture');
2
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJjb25zb2xlIiwibG9nIl0sInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL19fZml4dHVyZXNfXy93ZWJwYWNrLWJhc2ljL3NyYy9pbmRleC5qcyJdLCJzb3VyY2VzQ29udGVudCI6WyJjb25zb2xlLmxvZygnSGVsbG8gZnJvbSB3ZWJwYWNrLWJhc2ljIGZpeHR1cmUnKTtcbiJdLCJtYXBwaW5ncyI6IkFBQUFBLE9BQU8sQ0FBQ0MsR0FBRyxDQUFDLGtDQUFrQyxDQUFDIiwiaWdub3JlTGlzdCI6W119
@@ -0,0 +1,24 @@
1
+ const {
2
+ makeConfig
3
+ } = require('../../../src/index');
4
+ const fixtureRoot = __dirname;
5
+
6
+ // Wrap makeConfig to inject entrypath into env
7
+ const baseConfig = makeConfig({
8
+ rootPath: fixtureRoot,
9
+ basePath: 'src',
10
+ buildDir: 'dist',
11
+ tsconfigPathsOptions: false,
12
+ babelLoader: {
13
+ rootMode: 'upward'
14
+ }
15
+ });
16
+ module.exports = (env = {}, argv) => {
17
+ // Set explicit entry path relative to rootPath with full extension
18
+ const envWithEntry = {
19
+ ...env,
20
+ entrypath: env.entrypath || './src/index.js'
21
+ };
22
+ return baseConfig(envWithEntry, argv);
23
+ };
24
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJtYWtlQ29uZmlnIiwicmVxdWlyZSIsImZpeHR1cmVSb290IiwiX19kaXJuYW1lIiwiYmFzZUNvbmZpZyIsInJvb3RQYXRoIiwiYmFzZVBhdGgiLCJidWlsZERpciIsInRzY29uZmlnUGF0aHNPcHRpb25zIiwiYmFiZWxMb2FkZXIiLCJyb290TW9kZSIsIm1vZHVsZSIsImV4cG9ydHMiLCJlbnYiLCJhcmd2IiwiZW52V2l0aEVudHJ5IiwiZW50cnlwYXRoIl0sInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL19fZml4dHVyZXNfXy93ZWJwYWNrLWJhc2ljL3dlYnBhY2suY29uZmlnLmpzIl0sInNvdXJjZXNDb250ZW50IjpbImNvbnN0IHsgbWFrZUNvbmZpZyB9ID0gcmVxdWlyZSgnLi4vLi4vLi4vc3JjL2luZGV4Jyk7XG5cbmNvbnN0IGZpeHR1cmVSb290ID0gX19kaXJuYW1lO1xuXG4vLyBXcmFwIG1ha2VDb25maWcgdG8gaW5qZWN0IGVudHJ5cGF0aCBpbnRvIGVudlxuY29uc3QgYmFzZUNvbmZpZyA9IG1ha2VDb25maWcoe1xuICByb290UGF0aDogZml4dHVyZVJvb3QsXG4gIGJhc2VQYXRoOiAnc3JjJyxcbiAgYnVpbGREaXI6ICdkaXN0JyxcbiAgdHNjb25maWdQYXRoc09wdGlvbnM6IGZhbHNlLFxuICBiYWJlbExvYWRlcjoge1xuICAgIHJvb3RNb2RlOiAndXB3YXJkJyxcbiAgfSxcbn0pO1xuXG5tb2R1bGUuZXhwb3J0cyA9IChlbnYgPSB7fSwgYXJndikgPT4ge1xuICAvLyBTZXQgZXhwbGljaXQgZW50cnkgcGF0aCByZWxhdGl2ZSB0byByb290UGF0aCB3aXRoIGZ1bGwgZXh0ZW5zaW9uXG4gIGNvbnN0IGVudldpdGhFbnRyeSA9IHtcbiAgICAuLi5lbnYsXG4gICAgZW50cnlwYXRoOiBlbnYuZW50cnlwYXRoIHx8ICcuL3NyYy9pbmRleC5qcycsXG4gIH07XG4gIHJldHVybiBiYXNlQ29uZmlnKGVudldpdGhFbnRyeSwgYXJndik7XG59O1xuIl0sIm1hcHBpbmdzIjoiQUFBQSxNQUFNO0VBQUVBO0FBQVcsQ0FBQyxHQUFHQyxPQUFPLENBQUMsb0JBQW9CLENBQUM7QUFFcEQsTUFBTUMsV0FBVyxHQUFHQyxTQUFTOztBQUU3QjtBQUNBLE1BQU1DLFVBQVUsR0FBR0osVUFBVSxDQUFDO0VBQzVCSyxRQUFRLEVBQUVILFdBQVc7RUFDckJJLFFBQVEsRUFBRSxLQUFLO0VBQ2ZDLFFBQVEsRUFBRSxNQUFNO0VBQ2hCQyxvQkFBb0IsRUFBRSxLQUFLO0VBQzNCQyxXQUFXLEVBQUU7SUFDWEMsUUFBUSxFQUFFO0VBQ1o7QUFDRixDQUFDLENBQUM7QUFFRkMsTUFBTSxDQUFDQyxPQUFPLEdBQUcsQ0FBQ0MsR0FBRyxHQUFHLENBQUMsQ0FBQyxFQUFFQyxJQUFJLEtBQUs7RUFDbkM7RUFDQSxNQUFNQyxZQUFZLEdBQUc7SUFDbkIsR0FBR0YsR0FBRztJQUNORyxTQUFTLEVBQUVILEdBQUcsQ0FBQ0csU0FBUyxJQUFJO0VBQzlCLENBQUM7RUFDRCxPQUFPWixVQUFVLENBQUNXLFlBQVksRUFBRUQsSUFBSSxDQUFDO0FBQ3ZDLENBQUMiLCJpZ25vcmVMaXN0IjpbXX0=
@@ -0,0 +1,24 @@
1
+ const {
2
+ makeConfig
3
+ } = require('../../../src/index');
4
+ const fixtureRoot = __dirname;
5
+
6
+ // Wrap makeConfig to inject entrypath into env
7
+ const baseConfig = makeConfig({
8
+ rootPath: fixtureRoot,
9
+ basePath: 'src',
10
+ buildDir: 'dist',
11
+ tsconfigPathsOptions: false,
12
+ babelLoader: {
13
+ rootMode: 'upward'
14
+ }
15
+ });
16
+ module.exports = (env = {}, argv) => {
17
+ // Set explicit entry path relative to rootPath with full extension
18
+ const envWithEntry = {
19
+ ...env,
20
+ entrypath: env.entrypath || './src/index.jsx'
21
+ };
22
+ return baseConfig(envWithEntry, argv);
23
+ };
24
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJtYWtlQ29uZmlnIiwicmVxdWlyZSIsImZpeHR1cmVSb290IiwiX19kaXJuYW1lIiwiYmFzZUNvbmZpZyIsInJvb3RQYXRoIiwiYmFzZVBhdGgiLCJidWlsZERpciIsInRzY29uZmlnUGF0aHNPcHRpb25zIiwiYmFiZWxMb2FkZXIiLCJyb290TW9kZSIsIm1vZHVsZSIsImV4cG9ydHMiLCJlbnYiLCJhcmd2IiwiZW52V2l0aEVudHJ5IiwiZW50cnlwYXRoIl0sInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL19fZml4dHVyZXNfXy93ZWJwYWNrLXJlYWN0L3dlYnBhY2suY29uZmlnLmpzIl0sInNvdXJjZXNDb250ZW50IjpbImNvbnN0IHsgbWFrZUNvbmZpZyB9ID0gcmVxdWlyZSgnLi4vLi4vLi4vc3JjL2luZGV4Jyk7XG5cbmNvbnN0IGZpeHR1cmVSb290ID0gX19kaXJuYW1lO1xuXG4vLyBXcmFwIG1ha2VDb25maWcgdG8gaW5qZWN0IGVudHJ5cGF0aCBpbnRvIGVudlxuY29uc3QgYmFzZUNvbmZpZyA9IG1ha2VDb25maWcoe1xuICByb290UGF0aDogZml4dHVyZVJvb3QsXG4gIGJhc2VQYXRoOiAnc3JjJyxcbiAgYnVpbGREaXI6ICdkaXN0JyxcbiAgdHNjb25maWdQYXRoc09wdGlvbnM6IGZhbHNlLFxuICBiYWJlbExvYWRlcjoge1xuICAgIHJvb3RNb2RlOiAndXB3YXJkJyxcbiAgfSxcbn0pO1xuXG5tb2R1bGUuZXhwb3J0cyA9IChlbnYgPSB7fSwgYXJndikgPT4ge1xuICAvLyBTZXQgZXhwbGljaXQgZW50cnkgcGF0aCByZWxhdGl2ZSB0byByb290UGF0aCB3aXRoIGZ1bGwgZXh0ZW5zaW9uXG4gIGNvbnN0IGVudldpdGhFbnRyeSA9IHtcbiAgICAuLi5lbnYsXG4gICAgZW50cnlwYXRoOiBlbnYuZW50cnlwYXRoIHx8ICcuL3NyYy9pbmRleC5qc3gnLFxuICB9O1xuICByZXR1cm4gYmFzZUNvbmZpZyhlbnZXaXRoRW50cnksIGFyZ3YpO1xufTtcbiJdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTTtFQUFFQTtBQUFXLENBQUMsR0FBR0MsT0FBTyxDQUFDLG9CQUFvQixDQUFDO0FBRXBELE1BQU1DLFdBQVcsR0FBR0MsU0FBUzs7QUFFN0I7QUFDQSxNQUFNQyxVQUFVLEdBQUdKLFVBQVUsQ0FBQztFQUM1QkssUUFBUSxFQUFFSCxXQUFXO0VBQ3JCSSxRQUFRLEVBQUUsS0FBSztFQUNmQyxRQUFRLEVBQUUsTUFBTTtFQUNoQkMsb0JBQW9CLEVBQUUsS0FBSztFQUMzQkMsV0FBVyxFQUFFO0lBQ1hDLFFBQVEsRUFBRTtFQUNaO0FBQ0YsQ0FBQyxDQUFDO0FBRUZDLE1BQU0sQ0FBQ0MsT0FBTyxHQUFHLENBQUNDLEdBQUcsR0FBRyxDQUFDLENBQUMsRUFBRUMsSUFBSSxLQUFLO0VBQ25DO0VBQ0EsTUFBTUMsWUFBWSxHQUFHO0lBQ25CLEdBQUdGLEdBQUc7SUFDTkcsU0FBUyxFQUFFSCxHQUFHLENBQUNHLFNBQVMsSUFBSTtFQUM5QixDQUFDO0VBQ0QsT0FBT1osVUFBVSxDQUFDVyxZQUFZLEVBQUVELElBQUksQ0FBQztBQUN2QyxDQUFDIiwiaWdub3JlTGlzdCI6W119
package/lib/base/css.js CHANGED
@@ -57,7 +57,8 @@ const getSASSLoaders = ({
57
57
  loaders.push({
58
58
  loader: require.resolve('sass-resources-loader'),
59
59
  options: {
60
- resources: sassResources
60
+ resources: sassResources,
61
+ hoistUseStatements: true
61
62
  }
62
63
  });
63
64
  }
@@ -106,7 +107,7 @@ function getStyleRules({
106
107
  let foundSass = sassOptions?.implementation;
107
108
  try {
108
109
  if (!foundSass) foundSass = require.resolve('sass') || require.resolve('sass-embedded');
109
- } catch (e) {
110
+ } catch {
110
111
  foundSass = sassOptions?.implementation;
111
112
  if (sassOptions !== false) {
112
113
  console.warn('`sass` or `sass-embedded` packages not found. SASS cannot be used.');
@@ -199,4 +200,4 @@ function getStyleRules({
199
200
  }].filter(rule => rule)
200
201
  };
201
202
  }
202
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_autoprefixer","_interopRequireDefault","require","_miniCssExtractPlugin","_path","_postcssPresetEnv","_ramda","getCSSLoaders","mode","target","cssExtractOptions","miniCssExtractPluginLoader","loader","MiniCssExtractPlugin","options","emit","includes","loaders","resolve","sourceMap","importLoaders","modules","postcssOptions","plugins","autoprefixer","cssPresetEnv","getSASSLoaders","sassResources","sassOptions","push","resources","getStyleRules","rootPath","basePath","libraryInclude","always","libraryExclude","cssModulesOptions","outputStyle","globalStyleDir","absoluteBasePath","path","join","cssLoaders","cssModuleLoaders","map","test","exportLocalsConvention","process","env","NODE_ENV","localIdentName","foundSass","implementation","e","console","warn","sassLoaders","excludeCSSProcess","globalStyleRegex","RegExp","unshift","oneOf","include","exclude","use","sideEffects","slice","auto","filter","rule"],"sources":["../../src/base/css.js"],"sourcesContent":["import autoprefixer from 'autoprefixer';\nimport MiniCssExtractPlugin from 'mini-css-extract-plugin';\nimport path from 'path';\nimport cssPresetEnv from 'postcss-preset-env';\nimport { always } from 'ramda';\n\nconst getCSSLoaders = ({ mode, target, cssExtractOptions }) => {\n  const miniCssExtractPluginLoader = {\n    loader: MiniCssExtractPlugin.loader,\n    options: { emit: !target?.includes?.('node') },\n  };\n\n  const loaders = [\n    {\n      loader: require.resolve('css-loader'),\n      options:\n        mode === 'development' ?\n          {\n            sourceMap: true,\n            importLoaders: 1,\n            modules: {\n              mode: 'icss',\n            },\n          }\n        : {\n            importLoaders: 1,\n            modules: {\n              mode: 'icss',\n            },\n          },\n    },\n    {\n      loader: require.resolve('postcss-loader'),\n      options: {\n        postcssOptions: {\n          plugins: [autoprefixer(), cssPresetEnv()],\n        },\n      },\n    },\n  ];\n\n  return cssExtractOptions === false ? loaders : (\n      [miniCssExtractPluginLoader, ...loaders]\n    );\n};\n\nconst getSASSLoaders = ({ sassResources, sassOptions }) => {\n  const loaders = [\n    {\n      loader: require.resolve('sass-loader'),\n      options: { sassOptions },\n    },\n  ];\n  if (sassResources) {\n    loaders.push({\n      loader: require.resolve('sass-resources-loader'),\n      options: {\n        resources: sassResources,\n      },\n    });\n  }\n  return loaders;\n};\n\nexport default function getStyleRules({\n  rootPath,\n  basePath = 'src',\n  libraryInclude = always(false),\n  libraryExclude = always(false),\n  cssModulesOptions = {},\n  sassOptions = { outputStyle: 'expanded' },\n  sassResources,\n  globalStyleDir,\n  mode,\n  target,\n  cssExtractOptions,\n}) {\n  const absoluteBasePath = path.join(rootPath, basePath);\n  const cssLoaders = getCSSLoaders({ mode, target, cssExtractOptions });\n  const cssModuleLoaders = cssLoaders.map(loader => {\n    if (/($|\\/)css-loader/.test(loader.loader)) {\n      return {\n        ...loader,\n        options: {\n          ...loader.options,\n          modules: {\n            exportLocalsConvention: 'camelCase',\n            ...(process.env.NODE_ENV === 'testing' ?\n              { localIdentName: '[name]__[local]' }\n            : {}),\n            ...cssModulesOptions,\n          },\n        },\n      };\n    }\n    return loader;\n  });\n  // we don't need to find it if they specified the directory\n  let foundSass = sassOptions?.implementation;\n  try {\n    if (!foundSass)\n      foundSass = require.resolve('sass') || require.resolve('sass-embedded');\n  } catch (e) {\n    foundSass = sassOptions?.implementation;\n    if (sassOptions !== false) {\n      console.warn(\n        '`sass` or `sass-embedded` packages not found. SASS cannot be used.',\n      );\n    }\n  }\n  const sassLoaders =\n    sassOptions === false || !foundSass ?\n      []\n    : getSASSLoaders({ sassResources, sassOptions });\n  const excludeCSSProcess = [libraryExclude];\n\n  // global styles\n  if (globalStyleDir !== false) {\n    const globalStyleRegex = new RegExp(`${globalStyleDir}/`);\n    excludeCSSProcess.unshift(globalStyleRegex);\n  }\n  return {\n    test: /\\.s?css$/i,\n    oneOf: [\n      // css modules (local styles)\n      sassOptions !== false && {\n        test: /\\.scss$/i,\n        include: [absoluteBasePath, libraryInclude],\n        exclude: excludeCSSProcess,\n        use: [...cssModuleLoaders, ...sassLoaders],\n      },\n      // css-in-js like linaria do not use css-modules\n      {\n        test: /\\.wyw-in-js\\.css$/i,\n        include: [absoluteBasePath, libraryInclude],\n        exclude: excludeCSSProcess,\n        use: cssLoaders,\n      },\n      // plain css as css-modules\n      {\n        test: /\\.css$/i,\n        include: [absoluteBasePath, /\\.storybook/, libraryInclude],\n        exclude: [...excludeCSSProcess, /\\.wyw-in-js\\.css$/i],\n        use: cssModuleLoaders,\n      },\n      // global styles\n      globalStyleDir !== false && {\n        test: sassOptions === false ? /\\.css$/i : /\\.s?css$/i,\n        include: [absoluteBasePath],\n        exclude: [\n          sassOptions === false ? /\\.module\\.css$/i : /\\.module\\.s?css$/i,\n          new RegExp(`^((?!(${globalStyleDir}/|node_modules/)).)*$`),\n        ],\n        use: [...cssLoaders, ...sassLoaders],\n        // Don't consider CSS imports dead code even if the\n        // containing package claims to have no side effects.\n        // Remove this when webpack adds a warning or an error for this.\n        // See https://github.com/webpack/webpack/issues/6571\n        sideEffects: true,\n      },\n      globalStyleDir !== false && {\n        test: sassOptions === false ? /\\.module\\.css$/i : /\\.module\\.s?css$/i,\n        include: [absoluteBasePath],\n        exclude: [new RegExp(`^((?!(${globalStyleDir}/|node_modules/)).)*$`)],\n        use: [...cssModuleLoaders, ...sassLoaders],\n      },\n      // css-in-js like linaria do not use css-modules - 3beta.14 and below\n      {\n        test: /\\.css$/i,\n        include: [/node_modules\\/\\.cache/],\n        exclude: [absoluteBasePath, libraryInclude],\n        use: cssLoaders,\n      },\n      // package css\n      {\n        test: /\\.css$/i,\n        include: [/node_modules/],\n        use: cssModuleLoaders.slice(0, -1).map(loader => {\n          if (/($|\\/)css-loader/.test(loader.loader)) {\n            return {\n              ...loader,\n              options: {\n                ...loader.options,\n                modules: {\n                  ...loader.options.modules,\n                  auto: true,\n                  ...cssModulesOptions,\n                },\n              },\n            };\n          }\n          return loader;\n        }),\n        // Don't consider CSS imports dead code even if the\n        // containing package claims to have no side effects.\n        // Remove this when webpack adds a warning or an error for this.\n        // See https://github.com/webpack/webpack/issues/6571\n        sideEffects: !target?.includes?.('node'),\n      },\n    ].filter(rule => rule),\n  };\n}\n"],"mappings":";;;;;AAAA,IAAAA,aAAA,GAAAC,sBAAA,CAAAC,OAAA;AACA,IAAAC,qBAAA,GAAAF,sBAAA,CAAAC,OAAA;AACA,IAAAE,KAAA,GAAAH,sBAAA,CAAAC,OAAA;AACA,IAAAG,iBAAA,GAAAJ,sBAAA,CAAAC,OAAA;AACA,IAAAI,MAAA,GAAAJ,OAAA;AAEA,MAAMK,aAAa,GAAGA,CAAC;EAAEC,IAAI;EAAEC,MAAM;EAAEC;AAAkB,CAAC,KAAK;EAC7D,MAAMC,0BAA0B,GAAG;IACjCC,MAAM,EAAEC,6BAAoB,CAACD,MAAM;IACnCE,OAAO,EAAE;MAAEC,IAAI,EAAE,CAACN,MAAM,EAAEO,QAAQ,GAAG,MAAM;IAAE;EAC/C,CAAC;EAED,MAAMC,OAAO,GAAG,CACd;IACEL,MAAM,EAAEV,OAAO,CAACgB,OAAO,CAAC,YAAY,CAAC;IACrCJ,OAAO,EACLN,IAAI,KAAK,aAAa,GACpB;MACEW,SAAS,EAAE,IAAI;MACfC,aAAa,EAAE,CAAC;MAChBC,OAAO,EAAE;QACPb,IAAI,EAAE;MACR;IACF,CAAC,GACD;MACEY,aAAa,EAAE,CAAC;MAChBC,OAAO,EAAE;QACPb,IAAI,EAAE;MACR;IACF;EACN,CAAC,EACD;IACEI,MAAM,EAAEV,OAAO,CAACgB,OAAO,CAAC,gBAAgB,CAAC;IACzCJ,OAAO,EAAE;MACPQ,cAAc,EAAE;QACdC,OAAO,EAAE,CAAC,IAAAC,qBAAY,EAAC,CAAC,EAAE,IAAAC,yBAAY,EAAC,CAAC;MAC1C;IACF;EACF,CAAC,CACF;EAED,OAAOf,iBAAiB,KAAK,KAAK,GAAGO,OAAO,GACxC,CAACN,0BAA0B,EAAE,GAAGM,OAAO,CACxC;AACL,CAAC;AAED,MAAMS,cAAc,GAAGA,CAAC;EAAEC,aAAa;EAAEC;AAAY,CAAC,KAAK;EACzD,MAAMX,OAAO,GAAG,CACd;IACEL,MAAM,EAAEV,OAAO,CAACgB,OAAO,CAAC,aAAa,CAAC;IACtCJ,OAAO,EAAE;MAAEc;IAAY;EACzB,CAAC,CACF;EACD,IAAID,aAAa,EAAE;IACjBV,OAAO,CAACY,IAAI,CAAC;MACXjB,MAAM,EAAEV,OAAO,CAACgB,OAAO,CAAC,uBAAuB,CAAC;MAChDJ,OAAO,EAAE;QACPgB,SAAS,EAAEH;MACb;IACF,CAAC,CAAC;EACJ;EACA,OAAOV,OAAO;AAChB,CAAC;AAEc,SAASc,aAAaA,CAAC;EACpCC,QAAQ;EACRC,QAAQ,GAAG,KAAK;EAChBC,cAAc,GAAG,IAAAC,aAAM,EAAC,KAAK,CAAC;EAC9BC,cAAc,GAAG,IAAAD,aAAM,EAAC,KAAK,CAAC;EAC9BE,iBAAiB,GAAG,CAAC,CAAC;EACtBT,WAAW,GAAG;IAAEU,WAAW,EAAE;EAAW,CAAC;EACzCX,aAAa;EACbY,cAAc;EACd/B,IAAI;EACJC,MAAM;EACNC;AACF,CAAC,EAAE;EACD,MAAM8B,gBAAgB,GAAGC,aAAI,CAACC,IAAI,CAACV,QAAQ,EAAEC,QAAQ,CAAC;EACtD,MAAMU,UAAU,GAAGpC,aAAa,CAAC;IAAEC,IAAI;IAAEC,MAAM;IAAEC;EAAkB,CAAC,CAAC;EACrE,MAAMkC,gBAAgB,GAAGD,UAAU,CAACE,GAAG,CAACjC,MAAM,IAAI;IAChD,IAAI,kBAAkB,CAACkC,IAAI,CAAClC,MAAM,CAACA,MAAM,CAAC,EAAE;MAC1C,OAAO;QACL,GAAGA,MAAM;QACTE,OAAO,EAAE;UACP,GAAGF,MAAM,CAACE,OAAO;UACjBO,OAAO,EAAE;YACP0B,sBAAsB,EAAE,WAAW;YACnC,IAAIC,OAAO,CAACC,GAAG,CAACC,QAAQ,KAAK,SAAS,GACpC;cAAEC,cAAc,EAAE;YAAkB,CAAC,GACrC,CAAC,CAAC,CAAC;YACL,GAAGd;UACL;QACF;MACF,CAAC;IACH;IACA,OAAOzB,MAAM;EACf,CAAC,CAAC;EACF;EACA,IAAIwC,SAAS,GAAGxB,WAAW,EAAEyB,cAAc;EAC3C,IAAI;IACF,IAAI,CAACD,SAAS,EACZA,SAAS,GAAGlD,OAAO,CAACgB,OAAO,CAAC,MAAM,CAAC,IAAIhB,OAAO,CAACgB,OAAO,CAAC,eAAe,CAAC;EAC3E,CAAC,CAAC,OAAOoC,CAAC,EAAE;IACVF,SAAS,GAAGxB,WAAW,EAAEyB,cAAc;IACvC,IAAIzB,WAAW,KAAK,KAAK,EAAE;MACzB2B,OAAO,CAACC,IAAI,CACV,oEACF,CAAC;IACH;EACF;EACA,MAAMC,WAAW,GACf7B,WAAW,KAAK,KAAK,IAAI,CAACwB,SAAS,GACjC,EAAE,GACF1B,cAAc,CAAC;IAAEC,aAAa;IAAEC;EAAY,CAAC,CAAC;EAClD,MAAM8B,iBAAiB,GAAG,CAACtB,cAAc,CAAC;;EAE1C;EACA,IAAIG,cAAc,KAAK,KAAK,EAAE;IAC5B,MAAMoB,gBAAgB,GAAG,IAAIC,MAAM,CAAC,GAAGrB,cAAc,GAAG,CAAC;IACzDmB,iBAAiB,CAACG,OAAO,CAACF,gBAAgB,CAAC;EAC7C;EACA,OAAO;IACLb,IAAI,EAAE,WAAW;IACjBgB,KAAK,EAAE;IACL;IACAlC,WAAW,KAAK,KAAK,IAAI;MACvBkB,IAAI,EAAE,UAAU;MAChBiB,OAAO,EAAE,CAACvB,gBAAgB,EAAEN,cAAc,CAAC;MAC3C8B,OAAO,EAAEN,iBAAiB;MAC1BO,GAAG,EAAE,CAAC,GAAGrB,gBAAgB,EAAE,GAAGa,WAAW;IAC3C,CAAC;IACD;IACA;MACEX,IAAI,EAAE,oBAAoB;MAC1BiB,OAAO,EAAE,CAACvB,gBAAgB,EAAEN,cAAc,CAAC;MAC3C8B,OAAO,EAAEN,iBAAiB;MAC1BO,GAAG,EAAEtB;IACP,CAAC;IACD;IACA;MACEG,IAAI,EAAE,SAAS;MACfiB,OAAO,EAAE,CAACvB,gBAAgB,EAAE,aAAa,EAAEN,cAAc,CAAC;MAC1D8B,OAAO,EAAE,CAAC,GAAGN,iBAAiB,EAAE,oBAAoB,CAAC;MACrDO,GAAG,EAAErB;IACP,CAAC;IACD;IACAL,cAAc,KAAK,KAAK,IAAI;MAC1BO,IAAI,EAAElB,WAAW,KAAK,KAAK,GAAG,SAAS,GAAG,WAAW;MACrDmC,OAAO,EAAE,CAACvB,gBAAgB,CAAC;MAC3BwB,OAAO,EAAE,CACPpC,WAAW,KAAK,KAAK,GAAG,iBAAiB,GAAG,mBAAmB,EAC/D,IAAIgC,MAAM,CAAC,SAASrB,cAAc,uBAAuB,CAAC,CAC3D;MACD0B,GAAG,EAAE,CAAC,GAAGtB,UAAU,EAAE,GAAGc,WAAW,CAAC;MACpC;MACA;MACA;MACA;MACAS,WAAW,EAAE;IACf,CAAC,EACD3B,cAAc,KAAK,KAAK,IAAI;MAC1BO,IAAI,EAAElB,WAAW,KAAK,KAAK,GAAG,iBAAiB,GAAG,mBAAmB;MACrEmC,OAAO,EAAE,CAACvB,gBAAgB,CAAC;MAC3BwB,OAAO,EAAE,CAAC,IAAIJ,MAAM,CAAC,SAASrB,cAAc,uBAAuB,CAAC,CAAC;MACrE0B,GAAG,EAAE,CAAC,GAAGrB,gBAAgB,EAAE,GAAGa,WAAW;IAC3C,CAAC;IACD;IACA;MACEX,IAAI,EAAE,SAAS;MACfiB,OAAO,EAAE,CAAC,uBAAuB,CAAC;MAClCC,OAAO,EAAE,CAACxB,gBAAgB,EAAEN,cAAc,CAAC;MAC3C+B,GAAG,EAAEtB;IACP,CAAC;IACD;IACA;MACEG,IAAI,EAAE,SAAS;MACfiB,OAAO,EAAE,CAAC,cAAc,CAAC;MACzBE,GAAG,EAAErB,gBAAgB,CAACuB,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAACtB,GAAG,CAACjC,MAAM,IAAI;QAC/C,IAAI,kBAAkB,CAACkC,IAAI,CAAClC,MAAM,CAACA,MAAM,CAAC,EAAE;UAC1C,OAAO;YACL,GAAGA,MAAM;YACTE,OAAO,EAAE;cACP,GAAGF,MAAM,CAACE,OAAO;cACjBO,OAAO,EAAE;gBACP,GAAGT,MAAM,CAACE,OAAO,CAACO,OAAO;gBACzB+C,IAAI,EAAE,IAAI;gBACV,GAAG/B;cACL;YACF;UACF,CAAC;QACH;QACA,OAAOzB,MAAM;MACf,CAAC,CAAC;MACF;MACA;MACA;MACA;MACAsD,WAAW,EAAE,CAACzD,MAAM,EAAEO,QAAQ,GAAG,MAAM;IACzC,CAAC,CACF,CAACqD,MAAM,CAACC,IAAI,IAAIA,IAAI;EACvB,CAAC;AACH","ignoreList":[]}
203
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_autoprefixer","_interopRequireDefault","require","_miniCssExtractPlugin","_path","_postcssPresetEnv","_ramda","getCSSLoaders","mode","target","cssExtractOptions","miniCssExtractPluginLoader","loader","MiniCssExtractPlugin","options","emit","includes","loaders","resolve","sourceMap","importLoaders","modules","postcssOptions","plugins","autoprefixer","cssPresetEnv","getSASSLoaders","sassResources","sassOptions","push","resources","hoistUseStatements","getStyleRules","rootPath","basePath","libraryInclude","always","libraryExclude","cssModulesOptions","outputStyle","globalStyleDir","absoluteBasePath","path","join","cssLoaders","cssModuleLoaders","map","test","exportLocalsConvention","process","env","NODE_ENV","localIdentName","foundSass","implementation","console","warn","sassLoaders","excludeCSSProcess","globalStyleRegex","RegExp","unshift","oneOf","include","exclude","use","sideEffects","slice","auto","filter","rule"],"sources":["../../src/base/css.js"],"sourcesContent":["import autoprefixer from 'autoprefixer';\nimport MiniCssExtractPlugin from 'mini-css-extract-plugin';\nimport path from 'path';\nimport cssPresetEnv from 'postcss-preset-env';\nimport { always } from 'ramda';\n\nconst getCSSLoaders = ({ mode, target, cssExtractOptions }) => {\n  const miniCssExtractPluginLoader = {\n    loader: MiniCssExtractPlugin.loader,\n    options: { emit: !target?.includes?.('node') },\n  };\n\n  const loaders = [\n    {\n      loader: require.resolve('css-loader'),\n      options:\n        mode === 'development' ?\n          {\n            sourceMap: true,\n            importLoaders: 1,\n            modules: {\n              mode: 'icss',\n            },\n          }\n        : {\n            importLoaders: 1,\n            modules: {\n              mode: 'icss',\n            },\n          },\n    },\n    {\n      loader: require.resolve('postcss-loader'),\n      options: {\n        postcssOptions: {\n          plugins: [autoprefixer(), cssPresetEnv()],\n        },\n      },\n    },\n  ];\n\n  return cssExtractOptions === false ? loaders : (\n      [miniCssExtractPluginLoader, ...loaders]\n    );\n};\n\nconst getSASSLoaders = ({ sassResources, sassOptions }) => {\n  const loaders = [\n    {\n      loader: require.resolve('sass-loader'),\n      options: { sassOptions },\n    },\n  ];\n  if (sassResources) {\n    loaders.push({\n      loader: require.resolve('sass-resources-loader'),\n      options: {\n        resources: sassResources,\n        hoistUseStatements: true,\n      },\n    });\n  }\n  return loaders;\n};\n\nexport default function getStyleRules({\n  rootPath,\n  basePath = 'src',\n  libraryInclude = always(false),\n  libraryExclude = always(false),\n  cssModulesOptions = {},\n  sassOptions = { outputStyle: 'expanded' },\n  sassResources,\n  globalStyleDir,\n  mode,\n  target,\n  cssExtractOptions,\n}) {\n  const absoluteBasePath = path.join(rootPath, basePath);\n  const cssLoaders = getCSSLoaders({ mode, target, cssExtractOptions });\n  const cssModuleLoaders = cssLoaders.map(loader => {\n    if (/($|\\/)css-loader/.test(loader.loader)) {\n      return {\n        ...loader,\n        options: {\n          ...loader.options,\n          modules: {\n            exportLocalsConvention: 'camelCase',\n            ...(process.env.NODE_ENV === 'testing' ?\n              { localIdentName: '[name]__[local]' }\n            : {}),\n            ...cssModulesOptions,\n          },\n        },\n      };\n    }\n    return loader;\n  });\n  // we don't need to find it if they specified the directory\n  let foundSass = sassOptions?.implementation;\n  try {\n    if (!foundSass)\n      foundSass = require.resolve('sass') || require.resolve('sass-embedded');\n  } catch {\n    foundSass = sassOptions?.implementation;\n    if (sassOptions !== false) {\n      console.warn(\n        '`sass` or `sass-embedded` packages not found. SASS cannot be used.',\n      );\n    }\n  }\n  const sassLoaders =\n    sassOptions === false || !foundSass ?\n      []\n    : getSASSLoaders({ sassResources, sassOptions });\n  const excludeCSSProcess = [libraryExclude];\n\n  // global styles\n  if (globalStyleDir !== false) {\n    const globalStyleRegex = new RegExp(`${globalStyleDir}/`);\n    excludeCSSProcess.unshift(globalStyleRegex);\n  }\n  return {\n    test: /\\.s?css$/i,\n    oneOf: [\n      // css modules (local styles)\n      sassOptions !== false && {\n        test: /\\.scss$/i,\n        include: [absoluteBasePath, libraryInclude],\n        exclude: excludeCSSProcess,\n        use: [...cssModuleLoaders, ...sassLoaders],\n      },\n      // css-in-js like linaria do not use css-modules\n      {\n        test: /\\.wyw-in-js\\.css$/i,\n        include: [absoluteBasePath, libraryInclude],\n        exclude: excludeCSSProcess,\n        use: cssLoaders,\n      },\n      // plain css as css-modules\n      {\n        test: /\\.css$/i,\n        include: [absoluteBasePath, /\\.storybook/, libraryInclude],\n        exclude: [...excludeCSSProcess, /\\.wyw-in-js\\.css$/i],\n        use: cssModuleLoaders,\n      },\n      // global styles\n      globalStyleDir !== false && {\n        test: sassOptions === false ? /\\.css$/i : /\\.s?css$/i,\n        include: [absoluteBasePath],\n        exclude: [\n          sassOptions === false ? /\\.module\\.css$/i : /\\.module\\.s?css$/i,\n          new RegExp(`^((?!(${globalStyleDir}/|node_modules/)).)*$`),\n        ],\n        use: [...cssLoaders, ...sassLoaders],\n        // Don't consider CSS imports dead code even if the\n        // containing package claims to have no side effects.\n        // Remove this when webpack adds a warning or an error for this.\n        // See https://github.com/webpack/webpack/issues/6571\n        sideEffects: true,\n      },\n      globalStyleDir !== false && {\n        test: sassOptions === false ? /\\.module\\.css$/i : /\\.module\\.s?css$/i,\n        include: [absoluteBasePath],\n        exclude: [new RegExp(`^((?!(${globalStyleDir}/|node_modules/)).)*$`)],\n        use: [...cssModuleLoaders, ...sassLoaders],\n      },\n      // css-in-js like linaria do not use css-modules - 3beta.14 and below\n      {\n        test: /\\.css$/i,\n        include: [/node_modules\\/\\.cache/],\n        exclude: [absoluteBasePath, libraryInclude],\n        use: cssLoaders,\n      },\n      // package css\n      {\n        test: /\\.css$/i,\n        include: [/node_modules/],\n        use: cssModuleLoaders.slice(0, -1).map(loader => {\n          if (/($|\\/)css-loader/.test(loader.loader)) {\n            return {\n              ...loader,\n              options: {\n                ...loader.options,\n                modules: {\n                  ...loader.options.modules,\n                  auto: true,\n                  ...cssModulesOptions,\n                },\n              },\n            };\n          }\n          return loader;\n        }),\n        // Don't consider CSS imports dead code even if the\n        // containing package claims to have no side effects.\n        // Remove this when webpack adds a warning or an error for this.\n        // See https://github.com/webpack/webpack/issues/6571\n        sideEffects: !target?.includes?.('node'),\n      },\n    ].filter(rule => rule),\n  };\n}\n"],"mappings":"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","ignoreList":[]}