@storybook/react-native-theming 9.0.0-beta.10 → 9.0.0-beta.11

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.
Files changed (3) hide show
  1. package/dist/index.d.ts +14 -127
  2. package/dist/index.js +408 -17
  3. package/package.json +2 -2
package/dist/index.d.ts CHANGED
@@ -1,125 +1,9 @@
1
1
  import * as RN from 'react-native';
2
2
  import { ImageSourcePropType, ImageProps, TextStyle } from 'react-native';
3
- import * as React$1 from 'react';
3
+ import { Theme as Theme$1 } from './theming.js';
4
+ export { ThemeProvider, useTheme, withTheme } from './theming.js';
4
5
  import { ReactElement } from 'react';
5
6
 
6
- type IsPreReact19 = 2 extends Parameters<React.FunctionComponent<any>>['length']
7
- ? true
8
- : false
9
-
10
- // unpack all here to avoid infinite self-referencing when defining our own JSX namespace for the pre-React 19 case
11
- type ReactJSXElement = true extends IsPreReact19
12
- ? /** @ts-ignore */
13
- JSX.Element
14
- : /** @ts-ignore */
15
- React.JSX.Element
16
- type ReactJSXElementClass = true extends IsPreReact19
17
- ? /** @ts-ignore */
18
- JSX.ElementClass
19
- : /** @ts-ignore */
20
- React.JSX.ElementClass
21
- type ReactJSXElementAttributesProperty = true extends IsPreReact19
22
- ? /** @ts-ignore */
23
- JSX.ElementAttributesProperty
24
- : /** @ts-ignore */
25
- React.JSX.ElementAttributesProperty
26
- type ReactJSXElementChildrenAttribute = true extends IsPreReact19
27
- ? /** @ts-ignore */
28
- JSX.ElementChildrenAttribute
29
- : /** @ts-ignore */
30
- React.JSX.ElementChildrenAttribute
31
- type ReactJSXLibraryManagedAttributes<C, P> = true extends IsPreReact19
32
- ? /** @ts-ignore */
33
- JSX.LibraryManagedAttributes<C, P>
34
- : /** @ts-ignore */
35
- React.JSX.LibraryManagedAttributes<C, P>
36
- type ReactJSXIntrinsicAttributes = true extends IsPreReact19
37
- ? /** @ts-ignore */
38
- JSX.IntrinsicAttributes
39
- : /** @ts-ignore */
40
- React.JSX.IntrinsicAttributes
41
- type ReactJSXIntrinsicClassAttributes<T> = true extends IsPreReact19
42
- ? /** @ts-ignore */
43
- JSX.IntrinsicClassAttributes<T>
44
- : /** @ts-ignore */
45
- React.JSX.IntrinsicClassAttributes<T>
46
- type ReactJSXIntrinsicElements = true extends IsPreReact19
47
- ? /** @ts-ignore */
48
- JSX.IntrinsicElements
49
- : /** @ts-ignore */
50
- React.JSX.IntrinsicElements
51
-
52
- type ReactJSXElementType = true extends IsPreReact19
53
- ? // based on the code from @types/react@18.2.8
54
- // https://github.com/DefinitelyTyped/DefinitelyTyped/blob/3197efc097d522c4bf02b94e1a0766d007d6cdeb/types/react/index.d.ts#LL3204C13-L3204C13
55
- string | React.JSXElementConstructor<any>
56
- : /** @ts-ignore */
57
- React.JSX.ElementType
58
-
59
- declare namespace ReactJSX {
60
- type ElementType = ReactJSXElementType
61
- interface Element extends ReactJSXElement {}
62
- interface ElementClass extends ReactJSXElementClass {}
63
- interface ElementAttributesProperty
64
- extends ReactJSXElementAttributesProperty {}
65
- interface ElementChildrenAttribute extends ReactJSXElementChildrenAttribute {}
66
-
67
- type LibraryManagedAttributes<C, P> = ReactJSXLibraryManagedAttributes<C, P>
68
-
69
- interface IntrinsicAttributes extends ReactJSXIntrinsicAttributes {}
70
- interface IntrinsicClassAttributes<T>
71
- extends ReactJSXIntrinsicClassAttributes<T> {}
72
-
73
- type IntrinsicElements = ReactJSXIntrinsicElements
74
- }
75
-
76
- /**
77
- * @desc Utility type for getting props type of React component.
78
- * It takes `defaultProps` into an account - making props with defaults optional.
79
- */
80
- type PropsOf<
81
- C extends keyof ReactJSX.IntrinsicElements | React.JSXElementConstructor<any>
82
- > = ReactJSX.LibraryManagedAttributes<C, React.ComponentProps<C>>
83
-
84
- // We need to use this version of Omit as it's distributive (Will preserve unions)
85
- type DistributiveOmit<T, U> = T extends any
86
- ? Pick<T, Exclude<keyof T, U>>
87
- : never
88
-
89
- // Definitions by: Junyoung Clare Jang <https://github.com/Ailrun>
90
- // TypeScript Version: 3.1
91
-
92
-
93
-
94
- interface ThemeProviderProps {
95
- theme: Partial<Theme> | ((outerTheme: Theme) => Theme)
96
- children: React$1.ReactNode
97
- }
98
-
99
- declare function useTheme(): Theme
100
-
101
- interface ThemeProvider {
102
- (props: ThemeProviderProps): React$1.ReactElement
103
- }
104
-
105
- declare const ThemeProvider: ThemeProvider
106
-
107
- type withTheme = <
108
- C extends React$1.ComponentType<React$1.ComponentProps<C>>
109
- >(
110
- component: C
111
- ) => React$1.FC<DistributiveOmit<PropsOf<C>, 'theme'> & { theme?: Theme }>
112
-
113
- declare const withTheme: withTheme
114
-
115
- // Definitions by: Junyoung Clare Jang <https://github.com/Ailrun>
116
- // TypeScript Version: 3.4
117
-
118
-
119
-
120
- // tslint:disable-next-line: no-empty-interface
121
- export interface Theme extends StorybookTheme {}
122
-
123
7
  // Definitions by: Pat Sissons <https://github.com/patsissons>
124
8
  // TypeScript Version: 3.4
125
9
 
@@ -219,7 +103,7 @@ interface CreateStyledComponent<
219
103
  ...styles: ArrayInterpolation<
220
104
  ComponentProps &
221
105
  SpecificComponentProps &
222
- AdditionalProps & { theme: Theme },
106
+ AdditionalProps & { theme: Theme$1 },
223
107
  StyleType
224
108
  >
225
109
  ): StyledComponent<
@@ -235,7 +119,7 @@ interface CreateStyledComponent<
235
119
  ...styles: ArrayInterpolation<
236
120
  ComponentProps &
237
121
  SpecificComponentProps &
238
- AdditionalProps & { theme: Theme },
122
+ AdditionalProps & { theme: Theme$1 },
239
123
  StyleType
240
124
  >
241
125
  ): StyledComponent<
@@ -264,7 +148,7 @@ interface CreateStyled$1 {
264
148
  options: FilteringStyledOptions<React.ComponentProps<C>, ForwardedProps>
265
149
  ): CreateStyledComponent<
266
150
  Pick<React.ComponentProps<C>, ForwardedProps> & {
267
- theme?: Theme
151
+ theme?: Theme$1
268
152
  as?: React.ElementType
269
153
  },
270
154
  {},
@@ -277,7 +161,7 @@ interface CreateStyled$1 {
277
161
  options?: StyledOptions<React.ComponentProps<C>>
278
162
  ): CreateStyledComponent<
279
163
  React.ComponentProps<C> & {
280
- theme?: Theme
164
+ theme?: Theme$1
281
165
  as?: React.ElementType
282
166
  },
283
167
  {},
@@ -294,7 +178,7 @@ interface CreateStyled$1 {
294
178
  options: FilteringStyledOptions<React.ComponentProps<C>, ForwardedProps>
295
179
  ): CreateStyledComponent<
296
180
  Pick<React.ComponentProps<C>, ForwardedProps> & {
297
- theme?: Theme
181
+ theme?: Theme$1
298
182
  as?: React.ElementType
299
183
  },
300
184
  {},
@@ -306,7 +190,7 @@ interface CreateStyled$1 {
306
190
  component: C,
307
191
  options?: StyledOptions<React.ComponentProps<C>>
308
192
  ): CreateStyledComponent<
309
- React.ComponentProps<C> & { theme?: Theme; as?: React.ElementType },
193
+ React.ComponentProps<C> & { theme?: Theme$1; as?: React.ElementType },
310
194
  {},
311
195
  {},
312
196
  ReactNativeStyleType<React.ComponentProps<C>>
@@ -323,14 +207,14 @@ type ReactNative = typeof RN
323
207
  // those 2 are just copies of the `BaseCreateStyled` with supplied `C` type argument
324
208
  type HostClassComponent<C extends React.ComponentClass<any>> =
325
209
  CreateStyledComponent<
326
- React.ComponentProps<C> & { theme?: Theme; as?: React.ElementType },
210
+ React.ComponentProps<C> & { theme?: Theme$1; as?: React.ElementType },
327
211
  {},
328
212
  { ref?: React.Ref<InstanceType<C>> },
329
213
  ReactNativeStyleType<React.ComponentProps<C>>
330
214
  >
331
215
  type HostFunctionComponent<C extends React.FunctionComponent<any>> =
332
216
  CreateStyledComponent<
333
- React.ComponentProps<C> & { theme?: Theme; as?: React.ElementType },
217
+ React.ComponentProps<C> & { theme?: Theme$1; as?: React.ElementType },
334
218
  {},
335
219
  {},
336
220
  ReactNativeStyleType<React.ComponentProps<C>>
@@ -495,4 +379,7 @@ type StorybookTheme = StorybookThemeWeb;
495
379
  declare const theme: StorybookThemeWeb;
496
380
  declare const darkTheme: StorybookThemeWeb;
497
381
 
498
- export { StorybookTheme, StyledComponent, ThemeProvider, darkTheme, styled, theme, useTheme, withTheme };
382
+ interface Theme extends StorybookTheme {
383
+ }
384
+
385
+ export { StorybookTheme, StyledComponent, Theme, darkTheme, styled, theme };
package/dist/index.js CHANGED
@@ -1841,7 +1841,7 @@ var import_react_native = require("react-native");
1841
1841
  var import_css_to_react_native = __toESM(require_css_to_react_native());
1842
1842
  var React4 = __toESM(require("react"));
1843
1843
 
1844
- // ../../node_modules/@emotion/react/dist/emotion-element-b4c8b265.esm.js
1844
+ // ../../node_modules/@emotion/react/dist/emotion-element-d59e098f.esm.js
1845
1845
  var React2 = __toESM(require("react"));
1846
1846
  var import_react = require("react");
1847
1847
 
@@ -2358,7 +2358,8 @@ var compat = function compat2(element) {
2358
2358
  element.length < 1) {
2359
2359
  return;
2360
2360
  }
2361
- var value = element.value, parent = element.parent;
2361
+ var value = element.value;
2362
+ var parent = element.parent;
2362
2363
  var isImplicitRule = element.column === parent.column && element.line === parent.line;
2363
2364
  while (parent.type !== "rule") {
2364
2365
  parent = parent.parent;
@@ -2544,10 +2545,7 @@ var prefixer = function prefixer2(element, index2, children, callback) {
2544
2545
  };
2545
2546
  var getServerStylisCache = isBrowser ? void 0 : weakMemoize(function() {
2546
2547
  return memoize(function() {
2547
- var cache = {};
2548
- return function(name) {
2549
- return cache[name];
2550
- };
2548
+ return {};
2551
2549
  });
2552
2550
  });
2553
2551
  var defaultStylisPlugins = [prefixer];
@@ -2585,7 +2583,7 @@ var createCache = function createCache2(options) {
2585
2583
  }
2586
2584
  var _insert;
2587
2585
  var omnipresentPlugins = [compat, removeLabel];
2588
- if (isBrowser) {
2586
+ if (!getServerStylisCache) {
2589
2587
  var currentSheet;
2590
2588
  var finalizingPlugins = [stringify, rulesheet(function(rule) {
2591
2589
  currentSheet.insert(rule);
@@ -2669,11 +2667,323 @@ var hoistNonReactStatics = function(targetComponent, sourceComponent) {
2669
2667
  return (0, import_hoist_non_react_statics.default)(targetComponent, sourceComponent);
2670
2668
  };
2671
2669
 
2670
+ // ../../node_modules/@emotion/utils/dist/emotion-utils.esm.js
2671
+ var isBrowser2 = typeof document !== "undefined";
2672
+ function getRegisteredStyles(registered, registeredStyles, classNames) {
2673
+ var rawClassName = "";
2674
+ classNames.split(" ").forEach(function(className) {
2675
+ if (registered[className] !== void 0) {
2676
+ registeredStyles.push(registered[className] + ";");
2677
+ } else if (className) {
2678
+ rawClassName += className + " ";
2679
+ }
2680
+ });
2681
+ return rawClassName;
2682
+ }
2683
+ var registerStyles = function registerStyles2(cache, serialized, isStringTag) {
2684
+ var className = cache.key + "-" + serialized.name;
2685
+ if (
2686
+ // we only need to add the styles to the registered cache if the
2687
+ // class name could be used further down
2688
+ // the tree but if it's a string tag, we know it won't
2689
+ // so we don't have to add it to registered cache.
2690
+ // this improves memory usage since we can avoid storing the whole style string
2691
+ (isStringTag === false || // we need to always store it if we're in compat mode and
2692
+ // in node since emotion-server relies on whether a style is in
2693
+ // the registered cache to know whether a style is global or not
2694
+ // also, note that this check will be dead code eliminated in the browser
2695
+ isBrowser2 === false && cache.compat !== void 0) && cache.registered[className] === void 0
2696
+ ) {
2697
+ cache.registered[className] = serialized.styles;
2698
+ }
2699
+ };
2700
+ var insertStyles = function insertStyles2(cache, serialized, isStringTag) {
2701
+ registerStyles(cache, serialized, isStringTag);
2702
+ var className = cache.key + "-" + serialized.name;
2703
+ if (cache.inserted[serialized.name] === void 0) {
2704
+ var stylesForSSR = "";
2705
+ var current = serialized;
2706
+ do {
2707
+ var maybeStyles = cache.insert(serialized === current ? "." + className : "", current, cache.sheet, true);
2708
+ if (!isBrowser2 && maybeStyles !== void 0) {
2709
+ stylesForSSR += maybeStyles;
2710
+ }
2711
+ current = current.next;
2712
+ } while (current !== void 0);
2713
+ if (!isBrowser2 && stylesForSSR.length !== 0) {
2714
+ return stylesForSSR;
2715
+ }
2716
+ }
2717
+ };
2718
+
2719
+ // ../../node_modules/@emotion/hash/dist/emotion-hash.esm.js
2720
+ function murmur2(str) {
2721
+ var h = 0;
2722
+ var k, i = 0, len = str.length;
2723
+ for (; len >= 4; ++i, len -= 4) {
2724
+ k = str.charCodeAt(i) & 255 | (str.charCodeAt(++i) & 255) << 8 | (str.charCodeAt(++i) & 255) << 16 | (str.charCodeAt(++i) & 255) << 24;
2725
+ k = /* Math.imul(k, m): */
2726
+ (k & 65535) * 1540483477 + ((k >>> 16) * 59797 << 16);
2727
+ k ^= /* k >>> r: */
2728
+ k >>> 24;
2729
+ h = /* Math.imul(k, m): */
2730
+ (k & 65535) * 1540483477 + ((k >>> 16) * 59797 << 16) ^ /* Math.imul(h, m): */
2731
+ (h & 65535) * 1540483477 + ((h >>> 16) * 59797 << 16);
2732
+ }
2733
+ switch (len) {
2734
+ case 3:
2735
+ h ^= (str.charCodeAt(i + 2) & 255) << 16;
2736
+ case 2:
2737
+ h ^= (str.charCodeAt(i + 1) & 255) << 8;
2738
+ case 1:
2739
+ h ^= str.charCodeAt(i) & 255;
2740
+ h = /* Math.imul(h, m): */
2741
+ (h & 65535) * 1540483477 + ((h >>> 16) * 59797 << 16);
2742
+ }
2743
+ h ^= h >>> 13;
2744
+ h = /* Math.imul(h, m): */
2745
+ (h & 65535) * 1540483477 + ((h >>> 16) * 59797 << 16);
2746
+ return ((h ^ h >>> 15) >>> 0).toString(36);
2747
+ }
2748
+
2749
+ // ../../node_modules/@emotion/unitless/dist/emotion-unitless.esm.js
2750
+ var unitlessKeys = {
2751
+ animationIterationCount: 1,
2752
+ aspectRatio: 1,
2753
+ borderImageOutset: 1,
2754
+ borderImageSlice: 1,
2755
+ borderImageWidth: 1,
2756
+ boxFlex: 1,
2757
+ boxFlexGroup: 1,
2758
+ boxOrdinalGroup: 1,
2759
+ columnCount: 1,
2760
+ columns: 1,
2761
+ flex: 1,
2762
+ flexGrow: 1,
2763
+ flexPositive: 1,
2764
+ flexShrink: 1,
2765
+ flexNegative: 1,
2766
+ flexOrder: 1,
2767
+ gridRow: 1,
2768
+ gridRowEnd: 1,
2769
+ gridRowSpan: 1,
2770
+ gridRowStart: 1,
2771
+ gridColumn: 1,
2772
+ gridColumnEnd: 1,
2773
+ gridColumnSpan: 1,
2774
+ gridColumnStart: 1,
2775
+ msGridRow: 1,
2776
+ msGridRowSpan: 1,
2777
+ msGridColumn: 1,
2778
+ msGridColumnSpan: 1,
2779
+ fontWeight: 1,
2780
+ lineHeight: 1,
2781
+ opacity: 1,
2782
+ order: 1,
2783
+ orphans: 1,
2784
+ scale: 1,
2785
+ tabSize: 1,
2786
+ widows: 1,
2787
+ zIndex: 1,
2788
+ zoom: 1,
2789
+ WebkitLineClamp: 1,
2790
+ // SVG-related properties
2791
+ fillOpacity: 1,
2792
+ floodOpacity: 1,
2793
+ stopOpacity: 1,
2794
+ strokeDasharray: 1,
2795
+ strokeDashoffset: 1,
2796
+ strokeMiterlimit: 1,
2797
+ strokeOpacity: 1,
2798
+ strokeWidth: 1
2799
+ };
2800
+
2801
+ // ../../node_modules/@emotion/serialize/dist/emotion-serialize.esm.js
2802
+ var isDevelopment2 = false;
2803
+ var hyphenateRegex = /[A-Z]|^ms/g;
2804
+ var animationRegex = /_EMO_([^_]+?)_([^]*?)_EMO_/g;
2805
+ var isCustomProperty = function isCustomProperty2(property) {
2806
+ return property.charCodeAt(1) === 45;
2807
+ };
2808
+ var isProcessableValue = function isProcessableValue2(value) {
2809
+ return value != null && typeof value !== "boolean";
2810
+ };
2811
+ var processStyleName = /* @__PURE__ */ memoize(function(styleName) {
2812
+ return isCustomProperty(styleName) ? styleName : styleName.replace(hyphenateRegex, "-$&").toLowerCase();
2813
+ });
2814
+ var processStyleValue = function processStyleValue2(key, value) {
2815
+ switch (key) {
2816
+ case "animation":
2817
+ case "animationName": {
2818
+ if (typeof value === "string") {
2819
+ return value.replace(animationRegex, function(match2, p1, p2) {
2820
+ cursor = {
2821
+ name: p1,
2822
+ styles: p2,
2823
+ next: cursor
2824
+ };
2825
+ return p1;
2826
+ });
2827
+ }
2828
+ }
2829
+ }
2830
+ if (unitlessKeys[key] !== 1 && !isCustomProperty(key) && typeof value === "number" && value !== 0) {
2831
+ return value + "px";
2832
+ }
2833
+ return value;
2834
+ };
2835
+ var noComponentSelectorMessage = "Component selectors can only be used in conjunction with @emotion/babel-plugin, the swc Emotion plugin, or another Emotion-aware compiler transform.";
2836
+ function handleInterpolation(mergedProps, registered, interpolation) {
2837
+ if (interpolation == null) {
2838
+ return "";
2839
+ }
2840
+ var componentSelector = interpolation;
2841
+ if (componentSelector.__emotion_styles !== void 0) {
2842
+ return componentSelector;
2843
+ }
2844
+ switch (typeof interpolation) {
2845
+ case "boolean": {
2846
+ return "";
2847
+ }
2848
+ case "object": {
2849
+ var keyframes = interpolation;
2850
+ if (keyframes.anim === 1) {
2851
+ cursor = {
2852
+ name: keyframes.name,
2853
+ styles: keyframes.styles,
2854
+ next: cursor
2855
+ };
2856
+ return keyframes.name;
2857
+ }
2858
+ var serializedStyles = interpolation;
2859
+ if (serializedStyles.styles !== void 0) {
2860
+ var next2 = serializedStyles.next;
2861
+ if (next2 !== void 0) {
2862
+ while (next2 !== void 0) {
2863
+ cursor = {
2864
+ name: next2.name,
2865
+ styles: next2.styles,
2866
+ next: cursor
2867
+ };
2868
+ next2 = next2.next;
2869
+ }
2870
+ }
2871
+ var styles2 = serializedStyles.styles + ";";
2872
+ return styles2;
2873
+ }
2874
+ return createStringFromObject(mergedProps, registered, interpolation);
2875
+ }
2876
+ case "function": {
2877
+ if (mergedProps !== void 0) {
2878
+ var previousCursor = cursor;
2879
+ var result = interpolation(mergedProps);
2880
+ cursor = previousCursor;
2881
+ return handleInterpolation(mergedProps, registered, result);
2882
+ }
2883
+ break;
2884
+ }
2885
+ }
2886
+ var asString = interpolation;
2887
+ if (registered == null) {
2888
+ return asString;
2889
+ }
2890
+ var cached = registered[asString];
2891
+ return cached !== void 0 ? cached : asString;
2892
+ }
2893
+ function createStringFromObject(mergedProps, registered, obj) {
2894
+ var string = "";
2895
+ if (Array.isArray(obj)) {
2896
+ for (var i = 0; i < obj.length; i++) {
2897
+ string += handleInterpolation(mergedProps, registered, obj[i]) + ";";
2898
+ }
2899
+ } else {
2900
+ for (var key in obj) {
2901
+ var value = obj[key];
2902
+ if (typeof value !== "object") {
2903
+ var asString = value;
2904
+ if (registered != null && registered[asString] !== void 0) {
2905
+ string += key + "{" + registered[asString] + "}";
2906
+ } else if (isProcessableValue(asString)) {
2907
+ string += processStyleName(key) + ":" + processStyleValue(key, asString) + ";";
2908
+ }
2909
+ } else {
2910
+ if (key === "NO_COMPONENT_SELECTOR" && isDevelopment2) {
2911
+ throw new Error(noComponentSelectorMessage);
2912
+ }
2913
+ if (Array.isArray(value) && typeof value[0] === "string" && (registered == null || registered[value[0]] === void 0)) {
2914
+ for (var _i = 0; _i < value.length; _i++) {
2915
+ if (isProcessableValue(value[_i])) {
2916
+ string += processStyleName(key) + ":" + processStyleValue(key, value[_i]) + ";";
2917
+ }
2918
+ }
2919
+ } else {
2920
+ var interpolated = handleInterpolation(mergedProps, registered, value);
2921
+ switch (key) {
2922
+ case "animation":
2923
+ case "animationName": {
2924
+ string += processStyleName(key) + ":" + interpolated + ";";
2925
+ break;
2926
+ }
2927
+ default: {
2928
+ string += key + "{" + interpolated + "}";
2929
+ }
2930
+ }
2931
+ }
2932
+ }
2933
+ }
2934
+ }
2935
+ return string;
2936
+ }
2937
+ var labelPattern = /label:\s*([^\s;{]+)\s*(;|$)/g;
2938
+ var cursor;
2939
+ function serializeStyles(args, registered, mergedProps) {
2940
+ if (args.length === 1 && typeof args[0] === "object" && args[0] !== null && args[0].styles !== void 0) {
2941
+ return args[0];
2942
+ }
2943
+ var stringMode = true;
2944
+ var styles2 = "";
2945
+ cursor = void 0;
2946
+ var strings = args[0];
2947
+ if (strings == null || strings.raw === void 0) {
2948
+ stringMode = false;
2949
+ styles2 += handleInterpolation(mergedProps, registered, strings);
2950
+ } else {
2951
+ var asTemplateStringsArr = strings;
2952
+ styles2 += asTemplateStringsArr[0];
2953
+ }
2954
+ for (var i = 1; i < args.length; i++) {
2955
+ styles2 += handleInterpolation(mergedProps, registered, args[i]);
2956
+ if (stringMode) {
2957
+ var templateStringsArr = strings;
2958
+ styles2 += templateStringsArr[i];
2959
+ }
2960
+ }
2961
+ labelPattern.lastIndex = 0;
2962
+ var identifierName = "";
2963
+ var match2;
2964
+ while ((match2 = labelPattern.exec(styles2)) !== null) {
2965
+ identifierName += "-" + match2[1];
2966
+ }
2967
+ var name = murmur2(styles2) + identifierName;
2968
+ return {
2969
+ name,
2970
+ styles: styles2,
2971
+ next: cursor
2972
+ };
2973
+ }
2974
+
2672
2975
  // ../../node_modules/@emotion/use-insertion-effect-with-fallbacks/dist/emotion-use-insertion-effect-with-fallbacks.esm.js
2673
2976
  var React = __toESM(require("react"));
2977
+ var isBrowser3 = typeof document !== "undefined";
2978
+ var syncFallback = function syncFallback2(create) {
2979
+ return create();
2980
+ };
2981
+ var useInsertionEffect2 = React["useInsertionEffect"] ? React["useInsertionEffect"] : false;
2982
+ var useInsertionEffectAlwaysWithSyncFallback = !isBrowser3 ? syncFallback : useInsertionEffect2 || syncFallback;
2674
2983
 
2675
- // ../../node_modules/@emotion/react/dist/emotion-element-b4c8b265.esm.js
2676
- var isBrowser2 = typeof document !== "undefined";
2984
+ // ../../node_modules/@emotion/react/dist/emotion-element-d59e098f.esm.js
2985
+ var isDevelopment3 = false;
2986
+ var isBrowser4 = typeof document !== "undefined";
2677
2987
  var EmotionCacheContext = /* @__PURE__ */ React2.createContext(
2678
2988
  // we're doing this to avoid preconstruct's dead code elimination in this one case
2679
2989
  // because this module is primarily intended for the browser and node
@@ -2692,7 +3002,7 @@ var withEmotionCache = function withEmotionCache2(func) {
2692
3002
  return func(props, cache, ref);
2693
3003
  });
2694
3004
  };
2695
- if (!isBrowser2) {
3005
+ if (!isBrowser4) {
2696
3006
  withEmotionCache = function withEmotionCache3(func) {
2697
3007
  return function(props) {
2698
3008
  var cache = (0, import_react.useContext)(EmotionCacheContext);
@@ -2736,23 +3046,104 @@ var ThemeProvider = function ThemeProvider2(props) {
2736
3046
  };
2737
3047
  function withTheme(Component) {
2738
3048
  var componentName = Component.displayName || Component.name || "Component";
2739
- var render = function render2(props, ref) {
3049
+ var WithTheme = /* @__PURE__ */ React2.forwardRef(function render(props, ref) {
2740
3050
  var theme2 = React2.useContext(ThemeContext);
2741
3051
  return /* @__PURE__ */ React2.createElement(Component, _extends({
2742
3052
  theme: theme2,
2743
3053
  ref
2744
3054
  }, props));
2745
- };
2746
- var WithTheme = /* @__PURE__ */ React2.forwardRef(render);
3055
+ });
2747
3056
  WithTheme.displayName = "WithTheme(" + componentName + ")";
2748
3057
  return hoistNonReactStatics(WithTheme, Component);
2749
3058
  }
2750
3059
  var hasOwn = {}.hasOwnProperty;
3060
+ var typePropName = "__EMOTION_TYPE_PLEASE_DO_NOT_USE__";
3061
+ var createEmotionProps = function createEmotionProps2(type, props) {
3062
+ var newProps = {};
3063
+ for (var _key in props) {
3064
+ if (hasOwn.call(props, _key)) {
3065
+ newProps[_key] = props[_key];
3066
+ }
3067
+ }
3068
+ newProps[typePropName] = type;
3069
+ return newProps;
3070
+ };
3071
+ var Insertion = function Insertion2(_ref) {
3072
+ var cache = _ref.cache, serialized = _ref.serialized, isStringTag = _ref.isStringTag;
3073
+ registerStyles(cache, serialized, isStringTag);
3074
+ var rules = useInsertionEffectAlwaysWithSyncFallback(function() {
3075
+ return insertStyles(cache, serialized, isStringTag);
3076
+ });
3077
+ if (!isBrowser4 && rules !== void 0) {
3078
+ var _ref2;
3079
+ var serializedNames = serialized.name;
3080
+ var next2 = serialized.next;
3081
+ while (next2 !== void 0) {
3082
+ serializedNames += " " + next2.name;
3083
+ next2 = next2.next;
3084
+ }
3085
+ return /* @__PURE__ */ React2.createElement("style", (_ref2 = {}, _ref2["data-emotion"] = cache.key + " " + serializedNames, _ref2.dangerouslySetInnerHTML = {
3086
+ __html: rules
3087
+ }, _ref2.nonce = cache.sheet.nonce, _ref2));
3088
+ }
3089
+ return null;
3090
+ };
3091
+ var Emotion = /* @__PURE__ */ withEmotionCache(function(props, cache, ref) {
3092
+ var cssProp = props.css;
3093
+ if (typeof cssProp === "string" && cache.registered[cssProp] !== void 0) {
3094
+ cssProp = cache.registered[cssProp];
3095
+ }
3096
+ var WrappedComponent = props[typePropName];
3097
+ var registeredStyles = [cssProp];
3098
+ var className = "";
3099
+ if (typeof props.className === "string") {
3100
+ className = getRegisteredStyles(cache.registered, registeredStyles, props.className);
3101
+ } else if (props.className != null) {
3102
+ className = props.className + " ";
3103
+ }
3104
+ var serialized = serializeStyles(registeredStyles, void 0, React2.useContext(ThemeContext));
3105
+ className += cache.key + "-" + serialized.name;
3106
+ var newProps = {};
3107
+ for (var _key2 in props) {
3108
+ if (hasOwn.call(props, _key2) && _key2 !== "css" && _key2 !== typePropName && !isDevelopment3) {
3109
+ newProps[_key2] = props[_key2];
3110
+ }
3111
+ }
3112
+ newProps.className = className;
3113
+ if (ref) {
3114
+ newProps.ref = ref;
3115
+ }
3116
+ return /* @__PURE__ */ React2.createElement(React2.Fragment, null, /* @__PURE__ */ React2.createElement(Insertion, {
3117
+ cache,
3118
+ serialized,
3119
+ isStringTag: typeof WrappedComponent === "string"
3120
+ }), /* @__PURE__ */ React2.createElement(WrappedComponent, newProps));
3121
+ });
3122
+ var Emotion$1 = Emotion;
2751
3123
 
2752
3124
  // ../../node_modules/@emotion/react/dist/emotion-react.esm.js
2753
3125
  var React3 = __toESM(require("react"));
2754
3126
  var import_extends2 = __toESM(require_extends());
2755
3127
  var import_hoist_non_react_statics2 = __toESM(require_hoist_non_react_statics_cjs());
3128
+ var jsx = function jsx2(type, props) {
3129
+ var args = arguments;
3130
+ if (props == null || !hasOwn.call(props, "css")) {
3131
+ return React3.createElement.apply(void 0, args);
3132
+ }
3133
+ var argsLength = args.length;
3134
+ var createElementArgArray = new Array(argsLength);
3135
+ createElementArgArray[0] = Emotion$1;
3136
+ createElementArgArray[1] = createEmotionProps(type, props);
3137
+ for (var i = 2; i < argsLength; i++) {
3138
+ createElementArgArray[i] = args[i];
3139
+ }
3140
+ return React3.createElement.apply(null, createElementArgArray);
3141
+ };
3142
+ (function(_jsx) {
3143
+ var JSX;
3144
+ /* @__PURE__ */ (function(_JSX) {
3145
+ })(JSX || (JSX = _jsx.JSX || (_jsx.JSX = {})));
3146
+ })(jsx || (jsx = {}));
2756
3147
 
2757
3148
  // ../../node_modules/@emotion/primitives-core/dist/emotion-primitives-core.esm.js
2758
3149
  function interleave(vals) {
@@ -2770,7 +3161,7 @@ var styles;
2770
3161
  var generated = {};
2771
3162
  var buffer = "";
2772
3163
  var lastType;
2773
- function handleInterpolation(interpolation, i, arr) {
3164
+ function handleInterpolation2(interpolation, i, arr) {
2774
3165
  var type = typeof interpolation;
2775
3166
  if (type === "string") {
2776
3167
  interpolation = interpolation.replace(/\/\*[\s\S]*?\*\/|\/\/.*$/gm, "");
@@ -2779,7 +3170,7 @@ function handleInterpolation(interpolation, i, arr) {
2779
3170
  if (this === void 0)
2780
3171
  ;
2781
3172
  else {
2782
- handleInterpolation.call(this, interpolation(this), i, arr);
3173
+ handleInterpolation2.call(this, interpolation(this), i, arr);
2783
3174
  }
2784
3175
  return;
2785
3176
  }
@@ -2809,7 +3200,7 @@ function handleInterpolation(interpolation, i, arr) {
2809
3200
  styles.push(interpolation);
2810
3201
  }
2811
3202
  if (Array.isArray(interpolation)) {
2812
- interpolation.forEach(handleInterpolation, this);
3203
+ interpolation.forEach(handleInterpolation2, this);
2813
3204
  }
2814
3205
  lastType = type;
2815
3206
  }
@@ -2829,7 +3220,7 @@ function createCss(StyleSheet4) {
2829
3220
  vals = interleave(args);
2830
3221
  }
2831
3222
  try {
2832
- vals.forEach(handleInterpolation, this);
3223
+ vals.forEach(handleInterpolation2, this);
2833
3224
  } finally {
2834
3225
  buffer = prevBuffer;
2835
3226
  }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@storybook/react-native-theming",
3
- "version": "9.0.0-beta.10",
3
+ "version": "9.0.0-beta.11",
4
4
  "description": "A wrapper library around emotion 11 to provide theming support for react-native storybook",
5
5
  "keywords": [
6
6
  "react",
@@ -43,5 +43,5 @@
43
43
  "dist/**/*",
44
44
  "README.md"
45
45
  ],
46
- "gitHead": "bce7f35509d03e5a5efabb8862e993ea98e201d6"
46
+ "gitHead": "531ed8a758adc98bb436d0ccb32efcb369572ffe"
47
47
  }