@webstudio-is/react-sdk 0.145.0 → 0.163.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.
@@ -60,6 +60,7 @@ var nav = baseStyle;
60
60
  var section = baseStyle;
61
61
  var form = baseStyle;
62
62
  var label = baseStyle;
63
+ var time = baseStyle;
63
64
  var h1 = baseStyle;
64
65
  var h2 = baseStyle;
65
66
  var h3 = baseStyle;
@@ -375,5 +376,6 @@ export {
375
376
  sup,
376
377
  table,
377
378
  textarea,
379
+ time,
378
380
  ul
379
381
  };
package/lib/index.js CHANGED
@@ -214,8 +214,108 @@ var getPresetStyleRules = (component, presetStyle) => {
214
214
  // src/css/css.ts
215
215
  import {
216
216
  createRegularStyleSheet,
217
- createAtomicStyleSheet
217
+ generateAtomic
218
218
  } from "@webstudio-is/css-engine";
219
+
220
+ // src/core-components.ts
221
+ import { ListViewIcon, PaintBrushIcon } from "@webstudio-is/icons/svg";
222
+ var portalComponent = "Slot";
223
+ var collectionComponent = "ws:collection";
224
+ var collectionMeta = {
225
+ category: "data",
226
+ order: 2,
227
+ type: "container",
228
+ label: "Collection",
229
+ icon: ListViewIcon,
230
+ stylable: false,
231
+ template: [
232
+ {
233
+ type: "instance",
234
+ component: collectionComponent,
235
+ props: [
236
+ {
237
+ name: "data",
238
+ type: "json",
239
+ value: [
240
+ "Collection Item 1",
241
+ "Collection Item 2",
242
+ "Collection Item 3"
243
+ ]
244
+ },
245
+ {
246
+ name: "item",
247
+ type: "parameter",
248
+ variableName: "collectionItem",
249
+ variableAlias: "Collection Item"
250
+ }
251
+ ],
252
+ children: [
253
+ {
254
+ type: "instance",
255
+ component: "Box",
256
+ children: [{ type: "expression", value: "collectionItem" }]
257
+ }
258
+ ]
259
+ }
260
+ ]
261
+ };
262
+ var collectionPropsMeta = {
263
+ props: {
264
+ data: {
265
+ required: true,
266
+ control: "json",
267
+ type: "json"
268
+ }
269
+ },
270
+ initialProps: ["data"]
271
+ };
272
+ var descendantComponent = "ws:descendant";
273
+ var descendantMeta = {
274
+ category: "internal",
275
+ type: "control",
276
+ label: "Descendant",
277
+ icon: PaintBrushIcon,
278
+ detachable: false
279
+ };
280
+ var descendantPropsMeta = {
281
+ props: {
282
+ selector: {
283
+ required: true,
284
+ type: "string",
285
+ control: "select",
286
+ options: [
287
+ " p",
288
+ " h1",
289
+ " h2",
290
+ " h3",
291
+ " h4",
292
+ " h5",
293
+ " h6",
294
+ " :where(strong, b)",
295
+ " :where(em, i)",
296
+ " a",
297
+ " img",
298
+ " blockquote",
299
+ " code",
300
+ " :where(ul, ol)",
301
+ " li",
302
+ " hr"
303
+ ]
304
+ }
305
+ },
306
+ initialProps: ["selector"]
307
+ };
308
+ var coreMetas = {
309
+ [collectionComponent]: collectionMeta,
310
+ [descendantComponent]: descendantMeta
311
+ };
312
+ var corePropsMetas = {
313
+ [collectionComponent]: collectionPropsMeta,
314
+ [descendantComponent]: descendantPropsMeta
315
+ };
316
+ var isCoreComponent = (component) => component === collectionComponent || component === descendantComponent;
317
+
318
+ // src/css/css.ts
219
319
  var createImageValueTransformer = (assets, { assetBaseUrl }) => (styleValue) => {
220
320
  if (styleValue.type === "image" && styleValue.value.type === "asset") {
221
321
  const asset = assets.get(styleValue.value.value);
@@ -235,6 +335,8 @@ var createImageValueTransformer = (assets, { assetBaseUrl }) => (styleValue) =>
235
335
  };
236
336
  var generateCss = ({
237
337
  assets,
338
+ instances,
339
+ props,
238
340
  breakpoints,
239
341
  styles,
240
342
  styleSourceSelections,
@@ -242,12 +344,24 @@ var generateCss = ({
242
344
  assetBaseUrl,
243
345
  atomic
244
346
  }) => {
245
- const classesMap = /* @__PURE__ */ new Map();
246
- const regularSheet = createRegularStyleSheet({ name: "ssr-regular" });
247
- const atomicSheet = atomic ? createAtomicStyleSheet({ name: "ssr-atomic" }) : void 0;
248
- addGlobalRules(regularSheet, { assets, assetBaseUrl });
347
+ const sheet = createRegularStyleSheet({ name: "ssr" });
348
+ const parentIdByInstanceId = /* @__PURE__ */ new Map();
349
+ for (const instance of instances.values()) {
350
+ for (const child of instance.children) {
351
+ if (child.type === "id") {
352
+ parentIdByInstanceId.set(child.value, instance.id);
353
+ }
354
+ }
355
+ }
356
+ const descendantSelectorByInstanceId = /* @__PURE__ */ new Map();
357
+ for (const prop of props.values()) {
358
+ if (prop.name === "selector" && prop.type === "string") {
359
+ descendantSelectorByInstanceId.set(prop.instanceId, prop.value);
360
+ }
361
+ }
362
+ addGlobalRules(sheet, { assets, assetBaseUrl });
249
363
  for (const breakpoint of breakpoints.values()) {
250
- (atomicSheet ?? regularSheet).addMediaRule(breakpoint.id, breakpoint);
364
+ sheet.addMediaRule(breakpoint.id, breakpoint);
251
365
  }
252
366
  for (const [component, meta] of componentMetas) {
253
367
  const presetStyle = meta.presetStyle;
@@ -256,35 +370,52 @@ var generateCss = ({
256
370
  }
257
371
  const rules = getPresetStyleRules(component, presetStyle);
258
372
  for (const [selector, style] of rules) {
259
- regularSheet.addStyleRule({ style }, selector);
373
+ sheet.addStyleRule({ style }, selector);
260
374
  }
261
375
  }
262
- const styleRules = getStyleRules(styles, styleSourceSelections);
263
376
  const imageValueTransformer = createImageValueTransformer(assets, {
264
377
  assetBaseUrl
265
378
  });
266
- for (const { breakpointId, instanceId, state, style } of styleRules) {
267
- if (atomicSheet) {
268
- const { classes } = atomicSheet.addStyleRule(
269
- { breakpoint: breakpointId, style },
270
- state,
271
- imageValueTransformer
272
- );
273
- classesMap.set(instanceId, [
274
- ...classesMap.get(instanceId) ?? [],
275
- ...classes
276
- ]);
277
- continue;
379
+ sheet.setTransformer(imageValueTransformer);
380
+ for (const styleDecl of styles.values()) {
381
+ const rule = sheet.addMixinRule(styleDecl.styleSourceId);
382
+ rule.setDeclaration({
383
+ breakpoint: styleDecl.breakpointId,
384
+ selector: styleDecl.state ?? "",
385
+ property: styleDecl.property,
386
+ value: styleDecl.value
387
+ });
388
+ }
389
+ const instanceByRule = /* @__PURE__ */ new Map();
390
+ for (const selection of styleSourceSelections.values()) {
391
+ let { instanceId } = selection;
392
+ const { values } = selection;
393
+ let descendantSuffix = "";
394
+ const instance = instances.get(instanceId);
395
+ if (instance?.component === descendantComponent) {
396
+ const parentId = parentIdByInstanceId.get(instanceId);
397
+ const descendantSelector = descendantSelectorByInstanceId.get(instanceId);
398
+ if (parentId && descendantSelector) {
399
+ descendantSuffix = descendantSelector;
400
+ instanceId = parentId;
401
+ }
278
402
  }
279
- regularSheet.addStyleRule(
280
- { breakpoint: breakpointId, style },
281
- `[${idAttribute}="${instanceId}"]${state ?? ""}`,
282
- imageValueTransformer
403
+ const rule = sheet.addNestingRule(
404
+ `[${idAttribute}="${instanceId}"]`,
405
+ descendantSuffix
283
406
  );
407
+ rule.applyMixins(values);
408
+ instanceByRule.set(rule, instanceId);
409
+ }
410
+ if (atomic) {
411
+ return generateAtomic(sheet, {
412
+ getKey: (rule) => instanceByRule.get(rule) ?? "",
413
+ transformValue: imageValueTransformer
414
+ });
284
415
  }
285
416
  return {
286
- cssText: regularSheet.cssText + (atomicSheet?.cssText ?? ""),
287
- classesMap
417
+ cssText: sheet.cssText,
418
+ classesMap: /* @__PURE__ */ new Map()
288
419
  };
289
420
  };
290
421
 
@@ -405,65 +536,6 @@ var createInstanceElement = ({
405
536
  );
406
537
  };
407
538
 
408
- // src/core-components.ts
409
- import { ListViewIcon } from "@webstudio-is/icons/svg";
410
- var portalComponent = "Slot";
411
- var collectionComponent = "ws:collection";
412
- var collectionMeta = {
413
- category: "data",
414
- order: 7,
415
- type: "container",
416
- label: "Collection",
417
- icon: ListViewIcon,
418
- stylable: false,
419
- template: [
420
- {
421
- type: "instance",
422
- component: collectionComponent,
423
- props: [
424
- {
425
- name: "data",
426
- type: "json",
427
- value: [
428
- "Collection Item 1",
429
- "Collection Item 2",
430
- "Collection Item 3"
431
- ]
432
- },
433
- {
434
- name: "item",
435
- type: "parameter",
436
- variableName: "collectionItem",
437
- variableAlias: "Collection Item"
438
- }
439
- ],
440
- children: [
441
- {
442
- type: "instance",
443
- component: "Box",
444
- children: [{ type: "expression", value: "collectionItem" }]
445
- }
446
- ]
447
- }
448
- ]
449
- };
450
- var collectionPropsMeta = {
451
- props: {
452
- data: {
453
- required: true,
454
- control: "json",
455
- type: "json"
456
- }
457
- },
458
- initialProps: ["data"]
459
- };
460
- var coreMetas = {
461
- [collectionComponent]: collectionMeta
462
- };
463
- var corePropsMetas = {
464
- [collectionComponent]: collectionPropsMeta
465
- };
466
-
467
539
  // src/prop-meta.ts
468
540
  import { z } from "zod";
469
541
  var common = {
@@ -498,12 +570,10 @@ var Code = z.object({
498
570
  ...common,
499
571
  control: z.literal("code"),
500
572
  type: z.literal("string"),
501
- defaultValue: z.string().optional(),
502
- /**
503
- * The number of rows in <textarea>. If set to 0 an <input> will be used instead.
504
- * In line with Storybook team's plan: https://github.com/storybookjs/storybook/issues/21100
505
- */
506
- rows: z.number().optional()
573
+ defaultValue: z.string().optional()
574
+ });
575
+ var CodeText = Code.extend({
576
+ control: z.literal("codetext")
507
577
  });
508
578
  var Color = z.object({
509
579
  ...common,
@@ -604,6 +674,7 @@ var PropMeta = z.union([
604
674
  Range,
605
675
  Text,
606
676
  Code,
677
+ CodeText,
607
678
  Color,
608
679
  Boolean,
609
680
  Radio,
@@ -1011,7 +1082,9 @@ var componentCategories = [
1011
1082
  "media",
1012
1083
  "forms",
1013
1084
  "radix",
1014
- "hidden"
1085
+ "xml",
1086
+ "hidden",
1087
+ "internal"
1015
1088
  ];
1016
1089
  var stateCategories = ["states", "component-states"];
1017
1090
  var ComponentState = z3.object({
@@ -1314,6 +1387,9 @@ className=${JSON.stringify(classes.join(" "))}`;
1314
1387
  `;
1315
1388
  }
1316
1389
  }
1390
+ if (instance.component === descendantComponent) {
1391
+ return "";
1392
+ }
1317
1393
  if (conditionValue) {
1318
1394
  generatedElement += `}
1319
1395
  `;
@@ -1483,6 +1559,7 @@ export {
1483
1559
  createImageValueTransformer,
1484
1560
  createInstanceChildrenElements,
1485
1561
  defaultStates,
1562
+ descendantComponent,
1486
1563
  generateCss,
1487
1564
  generateDataFromEmbedTemplate,
1488
1565
  generateJsxChildren,
@@ -1498,6 +1575,7 @@ export {
1498
1575
  getStyleRules,
1499
1576
  idAttribute,
1500
1577
  indexAttribute,
1578
+ isCoreComponent,
1501
1579
  namespaceMeta,
1502
1580
  normalizeProps,
1503
1581
  portalComponent,
@@ -73,7 +73,6 @@ declare const WsComponentPropsMeta: z.ZodObject<{
73
73
  control: z.ZodLiteral<"code">;
74
74
  type: z.ZodLiteral<"string">;
75
75
  defaultValue: z.ZodOptional<z.ZodString>;
76
- rows: z.ZodOptional<z.ZodNumber>;
77
76
  label: z.ZodOptional<z.ZodString>;
78
77
  description: z.ZodOptional<z.ZodString>;
79
78
  required: z.ZodBoolean;
@@ -82,7 +81,6 @@ declare const WsComponentPropsMeta: z.ZodObject<{
82
81
  required: boolean;
83
82
  control: "code";
84
83
  defaultValue?: string | undefined;
85
- rows?: number | undefined;
86
84
  label?: string | undefined;
87
85
  description?: string | undefined;
88
86
  }, {
@@ -90,9 +88,29 @@ declare const WsComponentPropsMeta: z.ZodObject<{
90
88
  required: boolean;
91
89
  control: "code";
92
90
  defaultValue?: string | undefined;
93
- rows?: number | undefined;
94
91
  label?: string | undefined;
95
92
  description?: string | undefined;
93
+ }>, z.ZodObject<{
94
+ type: z.ZodLiteral<"string">;
95
+ required: z.ZodBoolean;
96
+ description: z.ZodOptional<z.ZodString>;
97
+ label: z.ZodOptional<z.ZodString>;
98
+ defaultValue: z.ZodOptional<z.ZodString>;
99
+ control: z.ZodLiteral<"codetext">;
100
+ }, "strip", z.ZodTypeAny, {
101
+ type: "string";
102
+ required: boolean;
103
+ control: "codetext";
104
+ description?: string | undefined;
105
+ label?: string | undefined;
106
+ defaultValue?: string | undefined;
107
+ }, {
108
+ type: "string";
109
+ required: boolean;
110
+ control: "codetext";
111
+ description?: string | undefined;
112
+ label?: string | undefined;
113
+ defaultValue?: string | undefined;
96
114
  }>, z.ZodObject<{
97
115
  control: z.ZodLiteral<"color">;
98
116
  type: z.ZodLiteral<"string">;
@@ -438,9 +456,15 @@ declare const WsComponentPropsMeta: z.ZodObject<{
438
456
  required: boolean;
439
457
  control: "code";
440
458
  defaultValue?: string | undefined;
441
- rows?: number | undefined;
442
459
  label?: string | undefined;
443
460
  description?: string | undefined;
461
+ } | {
462
+ type: "string";
463
+ required: boolean;
464
+ control: "codetext";
465
+ description?: string | undefined;
466
+ label?: string | undefined;
467
+ defaultValue?: string | undefined;
444
468
  } | {
445
469
  type: "string";
446
470
  required: boolean;
@@ -576,9 +600,15 @@ declare const WsComponentPropsMeta: z.ZodObject<{
576
600
  required: boolean;
577
601
  control: "code";
578
602
  defaultValue?: string | undefined;
579
- rows?: number | undefined;
580
603
  label?: string | undefined;
581
604
  description?: string | undefined;
605
+ } | {
606
+ type: "string";
607
+ required: boolean;
608
+ control: "codetext";
609
+ description?: string | undefined;
610
+ label?: string | undefined;
611
+ defaultValue?: string | undefined;
582
612
  } | {
583
613
  type: "string";
584
614
  required: boolean;
@@ -688,7 +718,7 @@ declare const WsComponentPropsMeta: z.ZodObject<{
688
718
  initialProps?: string[] | undefined;
689
719
  }>;
690
720
  export type WsComponentPropsMeta = z.infer<typeof WsComponentPropsMeta>;
691
- export declare const componentCategories: readonly ["general", "text", "data", "media", "forms", "radix", "hidden"];
721
+ export declare const componentCategories: readonly ["general", "text", "data", "media", "forms", "radix", "xml", "hidden", "internal"];
692
722
  export declare const stateCategories: readonly ["states", "component-states"];
693
723
  export declare const ComponentState: z.ZodObject<{
694
724
  category: z.ZodOptional<z.ZodEnum<["states", "component-states"]>>;
@@ -706,7 +736,7 @@ export declare const ComponentState: z.ZodObject<{
706
736
  export type ComponentState = z.infer<typeof ComponentState>;
707
737
  export declare const defaultStates: ComponentState[];
708
738
  export declare const WsComponentMeta: z.ZodObject<{
709
- category: z.ZodOptional<z.ZodEnum<["general", "text", "data", "media", "forms", "radix", "hidden"]>>;
739
+ category: z.ZodOptional<z.ZodEnum<["general", "text", "data", "media", "forms", "radix", "xml", "hidden", "internal"]>>;
710
740
  type: z.ZodEnum<["container", "control", "embed", "rich-text-child"]>;
711
741
  requiredAncestors: z.ZodOptional<z.ZodArray<z.ZodString, "many">>;
712
742
  invalidAncestors: z.ZodOptional<z.ZodArray<z.ZodString, "many">>;
@@ -3353,9 +3383,9 @@ export declare const WsComponentMeta: z.ZodObject<{
3353
3383
  }>]>, "many">>>;
3354
3384
  order: z.ZodOptional<z.ZodNumber>;
3355
3385
  }, "strip", z.ZodTypeAny, {
3356
- type: "embed" | "control" | "container" | "rich-text-child";
3386
+ type: "control" | "embed" | "container" | "rich-text-child";
3357
3387
  icon: string;
3358
- category?: "data" | "text" | "hidden" | "media" | "general" | "forms" | "radix" | undefined;
3388
+ category?: "data" | "xml" | "text" | "hidden" | "media" | "general" | "forms" | "radix" | "internal" | undefined;
3359
3389
  requiredAncestors?: string[] | undefined;
3360
3390
  invalidAncestors?: string[] | undefined;
3361
3391
  indexWithinAncestor?: string | undefined;
@@ -4246,9 +4276,9 @@ export declare const WsComponentMeta: z.ZodObject<{
4246
4276
  } | import("../embed-template").EmbedTemplateInstance)[] | undefined;
4247
4277
  order?: number | undefined;
4248
4278
  }, {
4249
- type: "embed" | "control" | "container" | "rich-text-child";
4279
+ type: "control" | "embed" | "container" | "rich-text-child";
4250
4280
  icon: string;
4251
- category?: "data" | "text" | "hidden" | "media" | "general" | "forms" | "radix" | undefined;
4281
+ category?: "data" | "xml" | "text" | "hidden" | "media" | "general" | "forms" | "radix" | "internal" | undefined;
4252
4282
  requiredAncestors?: string[] | undefined;
4253
4283
  invalidAncestors?: string[] | undefined;
4254
4284
  indexWithinAncestor?: string | undefined;
@@ -1,8 +1,10 @@
1
1
  import type { WsComponentMeta } from "./components/component-meta";
2
2
  export declare const portalComponent = "Slot";
3
3
  export declare const collectionComponent = "ws:collection";
4
+ export declare const descendantComponent = "ws:descendant";
4
5
  export declare const coreMetas: {
5
6
  "ws:collection": WsComponentMeta;
7
+ "ws:descendant": WsComponentMeta;
6
8
  };
7
9
  export declare const corePropsMetas: {
8
10
  "ws:collection": {
@@ -33,9 +35,160 @@ export declare const corePropsMetas: {
33
35
  required: boolean;
34
36
  control: "code";
35
37
  defaultValue?: string | undefined;
38
+ label?: string | undefined;
39
+ description?: string | undefined;
40
+ } | {
41
+ type: "string";
42
+ required: boolean;
43
+ control: "codetext";
44
+ description?: string | undefined;
45
+ label?: string | undefined;
46
+ defaultValue?: string | undefined;
47
+ } | {
48
+ type: "string";
49
+ required: boolean;
50
+ control: "color";
51
+ defaultValue?: string | undefined;
52
+ label?: string | undefined;
53
+ description?: string | undefined;
54
+ } | {
55
+ type: "boolean";
56
+ required: boolean;
57
+ control: "boolean";
58
+ defaultValue?: boolean | undefined;
59
+ label?: string | undefined;
60
+ description?: string | undefined;
61
+ } | {
62
+ options: string[];
63
+ type: "string";
64
+ required: boolean;
65
+ control: "radio";
66
+ defaultValue?: string | undefined;
67
+ label?: string | undefined;
68
+ description?: string | undefined;
69
+ } | {
70
+ options: string[];
71
+ type: "string";
72
+ required: boolean;
73
+ control: "inline-radio";
74
+ defaultValue?: string | undefined;
75
+ label?: string | undefined;
76
+ description?: string | undefined;
77
+ } | {
78
+ options: string[];
79
+ type: "string";
80
+ required: boolean;
81
+ control: "select";
82
+ defaultValue?: string | undefined;
83
+ label?: string | undefined;
84
+ description?: string | undefined;
85
+ } | {
86
+ options: string[];
87
+ type: "string[]";
88
+ required: boolean;
89
+ control: "check";
90
+ defaultValue?: string[] | undefined;
91
+ label?: string | undefined;
92
+ description?: string | undefined;
93
+ } | {
94
+ options: string[];
95
+ type: "string[]";
96
+ required: boolean;
97
+ control: "inline-check";
98
+ defaultValue?: string[] | undefined;
99
+ label?: string | undefined;
100
+ description?: string | undefined;
101
+ } | {
102
+ options: string[];
103
+ type: "string[]";
104
+ required: boolean;
105
+ control: "multi-select";
106
+ defaultValue?: string[] | undefined;
107
+ label?: string | undefined;
108
+ description?: string | undefined;
109
+ } | {
110
+ type: "string";
111
+ required: boolean;
112
+ control: "file";
113
+ defaultValue?: string | undefined;
114
+ accept?: string | undefined;
115
+ label?: string | undefined;
116
+ description?: string | undefined;
117
+ } | {
118
+ type: "string";
119
+ required: boolean;
120
+ control: "url";
121
+ defaultValue?: string | undefined;
122
+ label?: string | undefined;
123
+ description?: string | undefined;
124
+ } | {
125
+ type: "json";
126
+ required: boolean;
127
+ control: "json";
128
+ defaultValue?: unknown;
129
+ label?: string | undefined;
130
+ description?: string | undefined;
131
+ } | {
132
+ type: "string";
133
+ required: boolean;
134
+ control: "date";
135
+ defaultValue?: string | undefined;
136
+ label?: string | undefined;
137
+ description?: string | undefined;
138
+ } | {
139
+ type: "action";
140
+ required: boolean;
141
+ control: "action";
142
+ defaultValue?: undefined;
143
+ label?: string | undefined;
144
+ description?: string | undefined;
145
+ } | {
146
+ type: "string";
147
+ required: boolean;
148
+ control: "textContent";
149
+ defaultValue?: string | undefined;
150
+ label?: string | undefined;
151
+ description?: string | undefined;
152
+ }>;
153
+ initialProps?: string[] | undefined;
154
+ };
155
+ "ws:descendant": {
156
+ props: Record<string, {
157
+ type: "number";
158
+ required: boolean;
159
+ control: "number";
160
+ defaultValue?: number | undefined;
161
+ label?: string | undefined;
162
+ description?: string | undefined;
163
+ } | {
164
+ type: "number";
165
+ required: boolean;
166
+ control: "range";
167
+ defaultValue?: number | undefined;
168
+ label?: string | undefined;
169
+ description?: string | undefined;
170
+ } | {
171
+ type: "string";
172
+ required: boolean;
173
+ control: "text";
174
+ defaultValue?: string | undefined;
36
175
  rows?: number | undefined;
37
176
  label?: string | undefined;
38
177
  description?: string | undefined;
178
+ } | {
179
+ type: "string";
180
+ required: boolean;
181
+ control: "code";
182
+ defaultValue?: string | undefined;
183
+ label?: string | undefined;
184
+ description?: string | undefined;
185
+ } | {
186
+ type: "string";
187
+ required: boolean;
188
+ control: "codetext";
189
+ description?: string | undefined;
190
+ label?: string | undefined;
191
+ defaultValue?: string | undefined;
39
192
  } | {
40
193
  type: "string";
41
194
  required: boolean;
@@ -145,3 +298,4 @@ export declare const corePropsMetas: {
145
298
  initialProps?: string[] | undefined;
146
299
  };
147
300
  };
301
+ export declare const isCoreComponent: (component: string) => boolean;
@@ -1,8 +1,10 @@
1
1
  import { type TransformValue } from "@webstudio-is/css-engine";
2
- import type { Assets, Breakpoints, StyleSourceSelections, Styles } from "@webstudio-is/sdk";
2
+ import type { Assets, Breakpoints, Instances, Props, StyleSourceSelections, Styles } from "@webstudio-is/sdk";
3
3
  import type { WsComponentMeta } from "../components/component-meta";
4
4
  export type CssConfig = {
5
5
  assets: Assets;
6
+ instances: Instances;
7
+ props: Props;
6
8
  breakpoints: Breakpoints;
7
9
  styles: Styles;
8
10
  styleSourceSelections: StyleSourceSelections;
@@ -13,7 +15,7 @@ export type CssConfig = {
13
15
  export declare const createImageValueTransformer: (assets: Map<string, {
14
16
  type: "font";
15
17
  name: string;
16
- format: "ttf" | "woff" | "woff2" | "otf";
18
+ format: "ttf" | "woff" | "woff2";
17
19
  meta: ({
18
20
  family: string;
19
21
  style: "normal" | "italic" | "oblique";
@@ -60,7 +62,7 @@ export declare const createImageValueTransformer: (assets: Map<string, {
60
62
  }>, { assetBaseUrl }: {
61
63
  assetBaseUrl: string;
62
64
  }) => TransformValue;
63
- export declare const generateCss: ({ assets, breakpoints, styles, styleSourceSelections, componentMetas, assetBaseUrl, atomic, }: CssConfig) => {
65
+ export declare const generateCss: ({ assets, instances, props, breakpoints, styles, styleSourceSelections, componentMetas, assetBaseUrl, atomic, }: CssConfig) => {
64
66
  cssText: string;
65
67
  classesMap: Map<string, string[]>;
66
68
  };
@@ -1,6 +1,6 @@
1
- import type { StyleSheetAtomic, StyleSheetRegular } from "@webstudio-is/css-engine";
1
+ import type { StyleSheetRegular } from "@webstudio-is/css-engine";
2
2
  import type { Assets } from "@webstudio-is/sdk";
3
- export declare const addGlobalRules: (sheet: StyleSheetRegular | StyleSheetAtomic, { assets, assetBaseUrl }: {
3
+ export declare const addGlobalRules: (sheet: StyleSheetRegular, { assets, assetBaseUrl }: {
4
4
  assets: Assets;
5
5
  assetBaseUrl: string;
6
6
  }) => void;
@@ -5284,6 +5284,445 @@ export declare const label: ({
5284
5284
  value: string;
5285
5285
  };
5286
5286
  })[];
5287
+ export declare const time: ({
5288
+ value: {
5289
+ value: number;
5290
+ type: "unit";
5291
+ unit: "number" | "%" | "deg" | "grad" | "rad" | "turn" | "db" | "fr" | "hz" | "khz" | "cm" | "mm" | "q" | "in" | "pt" | "pc" | "px" | "em" | "rem" | "ex" | "rex" | "cap" | "rcap" | "ch" | "rch" | "ic" | "ric" | "lh" | "rlh" | "vw" | "svw" | "lvw" | "dvw" | "vh" | "svh" | "lvh" | "dvh" | "vi" | "svi" | "lvi" | "dvi" | "vb" | "svb" | "lvb" | "dvb" | "vmin" | "svmin" | "lvmin" | "dvmin" | "vmax" | "svmax" | "lvmax" | "dvmax" | "cqw" | "cqh" | "cqi" | "cqb" | "cqmin" | "cqmax" | "dpi" | "dpcm" | "dppx" | "x" | "st" | "s" | "ms";
5292
+ } | {
5293
+ value: string;
5294
+ type: "keyword";
5295
+ } | {
5296
+ value: string;
5297
+ type: "unparsed";
5298
+ hidden?: boolean | undefined;
5299
+ } | {
5300
+ value: string[];
5301
+ type: "fontFamily";
5302
+ } | {
5303
+ type: "rgb";
5304
+ r: number;
5305
+ g: number;
5306
+ b: number;
5307
+ alpha: number;
5308
+ } | {
5309
+ type: "function";
5310
+ name: string;
5311
+ args: {
5312
+ value: number;
5313
+ type: "unit";
5314
+ unit: "number" | "%" | "deg" | "grad" | "rad" | "turn" | "db" | "fr" | "hz" | "khz" | "cm" | "mm" | "q" | "in" | "pt" | "pc" | "px" | "em" | "rem" | "ex" | "rex" | "cap" | "rcap" | "ch" | "rch" | "ic" | "ric" | "lh" | "rlh" | "vw" | "svw" | "lvw" | "dvw" | "vh" | "svh" | "lvh" | "dvh" | "vi" | "svi" | "lvi" | "dvi" | "vb" | "svb" | "lvb" | "dvb" | "vmin" | "svmin" | "lvmin" | "dvmin" | "vmax" | "svmax" | "lvmax" | "dvmax" | "cqw" | "cqh" | "cqi" | "cqb" | "cqmin" | "cqmax" | "dpi" | "dpcm" | "dppx" | "x" | "st" | "s" | "ms";
5315
+ } | {
5316
+ value: string;
5317
+ type: "keyword";
5318
+ } | {
5319
+ value: string;
5320
+ type: "unparsed";
5321
+ hidden?: boolean | undefined;
5322
+ } | {
5323
+ value: string[];
5324
+ type: "fontFamily";
5325
+ } | {
5326
+ type: "rgb";
5327
+ r: number;
5328
+ g: number;
5329
+ b: number;
5330
+ alpha: number;
5331
+ } | any | {
5332
+ value: {
5333
+ value: string;
5334
+ type: "asset";
5335
+ } | {
5336
+ type: "url";
5337
+ url: string;
5338
+ };
5339
+ type: "image";
5340
+ hidden?: boolean | undefined;
5341
+ } | {
5342
+ value: ({
5343
+ value: number;
5344
+ type: "unit";
5345
+ unit: "number" | "%" | "deg" | "grad" | "rad" | "turn" | "db" | "fr" | "hz" | "khz" | "cm" | "mm" | "q" | "in" | "pt" | "pc" | "px" | "em" | "rem" | "ex" | "rex" | "cap" | "rcap" | "ch" | "rch" | "ic" | "ric" | "lh" | "rlh" | "vw" | "svw" | "lvw" | "dvw" | "vh" | "svh" | "lvh" | "dvh" | "vi" | "svi" | "lvi" | "dvi" | "vb" | "svb" | "lvb" | "dvb" | "vmin" | "svmin" | "lvmin" | "dvmin" | "vmax" | "svmax" | "lvmax" | "dvmax" | "cqw" | "cqh" | "cqi" | "cqb" | "cqmin" | "cqmax" | "dpi" | "dpcm" | "dppx" | "x" | "st" | "s" | "ms";
5346
+ } | {
5347
+ value: string;
5348
+ type: "keyword";
5349
+ } | {
5350
+ value: string;
5351
+ type: "unparsed";
5352
+ hidden?: boolean | undefined;
5353
+ } | {
5354
+ type: "rgb";
5355
+ r: number;
5356
+ g: number;
5357
+ b: number;
5358
+ alpha: number;
5359
+ } | any)[];
5360
+ type: "tuple";
5361
+ hidden?: boolean | undefined;
5362
+ } | {
5363
+ value: string;
5364
+ type: "invalid";
5365
+ } | {
5366
+ value: ({
5367
+ value: number;
5368
+ type: "unit";
5369
+ unit: "number" | "%" | "deg" | "grad" | "rad" | "turn" | "db" | "fr" | "hz" | "khz" | "cm" | "mm" | "q" | "in" | "pt" | "pc" | "px" | "em" | "rem" | "ex" | "rex" | "cap" | "rcap" | "ch" | "rch" | "ic" | "ric" | "lh" | "rlh" | "vw" | "svw" | "lvw" | "dvw" | "vh" | "svh" | "lvh" | "dvh" | "vi" | "svi" | "lvi" | "dvi" | "vb" | "svb" | "lvb" | "dvb" | "vmin" | "svmin" | "lvmin" | "dvmin" | "vmax" | "svmax" | "lvmax" | "dvmax" | "cqw" | "cqh" | "cqi" | "cqb" | "cqmin" | "cqmax" | "dpi" | "dpcm" | "dppx" | "x" | "st" | "s" | "ms";
5370
+ } | {
5371
+ value: string;
5372
+ type: "keyword";
5373
+ } | {
5374
+ value: string;
5375
+ type: "unparsed";
5376
+ hidden?: boolean | undefined;
5377
+ } | any | {
5378
+ value: {
5379
+ value: string;
5380
+ type: "asset";
5381
+ } | {
5382
+ type: "url";
5383
+ url: string;
5384
+ };
5385
+ type: "image";
5386
+ hidden?: boolean | undefined;
5387
+ } | {
5388
+ value: ({
5389
+ value: number;
5390
+ type: "unit";
5391
+ unit: "number" | "%" | "deg" | "grad" | "rad" | "turn" | "db" | "fr" | "hz" | "khz" | "cm" | "mm" | "q" | "in" | "pt" | "pc" | "px" | "em" | "rem" | "ex" | "rex" | "cap" | "rcap" | "ch" | "rch" | "ic" | "ric" | "lh" | "rlh" | "vw" | "svw" | "lvw" | "dvw" | "vh" | "svh" | "lvh" | "dvh" | "vi" | "svi" | "lvi" | "dvi" | "vb" | "svb" | "lvb" | "dvb" | "vmin" | "svmin" | "lvmin" | "dvmin" | "vmax" | "svmax" | "lvmax" | "dvmax" | "cqw" | "cqh" | "cqi" | "cqb" | "cqmin" | "cqmax" | "dpi" | "dpcm" | "dppx" | "x" | "st" | "s" | "ms";
5392
+ } | {
5393
+ value: string;
5394
+ type: "keyword";
5395
+ } | {
5396
+ value: string;
5397
+ type: "unparsed";
5398
+ hidden?: boolean | undefined;
5399
+ } | {
5400
+ type: "rgb";
5401
+ r: number;
5402
+ g: number;
5403
+ b: number;
5404
+ alpha: number;
5405
+ } | any)[];
5406
+ type: "tuple";
5407
+ hidden?: boolean | undefined;
5408
+ } | {
5409
+ value: string;
5410
+ type: "invalid";
5411
+ })[];
5412
+ type: "layers";
5413
+ } | {
5414
+ type: "guaranteedInvalid";
5415
+ } | {
5416
+ value: "";
5417
+ type: "unset";
5418
+ } | {
5419
+ value: string;
5420
+ type: "var";
5421
+ fallbacks: ({
5422
+ value: number;
5423
+ type: "unit";
5424
+ unit: "number" | "%" | "deg" | "grad" | "rad" | "turn" | "db" | "fr" | "hz" | "khz" | "cm" | "mm" | "q" | "in" | "pt" | "pc" | "px" | "em" | "rem" | "ex" | "rex" | "cap" | "rcap" | "ch" | "rch" | "ic" | "ric" | "lh" | "rlh" | "vw" | "svw" | "lvw" | "dvw" | "vh" | "svh" | "lvh" | "dvh" | "vi" | "svi" | "lvi" | "dvi" | "vb" | "svb" | "lvb" | "dvb" | "vmin" | "svmin" | "lvmin" | "dvmin" | "vmax" | "svmax" | "lvmax" | "dvmax" | "cqw" | "cqh" | "cqi" | "cqb" | "cqmin" | "cqmax" | "dpi" | "dpcm" | "dppx" | "x" | "st" | "s" | "ms";
5425
+ } | {
5426
+ value: string;
5427
+ type: "keyword";
5428
+ } | {
5429
+ value: string;
5430
+ type: "unparsed";
5431
+ hidden?: boolean | undefined;
5432
+ } | {
5433
+ value: string[];
5434
+ type: "fontFamily";
5435
+ } | {
5436
+ type: "rgb";
5437
+ r: number;
5438
+ g: number;
5439
+ b: number;
5440
+ alpha: number;
5441
+ } | any | {
5442
+ value: {
5443
+ value: string;
5444
+ type: "asset";
5445
+ } | {
5446
+ type: "url";
5447
+ url: string;
5448
+ };
5449
+ type: "image";
5450
+ hidden?: boolean | undefined;
5451
+ } | {
5452
+ value: ({
5453
+ value: number;
5454
+ type: "unit";
5455
+ unit: "number" | "%" | "deg" | "grad" | "rad" | "turn" | "db" | "fr" | "hz" | "khz" | "cm" | "mm" | "q" | "in" | "pt" | "pc" | "px" | "em" | "rem" | "ex" | "rex" | "cap" | "rcap" | "ch" | "rch" | "ic" | "ric" | "lh" | "rlh" | "vw" | "svw" | "lvw" | "dvw" | "vh" | "svh" | "lvh" | "dvh" | "vi" | "svi" | "lvi" | "dvi" | "vb" | "svb" | "lvb" | "dvb" | "vmin" | "svmin" | "lvmin" | "dvmin" | "vmax" | "svmax" | "lvmax" | "dvmax" | "cqw" | "cqh" | "cqi" | "cqb" | "cqmin" | "cqmax" | "dpi" | "dpcm" | "dppx" | "x" | "st" | "s" | "ms";
5456
+ } | {
5457
+ value: string;
5458
+ type: "keyword";
5459
+ } | {
5460
+ value: string;
5461
+ type: "unparsed";
5462
+ hidden?: boolean | undefined;
5463
+ } | {
5464
+ type: "rgb";
5465
+ r: number;
5466
+ g: number;
5467
+ b: number;
5468
+ alpha: number;
5469
+ } | any)[];
5470
+ type: "tuple";
5471
+ hidden?: boolean | undefined;
5472
+ } | {
5473
+ value: ({
5474
+ value: number;
5475
+ type: "unit";
5476
+ unit: "number" | "%" | "deg" | "grad" | "rad" | "turn" | "db" | "fr" | "hz" | "khz" | "cm" | "mm" | "q" | "in" | "pt" | "pc" | "px" | "em" | "rem" | "ex" | "rex" | "cap" | "rcap" | "ch" | "rch" | "ic" | "ric" | "lh" | "rlh" | "vw" | "svw" | "lvw" | "dvw" | "vh" | "svh" | "lvh" | "dvh" | "vi" | "svi" | "lvi" | "dvi" | "vb" | "svb" | "lvb" | "dvb" | "vmin" | "svmin" | "lvmin" | "dvmin" | "vmax" | "svmax" | "lvmax" | "dvmax" | "cqw" | "cqh" | "cqi" | "cqb" | "cqmin" | "cqmax" | "dpi" | "dpcm" | "dppx" | "x" | "st" | "s" | "ms";
5477
+ } | {
5478
+ value: string;
5479
+ type: "keyword";
5480
+ } | {
5481
+ value: string;
5482
+ type: "unparsed";
5483
+ hidden?: boolean | undefined;
5484
+ } | any | {
5485
+ value: {
5486
+ value: string;
5487
+ type: "asset";
5488
+ } | {
5489
+ type: "url";
5490
+ url: string;
5491
+ };
5492
+ type: "image";
5493
+ hidden?: boolean | undefined;
5494
+ } | {
5495
+ value: ({
5496
+ value: number;
5497
+ type: "unit";
5498
+ unit: "number" | "%" | "deg" | "grad" | "rad" | "turn" | "db" | "fr" | "hz" | "khz" | "cm" | "mm" | "q" | "in" | "pt" | "pc" | "px" | "em" | "rem" | "ex" | "rex" | "cap" | "rcap" | "ch" | "rch" | "ic" | "ric" | "lh" | "rlh" | "vw" | "svw" | "lvw" | "dvw" | "vh" | "svh" | "lvh" | "dvh" | "vi" | "svi" | "lvi" | "dvi" | "vb" | "svb" | "lvb" | "dvb" | "vmin" | "svmin" | "lvmin" | "dvmin" | "vmax" | "svmax" | "lvmax" | "dvmax" | "cqw" | "cqh" | "cqi" | "cqb" | "cqmin" | "cqmax" | "dpi" | "dpcm" | "dppx" | "x" | "st" | "s" | "ms";
5499
+ } | {
5500
+ value: string;
5501
+ type: "keyword";
5502
+ } | {
5503
+ value: string;
5504
+ type: "unparsed";
5505
+ hidden?: boolean | undefined;
5506
+ } | {
5507
+ type: "rgb";
5508
+ r: number;
5509
+ g: number;
5510
+ b: number;
5511
+ alpha: number;
5512
+ } | any)[];
5513
+ type: "tuple";
5514
+ hidden?: boolean | undefined;
5515
+ } | {
5516
+ value: string;
5517
+ type: "invalid";
5518
+ })[];
5519
+ type: "layers";
5520
+ } | {
5521
+ type: "guaranteedInvalid";
5522
+ })[];
5523
+ };
5524
+ } | {
5525
+ value: {
5526
+ value: string;
5527
+ type: "asset";
5528
+ } | {
5529
+ type: "url";
5530
+ url: string;
5531
+ };
5532
+ type: "image";
5533
+ hidden?: boolean | undefined;
5534
+ } | {
5535
+ value: ({
5536
+ value: number;
5537
+ type: "unit";
5538
+ unit: "number" | "%" | "deg" | "grad" | "rad" | "turn" | "db" | "fr" | "hz" | "khz" | "cm" | "mm" | "q" | "in" | "pt" | "pc" | "px" | "em" | "rem" | "ex" | "rex" | "cap" | "rcap" | "ch" | "rch" | "ic" | "ric" | "lh" | "rlh" | "vw" | "svw" | "lvw" | "dvw" | "vh" | "svh" | "lvh" | "dvh" | "vi" | "svi" | "lvi" | "dvi" | "vb" | "svb" | "lvb" | "dvb" | "vmin" | "svmin" | "lvmin" | "dvmin" | "vmax" | "svmax" | "lvmax" | "dvmax" | "cqw" | "cqh" | "cqi" | "cqb" | "cqmin" | "cqmax" | "dpi" | "dpcm" | "dppx" | "x" | "st" | "s" | "ms";
5539
+ } | {
5540
+ value: string;
5541
+ type: "keyword";
5542
+ } | {
5543
+ value: string;
5544
+ type: "unparsed";
5545
+ hidden?: boolean | undefined;
5546
+ } | {
5547
+ type: "rgb";
5548
+ r: number;
5549
+ g: number;
5550
+ b: number;
5551
+ alpha: number;
5552
+ } | any)[];
5553
+ type: "tuple";
5554
+ hidden?: boolean | undefined;
5555
+ } | {
5556
+ value: string;
5557
+ type: "invalid";
5558
+ } | {
5559
+ value: ({
5560
+ value: number;
5561
+ type: "unit";
5562
+ unit: "number" | "%" | "deg" | "grad" | "rad" | "turn" | "db" | "fr" | "hz" | "khz" | "cm" | "mm" | "q" | "in" | "pt" | "pc" | "px" | "em" | "rem" | "ex" | "rex" | "cap" | "rcap" | "ch" | "rch" | "ic" | "ric" | "lh" | "rlh" | "vw" | "svw" | "lvw" | "dvw" | "vh" | "svh" | "lvh" | "dvh" | "vi" | "svi" | "lvi" | "dvi" | "vb" | "svb" | "lvb" | "dvb" | "vmin" | "svmin" | "lvmin" | "dvmin" | "vmax" | "svmax" | "lvmax" | "dvmax" | "cqw" | "cqh" | "cqi" | "cqb" | "cqmin" | "cqmax" | "dpi" | "dpcm" | "dppx" | "x" | "st" | "s" | "ms";
5563
+ } | {
5564
+ value: string;
5565
+ type: "keyword";
5566
+ } | {
5567
+ value: string;
5568
+ type: "unparsed";
5569
+ hidden?: boolean | undefined;
5570
+ } | any | {
5571
+ value: {
5572
+ value: string;
5573
+ type: "asset";
5574
+ } | {
5575
+ type: "url";
5576
+ url: string;
5577
+ };
5578
+ type: "image";
5579
+ hidden?: boolean | undefined;
5580
+ } | {
5581
+ value: ({
5582
+ value: number;
5583
+ type: "unit";
5584
+ unit: "number" | "%" | "deg" | "grad" | "rad" | "turn" | "db" | "fr" | "hz" | "khz" | "cm" | "mm" | "q" | "in" | "pt" | "pc" | "px" | "em" | "rem" | "ex" | "rex" | "cap" | "rcap" | "ch" | "rch" | "ic" | "ric" | "lh" | "rlh" | "vw" | "svw" | "lvw" | "dvw" | "vh" | "svh" | "lvh" | "dvh" | "vi" | "svi" | "lvi" | "dvi" | "vb" | "svb" | "lvb" | "dvb" | "vmin" | "svmin" | "lvmin" | "dvmin" | "vmax" | "svmax" | "lvmax" | "dvmax" | "cqw" | "cqh" | "cqi" | "cqb" | "cqmin" | "cqmax" | "dpi" | "dpcm" | "dppx" | "x" | "st" | "s" | "ms";
5585
+ } | {
5586
+ value: string;
5587
+ type: "keyword";
5588
+ } | {
5589
+ value: string;
5590
+ type: "unparsed";
5591
+ hidden?: boolean | undefined;
5592
+ } | {
5593
+ type: "rgb";
5594
+ r: number;
5595
+ g: number;
5596
+ b: number;
5597
+ alpha: number;
5598
+ } | any)[];
5599
+ type: "tuple";
5600
+ hidden?: boolean | undefined;
5601
+ } | {
5602
+ value: string;
5603
+ type: "invalid";
5604
+ })[];
5605
+ type: "layers";
5606
+ } | {
5607
+ type: "guaranteedInvalid";
5608
+ } | {
5609
+ value: "";
5610
+ type: "unset";
5611
+ } | {
5612
+ value: string;
5613
+ type: "var";
5614
+ fallbacks: ({
5615
+ value: number;
5616
+ type: "unit";
5617
+ unit: "number" | "%" | "deg" | "grad" | "rad" | "turn" | "db" | "fr" | "hz" | "khz" | "cm" | "mm" | "q" | "in" | "pt" | "pc" | "px" | "em" | "rem" | "ex" | "rex" | "cap" | "rcap" | "ch" | "rch" | "ic" | "ric" | "lh" | "rlh" | "vw" | "svw" | "lvw" | "dvw" | "vh" | "svh" | "lvh" | "dvh" | "vi" | "svi" | "lvi" | "dvi" | "vb" | "svb" | "lvb" | "dvb" | "vmin" | "svmin" | "lvmin" | "dvmin" | "vmax" | "svmax" | "lvmax" | "dvmax" | "cqw" | "cqh" | "cqi" | "cqb" | "cqmin" | "cqmax" | "dpi" | "dpcm" | "dppx" | "x" | "st" | "s" | "ms";
5618
+ } | {
5619
+ value: string;
5620
+ type: "keyword";
5621
+ } | {
5622
+ value: string;
5623
+ type: "unparsed";
5624
+ hidden?: boolean | undefined;
5625
+ } | {
5626
+ value: string[];
5627
+ type: "fontFamily";
5628
+ } | {
5629
+ type: "rgb";
5630
+ r: number;
5631
+ g: number;
5632
+ b: number;
5633
+ alpha: number;
5634
+ } | any | {
5635
+ value: {
5636
+ value: string;
5637
+ type: "asset";
5638
+ } | {
5639
+ type: "url";
5640
+ url: string;
5641
+ };
5642
+ type: "image";
5643
+ hidden?: boolean | undefined;
5644
+ } | {
5645
+ value: ({
5646
+ value: number;
5647
+ type: "unit";
5648
+ unit: "number" | "%" | "deg" | "grad" | "rad" | "turn" | "db" | "fr" | "hz" | "khz" | "cm" | "mm" | "q" | "in" | "pt" | "pc" | "px" | "em" | "rem" | "ex" | "rex" | "cap" | "rcap" | "ch" | "rch" | "ic" | "ric" | "lh" | "rlh" | "vw" | "svw" | "lvw" | "dvw" | "vh" | "svh" | "lvh" | "dvh" | "vi" | "svi" | "lvi" | "dvi" | "vb" | "svb" | "lvb" | "dvb" | "vmin" | "svmin" | "lvmin" | "dvmin" | "vmax" | "svmax" | "lvmax" | "dvmax" | "cqw" | "cqh" | "cqi" | "cqb" | "cqmin" | "cqmax" | "dpi" | "dpcm" | "dppx" | "x" | "st" | "s" | "ms";
5649
+ } | {
5650
+ value: string;
5651
+ type: "keyword";
5652
+ } | {
5653
+ value: string;
5654
+ type: "unparsed";
5655
+ hidden?: boolean | undefined;
5656
+ } | {
5657
+ type: "rgb";
5658
+ r: number;
5659
+ g: number;
5660
+ b: number;
5661
+ alpha: number;
5662
+ } | any)[];
5663
+ type: "tuple";
5664
+ hidden?: boolean | undefined;
5665
+ } | {
5666
+ value: ({
5667
+ value: number;
5668
+ type: "unit";
5669
+ unit: "number" | "%" | "deg" | "grad" | "rad" | "turn" | "db" | "fr" | "hz" | "khz" | "cm" | "mm" | "q" | "in" | "pt" | "pc" | "px" | "em" | "rem" | "ex" | "rex" | "cap" | "rcap" | "ch" | "rch" | "ic" | "ric" | "lh" | "rlh" | "vw" | "svw" | "lvw" | "dvw" | "vh" | "svh" | "lvh" | "dvh" | "vi" | "svi" | "lvi" | "dvi" | "vb" | "svb" | "lvb" | "dvb" | "vmin" | "svmin" | "lvmin" | "dvmin" | "vmax" | "svmax" | "lvmax" | "dvmax" | "cqw" | "cqh" | "cqi" | "cqb" | "cqmin" | "cqmax" | "dpi" | "dpcm" | "dppx" | "x" | "st" | "s" | "ms";
5670
+ } | {
5671
+ value: string;
5672
+ type: "keyword";
5673
+ } | {
5674
+ value: string;
5675
+ type: "unparsed";
5676
+ hidden?: boolean | undefined;
5677
+ } | any | {
5678
+ value: {
5679
+ value: string;
5680
+ type: "asset";
5681
+ } | {
5682
+ type: "url";
5683
+ url: string;
5684
+ };
5685
+ type: "image";
5686
+ hidden?: boolean | undefined;
5687
+ } | {
5688
+ value: ({
5689
+ value: number;
5690
+ type: "unit";
5691
+ unit: "number" | "%" | "deg" | "grad" | "rad" | "turn" | "db" | "fr" | "hz" | "khz" | "cm" | "mm" | "q" | "in" | "pt" | "pc" | "px" | "em" | "rem" | "ex" | "rex" | "cap" | "rcap" | "ch" | "rch" | "ic" | "ric" | "lh" | "rlh" | "vw" | "svw" | "lvw" | "dvw" | "vh" | "svh" | "lvh" | "dvh" | "vi" | "svi" | "lvi" | "dvi" | "vb" | "svb" | "lvb" | "dvb" | "vmin" | "svmin" | "lvmin" | "dvmin" | "vmax" | "svmax" | "lvmax" | "dvmax" | "cqw" | "cqh" | "cqi" | "cqb" | "cqmin" | "cqmax" | "dpi" | "dpcm" | "dppx" | "x" | "st" | "s" | "ms";
5692
+ } | {
5693
+ value: string;
5694
+ type: "keyword";
5695
+ } | {
5696
+ value: string;
5697
+ type: "unparsed";
5698
+ hidden?: boolean | undefined;
5699
+ } | {
5700
+ type: "rgb";
5701
+ r: number;
5702
+ g: number;
5703
+ b: number;
5704
+ alpha: number;
5705
+ } | any)[];
5706
+ type: "tuple";
5707
+ hidden?: boolean | undefined;
5708
+ } | {
5709
+ value: string;
5710
+ type: "invalid";
5711
+ })[];
5712
+ type: "layers";
5713
+ } | {
5714
+ type: "guaranteedInvalid";
5715
+ })[];
5716
+ };
5717
+ state?: string | undefined;
5718
+ property: import("@webstudio-is/css-engine").StyleProperty;
5719
+ } | {
5720
+ property: "boxSizing";
5721
+ value: {
5722
+ type: "keyword";
5723
+ value: string;
5724
+ };
5725
+ })[];
5287
5726
  export declare const h1: ({
5288
5727
  value: {
5289
5728
  value: number;
@@ -10,6 +10,8 @@ type StyleRule = {
10
10
  /**
11
11
  * Merge styles from different style sources
12
12
  * and group by instance and breakpoint
13
+ *
14
+ * @deprecated
13
15
  */
14
16
  export declare const getStyleRules: (styles: Styles, styleSourceSelections: Map<string, {
15
17
  values: string[];
@@ -10695,7 +10695,7 @@ export declare const generateDataFromEmbedTemplate: (treeTemplate: ({
10695
10695
  type: "expression";
10696
10696
  } | EmbedTemplateInstance)[], metas: Map<Instance["component"], WsComponentMeta>, defaultBreakpointId: Breakpoint["id"], generateId?: () => string) => WebstudioFragment;
10697
10697
  export declare const namespaceMeta: (meta: WsComponentMeta, namespace: string, components: Set<EmbedTemplateInstance["component"]>) => {
10698
- type: "embed" | "control" | "container" | "rich-text-child";
10698
+ type: "control" | "embed" | "container" | "rich-text-child";
10699
10699
  description?: string | undefined;
10700
10700
  label?: string | undefined;
10701
10701
  order?: number | undefined;
@@ -10706,7 +10706,7 @@ export declare const namespaceMeta: (meta: WsComponentMeta, namespace: string, c
10706
10706
  value: string;
10707
10707
  type: "expression";
10708
10708
  } | EmbedTemplateInstance)[] | undefined;
10709
- category?: "data" | "text" | "hidden" | "media" | "general" | "forms" | "radix" | undefined;
10709
+ category?: "data" | "xml" | "text" | "hidden" | "media" | "general" | "forms" | "radix" | "internal" | undefined;
10710
10710
  requiredAncestors?: string[] | undefined;
10711
10711
  invalidAncestors?: string[] | undefined;
10712
10712
  indexWithinAncestor?: string | undefined;
@@ -73,11 +73,6 @@ export declare const PropMeta: z.ZodUnion<[z.ZodObject<{
73
73
  control: z.ZodLiteral<"code">;
74
74
  type: z.ZodLiteral<"string">;
75
75
  defaultValue: z.ZodOptional<z.ZodString>;
76
- /**
77
- * The number of rows in <textarea>. If set to 0 an <input> will be used instead.
78
- * In line with Storybook team's plan: https://github.com/storybookjs/storybook/issues/21100
79
- */
80
- rows: z.ZodOptional<z.ZodNumber>;
81
76
  label: z.ZodOptional<z.ZodString>;
82
77
  description: z.ZodOptional<z.ZodString>;
83
78
  required: z.ZodBoolean;
@@ -86,7 +81,6 @@ export declare const PropMeta: z.ZodUnion<[z.ZodObject<{
86
81
  required: boolean;
87
82
  control: "code";
88
83
  defaultValue?: string | undefined;
89
- rows?: number | undefined;
90
84
  label?: string | undefined;
91
85
  description?: string | undefined;
92
86
  }, {
@@ -94,9 +88,29 @@ export declare const PropMeta: z.ZodUnion<[z.ZodObject<{
94
88
  required: boolean;
95
89
  control: "code";
96
90
  defaultValue?: string | undefined;
97
- rows?: number | undefined;
98
91
  label?: string | undefined;
99
92
  description?: string | undefined;
93
+ }>, z.ZodObject<{
94
+ type: z.ZodLiteral<"string">;
95
+ required: z.ZodBoolean;
96
+ description: z.ZodOptional<z.ZodString>;
97
+ label: z.ZodOptional<z.ZodString>;
98
+ defaultValue: z.ZodOptional<z.ZodString>;
99
+ control: z.ZodLiteral<"codetext">;
100
+ }, "strip", z.ZodTypeAny, {
101
+ type: "string";
102
+ required: boolean;
103
+ control: "codetext";
104
+ description?: string | undefined;
105
+ label?: string | undefined;
106
+ defaultValue?: string | undefined;
107
+ }, {
108
+ type: "string";
109
+ required: boolean;
110
+ control: "codetext";
111
+ description?: string | undefined;
112
+ label?: string | undefined;
113
+ defaultValue?: string | undefined;
100
114
  }>, z.ZodObject<{
101
115
  control: z.ZodLiteral<"color">;
102
116
  type: z.ZodLiteral<"string">;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@webstudio-is/react-sdk",
3
- "version": "0.145.0",
3
+ "version": "0.163.0",
4
4
  "description": "Webstudio JavaScript / TypeScript API",
5
5
  "author": "Webstudio <github@webstudio.is>",
6
6
  "homepage": "https://webstudio.is",
@@ -28,24 +28,22 @@
28
28
  "html-tags": "^3.3.1",
29
29
  "nanoid": "^5.0.1",
30
30
  "title-case": "^4.1.0",
31
- "@webstudio-is/css-engine": "0.145.0",
32
- "@webstudio-is/fonts": "0.145.0",
33
- "@webstudio-is/icons": "^0.145.0",
34
- "@webstudio-is/image": "0.145.0",
35
- "@webstudio-is/sdk": "0.145.0"
31
+ "@webstudio-is/css-engine": "0.163.0",
32
+ "@webstudio-is/fonts": "0.163.0",
33
+ "@webstudio-is/image": "0.163.0",
34
+ "@webstudio-is/icons": "^0.163.0",
35
+ "@webstudio-is/sdk": "0.163.0"
36
36
  },
37
37
  "exports": {
38
38
  ".": {
39
39
  "webstudio": "./src/index.ts",
40
40
  "types": "./lib/types/index.d.ts",
41
- "import": "./lib/index.js",
42
- "require": "./lib/index.js"
41
+ "import": "./lib/index.js"
43
42
  },
44
43
  "./css-normalize": {
45
44
  "webstudio": "./src/css/normalize.ts",
46
45
  "types": "./lib/types/css/normalize.d.ts",
47
- "import": "./lib/css/normalize.js",
48
- "require": "./lib/css/normalize.js"
46
+ "import": "./lib/css/normalize.js"
49
47
  }
50
48
  },
51
49
  "files": [