@linaria/react 4.1.4 → 4.2.0

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.
@@ -0,0 +1,260 @@
1
+ var __defProp = Object.defineProperty;
2
+ var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
3
+ var __publicField = (obj, key, value) => {
4
+ __defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
5
+ return value;
6
+ };
7
+ var __accessCheck = (obj, member, msg) => {
8
+ if (!member.has(obj))
9
+ throw TypeError("Cannot " + msg);
10
+ };
11
+ var __privateGet = (obj, member, getter) => {
12
+ __accessCheck(obj, member, "read from private field");
13
+ return getter ? getter.call(obj) : member.get(obj);
14
+ };
15
+ var __privateAdd = (obj, member, value) => {
16
+ if (member.has(obj))
17
+ throw TypeError("Cannot add the same private member more than once");
18
+ member instanceof WeakSet ? member.add(obj) : member.set(obj, value);
19
+ };
20
+ var __privateSet = (obj, member, value, setter) => {
21
+ __accessCheck(obj, member, "write to private field");
22
+ setter ? setter.call(obj, value) : member.set(obj, value);
23
+ return value;
24
+ };
25
+ var __privateWrapper = (obj, member, setter, getter) => ({
26
+ set _(value) {
27
+ __privateSet(obj, member, value, setter);
28
+ },
29
+ get _() {
30
+ return __privateGet(obj, member, getter);
31
+ }
32
+ });
33
+
34
+ // src/processors/styled.ts
35
+ import {
36
+ buildSlug,
37
+ hasMeta,
38
+ TaggedTemplateProcessor,
39
+ validateParams,
40
+ ValueType,
41
+ toValidCSSIdentifier
42
+ } from "@linaria/tags";
43
+ import { slugify } from "@linaria/utils";
44
+ var isNotNull = (x) => x !== null;
45
+ var singleQuotedStringLiteral = (value) => ({
46
+ type: "StringLiteral",
47
+ value,
48
+ extra: {
49
+ rawValue: value,
50
+ raw: `'${value}'`
51
+ }
52
+ });
53
+ var _variableIdx, _variablesCache;
54
+ var StyledProcessor = class extends TaggedTemplateProcessor {
55
+ constructor(params, ...args) {
56
+ validateParams(
57
+ params,
58
+ ["tag", ["call", "member"], ["template", "call"]],
59
+ "Invalid usage of `styled` tag"
60
+ );
61
+ const [tag, tagOp, template] = params;
62
+ if (template[0] === "call") {
63
+ throw TaggedTemplateProcessor.SKIP;
64
+ }
65
+ super([tag, template], ...args);
66
+ __publicField(this, "component");
67
+ __privateAdd(this, _variableIdx, 0);
68
+ __privateAdd(this, _variablesCache, /* @__PURE__ */ new Map());
69
+ let component;
70
+ if (tagOp[0] === "call" && tagOp.length === 2) {
71
+ const value = tagOp[1];
72
+ if (value.kind === ValueType.FUNCTION) {
73
+ component = "FunctionalComponent";
74
+ } else {
75
+ component = {
76
+ node: value.ex,
77
+ source: value.source
78
+ };
79
+ this.dependencies.push(value);
80
+ }
81
+ }
82
+ if (tagOp[0] === "member") {
83
+ [, component] = tagOp;
84
+ }
85
+ if (!component) {
86
+ throw new Error("Invalid usage of `styled` tag");
87
+ }
88
+ this.component = component;
89
+ }
90
+ addInterpolation(node, precedingCss, source, unit = "") {
91
+ const id = this.getVariableId(source, unit, precedingCss);
92
+ this.interpolations.push({
93
+ id,
94
+ node,
95
+ source,
96
+ unit
97
+ });
98
+ return id;
99
+ }
100
+ doEvaltimeReplacement() {
101
+ this.replacer(this.value, false);
102
+ }
103
+ doRuntimeReplacement() {
104
+ const t = this.astService;
105
+ const props = this.getProps();
106
+ this.replacer(
107
+ t.callExpression(this.tagExpression, [this.getTagComponentProps(props)]),
108
+ true
109
+ );
110
+ }
111
+ extractRules(valueCache, cssText, loc) {
112
+ const rules = {};
113
+ let selector = `.${this.className}`;
114
+ let value = typeof this.component === "string" ? null : valueCache.get(this.component.node.name);
115
+ while (hasMeta(value)) {
116
+ selector += `.${value.__linaria.className}`;
117
+ value = value.__linaria.extends;
118
+ }
119
+ rules[selector] = {
120
+ cssText,
121
+ className: this.className,
122
+ displayName: this.displayName,
123
+ start: (loc == null ? void 0 : loc.start) ?? null
124
+ };
125
+ return rules;
126
+ }
127
+ get asSelector() {
128
+ return `.${this.className}`;
129
+ }
130
+ get tagExpressionArgument() {
131
+ const t = this.astService;
132
+ if (typeof this.component === "string") {
133
+ if (this.component === "FunctionalComponent") {
134
+ return t.arrowFunctionExpression([], t.blockStatement([]));
135
+ }
136
+ return singleQuotedStringLiteral(this.component);
137
+ }
138
+ return t.callExpression(t.identifier(this.component.node.name), []);
139
+ }
140
+ get tagExpression() {
141
+ const t = this.astService;
142
+ return t.callExpression(this.tag, [this.tagExpressionArgument]);
143
+ }
144
+ get value() {
145
+ const t = this.astService;
146
+ const extendsNode = typeof this.component === "string" ? null : this.component.node.name;
147
+ return t.objectExpression([
148
+ t.objectProperty(
149
+ t.stringLiteral("displayName"),
150
+ t.stringLiteral(this.displayName)
151
+ ),
152
+ t.objectProperty(
153
+ t.stringLiteral("__linaria"),
154
+ t.objectExpression([
155
+ t.objectProperty(
156
+ t.stringLiteral("className"),
157
+ t.stringLiteral(this.className)
158
+ ),
159
+ t.objectProperty(
160
+ t.stringLiteral("extends"),
161
+ extendsNode ? t.callExpression(t.identifier(extendsNode), []) : t.nullLiteral()
162
+ )
163
+ ])
164
+ )
165
+ ]);
166
+ }
167
+ toString() {
168
+ const res = (arg) => `${this.tagSourceCode()}(${arg})\`\u2026\``;
169
+ if (typeof this.component === "string") {
170
+ if (this.component === "FunctionalComponent") {
171
+ return res("() => {\u2026}");
172
+ }
173
+ return res(`'${this.component}'`);
174
+ }
175
+ return res(this.component.source);
176
+ }
177
+ getCustomVariableId(source, unit, precedingCss) {
178
+ const context = this.getVariableContext(source, unit, precedingCss);
179
+ const customSlugFn = this.options.variableNameSlug;
180
+ if (!customSlugFn) {
181
+ return void 0;
182
+ }
183
+ return typeof customSlugFn === "function" ? customSlugFn(context) : buildSlug(customSlugFn, context);
184
+ }
185
+ getProps() {
186
+ const propsObj = {
187
+ name: this.displayName,
188
+ class: this.className
189
+ };
190
+ if (this.interpolations.length) {
191
+ propsObj.vars = {};
192
+ this.interpolations.forEach(({ id, unit, node }) => {
193
+ const items = [this.astService.callExpression(node, [])];
194
+ if (unit) {
195
+ items.push(this.astService.stringLiteral(unit));
196
+ }
197
+ propsObj.vars[id] = items;
198
+ });
199
+ }
200
+ return propsObj;
201
+ }
202
+ getTagComponentProps(props) {
203
+ const t = this.astService;
204
+ const propExpressions = Object.entries(props).map(([key, value]) => {
205
+ if (!value) {
206
+ return null;
207
+ }
208
+ const keyNode = t.identifier(key);
209
+ if (typeof value === "string") {
210
+ return t.objectProperty(keyNode, t.stringLiteral(value));
211
+ }
212
+ if (typeof value === "boolean") {
213
+ return t.objectProperty(keyNode, t.booleanLiteral(value));
214
+ }
215
+ const vars = Object.entries(value).map(([propName, propValue]) => {
216
+ return t.objectProperty(
217
+ t.stringLiteral(propName),
218
+ t.arrayExpression(propValue)
219
+ );
220
+ });
221
+ return t.objectProperty(keyNode, t.objectExpression(vars));
222
+ }).filter(isNotNull);
223
+ return t.objectExpression(propExpressions);
224
+ }
225
+ getVariableContext(source, unit, precedingCss) {
226
+ const getIndex = () => {
227
+ return __privateWrapper(this, _variableIdx)._++;
228
+ };
229
+ return {
230
+ componentName: this.displayName,
231
+ componentSlug: this.slug,
232
+ get index() {
233
+ return getIndex();
234
+ },
235
+ precedingCss,
236
+ processor: this.constructor.name,
237
+ source,
238
+ unit,
239
+ valueSlug: slugify(source + unit)
240
+ };
241
+ }
242
+ getVariableId(source, unit, precedingCss) {
243
+ const value = source + unit;
244
+ if (!__privateGet(this, _variablesCache).has(value)) {
245
+ const id = this.getCustomVariableId(source, unit, precedingCss);
246
+ if (id) {
247
+ return toValidCSSIdentifier(id);
248
+ }
249
+ const context = this.getVariableContext(source, unit, precedingCss);
250
+ __privateGet(this, _variablesCache).set(value, `${this.slug}-${context.index}`);
251
+ }
252
+ return __privateGet(this, _variablesCache).get(value);
253
+ }
254
+ };
255
+ _variableIdx = new WeakMap();
256
+ _variablesCache = new WeakMap();
257
+ export {
258
+ StyledProcessor as default
259
+ };
260
+ //# sourceMappingURL=styled.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/processors/styled.ts"],"sourcesContent":["import type {\n CallExpression,\n Expression,\n ObjectExpression,\n SourceLocation,\n StringLiteral,\n} from '@babel/types';\n\nimport type {\n Params,\n Rules,\n TailProcessorParams,\n ValueCache,\n WrappedNode,\n} from '@linaria/tags';\nimport {\n buildSlug,\n hasMeta,\n TaggedTemplateProcessor,\n validateParams,\n ValueType,\n toValidCSSIdentifier,\n} from '@linaria/tags';\nimport type { IVariableContext } from '@linaria/utils';\nimport { slugify } from '@linaria/utils';\n\nconst isNotNull = <T>(x: T | null): x is T => x !== null;\n\nexport interface IProps {\n atomic?: boolean;\n class?: string;\n name: string;\n vars?: Record<string, Expression[]>;\n}\n\nconst singleQuotedStringLiteral = (value: string): StringLiteral => ({\n type: 'StringLiteral',\n value,\n extra: {\n rawValue: value,\n raw: `'${value}'`,\n },\n});\n\nexport default class StyledProcessor extends TaggedTemplateProcessor {\n public component: WrappedNode;\n\n #variableIdx = 0;\n\n #variablesCache = new Map<string, string>();\n\n constructor(params: Params, ...args: TailProcessorParams) {\n validateParams(\n params,\n ['tag', ['call', 'member'], ['template', 'call']],\n 'Invalid usage of `styled` tag'\n );\n\n const [tag, tagOp, template] = params;\n\n if (template[0] === 'call') {\n // It is already transformed styled-literal. Skip it.\n // eslint-disable-next-line @typescript-eslint/no-throw-literal\n throw TaggedTemplateProcessor.SKIP;\n }\n\n super([tag, template], ...args);\n\n let component: WrappedNode | undefined;\n if (tagOp[0] === 'call' && tagOp.length === 2) {\n const value = tagOp[1];\n if (value.kind === ValueType.FUNCTION) {\n component = 'FunctionalComponent';\n } else {\n component = {\n node: value.ex,\n source: value.source,\n };\n\n this.dependencies.push(value);\n }\n }\n\n if (tagOp[0] === 'member') {\n [, component] = tagOp;\n }\n\n if (!component) {\n throw new Error('Invalid usage of `styled` tag');\n }\n\n this.component = component;\n }\n\n public override addInterpolation(\n node: Expression,\n precedingCss: string,\n source: string,\n unit = ''\n ): string {\n const id = this.getVariableId(source, unit, precedingCss);\n\n this.interpolations.push({\n id,\n node,\n source,\n unit,\n });\n\n return id;\n }\n\n public override doEvaltimeReplacement(): void {\n this.replacer(this.value, false);\n }\n\n public override doRuntimeReplacement(): void {\n const t = this.astService;\n\n const props = this.getProps();\n\n this.replacer(\n t.callExpression(this.tagExpression, [this.getTagComponentProps(props)]),\n true\n );\n }\n\n public override extractRules(\n valueCache: ValueCache,\n cssText: string,\n loc?: SourceLocation | null\n ): Rules {\n const rules: Rules = {};\n\n let selector = `.${this.className}`;\n\n // If `styled` wraps another component and not a primitive,\n // get its class name to create a more specific selector\n // it'll ensure that styles are overridden properly\n let value =\n typeof this.component === 'string'\n ? null\n : valueCache.get(this.component.node.name);\n while (hasMeta(value)) {\n selector += `.${value.__linaria.className}`;\n value = value.__linaria.extends;\n }\n\n rules[selector] = {\n cssText,\n className: this.className,\n displayName: this.displayName,\n start: loc?.start ?? null,\n };\n\n return rules;\n }\n\n public override get asSelector(): string {\n return `.${this.className}`;\n }\n\n protected get tagExpressionArgument(): Expression {\n const t = this.astService;\n if (typeof this.component === 'string') {\n if (this.component === 'FunctionalComponent') {\n return t.arrowFunctionExpression([], t.blockStatement([]));\n }\n\n return singleQuotedStringLiteral(this.component);\n }\n\n return t.callExpression(t.identifier(this.component.node.name), []);\n }\n\n protected get tagExpression(): CallExpression {\n const t = this.astService;\n return t.callExpression(this.tag, [this.tagExpressionArgument]);\n }\n\n public override get value(): ObjectExpression {\n const t = this.astService;\n const extendsNode =\n typeof this.component === 'string' ? null : this.component.node.name;\n\n return t.objectExpression([\n t.objectProperty(\n t.stringLiteral('displayName'),\n t.stringLiteral(this.displayName)\n ),\n t.objectProperty(\n t.stringLiteral('__linaria'),\n t.objectExpression([\n t.objectProperty(\n t.stringLiteral('className'),\n t.stringLiteral(this.className)\n ),\n t.objectProperty(\n t.stringLiteral('extends'),\n extendsNode\n ? t.callExpression(t.identifier(extendsNode), [])\n : t.nullLiteral()\n ),\n ])\n ),\n ]);\n }\n\n public override toString(): string {\n const res = (arg: string) => `${this.tagSourceCode()}(${arg})\\`…\\``;\n\n if (typeof this.component === 'string') {\n if (this.component === 'FunctionalComponent') {\n return res('() => {…}');\n }\n\n return res(`'${this.component}'`);\n }\n\n return res(this.component.source);\n }\n\n protected getCustomVariableId(\n source: string,\n unit: string,\n precedingCss: string\n ) {\n const context = this.getVariableContext(source, unit, precedingCss);\n const customSlugFn = this.options.variableNameSlug;\n if (!customSlugFn) {\n return undefined;\n }\n\n return typeof customSlugFn === 'function'\n ? customSlugFn(context)\n : buildSlug(customSlugFn, context);\n }\n\n protected getProps(): IProps {\n const propsObj: IProps = {\n name: this.displayName,\n class: this.className,\n };\n\n // If we found any interpolations, also pass them, so they can be applied\n if (this.interpolations.length) {\n propsObj.vars = {};\n this.interpolations.forEach(({ id, unit, node }) => {\n const items: Expression[] = [this.astService.callExpression(node, [])];\n\n if (unit) {\n items.push(this.astService.stringLiteral(unit));\n }\n\n propsObj.vars![id] = items;\n });\n }\n\n return propsObj;\n }\n\n protected getTagComponentProps(props: IProps): ObjectExpression {\n const t = this.astService;\n\n const propExpressions = Object.entries(props)\n .map(([key, value]: [key: string, value: IProps[keyof IProps]]) => {\n if (!value) {\n return null;\n }\n\n const keyNode = t.identifier(key);\n\n if (typeof value === 'string') {\n return t.objectProperty(keyNode, t.stringLiteral(value));\n }\n\n if (typeof value === 'boolean') {\n return t.objectProperty(keyNode, t.booleanLiteral(value));\n }\n\n const vars = Object.entries(value).map(([propName, propValue]) => {\n return t.objectProperty(\n t.stringLiteral(propName),\n t.arrayExpression(propValue)\n );\n });\n\n return t.objectProperty(keyNode, t.objectExpression(vars));\n })\n .filter(isNotNull);\n\n return t.objectExpression(propExpressions);\n }\n\n protected getVariableContext(\n source: string,\n unit: string,\n precedingCss: string\n ): IVariableContext {\n const getIndex = () => {\n // eslint-disable-next-line no-plusplus\n return this.#variableIdx++;\n };\n\n return {\n componentName: this.displayName,\n componentSlug: this.slug,\n get index() {\n return getIndex();\n },\n precedingCss,\n processor: this.constructor.name,\n source,\n unit,\n valueSlug: slugify(source + unit),\n };\n }\n\n protected getVariableId(\n source: string,\n unit: string,\n precedingCss: string\n ): string {\n const value = source + unit;\n if (!this.#variablesCache.has(value)) {\n const id = this.getCustomVariableId(source, unit, precedingCss);\n if (id) {\n return toValidCSSIdentifier(id);\n }\n\n const context = this.getVariableContext(source, unit, precedingCss);\n\n // make the variable unique to this styled component\n this.#variablesCache.set(value, `${this.slug}-${context.index}`);\n }\n\n return this.#variablesCache.get(value)!;\n }\n}\n"],"mappings":"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","names":[]}
package/package.json CHANGED
@@ -1,12 +1,13 @@
1
1
  {
2
2
  "name": "@linaria/react",
3
3
  "description": "Blazing fast zero-runtime CSS in JS library",
4
- "version": "4.1.4",
4
+ "version": "4.2.0",
5
5
  "bugs": "https://github.com/callstack/linaria/issues",
6
6
  "dependencies": {
7
7
  "@emotion/is-prop-valid": "^0.8.8",
8
- "@linaria/core": "^4.1.3",
9
- "@linaria/tags": "^4.1.3",
8
+ "@linaria/core": "^4.2.0",
9
+ "@linaria/tags": "^4.1.4",
10
+ "@linaria/utils": "^4.2.2",
10
11
  "ts-invariant": "^0.10.3"
11
12
  },
12
13
  "devDependencies": {
@@ -24,18 +25,17 @@
24
25
  "./package.json": "./package.json",
25
26
  ".": {
26
27
  "types": "./types/index.d.ts",
27
- "import": "./esm/index.js",
28
- "default": "./lib/index.js"
28
+ "import": "./dist/index.mjs",
29
+ "default": "./dist/index.js"
29
30
  },
30
31
  "./*": {
31
32
  "types": "./types/*.d.ts",
32
- "import": "./esm/*.js",
33
- "default": "./lib/*.js"
33
+ "import": "./dist/*.mjs",
34
+ "default": "./dist/*.js"
34
35
  }
35
36
  },
36
37
  "files": [
37
- "esm/",
38
- "lib/",
38
+ "dist/",
39
39
  "processors/",
40
40
  "types/"
41
41
  ],
@@ -50,11 +50,11 @@
50
50
  "license": "MIT",
51
51
  "linaria": {
52
52
  "tags": {
53
- "styled": "./lib/processors/styled.js"
53
+ "styled": "./dist/processors/styled.js"
54
54
  }
55
55
  },
56
- "main": "lib/index.js",
57
- "module": "esm/index.js",
56
+ "main": "dist/index.js",
57
+ "module": "dist/index.mjs",
58
58
  "peerDependencies": {
59
59
  "react": ">=16"
60
60
  },
@@ -63,6 +63,15 @@
63
63
  },
64
64
  "repository": "git@github.com:callstack/linaria.git",
65
65
  "sideEffects": false,
66
+ "tsup": {
67
+ "entry": [
68
+ "src/index.ts",
69
+ "src/processors/styled.ts"
70
+ ],
71
+ "splitting": false,
72
+ "sourcemap": true,
73
+ "clean": true
74
+ },
66
75
  "types": "types/index.d.ts",
67
76
  "typesVersions": {
68
77
  "*": {
@@ -72,11 +81,10 @@
72
81
  }
73
82
  },
74
83
  "scripts": {
75
- "build": "npm run build:lib && npm run build:esm && npm run build:declarations",
84
+ "build": "npm run build:dist && npm run build:declarations",
76
85
  "build:corejs-test": "cross-env NODE_ENV=legacy babel src --out-dir lib --extensions '.js,.jsx,.ts,.tsx' --ignore \"src/processors/**/*\"",
77
86
  "build:declarations": "tsc --emitDeclarationOnly --outDir types",
78
- "build:esm": "babel src --out-dir esm --extensions '.js,.jsx,.ts,.tsx' --source-maps --delete-dir-on-start",
79
- "build:lib": "cross-env NODE_ENV=legacy babel src --out-dir lib --extensions '.js,.jsx,.ts,.tsx' --source-maps --delete-dir-on-start",
87
+ "build:dist": "tsup --format cjs,esm",
80
88
  "test": "jest --config ../../jest.config.js --rootDir .",
81
89
  "test:dts": "dtslint --localTs ../../node_modules/typescript/lib __dtslint__",
82
90
  "typecheck": "tsc --noEmit --composite false",
@@ -2,4 +2,4 @@ Object.defineProperty(exports, '__esModule', {
2
2
  value: true,
3
3
  });
4
4
 
5
- exports.default = require('../lib/processors/styled').default;
5
+ exports.default = require('../dist/processors/styled').default;
@@ -1,6 +1,7 @@
1
1
  import type { CallExpression, Expression, ObjectExpression, SourceLocation } from '@babel/types';
2
- import type { Rules, WrappedNode, ValueCache, Params, TailProcessorParams } from '@linaria/tags';
2
+ import type { Params, Rules, TailProcessorParams, ValueCache, WrappedNode } from '@linaria/tags';
3
3
  import { TaggedTemplateProcessor } from '@linaria/tags';
4
+ import type { IVariableContext } from '@linaria/utils';
4
5
  export interface IProps {
5
6
  atomic?: boolean;
6
7
  class?: string;
@@ -11,7 +12,7 @@ export default class StyledProcessor extends TaggedTemplateProcessor {
11
12
  #private;
12
13
  component: WrappedNode;
13
14
  constructor(params: Params, ...args: TailProcessorParams);
14
- addInterpolation(node: Expression, source: string, unit?: string): string;
15
+ addInterpolation(node: Expression, precedingCss: string, source: string, unit?: string): string;
15
16
  doEvaltimeReplacement(): void;
16
17
  doRuntimeReplacement(): void;
17
18
  extractRules(valueCache: ValueCache, cssText: string, loc?: SourceLocation | null): Rules;
@@ -20,7 +21,9 @@ export default class StyledProcessor extends TaggedTemplateProcessor {
20
21
  protected get tagExpression(): CallExpression;
21
22
  get value(): ObjectExpression;
22
23
  toString(): string;
24
+ protected getCustomVariableId(source: string, unit: string, precedingCss: string): string | undefined;
23
25
  protected getProps(): IProps;
24
26
  protected getTagComponentProps(props: IProps): ObjectExpression;
25
- protected getVariableId(value: string): string;
27
+ protected getVariableContext(source: string, unit: string, precedingCss: string): IVariableContext;
28
+ protected getVariableId(source: string, unit: string, precedingCss: string): string;
26
29
  }
package/esm/index.js DELETED
@@ -1,2 +0,0 @@
1
- export { default as styled } from './styled';
2
- //# sourceMappingURL=index.js.map
package/esm/index.js.map DELETED
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.js","names":["default","styled"],"sources":["../src/index.ts"],"sourcesContent":["export { default as styled } from './styled';\nexport type { StyledJSXIntrinsics, Styled } from './styled';\nexport type { CSSProperties } from '@linaria/core';\nexport type { StyledMeta } from '@linaria/tags';\n"],"mappings":"AAAA,SAASA,OAAO,IAAIC,MAApB,QAAkC,UAAlC"}
@@ -1,205 +0,0 @@
1
- import { TaggedTemplateProcessor, ValueType, hasMeta, validateParams } from '@linaria/tags';
2
-
3
- const isNotNull = x => x !== null;
4
-
5
- const singleQuotedStringLiteral = value => ({
6
- type: 'StringLiteral',
7
- value,
8
- extra: {
9
- rawValue: value,
10
- raw: `'${value}'`
11
- }
12
- });
13
-
14
- export default class StyledProcessor extends TaggedTemplateProcessor {
15
- #variableIdx = 0;
16
- #variablesCache = new Map();
17
-
18
- constructor(params, ...args) {
19
- validateParams(params, ['tag', ['call', 'member'], ['template', 'call']], 'Invalid usage of `styled` tag');
20
- const [tag, tagOp, template] = params;
21
-
22
- if (template[0] === 'call') {
23
- // It is already transformed styled-literal. Skip it.
24
- // eslint-disable-next-line @typescript-eslint/no-throw-literal
25
- throw TaggedTemplateProcessor.SKIP;
26
- }
27
-
28
- super([tag, template], ...args);
29
- let component;
30
-
31
- if (tagOp[0] === 'call' && tagOp.length === 2) {
32
- const value = tagOp[1];
33
-
34
- if (value.kind === ValueType.FUNCTION) {
35
- component = 'FunctionalComponent';
36
- } else {
37
- component = {
38
- node: value.ex,
39
- source: value.source
40
- };
41
- this.dependencies.push(value);
42
- }
43
- }
44
-
45
- if (tagOp[0] === 'member') {
46
- [, component] = tagOp;
47
- }
48
-
49
- if (!component) {
50
- throw new Error('Invalid usage of `styled` tag');
51
- }
52
-
53
- this.component = component;
54
- }
55
-
56
- addInterpolation(node, source, unit = '') {
57
- const id = this.getVariableId(source + unit);
58
- this.interpolations.push({
59
- id,
60
- node,
61
- source,
62
- unit
63
- });
64
- return id;
65
- }
66
-
67
- doEvaltimeReplacement() {
68
- this.replacer(this.value, false);
69
- }
70
-
71
- doRuntimeReplacement() {
72
- const t = this.astService;
73
- const props = this.getProps();
74
- this.replacer(t.callExpression(this.tagExpression, [this.getTagComponentProps(props)]), true);
75
- }
76
-
77
- extractRules(valueCache, cssText, loc) {
78
- const rules = {};
79
- let selector = `.${this.className}`; // If `styled` wraps another component and not a primitive,
80
- // get its class name to create a more specific selector
81
- // it'll ensure that styles are overridden properly
82
-
83
- let value = typeof this.component === 'string' ? null : valueCache.get(this.component.node.name);
84
-
85
- while (hasMeta(value)) {
86
- selector += `.${value.__linaria.className}`;
87
- value = value.__linaria.extends;
88
- }
89
-
90
- rules[selector] = {
91
- cssText,
92
- className: this.className,
93
- displayName: this.displayName,
94
- start: loc?.start ?? null
95
- };
96
- return rules;
97
- }
98
-
99
- get asSelector() {
100
- return `.${this.className}`;
101
- }
102
-
103
- get tagExpressionArgument() {
104
- const t = this.astService;
105
-
106
- if (typeof this.component === 'string') {
107
- if (this.component === 'FunctionalComponent') {
108
- return t.arrowFunctionExpression([], t.blockStatement([]));
109
- }
110
-
111
- return singleQuotedStringLiteral(this.component);
112
- }
113
-
114
- return t.callExpression(t.identifier(this.component.node.name), []);
115
- }
116
-
117
- get tagExpression() {
118
- const t = this.astService;
119
- return t.callExpression(this.tag, [this.tagExpressionArgument]);
120
- }
121
-
122
- get value() {
123
- const t = this.astService;
124
- const extendsNode = typeof this.component === 'string' ? null : this.component.node.name;
125
- return t.objectExpression([t.objectProperty(t.stringLiteral('displayName'), t.stringLiteral(this.displayName)), t.objectProperty(t.stringLiteral('__linaria'), t.objectExpression([t.objectProperty(t.stringLiteral('className'), t.stringLiteral(this.className)), t.objectProperty(t.stringLiteral('extends'), extendsNode ? t.callExpression(t.identifier(extendsNode), []) : t.nullLiteral())]))]);
126
- }
127
-
128
- toString() {
129
- const res = arg => `${this.tagSourceCode()}(${arg})\`…\``;
130
-
131
- if (typeof this.component === 'string') {
132
- if (this.component === 'FunctionalComponent') {
133
- return res('() => {…}');
134
- }
135
-
136
- return res(`'${this.component}'`);
137
- }
138
-
139
- return res(this.component.source);
140
- }
141
-
142
- getProps() {
143
- const propsObj = {
144
- name: this.displayName,
145
- class: this.className
146
- }; // If we found any interpolations, also pass them, so they can be applied
147
-
148
- if (this.interpolations.length) {
149
- propsObj.vars = {};
150
- this.interpolations.forEach(({
151
- id,
152
- unit,
153
- node
154
- }) => {
155
- const items = [this.astService.callExpression(node, [])];
156
-
157
- if (unit) {
158
- items.push(this.astService.stringLiteral(unit));
159
- }
160
-
161
- propsObj.vars[id] = items;
162
- });
163
- }
164
-
165
- return propsObj;
166
- }
167
-
168
- getTagComponentProps(props) {
169
- const t = this.astService;
170
- const propExpressions = Object.entries(props).map(([key, value]) => {
171
- if (!value) {
172
- return null;
173
- }
174
-
175
- const keyNode = t.identifier(key);
176
-
177
- if (typeof value === 'string') {
178
- return t.objectProperty(keyNode, t.stringLiteral(value));
179
- }
180
-
181
- if (typeof value === 'boolean') {
182
- return t.objectProperty(keyNode, t.booleanLiteral(value));
183
- }
184
-
185
- const vars = Object.entries(value).map(([propName, propValue]) => {
186
- return t.objectProperty(t.stringLiteral(propName), t.arrayExpression(propValue));
187
- });
188
- return t.objectProperty(keyNode, t.objectExpression(vars));
189
- }).filter(isNotNull);
190
- return t.objectExpression(propExpressions);
191
- } // eslint-disable-next-line @typescript-eslint/no-unused-vars
192
-
193
-
194
- getVariableId(value) {
195
- if (!this.#variablesCache.has(value)) {
196
- // make the variable unique to this styled component
197
- // eslint-disable-next-line no-plusplus
198
- this.#variablesCache.set(value, `${this.slug}-${this.#variableIdx++}`);
199
- }
200
-
201
- return this.#variablesCache.get(value);
202
- }
203
-
204
- }
205
- //# sourceMappingURL=styled.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"styled.js","names":["TaggedTemplateProcessor","ValueType","hasMeta","validateParams","isNotNull","x","singleQuotedStringLiteral","value","type","extra","rawValue","raw","StyledProcessor","variableIdx","variablesCache","Map","constructor","params","args","tag","tagOp","template","SKIP","component","length","kind","FUNCTION","node","ex","source","dependencies","push","Error","addInterpolation","unit","id","getVariableId","interpolations","doEvaltimeReplacement","replacer","doRuntimeReplacement","t","astService","props","getProps","callExpression","tagExpression","getTagComponentProps","extractRules","valueCache","cssText","loc","rules","selector","className","get","name","__linaria","extends","displayName","start","asSelector","tagExpressionArgument","arrowFunctionExpression","blockStatement","identifier","extendsNode","objectExpression","objectProperty","stringLiteral","nullLiteral","toString","res","arg","tagSourceCode","propsObj","class","vars","forEach","items","propExpressions","Object","entries","map","key","keyNode","booleanLiteral","propName","propValue","arrayExpression","filter","has","set","slug"],"sources":["../../src/processors/styled.ts"],"sourcesContent":["import type {\n CallExpression,\n Expression,\n ObjectExpression,\n SourceLocation,\n StringLiteral,\n} from '@babel/types';\n\nimport type {\n Rules,\n WrappedNode,\n ValueCache,\n Params,\n TailProcessorParams,\n} from '@linaria/tags';\nimport {\n TaggedTemplateProcessor,\n ValueType,\n hasMeta,\n validateParams,\n} from '@linaria/tags';\n\nconst isNotNull = <T>(x: T | null): x is T => x !== null;\n\nexport interface IProps {\n atomic?: boolean;\n class?: string;\n name: string;\n vars?: Record<string, Expression[]>;\n}\n\nconst singleQuotedStringLiteral = (value: string): StringLiteral => ({\n type: 'StringLiteral',\n value,\n extra: {\n rawValue: value,\n raw: `'${value}'`,\n },\n});\n\nexport default class StyledProcessor extends TaggedTemplateProcessor {\n public component: WrappedNode;\n\n #variableIdx = 0;\n\n #variablesCache = new Map<string, string>();\n\n constructor(params: Params, ...args: TailProcessorParams) {\n validateParams(\n params,\n ['tag', ['call', 'member'], ['template', 'call']],\n 'Invalid usage of `styled` tag'\n );\n\n const [tag, tagOp, template] = params;\n\n if (template[0] === 'call') {\n // It is already transformed styled-literal. Skip it.\n // eslint-disable-next-line @typescript-eslint/no-throw-literal\n throw TaggedTemplateProcessor.SKIP;\n }\n\n super([tag, template], ...args);\n\n let component: WrappedNode | undefined;\n if (tagOp[0] === 'call' && tagOp.length === 2) {\n const value = tagOp[1];\n if (value.kind === ValueType.FUNCTION) {\n component = 'FunctionalComponent';\n } else {\n component = {\n node: value.ex,\n source: value.source,\n };\n\n this.dependencies.push(value);\n }\n }\n\n if (tagOp[0] === 'member') {\n [, component] = tagOp;\n }\n\n if (!component) {\n throw new Error('Invalid usage of `styled` tag');\n }\n\n this.component = component;\n }\n\n public override addInterpolation(\n node: Expression,\n source: string,\n unit = ''\n ): string {\n const id = this.getVariableId(source + unit);\n\n this.interpolations.push({\n id,\n node,\n source,\n unit,\n });\n\n return id;\n }\n\n public override doEvaltimeReplacement(): void {\n this.replacer(this.value, false);\n }\n\n public override doRuntimeReplacement(): void {\n const t = this.astService;\n\n const props = this.getProps();\n\n this.replacer(\n t.callExpression(this.tagExpression, [this.getTagComponentProps(props)]),\n true\n );\n }\n\n public override extractRules(\n valueCache: ValueCache,\n cssText: string,\n loc?: SourceLocation | null\n ): Rules {\n const rules: Rules = {};\n\n let selector = `.${this.className}`;\n\n // If `styled` wraps another component and not a primitive,\n // get its class name to create a more specific selector\n // it'll ensure that styles are overridden properly\n let value =\n typeof this.component === 'string'\n ? null\n : valueCache.get(this.component.node.name);\n while (hasMeta(value)) {\n selector += `.${value.__linaria.className}`;\n value = value.__linaria.extends;\n }\n\n rules[selector] = {\n cssText,\n className: this.className,\n displayName: this.displayName,\n start: loc?.start ?? null,\n };\n\n return rules;\n }\n\n public override get asSelector(): string {\n return `.${this.className}`;\n }\n\n protected get tagExpressionArgument(): Expression {\n const t = this.astService;\n if (typeof this.component === 'string') {\n if (this.component === 'FunctionalComponent') {\n return t.arrowFunctionExpression([], t.blockStatement([]));\n }\n\n return singleQuotedStringLiteral(this.component);\n }\n\n return t.callExpression(t.identifier(this.component.node.name), []);\n }\n\n protected get tagExpression(): CallExpression {\n const t = this.astService;\n return t.callExpression(this.tag, [this.tagExpressionArgument]);\n }\n\n public override get value(): ObjectExpression {\n const t = this.astService;\n const extendsNode =\n typeof this.component === 'string' ? null : this.component.node.name;\n\n return t.objectExpression([\n t.objectProperty(\n t.stringLiteral('displayName'),\n t.stringLiteral(this.displayName)\n ),\n t.objectProperty(\n t.stringLiteral('__linaria'),\n t.objectExpression([\n t.objectProperty(\n t.stringLiteral('className'),\n t.stringLiteral(this.className)\n ),\n t.objectProperty(\n t.stringLiteral('extends'),\n extendsNode\n ? t.callExpression(t.identifier(extendsNode), [])\n : t.nullLiteral()\n ),\n ])\n ),\n ]);\n }\n\n public override toString(): string {\n const res = (arg: string) => `${this.tagSourceCode()}(${arg})\\`…\\``;\n\n if (typeof this.component === 'string') {\n if (this.component === 'FunctionalComponent') {\n return res('() => {…}');\n }\n\n return res(`'${this.component}'`);\n }\n\n return res(this.component.source);\n }\n\n protected getProps(): IProps {\n const propsObj: IProps = {\n name: this.displayName,\n class: this.className,\n };\n\n // If we found any interpolations, also pass them, so they can be applied\n if (this.interpolations.length) {\n propsObj.vars = {};\n this.interpolations.forEach(({ id, unit, node }) => {\n const items: Expression[] = [this.astService.callExpression(node, [])];\n\n if (unit) {\n items.push(this.astService.stringLiteral(unit));\n }\n\n propsObj.vars![id] = items;\n });\n }\n\n return propsObj;\n }\n\n protected getTagComponentProps(props: IProps): ObjectExpression {\n const t = this.astService;\n\n const propExpressions = Object.entries(props)\n .map(([key, value]: [key: string, value: IProps[keyof IProps]]) => {\n if (!value) {\n return null;\n }\n\n const keyNode = t.identifier(key);\n\n if (typeof value === 'string') {\n return t.objectProperty(keyNode, t.stringLiteral(value));\n }\n\n if (typeof value === 'boolean') {\n return t.objectProperty(keyNode, t.booleanLiteral(value));\n }\n\n const vars = Object.entries(value).map(([propName, propValue]) => {\n return t.objectProperty(\n t.stringLiteral(propName),\n t.arrayExpression(propValue)\n );\n });\n\n return t.objectProperty(keyNode, t.objectExpression(vars));\n })\n .filter(isNotNull);\n\n return t.objectExpression(propExpressions);\n }\n\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n protected getVariableId(value: string): string {\n if (!this.#variablesCache.has(value)) {\n // make the variable unique to this styled component\n // eslint-disable-next-line no-plusplus\n this.#variablesCache.set(value, `${this.slug}-${this.#variableIdx++}`);\n }\n\n return this.#variablesCache.get(value)!;\n }\n}\n"],"mappings":"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"}