@stylexjs/shared 0.1.0-beta.6 → 0.1.0-beta.7

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/lib/index.d.ts CHANGED
@@ -25,10 +25,12 @@ export type InjectableStyle = {
25
25
  export type StyleRule = readonly [string, string, InjectableStyle];
26
26
 
27
27
  export type CompiledStyles = {
28
- readonly [key: string]: string | { readonly [key: string]: string };
28
+ readonly [key: string]: string | null;
29
+ readonly $$css: true;
29
30
  };
30
31
  export type MutableCompiledStyles = {
31
- [key: string]: string | { [key: string]: string };
32
+ [key: string]: string | null;
33
+ $$css: true;
32
34
  };
33
35
 
34
36
  export type CompiledNamespaces = { readonly [key: string]: CompiledStyles };
@@ -41,7 +41,11 @@ function styleXCreateSet(namespaces) {
41
41
  throw new Error(messages.ILLEGAL_NAMESPACE_VALUE);
42
42
  }
43
43
  const [resolvedNamespace, injected] = styleXCreateNamespace(namespace, options);
44
- resolvedNamespaces[namespaceName] = (0, _objectUtils.flattenObject)(resolvedNamespace);
44
+ const compiledNamespace = (0, _objectUtils.flattenObject)(resolvedNamespace);
45
+ resolvedNamespaces[namespaceName] = {
46
+ ...compiledNamespace,
47
+ $$css: true
48
+ };
45
49
  for (const cn of Object.keys(injected)) {
46
50
  if (injectedStyles[cn] == null) {
47
51
  injectedStyles[cn] = injected[cn];
@@ -88,7 +92,7 @@ function styleXCreateNamespace(style, options) {
88
92
  return (0, _expandShorthands.default)([innerKey, innerValue]);
89
93
  }))]];
90
94
  } else {
91
- if (typeof value !== 'string' && typeof value !== 'number' && !Array.isArray(value)) {
95
+ if (value !== null && typeof value !== 'string' && typeof value !== 'number' && !Array.isArray(value)) {
92
96
  throw new Error(messages.ILLEGAL_PROP_VALUE);
93
97
  }
94
98
  if (Array.isArray(value) && value.some(val => typeof val === 'object')) {
@@ -112,15 +116,23 @@ function styleXCreateNamespace(style, options) {
112
116
  const pseudo = key;
113
117
  const innerObj = {};
114
118
  for (const [innerKey, innerVal] of (0, _objectUtils.objEntries)(val)) {
115
- const [updatedKey, className, cssRule] = (0, _convertToClassName.default)([innerKey, innerVal], pseudo, options);
116
- innerObj[updatedKey] = className;
117
- injectedStyles[updatedKey + pseudo] = [className, cssRule];
119
+ if (innerVal === null) {
120
+ innerObj[innerKey] = null;
121
+ } else {
122
+ const [updatedKey, className, cssRule] = (0, _convertToClassName.default)([innerKey, innerVal], pseudo, options);
123
+ innerObj[updatedKey] = className;
124
+ injectedStyles[updatedKey + pseudo] = [className, cssRule];
125
+ }
118
126
  }
119
127
  resolvedNamespace[key] = innerObj;
120
128
  } else {
121
- const [updatedKey, className, cssRule] = (0, _convertToClassName.default)([key, val], undefined, options);
122
- resolvedNamespace[updatedKey] = className;
123
- injectedStyles[updatedKey] = [className, cssRule];
129
+ if (val === null) {
130
+ resolvedNamespace[key] = null;
131
+ } else {
132
+ const [updatedKey, className, cssRule] = (0, _convertToClassName.default)([key, val], undefined, options);
133
+ resolvedNamespace[updatedKey] = className;
134
+ injectedStyles[updatedKey] = [className, cssRule];
135
+ }
124
136
  }
125
137
  }
126
138
  const finalInjectedStyles = (0, _objectUtils.objFromEntries)((0, _objectUtils.objValues)(injectedStyles));
@@ -0,0 +1,265 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.StylexValueBuilder = void 0;
7
+ exports.default = stylexDefaultValue;
8
+ var messages = _interopRequireWildcard(require("./messages"));
9
+ var _dashify = _interopRequireDefault(require("./utils/dashify"));
10
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
11
+ function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
12
+ function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
13
+ function _classPrivateMethodInitSpec(obj, privateSet) { _checkPrivateRedeclaration(obj, privateSet); privateSet.add(obj); }
14
+ function _checkPrivateRedeclaration(obj, privateCollection) { if (privateCollection.has(obj)) { throw new TypeError("Cannot initialize the same private elements twice on an object"); } }
15
+ function _classPrivateMethodGet(receiver, privateSet, fn) { if (!privateSet.has(receiver)) { throw new TypeError("attempted to get private field on non-instance"); } return fn; }
16
+ var _set = /*#__PURE__*/new WeakSet();
17
+ class StylexValueBuilder {
18
+ constructor(defaultValue) {
19
+ _classPrivateMethodInitSpec(this, _set);
20
+ this.default = defaultValue;
21
+ }
22
+ // @media Queries
23
+
24
+ mediaPrint(value) {
25
+ return _classPrivateMethodGet(this, _set, _set2).call(this, '@media print', value);
26
+ }
27
+ mediaWidth(_ref, value) {
28
+ let [min, max] = _ref;
29
+ if (min > 0 && max < Infinity) {
30
+ return _classPrivateMethodGet(this, _set, _set2).call(this, `@media (min-width: ${min}px and max-width: ${max}px)`, value);
31
+ } else if (min === 0) {
32
+ return _classPrivateMethodGet(this, _set, _set2).call(this, `@media (max-width: ${max}px)`, value);
33
+ } else if (max === Infinity) {
34
+ return _classPrivateMethodGet(this, _set, _set2).call(this, `@media (min-width: ${min}px)`, value);
35
+ }
36
+ throw new Error(messages.INVALID_MEDIA_QUERY);
37
+ }
38
+ mediaHeight(_ref2, value) {
39
+ let [min, max] = _ref2;
40
+ if (min > 0 && max < Infinity) {
41
+ return _classPrivateMethodGet(this, _set, _set2).call(this, `@media (min-height: ${min}px and max-height: ${max}px)`, value);
42
+ } else if (min === 0) {
43
+ return _classPrivateMethodGet(this, _set, _set2).call(this, `@media (max-height: ${max}px)`, value);
44
+ } else if (max === Infinity) {
45
+ return _classPrivateMethodGet(this, _set, _set2).call(this, `@media (min-height: ${min}px)`, value);
46
+ }
47
+ throw new Error(messages.INVALID_MEDIA_QUERY);
48
+ }
49
+ mediaAspectRatio(_ref3, value) {
50
+ let [min, max] = _ref3;
51
+ if (min > 0 && max < Infinity) {
52
+ return _classPrivateMethodGet(this, _set, _set2).call(this, `@media (min-aspect-ratio: ${min} and max-aspect-ratio: $, })`, value);
53
+ } else if (min === 0) {
54
+ return _classPrivateMethodGet(this, _set, _set2).call(this, `@media (max-aspect-ratio: ${max})`, value);
55
+ } else if (max === Infinity) {
56
+ return _classPrivateMethodGet(this, _set, _set2).call(this, `@media (min-aspect-ratio: ${min})`, value);
57
+ }
58
+ throw new Error(messages.INVALID_MEDIA_QUERY);
59
+ }
60
+ mediaPortrait(value) {
61
+ return _classPrivateMethodGet(this, _set, _set2).call(this, '@media (orientation: portrait)', value);
62
+ }
63
+ mediaLandscape(value) {
64
+ return _classPrivateMethodGet(this, _set, _set2).call(this, '@media (orientation: landscape)', value);
65
+ }
66
+ mediaSRGBDisplay(value) {
67
+ return _classPrivateMethodGet(this, _set, _set2).call(this, '@media (color-gamut: srgb)', value);
68
+ }
69
+ mediaP3Display(value) {
70
+ return _classPrivateMethodGet(this, _set, _set2).call(this, '@media (color-gamut: p3)', value);
71
+ }
72
+ mediaRec2020Display(value) {
73
+ return _classPrivateMethodGet(this, _set, _set2).call(this, '@media (color-gamut: rec2020)', value);
74
+ }
75
+ mediaIsFullscreen(value) {
76
+ return _classPrivateMethodGet(this, _set, _set2).call(this, '@media (display-mode: fullscreen)', value);
77
+ }
78
+
79
+ // These are confusing, so skipping them for now
80
+ // mediaIsStandalone
81
+ // mediaIsMinimalUI
82
+
83
+ mediaSDRDisplay(value) {
84
+ return _classPrivateMethodGet(this, _set, _set2).call(this, '@media (dynamic-range: standard)', value);
85
+ }
86
+ mediaHDRDisplay(value) {
87
+ return _classPrivateMethodGet(this, _set, _set2).call(this, '@media (dynamic-range: high)', value);
88
+ }
89
+ mediaSupportsHDRVideo(value) {
90
+ return _classPrivateMethodGet(this, _set, _set2).call(this, '@media (video-dynamic-range: high)', value);
91
+ }
92
+
93
+ //<TAddedValue> mediaHasColor(value: TAddedValue): StylexValueBuilder<TValue | TAddedValue> {
94
+ // return this.#set('@media (color)', value);
95
+ // }
96
+
97
+ primaryInputCanHover(value) {
98
+ return _classPrivateMethodGet(this, _set, _set2).call(this, '@media (hover: hover)', value);
99
+ }
100
+ primaryInputCanNotHover(value) {
101
+ return _classPrivateMethodGet(this, _set, _set2).call(this, '@media (hover: none)', value);
102
+ }
103
+ someInputCanHover(value) {
104
+ return _classPrivateMethodGet(this, _set, _set2).call(this, '@media (any-hover: hover)', value);
105
+ }
106
+ noInputCanHover(value) {
107
+ return _classPrivateMethodGet(this, _set, _set2).call(this, '@media (any-hover: none)', value);
108
+ }
109
+ somePointerIsFine(value) {
110
+ return _classPrivateMethodGet(this, _set, _set2).call(this, '@media (any-pointer: fine)', value);
111
+ }
112
+ somePointerIsCoarse(value) {
113
+ return _classPrivateMethodGet(this, _set, _set2).call(this, '@media (any-pointer: coarse)', value);
114
+ }
115
+ primaryPointerIsFine(value) {
116
+ return _classPrivateMethodGet(this, _set, _set2).call(this, '@media (pointer: fine)', value);
117
+ }
118
+ primaryPointerIsCoarse(value) {
119
+ return _classPrivateMethodGet(this, _set, _set2).call(this, '@media (pointer: coarse)', value);
120
+ }
121
+ lightMode(value) {
122
+ return _classPrivateMethodGet(this, _set, _set2).call(this, '@media (prefers-color-scheme: light)', value);
123
+ }
124
+ darkMode(value) {
125
+ return _classPrivateMethodGet(this, _set, _set2).call(this, '@media (prefers-color-scheme: dark)', value);
126
+ }
127
+ userPrefersMoreContrast(value) {
128
+ return _classPrivateMethodGet(this, _set, _set2).call(this, '@media (prefers-contrast: more)', value);
129
+ }
130
+ userPrefersLessContrast(value) {
131
+ return _classPrivateMethodGet(this, _set, _set2).call(this, '@media (prefers-contrast: less)', value);
132
+ }
133
+ userPrefersReducedMotion(value) {
134
+ return _classPrivateMethodGet(this, _set, _set2).call(this, '@media (prefers-reduced-motion)', value);
135
+ }
136
+ noScript(value) {
137
+ return _classPrivateMethodGet(this, _set, _set2).call(this, '@media (scripting: none)', value);
138
+ }
139
+ matchMediaUNSAFE(query, value) {
140
+ return _classPrivateMethodGet(this, _set, _set2).call(this, `@media ${query}`, value);
141
+ }
142
+ supports(selector, value) {
143
+ const toSelector = _ref4 => {
144
+ let [k, v] = _ref4;
145
+ return `(${(0, _dashify.default)(k)}: ${String(v)})`;
146
+ };
147
+ const query = Object.entries(selector).map(toSelector).join(' and ');
148
+ return _classPrivateMethodGet(this, _set, _set2).call(this, `@supports ${query}`, value);
149
+ }
150
+ supportsNot(selector, value) {
151
+ const toSelector = _ref5 => {
152
+ let [k, v] = _ref5;
153
+ return `(not (${(0, _dashify.default)(k)}: ${String(v)}))`;
154
+ };
155
+ const query = Object.entries(selector).map(toSelector).join(' and ');
156
+ return _classPrivateMethodGet(this, _set, _set2).call(this, `@supports ${query}`, value);
157
+ }
158
+
159
+ // Pseudo Classes
160
+
161
+ hover(value) {
162
+ return _classPrivateMethodGet(this, _set, _set2).call(this, ':hover', value);
163
+ }
164
+ focus(value) {
165
+ return _classPrivateMethodGet(this, _set, _set2).call(this, ':focus', value);
166
+ }
167
+ focusVisible(value) {
168
+ return _classPrivateMethodGet(this, _set, _set2).call(this, ':focus-visible', value);
169
+ }
170
+ focusWithin(value) {
171
+ return _classPrivateMethodGet(this, _set, _set2).call(this, ':focus-within', value);
172
+ }
173
+ active(value) {
174
+ return _classPrivateMethodGet(this, _set, _set2).call(this, ':active', value);
175
+ }
176
+ anyLink(value) {
177
+ return _classPrivateMethodGet(this, _set, _set2).call(this, ':any-link', value);
178
+ }
179
+ autofill(value) {
180
+ return _classPrivateMethodGet(this, _set, _set2).call(this, ':autofill', value);
181
+ }
182
+ checked(value) {
183
+ return _classPrivateMethodGet(this, _set, _set2).call(this, ':checked', value);
184
+ }
185
+ defaultSelection(value) {
186
+ return _classPrivateMethodGet(this, _set, _set2).call(this, ':default', value);
187
+ }
188
+ disabled(value) {
189
+ return _classPrivateMethodGet(this, _set, _set2).call(this, ':disabled', value);
190
+ }
191
+ empty(value) {
192
+ return _classPrivateMethodGet(this, _set, _set2).call(this, ':empty', value);
193
+ }
194
+ enabled(value) {
195
+ return _classPrivateMethodGet(this, _set, _set2).call(this, ':enabled', value);
196
+ }
197
+ fullscreen(value) {
198
+ return _classPrivateMethodGet(this, _set, _set2).call(this, ':fullscreen', value);
199
+ }
200
+ indeterminate(value) {
201
+ return _classPrivateMethodGet(this, _set, _set2).call(this, ':indeterminate', value);
202
+ }
203
+ invalid(value) {
204
+ return _classPrivateMethodGet(this, _set, _set2).call(this, ':invalid', value);
205
+ }
206
+ isUNSAFE(selector, value) {
207
+ return _classPrivateMethodGet(this, _set, _set2).call(this, `:is(${selector})`, value);
208
+ }
209
+ notUNSAFE(selector, value) {
210
+ return _classPrivateMethodGet(this, _set, _set2).call(this, `:not(${selector})`, value);
211
+ }
212
+ lang(value) {
213
+ return _classPrivateMethodGet(this, _set, _set2).call(this, ':lang', value);
214
+ }
215
+ dirRTLUNSFAE(value) {
216
+ return _classPrivateMethodGet(this, _set, _set2).call(this, ':dir(rtl)', value);
217
+ }
218
+ link(value) {
219
+ return _classPrivateMethodGet(this, _set, _set2).call(this, ':link', value);
220
+ }
221
+ optional(value) {
222
+ return _classPrivateMethodGet(this, _set, _set2).call(this, ':optional', value);
223
+ }
224
+ pictureInPicture(value) {
225
+ return _classPrivateMethodGet(this, _set, _set2).call(this, ':picture-in-picture', value);
226
+ }
227
+ placeholderShown(value) {
228
+ return _classPrivateMethodGet(this, _set, _set2).call(this, ':placeholder-shown', value);
229
+ }
230
+ paused(value) {
231
+ return _classPrivateMethodGet(this, _set, _set2).call(this, ':paused', value);
232
+ }
233
+ playing(value) {
234
+ return _classPrivateMethodGet(this, _set, _set2).call(this, ':playing', value);
235
+ }
236
+ readOnly(value) {
237
+ return _classPrivateMethodGet(this, _set, _set2).call(this, ':read-only', value);
238
+ }
239
+ readWrite(value) {
240
+ return _classPrivateMethodGet(this, _set, _set2).call(this, ':read-write', value);
241
+ }
242
+ required(value) {
243
+ return _classPrivateMethodGet(this, _set, _set2).call(this, ':required', value);
244
+ }
245
+ target(value) {
246
+ return _classPrivateMethodGet(this, _set, _set2).call(this, ':target', value);
247
+ }
248
+ valid(value) {
249
+ return _classPrivateMethodGet(this, _set, _set2).call(this, ':valid', value);
250
+ }
251
+ visited(value) {
252
+ return _classPrivateMethodGet(this, _set, _set2).call(this, ':visited', value);
253
+ }
254
+ pseudoUNSAFE(selector, value) {
255
+ return _classPrivateMethodGet(this, _set, _set2).call(this, `:${selector}`, value);
256
+ }
257
+ }
258
+ exports.StylexValueBuilder = StylexValueBuilder;
259
+ function _set2(key, value) {
260
+ this[key] = value;
261
+ return this;
262
+ }
263
+ function stylexDefaultValue(value) {
264
+ return new StylexValueBuilder(value);
265
+ }
@@ -26,7 +26,7 @@ var _stylexInclude = require("../stylex-include");
26
26
  function flattenObject(obj) {
27
27
  const result = {};
28
28
  for (const [key, value] of objEntries(obj)) {
29
- if (typeof value === 'string') {
29
+ if (typeof value === 'string' || value == null) {
30
30
  result[key] = value;
31
31
  } else if (value instanceof _stylexInclude.IncludedStyles) {
32
32
  result[key] = value;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@stylexjs/shared",
3
- "version": "0.1.0-beta.6",
3
+ "version": "0.1.0-beta.7",
4
4
  "description": "Shared Code for Stylex compile and runtime.",
5
5
  "main": "lib/index.js",
6
6
  "repository": "https://www.github.com/facebookexternal/stylex",