@ntbjs/react-components 1.1.0-beta.63 → 1.1.0-beta.631

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.
@@ -234,6 +234,8 @@ function _toConsumableArray(arr) {
234
234
  return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread();
235
235
  }
236
236
 
237
+ var isDevelopment$2 = false;
238
+
237
239
  /*
238
240
 
239
241
  Based off glamor's StyleSheet, thanks Sunil ❤️
@@ -256,10 +258,9 @@ styleSheet.flush()
256
258
  - empties the stylesheet of all its contents
257
259
 
258
260
  */
259
- // $FlowFixMe
261
+
260
262
  function sheetForTag(tag) {
261
263
  if (tag.sheet) {
262
- // $FlowFixMe
263
264
  return tag.sheet;
264
265
  } // this weirdness brought to you by firefox
265
266
 
@@ -268,10 +269,13 @@ function sheetForTag(tag) {
268
269
 
269
270
  for (var i = 0; i < document.styleSheets.length; i++) {
270
271
  if (document.styleSheets[i].ownerNode === tag) {
271
- // $FlowFixMe
272
272
  return document.styleSheets[i];
273
273
  }
274
- }
274
+ } // this function should always return with a value
275
+ // TS can't understand it though so we make it stop complaining here
276
+
277
+
278
+ return undefined;
275
279
  }
276
280
 
277
281
  function createStyleElement(options) {
@@ -312,7 +316,7 @@ var StyleSheet = /*#__PURE__*/function () {
312
316
  _this.tags.push(tag);
313
317
  };
314
318
 
315
- this.isSpeedy = options.speedy === undefined ? process.env.NODE_ENV === 'production' : options.speedy;
319
+ this.isSpeedy = options.speedy === undefined ? !isDevelopment$2 : options.speedy;
316
320
  this.tags = [];
317
321
  this.ctr = 0;
318
322
  this.nonce = options.nonce; // key is the value of the data-emotion attribute, it's used to identify different sheets
@@ -340,18 +344,6 @@ var StyleSheet = /*#__PURE__*/function () {
340
344
 
341
345
  var tag = this.tags[this.tags.length - 1];
342
346
 
343
- if (process.env.NODE_ENV !== 'production') {
344
- var isImportRule = rule.charCodeAt(0) === 64 && rule.charCodeAt(1) === 105;
345
-
346
- if (isImportRule && this._alreadyInsertedOrderInsensitiveRule) {
347
- // this would only cause problem in speedy mode
348
- // but we don't want enabling speedy to affect the observable behavior
349
- // so we report this error at all times
350
- console.error("You're attempting to insert the following rule:\n" + rule + '\n\n`@import` rules must be before all other types of rules in a stylesheet but other rules have already been inserted. Please ensure that `@import` rules are before all other rules.');
351
- }
352
- this._alreadyInsertedOrderInsensitiveRule = this._alreadyInsertedOrderInsensitiveRule || !isImportRule;
353
- }
354
-
355
347
  if (this.isSpeedy) {
356
348
  var sheet = sheetForTag(tag);
357
349
 
@@ -360,9 +352,6 @@ var StyleSheet = /*#__PURE__*/function () {
360
352
  // the big drawback is that the css won't be editable in devtools
361
353
  sheet.insertRule(rule, sheet.cssRules.length);
362
354
  } catch (e) {
363
- if (process.env.NODE_ENV !== 'production' && !/:(-moz-placeholder|-moz-focus-inner|-moz-focusring|-ms-input-placeholder|-moz-read-write|-moz-read-only|-ms-clear|-ms-expand|-ms-reveal){/.test(rule)) {
364
- console.error("There was a problem inserting the following rule: \"" + rule + "\"", e);
365
- }
366
355
  }
367
356
  } else {
368
357
  tag.appendChild(document.createTextNode(rule));
@@ -372,16 +361,13 @@ var StyleSheet = /*#__PURE__*/function () {
372
361
  };
373
362
 
374
363
  _proto.flush = function flush() {
375
- // $FlowFixMe
376
364
  this.tags.forEach(function (tag) {
377
- return tag.parentNode && tag.parentNode.removeChild(tag);
365
+ var _tag$parentNode;
366
+
367
+ return (_tag$parentNode = tag.parentNode) == null ? void 0 : _tag$parentNode.removeChild(tag);
378
368
  });
379
369
  this.tags = [];
380
370
  this.ctr = 0;
381
-
382
- if (process.env.NODE_ENV !== 'production') {
383
- this._alreadyInsertedOrderInsensitiveRule = false;
384
- }
385
371
  };
386
372
 
387
373
  return StyleSheet;
@@ -986,11 +972,11 @@ function rulesheet (callback) {
986
972
  }
987
973
 
988
974
  var weakMemoize = function weakMemoize(func) {
989
- // $FlowFixMe flow doesn't include all non-primitive types as allowed for weakmaps
990
975
  var cache = new WeakMap();
991
976
  return function (arg) {
992
977
  if (cache.has(arg)) {
993
- // $FlowFixMe
978
+ // Use non-null assertion because we just checked that the cache `has` it
979
+ // This allows us to remove `undefined` from the return value
994
980
  return cache.get(arg);
995
981
  }
996
982
 
@@ -1008,6 +994,8 @@ function memoize$1(fn) {
1008
994
  };
1009
995
  }
1010
996
 
997
+ var isBrowser$3 = typeof document !== 'undefined';
998
+
1011
999
  var identifierWithPointTracking = function identifierWithPointTracking(begin, points, index) {
1012
1000
  var previous = 0;
1013
1001
  var character = 0;
@@ -1086,8 +1074,8 @@ var compat = function compat(element) {
1086
1074
  return;
1087
1075
  }
1088
1076
 
1089
- var value = element.value,
1090
- parent = element.parent;
1077
+ var value = element.value;
1078
+ var parent = element.parent;
1091
1079
  var isImplicitRule = element.column === parent.column && element.line === parent.line;
1092
1080
 
1093
1081
  while (parent.type !== 'rule') {
@@ -1132,114 +1120,6 @@ var removeLabel = function removeLabel(element) {
1132
1120
  }
1133
1121
  }
1134
1122
  };
1135
- var ignoreFlag = 'emotion-disable-server-rendering-unsafe-selector-warning-please-do-not-use-this-the-warning-exists-for-a-reason';
1136
-
1137
- var isIgnoringComment = function isIgnoringComment(element) {
1138
- return element.type === 'comm' && element.children.indexOf(ignoreFlag) > -1;
1139
- };
1140
-
1141
- var createUnsafeSelectorsAlarm = function createUnsafeSelectorsAlarm(cache) {
1142
- return function (element, index, children) {
1143
- if (element.type !== 'rule' || cache.compat) return;
1144
- var unsafePseudoClasses = element.value.match(/(:first|:nth|:nth-last)-child/g);
1145
-
1146
- if (unsafePseudoClasses) {
1147
- var isNested = !!element.parent; // in nested rules comments become children of the "auto-inserted" rule and that's always the `element.parent`
1148
- //
1149
- // considering this input:
1150
- // .a {
1151
- // .b /* comm */ {}
1152
- // color: hotpink;
1153
- // }
1154
- // we get output corresponding to this:
1155
- // .a {
1156
- // & {
1157
- // /* comm */
1158
- // color: hotpink;
1159
- // }
1160
- // .b {}
1161
- // }
1162
-
1163
- var commentContainer = isNested ? element.parent.children : // global rule at the root level
1164
- children;
1165
-
1166
- for (var i = commentContainer.length - 1; i >= 0; i--) {
1167
- var node = commentContainer[i];
1168
-
1169
- if (node.line < element.line) {
1170
- break;
1171
- } // it is quite weird but comments are *usually* put at `column: element.column - 1`
1172
- // so we seek *from the end* for the node that is earlier than the rule's `element` and check that
1173
- // this will also match inputs like this:
1174
- // .a {
1175
- // /* comm */
1176
- // .b {}
1177
- // }
1178
- //
1179
- // but that is fine
1180
- //
1181
- // it would be the easiest to change the placement of the comment to be the first child of the rule:
1182
- // .a {
1183
- // .b { /* comm */ }
1184
- // }
1185
- // with such inputs we wouldn't have to search for the comment at all
1186
- // TODO: consider changing this comment placement in the next major version
1187
-
1188
-
1189
- if (node.column < element.column) {
1190
- if (isIgnoringComment(node)) {
1191
- return;
1192
- }
1193
-
1194
- break;
1195
- }
1196
- }
1197
-
1198
- unsafePseudoClasses.forEach(function (unsafePseudoClass) {
1199
- console.error("The pseudo class \"" + unsafePseudoClass + "\" is potentially unsafe when doing server-side rendering. Try changing it to \"" + unsafePseudoClass.split('-child')[0] + "-of-type\".");
1200
- });
1201
- }
1202
- };
1203
- };
1204
-
1205
- var isImportRule = function isImportRule(element) {
1206
- return element.type.charCodeAt(1) === 105 && element.type.charCodeAt(0) === 64;
1207
- };
1208
-
1209
- var isPrependedWithRegularRules = function isPrependedWithRegularRules(index, children) {
1210
- for (var i = index - 1; i >= 0; i--) {
1211
- if (!isImportRule(children[i])) {
1212
- return true;
1213
- }
1214
- }
1215
-
1216
- return false;
1217
- }; // use this to remove incorrect elements from further processing
1218
- // so they don't get handed to the `sheet` (or anything else)
1219
- // as that could potentially lead to additional logs which in turn could be overhelming to the user
1220
-
1221
-
1222
- var nullifyElement = function nullifyElement(element) {
1223
- element.type = '';
1224
- element.value = '';
1225
- element["return"] = '';
1226
- element.children = '';
1227
- element.props = '';
1228
- };
1229
-
1230
- var incorrectImportAlarm = function incorrectImportAlarm(element, index, children) {
1231
- if (!isImportRule(element)) {
1232
- return;
1233
- }
1234
-
1235
- if (element.parent) {
1236
- console.error("`@import` rules can't be nested inside other rules. Please move it to the top level and put it before regular rules. Keep in mind that they can only be used within global styles.");
1237
- nullifyElement(element);
1238
- } else if (isPrependedWithRegularRules(index, children)) {
1239
- console.error("`@import` rules can't be after other rules. Please put your `@import` rules before your other rules.");
1240
- nullifyElement(element);
1241
- }
1242
- };
1243
1123
 
1244
1124
  /* eslint-disable no-fallthrough */
1245
1125
 
@@ -1453,13 +1333,9 @@ var prefixer = function prefixer(element, index, children, callback) {
1453
1333
  }
1454
1334
  };
1455
1335
 
1456
- var isBrowser$4 = typeof document !== 'undefined';
1457
- var getServerStylisCache = isBrowser$4 ? undefined : weakMemoize(function () {
1336
+ var getServerStylisCache = isBrowser$3 ? undefined : weakMemoize(function () {
1458
1337
  return memoize$1(function () {
1459
- var cache = {};
1460
- return function (name) {
1461
- return cache[name];
1462
- };
1338
+ return {};
1463
1339
  });
1464
1340
  });
1465
1341
  var defaultStylisPlugins = [prefixer];
@@ -1467,11 +1343,7 @@ var defaultStylisPlugins = [prefixer];
1467
1343
  var createCache = function createCache(options) {
1468
1344
  var key = options.key;
1469
1345
 
1470
- if (process.env.NODE_ENV !== 'production' && !key) {
1471
- throw new Error("You have to configure `key` for your cache. Please make sure it's unique (and not equal to 'css') as it's used for linking styles to your cache.\n" + "If multiple caches share the same key they might \"fight\" for each other's style elements.");
1472
- }
1473
-
1474
- if (isBrowser$4 && key === 'css') {
1346
+ if (isBrowser$3 && key === 'css') {
1475
1347
  var ssrStyles = document.querySelectorAll("style[data-emotion]:not([data-s])"); // get SSRed styles out of the way of React's hydration
1476
1348
  // document.head is a safe place to move them to(though note document.head is not necessarily the last place they will be)
1477
1349
  // note this very very intentionally targets all style elements regardless of the key to ensure
@@ -1489,6 +1361,7 @@ var createCache = function createCache(options) {
1489
1361
  if (dataEmotionAttribute.indexOf(' ') === -1) {
1490
1362
  return;
1491
1363
  }
1364
+
1492
1365
  document.head.appendChild(node);
1493
1366
  node.setAttribute('data-s', '');
1494
1367
  });
@@ -1496,23 +1369,16 @@ var createCache = function createCache(options) {
1496
1369
 
1497
1370
  var stylisPlugins = options.stylisPlugins || defaultStylisPlugins;
1498
1371
 
1499
- if (process.env.NODE_ENV !== 'production') {
1500
- // $FlowFixMe
1501
- if (/[^a-z-]/.test(key)) {
1502
- throw new Error("Emotion key must only contain lower case alphabetical characters and - but \"" + key + "\" was passed");
1503
- }
1504
- }
1505
-
1506
1372
  var inserted = {};
1507
1373
  var container;
1508
1374
  var nodesToHydrate = [];
1509
1375
 
1510
- if (isBrowser$4) {
1376
+ if (isBrowser$3) {
1511
1377
  container = options.container || document.head;
1512
1378
  Array.prototype.forEach.call( // this means we will ignore elements which don't have a space in them which
1513
1379
  // means that the style elements we're looking at are only Emotion 11 server-rendered style elements
1514
1380
  document.querySelectorAll("style[data-emotion^=\"" + key + " \"]"), function (node) {
1515
- var attrib = node.getAttribute("data-emotion").split(' '); // $FlowFixMe
1381
+ var attrib = node.getAttribute("data-emotion").split(' ');
1516
1382
 
1517
1383
  for (var i = 1; i < attrib.length; i++) {
1518
1384
  inserted[attrib[i]] = true;
@@ -1526,28 +1392,9 @@ var createCache = function createCache(options) {
1526
1392
 
1527
1393
  var omnipresentPlugins = [compat, removeLabel];
1528
1394
 
1529
- if (process.env.NODE_ENV !== 'production') {
1530
- omnipresentPlugins.push(createUnsafeSelectorsAlarm({
1531
- get compat() {
1532
- return cache.compat;
1533
- }
1534
-
1535
- }), incorrectImportAlarm);
1536
- }
1537
-
1538
- if (isBrowser$4) {
1395
+ if (!getServerStylisCache) {
1539
1396
  var currentSheet;
1540
- var finalizingPlugins = [stringify, process.env.NODE_ENV !== 'production' ? function (element) {
1541
- if (!element.root) {
1542
- if (element["return"]) {
1543
- currentSheet.insert(element["return"]);
1544
- } else if (element.value && element.type !== COMMENT) {
1545
- // insert empty rule in non-production environments
1546
- // so @emotion/jest can grab `key` from the (JS)DOM for caches without any rules inserted yet
1547
- currentSheet.insert(element.value + "{}");
1548
- }
1549
- }
1550
- } : rulesheet(function (rule) {
1397
+ var finalizingPlugins = [stringify, rulesheet(function (rule) {
1551
1398
  currentSheet.insert(rule);
1552
1399
  })];
1553
1400
  var serializer = middleware(omnipresentPlugins.concat(stylisPlugins, finalizingPlugins));
@@ -1559,14 +1406,6 @@ var createCache = function createCache(options) {
1559
1406
  _insert = function insert(selector, serialized, sheet, shouldCache) {
1560
1407
  currentSheet = sheet;
1561
1408
 
1562
- if (process.env.NODE_ENV !== 'production' && serialized.map !== undefined) {
1563
- currentSheet = {
1564
- insert: function insert(rule) {
1565
- sheet.insert(rule + serialized.map);
1566
- }
1567
- };
1568
- }
1569
-
1570
1409
  stylis(selector ? selector + "{" + serialized.styles + "}" : serialized.styles);
1571
1410
 
1572
1411
  if (shouldCache) {
@@ -1580,8 +1419,7 @@ var createCache = function createCache(options) {
1580
1419
 
1581
1420
  var _stylis = function _stylis(styles) {
1582
1421
  return serialize(compile(styles), _serializer);
1583
- }; // $FlowFixMe
1584
-
1422
+ };
1585
1423
 
1586
1424
  var serverStylisCache = getServerStylisCache(stylisPlugins)(key);
1587
1425
 
@@ -1607,12 +1445,6 @@ var createCache = function createCache(options) {
1607
1445
  cache.inserted[name] = true;
1608
1446
  }
1609
1447
 
1610
- if ( // using === development instead of !== production
1611
- // because if people do ssr in tests, the source maps showing up would be annoying
1612
- process.env.NODE_ENV === 'development' && serialized.map !== undefined) {
1613
- return rules + serialized.map;
1614
- }
1615
-
1616
1448
  return rules;
1617
1449
  } else {
1618
1450
  // in compat mode, we put the styles on the inserted cache so
@@ -1876,13 +1708,14 @@ var TYPE_STATICS = {};
1876
1708
  TYPE_STATICS[reactIs.ForwardRef] = FORWARD_REF_STATICS;
1877
1709
  TYPE_STATICS[reactIs.Memo] = MEMO_STATICS;
1878
1710
 
1879
- var isBrowser$3 = typeof document !== 'undefined';
1711
+ var isBrowser$2 = typeof document !== 'undefined';
1712
+
1880
1713
  function getRegisteredStyles(registered, registeredStyles, classNames) {
1881
1714
  var rawClassName = '';
1882
1715
  classNames.split(' ').forEach(function (className) {
1883
1716
  if (registered[className] !== undefined) {
1884
1717
  registeredStyles.push(registered[className] + ";");
1885
- } else {
1718
+ } else if (className) {
1886
1719
  rawClassName += className + " ";
1887
1720
  }
1888
1721
  });
@@ -1900,7 +1733,7 @@ var registerStyles = function registerStyles(cache, serialized, isStringTag) {
1900
1733
  // in node since emotion-server relies on whether a style is in
1901
1734
  // the registered cache to know whether a style is global or not
1902
1735
  // also, note that this check will be dead code eliminated in the browser
1903
- isBrowser$3 === false && cache.compat !== undefined) && cache.registered[className] === undefined) {
1736
+ isBrowser$2 === false && cache.compat !== undefined) && cache.registered[className] === undefined) {
1904
1737
  cache.registered[className] = serialized.styles;
1905
1738
  }
1906
1739
  };
@@ -1915,14 +1748,14 @@ var insertStyles = function insertStyles(cache, serialized, isStringTag) {
1915
1748
  do {
1916
1749
  var maybeStyles = cache.insert(serialized === current ? "." + className : '', current, cache.sheet, true);
1917
1750
 
1918
- if (!isBrowser$3 && maybeStyles !== undefined) {
1751
+ if (!isBrowser$2 && maybeStyles !== undefined) {
1919
1752
  stylesForSSR += maybeStyles;
1920
1753
  }
1921
1754
 
1922
1755
  current = current.next;
1923
1756
  } while (current !== undefined);
1924
1757
 
1925
- if (!isBrowser$3 && stylesForSSR.length !== 0) {
1758
+ if (!isBrowser$2 && stylesForSSR.length !== 0) {
1926
1759
  return stylesForSSR;
1927
1760
  }
1928
1761
  }
@@ -2016,6 +1849,7 @@ var unitlessKeys = {
2016
1849
  opacity: 1,
2017
1850
  order: 1,
2018
1851
  orphans: 1,
1852
+ scale: 1,
2019
1853
  tabSize: 1,
2020
1854
  widows: 1,
2021
1855
  zIndex: 1,
@@ -2040,8 +1874,8 @@ function memoize(fn) {
2040
1874
  };
2041
1875
  }
2042
1876
 
2043
- var ILLEGAL_ESCAPE_SEQUENCE_ERROR = "You have illegal escape sequence in your template literal, most likely inside content's property value.\nBecause you write your CSS inside a JavaScript string you actually have to do double escaping, so for example \"content: '\\00d7';\" should become \"content: '\\\\00d7';\".\nYou can read more about this here:\nhttps://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Template_literals#ES2018_revision_of_illegal_escape_sequences";
2044
- var UNDEFINED_AS_OBJECT_KEY_ERROR = "You have passed in falsy value as style object's key (can happen when in example you pass unexported component as computed key).";
1877
+ var isDevelopment$1 = false;
1878
+
2045
1879
  var hyphenateRegex = /[A-Z]|^ms/g;
2046
1880
  var animationRegex = /_EMO_([^_]+?)_([^]*?)_EMO_/g;
2047
1881
 
@@ -2082,34 +1916,6 @@ var processStyleValue = function processStyleValue(key, value) {
2082
1916
  return value;
2083
1917
  };
2084
1918
 
2085
- if (process.env.NODE_ENV !== 'production') {
2086
- var contentValuePattern = /(var|attr|counters?|url|element|(((repeating-)?(linear|radial))|conic)-gradient)\(|(no-)?(open|close)-quote/;
2087
- var contentValues = ['normal', 'none', 'initial', 'inherit', 'unset'];
2088
- var oldProcessStyleValue = processStyleValue;
2089
- var msPattern = /^-ms-/;
2090
- var hyphenPattern = /-(.)/g;
2091
- var hyphenatedCache = {};
2092
-
2093
- processStyleValue = function processStyleValue(key, value) {
2094
- if (key === 'content') {
2095
- if (typeof value !== 'string' || contentValues.indexOf(value) === -1 && !contentValuePattern.test(value) && (value.charAt(0) !== value.charAt(value.length - 1) || value.charAt(0) !== '"' && value.charAt(0) !== "'")) {
2096
- throw new Error("You seem to be using a value for 'content' without quotes, try replacing it with `content: '\"" + value + "\"'`");
2097
- }
2098
- }
2099
-
2100
- var processed = oldProcessStyleValue(key, value);
2101
-
2102
- if (processed !== '' && !isCustomProperty(key) && key.indexOf('-') !== -1 && hyphenatedCache[key] === undefined) {
2103
- hyphenatedCache[key] = true;
2104
- console.error("Using kebab-case for css properties in objects is not supported. Did you mean " + key.replace(msPattern, 'ms-').replace(hyphenPattern, function (str, _char) {
2105
- return _char.toUpperCase();
2106
- }) + "?");
2107
- }
2108
-
2109
- return processed;
2110
- };
2111
- }
2112
-
2113
1919
  var noComponentSelectorMessage = 'Component selectors can only be used in conjunction with ' + '@emotion/babel-plugin, the swc Emotion plugin, or another Emotion-aware ' + 'compiler transform.';
2114
1920
 
2115
1921
  function handleInterpolation(mergedProps, registered, interpolation) {
@@ -2117,12 +1923,11 @@ function handleInterpolation(mergedProps, registered, interpolation) {
2117
1923
  return '';
2118
1924
  }
2119
1925
 
2120
- if (interpolation.__emotion_styles !== undefined) {
2121
- if (process.env.NODE_ENV !== 'production' && interpolation.toString() === 'NO_COMPONENT_SELECTOR') {
2122
- throw new Error(noComponentSelectorMessage);
2123
- }
1926
+ var componentSelector = interpolation;
2124
1927
 
2125
- return interpolation;
1928
+ if (componentSelector.__emotion_styles !== undefined) {
1929
+
1930
+ return componentSelector;
2126
1931
  }
2127
1932
 
2128
1933
  switch (typeof interpolation) {
@@ -2133,17 +1938,21 @@ function handleInterpolation(mergedProps, registered, interpolation) {
2133
1938
 
2134
1939
  case 'object':
2135
1940
  {
2136
- if (interpolation.anim === 1) {
1941
+ var keyframes = interpolation;
1942
+
1943
+ if (keyframes.anim === 1) {
2137
1944
  cursor = {
2138
- name: interpolation.name,
2139
- styles: interpolation.styles,
1945
+ name: keyframes.name,
1946
+ styles: keyframes.styles,
2140
1947
  next: cursor
2141
1948
  };
2142
- return interpolation.name;
1949
+ return keyframes.name;
2143
1950
  }
2144
1951
 
2145
- if (interpolation.styles !== undefined) {
2146
- var next = interpolation.next;
1952
+ var serializedStyles = interpolation;
1953
+
1954
+ if (serializedStyles.styles !== undefined) {
1955
+ var next = serializedStyles.next;
2147
1956
 
2148
1957
  if (next !== undefined) {
2149
1958
  // not the most efficient thing ever but this is a pretty rare case
@@ -2158,12 +1967,7 @@ function handleInterpolation(mergedProps, registered, interpolation) {
2158
1967
  }
2159
1968
  }
2160
1969
 
2161
- var styles = interpolation.styles + ";";
2162
-
2163
- if (process.env.NODE_ENV !== 'production' && interpolation.map !== undefined) {
2164
- styles += interpolation.map;
2165
- }
2166
-
1970
+ var styles = serializedStyles.styles + ";";
2167
1971
  return styles;
2168
1972
  }
2169
1973
 
@@ -2177,37 +1981,21 @@ function handleInterpolation(mergedProps, registered, interpolation) {
2177
1981
  var result = interpolation(mergedProps);
2178
1982
  cursor = previousCursor;
2179
1983
  return handleInterpolation(mergedProps, registered, result);
2180
- } else if (process.env.NODE_ENV !== 'production') {
2181
- console.error('Functions that are interpolated in css calls will be stringified.\n' + 'If you want to have a css call based on props, create a function that returns a css call like this\n' + 'let dynamicStyle = (props) => css`color: ${props.color}`\n' + 'It can be called directly with props or interpolated in a styled call like this\n' + "let SomeComponent = styled('div')`${dynamicStyle}`");
2182
1984
  }
2183
1985
 
2184
1986
  break;
2185
1987
  }
2186
-
2187
- case 'string':
2188
- if (process.env.NODE_ENV !== 'production') {
2189
- var matched = [];
2190
- var replaced = interpolation.replace(animationRegex, function (match, p1, p2) {
2191
- var fakeVarName = "animation" + matched.length;
2192
- matched.push("const " + fakeVarName + " = keyframes`" + p2.replace(/^@keyframes animation-\w+/, '') + "`");
2193
- return "${" + fakeVarName + "}";
2194
- });
2195
-
2196
- if (matched.length) {
2197
- console.error('`keyframes` output got interpolated into plain string, please wrap it with `css`.\n\n' + 'Instead of doing this:\n\n' + [].concat(matched, ["`" + replaced + "`"]).join('\n') + '\n\nYou should wrap it with `css` like this:\n\n' + ("css`" + replaced + "`"));
2198
- }
2199
- }
2200
-
2201
- break;
2202
1988
  } // finalize string values (regular strings and functions interpolated into css calls)
2203
1989
 
2204
1990
 
1991
+ var asString = interpolation;
1992
+
2205
1993
  if (registered == null) {
2206
- return interpolation;
1994
+ return asString;
2207
1995
  }
2208
1996
 
2209
- var cached = registered[interpolation];
2210
- return cached !== undefined ? cached : interpolation;
1997
+ var cached = registered[asString];
1998
+ return cached !== undefined ? cached : asString;
2211
1999
  }
2212
2000
 
2213
2001
  function createStringFromObject(mergedProps, registered, obj) {
@@ -2218,44 +2006,43 @@ function createStringFromObject(mergedProps, registered, obj) {
2218
2006
  string += handleInterpolation(mergedProps, registered, obj[i]) + ";";
2219
2007
  }
2220
2008
  } else {
2221
- for (var _key in obj) {
2222
- var value = obj[_key];
2009
+ for (var key in obj) {
2010
+ var value = obj[key];
2223
2011
 
2224
2012
  if (typeof value !== 'object') {
2225
- if (registered != null && registered[value] !== undefined) {
2226
- string += _key + "{" + registered[value] + "}";
2227
- } else if (isProcessableValue(value)) {
2228
- string += processStyleName(_key) + ":" + processStyleValue(_key, value) + ";";
2013
+ var asString = value;
2014
+
2015
+ if (registered != null && registered[asString] !== undefined) {
2016
+ string += key + "{" + registered[asString] + "}";
2017
+ } else if (isProcessableValue(asString)) {
2018
+ string += processStyleName(key) + ":" + processStyleValue(key, asString) + ";";
2229
2019
  }
2230
2020
  } else {
2231
- if (_key === 'NO_COMPONENT_SELECTOR' && process.env.NODE_ENV !== 'production') {
2021
+ if (key === 'NO_COMPONENT_SELECTOR' && isDevelopment$1) {
2232
2022
  throw new Error(noComponentSelectorMessage);
2233
2023
  }
2234
2024
 
2235
2025
  if (Array.isArray(value) && typeof value[0] === 'string' && (registered == null || registered[value[0]] === undefined)) {
2236
2026
  for (var _i = 0; _i < value.length; _i++) {
2237
2027
  if (isProcessableValue(value[_i])) {
2238
- string += processStyleName(_key) + ":" + processStyleValue(_key, value[_i]) + ";";
2028
+ string += processStyleName(key) + ":" + processStyleValue(key, value[_i]) + ";";
2239
2029
  }
2240
2030
  }
2241
2031
  } else {
2242
2032
  var interpolated = handleInterpolation(mergedProps, registered, value);
2243
2033
 
2244
- switch (_key) {
2034
+ switch (key) {
2245
2035
  case 'animation':
2246
2036
  case 'animationName':
2247
2037
  {
2248
- string += processStyleName(_key) + ":" + interpolated + ";";
2038
+ string += processStyleName(key) + ":" + interpolated + ";";
2249
2039
  break;
2250
2040
  }
2251
2041
 
2252
2042
  default:
2253
2043
  {
2254
- if (process.env.NODE_ENV !== 'production' && _key === 'undefined') {
2255
- console.error(UNDEFINED_AS_OBJECT_KEY_ERROR);
2256
- }
2257
2044
 
2258
- string += _key + "{" + interpolated + "}";
2045
+ string += key + "{" + interpolated + "}";
2259
2046
  }
2260
2047
  }
2261
2048
  }
@@ -2266,17 +2053,11 @@ function createStringFromObject(mergedProps, registered, obj) {
2266
2053
  return string;
2267
2054
  }
2268
2055
 
2269
- var labelPattern = /label:\s*([^\s;\n{]+)\s*(;|$)/g;
2270
- var sourceMapPattern;
2271
-
2272
- if (process.env.NODE_ENV !== 'production') {
2273
- sourceMapPattern = /\/\*#\ssourceMappingURL=data:application\/json;\S+\s+\*\//g;
2274
- } // this is the cursor for keyframes
2056
+ var labelPattern = /label:\s*([^\s;{]+)\s*(;|$)/g; // this is the cursor for keyframes
2275
2057
  // keyframes are stored on the SerializedStyles object as a linked list
2276
2058
 
2277
-
2278
2059
  var cursor;
2279
- var serializeStyles = function serializeStyles(args, registered, mergedProps) {
2060
+ function serializeStyles(args, registered, mergedProps) {
2280
2061
  if (args.length === 1 && typeof args[0] === 'object' && args[0] !== null && args[0].styles !== undefined) {
2281
2062
  return args[0];
2282
2063
  }
@@ -2290,11 +2071,9 @@ var serializeStyles = function serializeStyles(args, registered, mergedProps) {
2290
2071
  stringMode = false;
2291
2072
  styles += handleInterpolation(mergedProps, registered, strings);
2292
2073
  } else {
2293
- if (process.env.NODE_ENV !== 'production' && strings[0] === undefined) {
2294
- console.error(ILLEGAL_ESCAPE_SEQUENCE_ERROR);
2295
- }
2074
+ var asTemplateStringsArr = strings;
2296
2075
 
2297
- styles += strings[0];
2076
+ styles += asTemplateStringsArr[0];
2298
2077
  } // we start at 1 since we've already handled the first arg
2299
2078
 
2300
2079
 
@@ -2302,21 +2081,10 @@ var serializeStyles = function serializeStyles(args, registered, mergedProps) {
2302
2081
  styles += handleInterpolation(mergedProps, registered, args[i]);
2303
2082
 
2304
2083
  if (stringMode) {
2305
- if (process.env.NODE_ENV !== 'production' && strings[i] === undefined) {
2306
- console.error(ILLEGAL_ESCAPE_SEQUENCE_ERROR);
2307
- }
2084
+ var templateStringsArr = strings;
2308
2085
 
2309
- styles += strings[i];
2086
+ styles += templateStringsArr[i];
2310
2087
  }
2311
- }
2312
-
2313
- var sourceMap;
2314
-
2315
- if (process.env.NODE_ENV !== 'production') {
2316
- styles = styles.replace(sourceMapPattern, function (match) {
2317
- sourceMap = match;
2318
- return '';
2319
- });
2320
2088
  } // using a global regex with .exec is stateful so lastIndex has to be reset each time
2321
2089
 
2322
2090
 
@@ -2325,44 +2093,30 @@ var serializeStyles = function serializeStyles(args, registered, mergedProps) {
2325
2093
  var match; // https://esbench.com/bench/5b809c2cf2949800a0f61fb5
2326
2094
 
2327
2095
  while ((match = labelPattern.exec(styles)) !== null) {
2328
- identifierName += '-' + // $FlowFixMe we know it's not null
2329
- match[1];
2096
+ identifierName += '-' + match[1];
2330
2097
  }
2331
2098
 
2332
2099
  var name = murmur2(styles) + identifierName;
2333
2100
 
2334
- if (process.env.NODE_ENV !== 'production') {
2335
- // $FlowFixMe SerializedStyles type doesn't have toString property (and we don't want to add it)
2336
- return {
2337
- name: name,
2338
- styles: styles,
2339
- map: sourceMap,
2340
- next: cursor,
2341
- toString: function toString() {
2342
- return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop).";
2343
- }
2344
- };
2345
- }
2346
-
2347
2101
  return {
2348
2102
  name: name,
2349
2103
  styles: styles,
2350
2104
  next: cursor
2351
2105
  };
2352
- };
2106
+ }
2353
2107
 
2354
- var isBrowser$2 = typeof document !== 'undefined';
2108
+ var isBrowser$1 = typeof document !== 'undefined';
2355
2109
 
2356
2110
  var syncFallback = function syncFallback(create) {
2357
2111
  return create();
2358
2112
  };
2359
2113
 
2360
2114
  var useInsertionEffect = React__namespace['useInsertion' + 'Effect'] ? React__namespace['useInsertion' + 'Effect'] : false;
2361
- var useInsertionEffectAlwaysWithSyncFallback = !isBrowser$2 ? syncFallback : useInsertionEffect || syncFallback;
2362
- var useInsertionEffectWithLayoutFallback = useInsertionEffect || React__namespace.useLayoutEffect;
2115
+ var useInsertionEffectAlwaysWithSyncFallback = !isBrowser$1 ? syncFallback : useInsertionEffect || syncFallback;
2363
2116
 
2364
- var isBrowser$1 = typeof document !== 'undefined';
2365
- var hasOwnProperty = {}.hasOwnProperty;
2117
+ var isDevelopment = false;
2118
+
2119
+ var isBrowser = typeof document !== 'undefined';
2366
2120
 
2367
2121
  var EmotionCacheContext = /* #__PURE__ */React__namespace.createContext( // we're doing this to avoid preconstruct's dead code elimination in this one case
2368
2122
  // because this module is primarily intended for the browser and node
@@ -2374,14 +2128,9 @@ typeof HTMLElement !== 'undefined' ? /* #__PURE__ */createCache({
2374
2128
  key: 'css'
2375
2129
  }) : null);
2376
2130
 
2377
- if (process.env.NODE_ENV !== 'production') {
2378
- EmotionCacheContext.displayName = 'EmotionCacheContext';
2379
- }
2380
-
2381
2131
  EmotionCacheContext.Provider;
2382
2132
 
2383
2133
  var withEmotionCache = function withEmotionCache(func) {
2384
- // $FlowFixMe
2385
2134
  return /*#__PURE__*/React.forwardRef(function (props, ref) {
2386
2135
  // the cache will never be null in the browser
2387
2136
  var cache = React.useContext(EmotionCacheContext);
@@ -2389,7 +2138,7 @@ var withEmotionCache = function withEmotionCache(func) {
2389
2138
  });
2390
2139
  };
2391
2140
 
2392
- if (!isBrowser$1) {
2141
+ if (!isBrowser) {
2393
2142
  withEmotionCache = function withEmotionCache(func) {
2394
2143
  return function (props) {
2395
2144
  var cache = React.useContext(EmotionCacheContext);
@@ -2415,81 +2164,25 @@ if (!isBrowser$1) {
2415
2164
 
2416
2165
  var ThemeContext = /* #__PURE__ */React__namespace.createContext({});
2417
2166
 
2418
- if (process.env.NODE_ENV !== 'production') {
2419
- ThemeContext.displayName = 'EmotionThemeContext';
2420
- }
2421
-
2422
- var getLastPart = function getLastPart(functionName) {
2423
- // The match may be something like 'Object.createEmotionProps' or
2424
- // 'Loader.prototype.render'
2425
- var parts = functionName.split('.');
2426
- return parts[parts.length - 1];
2427
- };
2428
-
2429
- var getFunctionNameFromStackTraceLine = function getFunctionNameFromStackTraceLine(line) {
2430
- // V8
2431
- var match = /^\s+at\s+([A-Za-z0-9$.]+)\s/.exec(line);
2432
- if (match) return getLastPart(match[1]); // Safari / Firefox
2433
-
2434
- match = /^([A-Za-z0-9$.]+)@/.exec(line);
2435
- if (match) return getLastPart(match[1]);
2436
- return undefined;
2437
- };
2438
-
2439
- var internalReactFunctionNames = /* #__PURE__ */new Set(['renderWithHooks', 'processChild', 'finishClassComponent', 'renderToString']); // These identifiers come from error stacks, so they have to be valid JS
2440
- // identifiers, thus we only need to replace what is a valid character for JS,
2441
- // but not for CSS.
2442
-
2443
- var sanitizeIdentifier = function sanitizeIdentifier(identifier) {
2444
- return identifier.replace(/\$/g, '-');
2445
- };
2446
-
2447
- var getLabelFromStackTrace = function getLabelFromStackTrace(stackTrace) {
2448
- if (!stackTrace) return undefined;
2449
- var lines = stackTrace.split('\n');
2450
-
2451
- for (var i = 0; i < lines.length; i++) {
2452
- var functionName = getFunctionNameFromStackTraceLine(lines[i]); // The first line of V8 stack traces is just "Error"
2453
-
2454
- if (!functionName) continue; // If we reach one of these, we have gone too far and should quit
2455
-
2456
- if (internalReactFunctionNames.has(functionName)) break; // The component name is the first function in the stack that starts with an
2457
- // uppercase letter
2458
-
2459
- if (/^[A-Z]/.test(functionName)) return sanitizeIdentifier(functionName);
2460
- }
2461
-
2462
- return undefined;
2463
- };
2167
+ var hasOwn = {}.hasOwnProperty;
2464
2168
 
2465
2169
  var typePropName = '__EMOTION_TYPE_PLEASE_DO_NOT_USE__';
2466
- var labelPropName = '__EMOTION_LABEL_PLEASE_DO_NOT_USE__';
2467
2170
  var createEmotionProps = function createEmotionProps(type, props) {
2468
- if (process.env.NODE_ENV !== 'production' && typeof props.css === 'string' && // check if there is a css declaration
2469
- props.css.indexOf(':') !== -1) {
2470
- throw new Error("Strings are not allowed as css prop values, please wrap it in a css template literal from '@emotion/react' like this: css`" + props.css + "`");
2471
- }
2472
2171
 
2473
2172
  var newProps = {};
2474
2173
 
2475
- for (var key in props) {
2476
- if (hasOwnProperty.call(props, key)) {
2477
- newProps[key] = props[key];
2174
+ for (var _key in props) {
2175
+ if (hasOwn.call(props, _key)) {
2176
+ newProps[_key] = props[_key];
2478
2177
  }
2479
2178
  }
2480
2179
 
2481
- newProps[typePropName] = type; // For performance, only call getLabelFromStackTrace in development and when
2482
- // the label hasn't already been computed
2483
-
2484
- if (process.env.NODE_ENV !== 'production' && !!props.css && (typeof props.css !== 'object' || typeof props.css.name !== 'string' || props.css.name.indexOf('-') === -1)) {
2485
- var label = getLabelFromStackTrace(new Error().stack);
2486
- if (label) newProps[labelPropName] = label;
2487
- }
2180
+ newProps[typePropName] = type; // Runtime labeling is an opt-in feature because:
2488
2181
 
2489
2182
  return newProps;
2490
2183
  };
2491
2184
 
2492
- var Insertion$1 = function Insertion(_ref) {
2185
+ var Insertion = function Insertion(_ref) {
2493
2186
  var cache = _ref.cache,
2494
2187
  serialized = _ref.serialized,
2495
2188
  isStringTag = _ref.isStringTag;
@@ -2498,7 +2191,7 @@ var Insertion$1 = function Insertion(_ref) {
2498
2191
  return insertStyles(cache, serialized, isStringTag);
2499
2192
  });
2500
2193
 
2501
- if (!isBrowser$1 && rules !== undefined) {
2194
+ if (!isBrowser && rules !== undefined) {
2502
2195
  var _ref2;
2503
2196
 
2504
2197
  var serializedNames = serialized.name;
@@ -2538,175 +2231,35 @@ var Emotion = /* #__PURE__ */withEmotionCache(function (props, cache, ref) {
2538
2231
 
2539
2232
  var serialized = serializeStyles(registeredStyles, undefined, React__namespace.useContext(ThemeContext));
2540
2233
 
2541
- if (process.env.NODE_ENV !== 'production' && serialized.name.indexOf('-') === -1) {
2542
- var labelFromStack = props[labelPropName];
2543
-
2544
- if (labelFromStack) {
2545
- serialized = serializeStyles([serialized, 'label:' + labelFromStack + ';']);
2546
- }
2547
- }
2548
-
2549
2234
  className += cache.key + "-" + serialized.name;
2550
2235
  var newProps = {};
2551
2236
 
2552
- for (var key in props) {
2553
- if (hasOwnProperty.call(props, key) && key !== 'css' && key !== typePropName && (process.env.NODE_ENV === 'production' || key !== labelPropName)) {
2554
- newProps[key] = props[key];
2237
+ for (var _key2 in props) {
2238
+ if (hasOwn.call(props, _key2) && _key2 !== 'css' && _key2 !== typePropName && (!isDevelopment )) {
2239
+ newProps[_key2] = props[_key2];
2555
2240
  }
2556
2241
  }
2557
2242
 
2558
- newProps.ref = ref;
2559
2243
  newProps.className = className;
2560
- return /*#__PURE__*/React__namespace.createElement(React__namespace.Fragment, null, /*#__PURE__*/React__namespace.createElement(Insertion$1, {
2244
+
2245
+ if (ref) {
2246
+ newProps.ref = ref;
2247
+ }
2248
+
2249
+ return /*#__PURE__*/React__namespace.createElement(React__namespace.Fragment, null, /*#__PURE__*/React__namespace.createElement(Insertion, {
2561
2250
  cache: cache,
2562
2251
  serialized: serialized,
2563
2252
  isStringTag: typeof WrappedComponent === 'string'
2564
2253
  }), /*#__PURE__*/React__namespace.createElement(WrappedComponent, newProps));
2565
2254
  });
2566
2255
 
2567
- if (process.env.NODE_ENV !== 'production') {
2568
- Emotion.displayName = 'EmotionCssPropInternal';
2569
- }
2570
-
2571
2256
  var Emotion$1 = Emotion;
2572
2257
 
2573
- var pkg = {
2574
- name: "@emotion/react",
2575
- version: "11.11.1",
2576
- main: "dist/emotion-react.cjs.js",
2577
- module: "dist/emotion-react.esm.js",
2578
- browser: {
2579
- "./dist/emotion-react.esm.js": "./dist/emotion-react.browser.esm.js"
2580
- },
2581
- exports: {
2582
- ".": {
2583
- module: {
2584
- worker: "./dist/emotion-react.worker.esm.js",
2585
- browser: "./dist/emotion-react.browser.esm.js",
2586
- "default": "./dist/emotion-react.esm.js"
2587
- },
2588
- "import": "./dist/emotion-react.cjs.mjs",
2589
- "default": "./dist/emotion-react.cjs.js"
2590
- },
2591
- "./jsx-runtime": {
2592
- module: {
2593
- worker: "./jsx-runtime/dist/emotion-react-jsx-runtime.worker.esm.js",
2594
- browser: "./jsx-runtime/dist/emotion-react-jsx-runtime.browser.esm.js",
2595
- "default": "./jsx-runtime/dist/emotion-react-jsx-runtime.esm.js"
2596
- },
2597
- "import": "./jsx-runtime/dist/emotion-react-jsx-runtime.cjs.mjs",
2598
- "default": "./jsx-runtime/dist/emotion-react-jsx-runtime.cjs.js"
2599
- },
2600
- "./_isolated-hnrs": {
2601
- module: {
2602
- worker: "./_isolated-hnrs/dist/emotion-react-_isolated-hnrs.worker.esm.js",
2603
- browser: "./_isolated-hnrs/dist/emotion-react-_isolated-hnrs.browser.esm.js",
2604
- "default": "./_isolated-hnrs/dist/emotion-react-_isolated-hnrs.esm.js"
2605
- },
2606
- "import": "./_isolated-hnrs/dist/emotion-react-_isolated-hnrs.cjs.mjs",
2607
- "default": "./_isolated-hnrs/dist/emotion-react-_isolated-hnrs.cjs.js"
2608
- },
2609
- "./jsx-dev-runtime": {
2610
- module: {
2611
- worker: "./jsx-dev-runtime/dist/emotion-react-jsx-dev-runtime.worker.esm.js",
2612
- browser: "./jsx-dev-runtime/dist/emotion-react-jsx-dev-runtime.browser.esm.js",
2613
- "default": "./jsx-dev-runtime/dist/emotion-react-jsx-dev-runtime.esm.js"
2614
- },
2615
- "import": "./jsx-dev-runtime/dist/emotion-react-jsx-dev-runtime.cjs.mjs",
2616
- "default": "./jsx-dev-runtime/dist/emotion-react-jsx-dev-runtime.cjs.js"
2617
- },
2618
- "./package.json": "./package.json",
2619
- "./types/css-prop": "./types/css-prop.d.ts",
2620
- "./macro": {
2621
- types: {
2622
- "import": "./macro.d.mts",
2623
- "default": "./macro.d.ts"
2624
- },
2625
- "default": "./macro.js"
2626
- }
2627
- },
2628
- types: "types/index.d.ts",
2629
- files: [
2630
- "src",
2631
- "dist",
2632
- "jsx-runtime",
2633
- "jsx-dev-runtime",
2634
- "_isolated-hnrs",
2635
- "types/*.d.ts",
2636
- "macro.*"
2637
- ],
2638
- sideEffects: false,
2639
- author: "Emotion Contributors",
2640
- license: "MIT",
2641
- scripts: {
2642
- "test:typescript": "dtslint types"
2643
- },
2644
- dependencies: {
2645
- "@babel/runtime": "^7.18.3",
2646
- "@emotion/babel-plugin": "^11.11.0",
2647
- "@emotion/cache": "^11.11.0",
2648
- "@emotion/serialize": "^1.1.2",
2649
- "@emotion/use-insertion-effect-with-fallbacks": "^1.0.1",
2650
- "@emotion/utils": "^1.2.1",
2651
- "@emotion/weak-memoize": "^0.3.1",
2652
- "hoist-non-react-statics": "^3.3.1"
2653
- },
2654
- peerDependencies: {
2655
- react: ">=16.8.0"
2656
- },
2657
- peerDependenciesMeta: {
2658
- "@types/react": {
2659
- optional: true
2660
- }
2661
- },
2662
- devDependencies: {
2663
- "@definitelytyped/dtslint": "0.0.112",
2664
- "@emotion/css": "11.11.0",
2665
- "@emotion/css-prettifier": "1.1.3",
2666
- "@emotion/server": "11.11.0",
2667
- "@emotion/styled": "11.11.0",
2668
- "html-tag-names": "^1.1.2",
2669
- react: "16.14.0",
2670
- "svg-tag-names": "^1.1.1",
2671
- typescript: "^4.5.5"
2672
- },
2673
- repository: "https://github.com/emotion-js/emotion/tree/main/packages/react",
2674
- publishConfig: {
2675
- access: "public"
2676
- },
2677
- "umd:main": "dist/emotion-react.umd.min.js",
2678
- preconstruct: {
2679
- entrypoints: [
2680
- "./index.js",
2681
- "./jsx-runtime.js",
2682
- "./jsx-dev-runtime.js",
2683
- "./_isolated-hnrs.js"
2684
- ],
2685
- umdName: "emotionReact",
2686
- exports: {
2687
- envConditions: [
2688
- "browser",
2689
- "worker"
2690
- ],
2691
- extra: {
2692
- "./types/css-prop": "./types/css-prop.d.ts",
2693
- "./macro": {
2694
- types: {
2695
- "import": "./macro.d.mts",
2696
- "default": "./macro.d.ts"
2697
- },
2698
- "default": "./macro.js"
2699
- }
2700
- }
2701
- }
2702
- }
2703
- };
2704
-
2705
2258
  var jsx = function jsx(type, props) {
2259
+ // eslint-disable-next-line prefer-rest-params
2706
2260
  var args = arguments;
2707
2261
 
2708
- if (props == null || !hasOwnProperty.call(props, 'css')) {
2709
- // $FlowFixMe
2262
+ if (props == null || !hasOwn.call(props, 'css')) {
2710
2263
  return React__namespace.createElement.apply(undefined, args);
2711
2264
  }
2712
2265
 
@@ -2717,121 +2270,16 @@ var jsx = function jsx(type, props) {
2717
2270
 
2718
2271
  for (var i = 2; i < argsLength; i++) {
2719
2272
  createElementArgArray[i] = args[i];
2720
- } // $FlowFixMe
2721
-
2273
+ }
2722
2274
 
2723
2275
  return React__namespace.createElement.apply(null, createElementArgArray);
2724
2276
  };
2725
2277
 
2726
- var warnedAboutCssPropForGlobal = false; // maintain place over rerenders.
2727
- // initial render from browser, insertBefore context.sheet.tags[0] or if a style hasn't been inserted there yet, appendChild
2728
- // initial client-side render from SSR, use place of hydrating tag
2729
-
2730
- var Global = /* #__PURE__ */withEmotionCache(function (props, cache) {
2731
- if (process.env.NODE_ENV !== 'production' && !warnedAboutCssPropForGlobal && ( // check for className as well since the user is
2732
- // probably using the custom createElement which
2733
- // means it will be turned into a className prop
2734
- // $FlowFixMe I don't really want to add it to the type since it shouldn't be used
2735
- props.className || props.css)) {
2736
- console.error("It looks like you're using the css prop on Global, did you mean to use the styles prop instead?");
2737
- warnedAboutCssPropForGlobal = true;
2738
- }
2739
-
2740
- var styles = props.styles;
2741
- var serialized = serializeStyles([styles], undefined, React__namespace.useContext(ThemeContext));
2742
-
2743
- if (!isBrowser$1) {
2744
- var _ref;
2745
-
2746
- var serializedNames = serialized.name;
2747
- var serializedStyles = serialized.styles;
2748
- var next = serialized.next;
2749
-
2750
- while (next !== undefined) {
2751
- serializedNames += ' ' + next.name;
2752
- serializedStyles += next.styles;
2753
- next = next.next;
2754
- }
2755
-
2756
- var shouldCache = cache.compat === true;
2757
- var rules = cache.insert("", {
2758
- name: serializedNames,
2759
- styles: serializedStyles
2760
- }, cache.sheet, shouldCache);
2761
-
2762
- if (shouldCache) {
2763
- return null;
2764
- }
2278
+ (function (_jsx) {
2279
+ var JSX;
2765
2280
 
2766
- return /*#__PURE__*/React__namespace.createElement("style", (_ref = {}, _ref["data-emotion"] = cache.key + "-global " + serializedNames, _ref.dangerouslySetInnerHTML = {
2767
- __html: rules
2768
- }, _ref.nonce = cache.sheet.nonce, _ref));
2769
- } // yes, i know these hooks are used conditionally
2770
- // but it is based on a constant that will never change at runtime
2771
- // it's effectively like having two implementations and switching them out
2772
- // so it's not actually breaking anything
2773
-
2774
-
2775
- var sheetRef = React__namespace.useRef();
2776
- useInsertionEffectWithLayoutFallback(function () {
2777
- var key = cache.key + "-global"; // use case of https://github.com/emotion-js/emotion/issues/2675
2778
-
2779
- var sheet = new cache.sheet.constructor({
2780
- key: key,
2781
- nonce: cache.sheet.nonce,
2782
- container: cache.sheet.container,
2783
- speedy: cache.sheet.isSpeedy
2784
- });
2785
- var rehydrating = false; // $FlowFixMe
2786
-
2787
- var node = document.querySelector("style[data-emotion=\"" + key + " " + serialized.name + "\"]");
2788
-
2789
- if (cache.sheet.tags.length) {
2790
- sheet.before = cache.sheet.tags[0];
2791
- }
2792
-
2793
- if (node !== null) {
2794
- rehydrating = true; // clear the hash so this node won't be recognizable as rehydratable by other <Global/>s
2795
-
2796
- node.setAttribute('data-emotion', key);
2797
- sheet.hydrate([node]);
2798
- }
2799
-
2800
- sheetRef.current = [sheet, rehydrating];
2801
- return function () {
2802
- sheet.flush();
2803
- };
2804
- }, [cache]);
2805
- useInsertionEffectWithLayoutFallback(function () {
2806
- var sheetRefCurrent = sheetRef.current;
2807
- var sheet = sheetRefCurrent[0],
2808
- rehydrating = sheetRefCurrent[1];
2809
-
2810
- if (rehydrating) {
2811
- sheetRefCurrent[1] = false;
2812
- return;
2813
- }
2814
-
2815
- if (serialized.next !== undefined) {
2816
- // insert keyframes
2817
- insertStyles(cache, serialized.next, true);
2818
- }
2819
-
2820
- if (sheet.tags.length) {
2821
- // if this doesn't exist then it will be null so the style element will be appended
2822
- var element = sheet.tags[sheet.tags.length - 1].nextElementSibling;
2823
- sheet.before = element;
2824
- sheet.flush();
2825
- }
2826
-
2827
- cache.insert("", serialized, sheet, false);
2828
- }, [cache, serialized.name]);
2829
- return null;
2830
- });
2831
-
2832
- if (process.env.NODE_ENV !== 'production') {
2833
- Global.displayName = 'EmotionGlobal';
2834
- }
2281
+ (function (_JSX) {})(JSX || (JSX = _jsx.JSX || (_jsx.JSX = {})));
2282
+ })(jsx || (jsx = {}));
2835
2283
 
2836
2284
  function css$2() {
2837
2285
  for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
@@ -2841,10 +2289,9 @@ function css$2() {
2841
2289
  return serializeStyles(args);
2842
2290
  }
2843
2291
 
2844
- var keyframes = function keyframes() {
2292
+ function keyframes() {
2845
2293
  var insertable = css$2.apply(void 0, arguments);
2846
- var name = "animation-" + insertable.name; // $FlowFixMe
2847
-
2294
+ var name = "animation-" + insertable.name;
2848
2295
  return {
2849
2296
  name: name,
2850
2297
  styles: "@keyframes " + name + "{" + insertable.styles + "}",
@@ -2853,169 +2300,6 @@ var keyframes = function keyframes() {
2853
2300
  return "_EMO_" + this.name + "_" + this.styles + "_EMO_";
2854
2301
  }
2855
2302
  };
2856
- };
2857
-
2858
- var classnames = function classnames(args) {
2859
- var len = args.length;
2860
- var i = 0;
2861
- var cls = '';
2862
-
2863
- for (; i < len; i++) {
2864
- var arg = args[i];
2865
- if (arg == null) continue;
2866
- var toAdd = void 0;
2867
-
2868
- switch (typeof arg) {
2869
- case 'boolean':
2870
- break;
2871
-
2872
- case 'object':
2873
- {
2874
- if (Array.isArray(arg)) {
2875
- toAdd = classnames(arg);
2876
- } else {
2877
- if (process.env.NODE_ENV !== 'production' && arg.styles !== undefined && arg.name !== undefined) {
2878
- console.error('You have passed styles created with `css` from `@emotion/react` package to the `cx`.\n' + '`cx` is meant to compose class names (strings) so you should convert those styles to a class name by passing them to the `css` received from <ClassNames/> component.');
2879
- }
2880
-
2881
- toAdd = '';
2882
-
2883
- for (var k in arg) {
2884
- if (arg[k] && k) {
2885
- toAdd && (toAdd += ' ');
2886
- toAdd += k;
2887
- }
2888
- }
2889
- }
2890
-
2891
- break;
2892
- }
2893
-
2894
- default:
2895
- {
2896
- toAdd = arg;
2897
- }
2898
- }
2899
-
2900
- if (toAdd) {
2901
- cls && (cls += ' ');
2902
- cls += toAdd;
2903
- }
2904
- }
2905
-
2906
- return cls;
2907
- };
2908
-
2909
- function merge(registered, css, className) {
2910
- var registeredStyles = [];
2911
- var rawClassName = getRegisteredStyles(registered, registeredStyles, className);
2912
-
2913
- if (registeredStyles.length < 2) {
2914
- return className;
2915
- }
2916
-
2917
- return rawClassName + css(registeredStyles);
2918
- }
2919
-
2920
- var Insertion = function Insertion(_ref) {
2921
- var cache = _ref.cache,
2922
- serializedArr = _ref.serializedArr;
2923
- var rules = useInsertionEffectAlwaysWithSyncFallback(function () {
2924
- var rules = '';
2925
-
2926
- for (var i = 0; i < serializedArr.length; i++) {
2927
- var res = insertStyles(cache, serializedArr[i], false);
2928
-
2929
- if (!isBrowser$1 && res !== undefined) {
2930
- rules += res;
2931
- }
2932
- }
2933
-
2934
- if (!isBrowser$1) {
2935
- return rules;
2936
- }
2937
- });
2938
-
2939
- if (!isBrowser$1 && rules.length !== 0) {
2940
- var _ref2;
2941
-
2942
- return /*#__PURE__*/React__namespace.createElement("style", (_ref2 = {}, _ref2["data-emotion"] = cache.key + " " + serializedArr.map(function (serialized) {
2943
- return serialized.name;
2944
- }).join(' '), _ref2.dangerouslySetInnerHTML = {
2945
- __html: rules
2946
- }, _ref2.nonce = cache.sheet.nonce, _ref2));
2947
- }
2948
-
2949
- return null;
2950
- };
2951
-
2952
- var ClassNames = /* #__PURE__ */withEmotionCache(function (props, cache) {
2953
- var hasRendered = false;
2954
- var serializedArr = [];
2955
-
2956
- var css = function css() {
2957
- if (hasRendered && process.env.NODE_ENV !== 'production') {
2958
- throw new Error('css can only be used during render');
2959
- }
2960
-
2961
- for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
2962
- args[_key] = arguments[_key];
2963
- }
2964
-
2965
- var serialized = serializeStyles(args, cache.registered);
2966
- serializedArr.push(serialized); // registration has to happen here as the result of this might get consumed by `cx`
2967
-
2968
- registerStyles(cache, serialized, false);
2969
- return cache.key + "-" + serialized.name;
2970
- };
2971
-
2972
- var cx = function cx() {
2973
- if (hasRendered && process.env.NODE_ENV !== 'production') {
2974
- throw new Error('cx can only be used during render');
2975
- }
2976
-
2977
- for (var _len2 = arguments.length, args = new Array(_len2), _key2 = 0; _key2 < _len2; _key2++) {
2978
- args[_key2] = arguments[_key2];
2979
- }
2980
-
2981
- return merge(cache.registered, css, classnames(args));
2982
- };
2983
-
2984
- var content = {
2985
- css: css,
2986
- cx: cx,
2987
- theme: React__namespace.useContext(ThemeContext)
2988
- };
2989
- var ele = props.children(content);
2990
- hasRendered = true;
2991
- return /*#__PURE__*/React__namespace.createElement(React__namespace.Fragment, null, /*#__PURE__*/React__namespace.createElement(Insertion, {
2992
- cache: cache,
2993
- serializedArr: serializedArr
2994
- }), ele);
2995
- });
2996
-
2997
- if (process.env.NODE_ENV !== 'production') {
2998
- ClassNames.displayName = 'EmotionClassNames';
2999
- }
3000
-
3001
- if (process.env.NODE_ENV !== 'production') {
3002
- var isBrowser = typeof document !== 'undefined'; // #1727, #2905 for some reason Jest and Vitest evaluate modules twice if some consuming module gets mocked
3003
-
3004
- var isTestEnv = typeof jest !== 'undefined' || typeof vi !== 'undefined';
3005
-
3006
- if (isBrowser && !isTestEnv) {
3007
- // globalThis has wide browser support - https://caniuse.com/?search=globalThis, Node.js 12 and later
3008
- var globalContext = // $FlowIgnore
3009
- typeof globalThis !== 'undefined' ? globalThis // eslint-disable-line no-undef
3010
- : isBrowser ? window : global;
3011
- var globalKey = "__EMOTION_REACT_" + pkg.version.split('.')[0] + "__";
3012
-
3013
- if (globalContext[globalKey]) {
3014
- console.warn('You are loading @emotion/react when it is already loaded. Running ' + 'multiple instances may cause problems. This can happen if multiple ' + 'versions are used, or if multiple builds of the same version are ' + 'used.');
3015
- }
3016
-
3017
- globalContext[globalKey] = true;
3018
- }
3019
2303
  }
3020
2304
 
3021
2305
  function _arrayWithHoles(arr) {
@@ -3106,6 +2390,10 @@ function _taggedTemplateLiteral(strings, raw) {
3106
2390
  }));
3107
2391
  }
3108
2392
 
2393
+ /**
2394
+ * Custom positioning reference element.
2395
+ * @see https://floating-ui.com/docs/virtual-elements
2396
+ */
3109
2397
  const min = Math.min;
3110
2398
  const max = Math.max;
3111
2399
  const round = Math.round;
@@ -3115,15 +2403,27 @@ const createCoords = v => ({
3115
2403
  y: v
3116
2404
  });
3117
2405
  function rectToClientRect(rect) {
2406
+ const {
2407
+ x,
2408
+ y,
2409
+ width,
2410
+ height
2411
+ } = rect;
3118
2412
  return {
3119
- ...rect,
3120
- top: rect.y,
3121
- left: rect.x,
3122
- right: rect.x + rect.width,
3123
- bottom: rect.y + rect.height
2413
+ width,
2414
+ height,
2415
+ top: y,
2416
+ left: x,
2417
+ right: x + width,
2418
+ bottom: y + height,
2419
+ x,
2420
+ y
3124
2421
  };
3125
2422
  }
3126
2423
 
2424
+ function hasWindow() {
2425
+ return typeof window !== 'undefined';
2426
+ }
3127
2427
  function getNodeName(node) {
3128
2428
  if (isNode(node)) {
3129
2429
  return (node.nodeName || '').toLowerCase();
@@ -3135,28 +2435,37 @@ function getNodeName(node) {
3135
2435
  }
3136
2436
  function getWindow(node) {
3137
2437
  var _node$ownerDocument;
3138
- return (node == null ? void 0 : (_node$ownerDocument = node.ownerDocument) == null ? void 0 : _node$ownerDocument.defaultView) || window;
2438
+ return (node == null || (_node$ownerDocument = node.ownerDocument) == null ? void 0 : _node$ownerDocument.defaultView) || window;
3139
2439
  }
3140
2440
  function getDocumentElement(node) {
3141
2441
  var _ref;
3142
2442
  return (_ref = (isNode(node) ? node.ownerDocument : node.document) || window.document) == null ? void 0 : _ref.documentElement;
3143
2443
  }
3144
2444
  function isNode(value) {
2445
+ if (!hasWindow()) {
2446
+ return false;
2447
+ }
3145
2448
  return value instanceof Node || value instanceof getWindow(value).Node;
3146
2449
  }
3147
2450
  function isElement(value) {
2451
+ if (!hasWindow()) {
2452
+ return false;
2453
+ }
3148
2454
  return value instanceof Element || value instanceof getWindow(value).Element;
3149
2455
  }
3150
2456
  function isHTMLElement(value) {
2457
+ if (!hasWindow()) {
2458
+ return false;
2459
+ }
3151
2460
  return value instanceof HTMLElement || value instanceof getWindow(value).HTMLElement;
3152
2461
  }
3153
2462
  function isShadowRoot(value) {
3154
- // Browsers without `ShadowRoot` support.
3155
- if (typeof ShadowRoot === 'undefined') {
2463
+ if (!hasWindow() || typeof ShadowRoot === 'undefined') {
3156
2464
  return false;
3157
2465
  }
3158
2466
  return value instanceof ShadowRoot || value instanceof getWindow(value).ShadowRoot;
3159
2467
  }
2468
+ const invalidOverflowDisplayValues = /*#__PURE__*/new Set(['inline', 'contents']);
3160
2469
  function isOverflowElement(element) {
3161
2470
  const {
3162
2471
  overflow,
@@ -3164,14 +2473,15 @@ function isOverflowElement(element) {
3164
2473
  overflowY,
3165
2474
  display
3166
2475
  } = getComputedStyle$1(element);
3167
- return /auto|scroll|overlay|hidden|clip/.test(overflow + overflowY + overflowX) && !['inline', 'contents'].includes(display);
2476
+ return /auto|scroll|overlay|hidden|clip/.test(overflow + overflowY + overflowX) && !invalidOverflowDisplayValues.has(display);
3168
2477
  }
3169
2478
  function isWebKit() {
3170
2479
  if (typeof CSS === 'undefined' || !CSS.supports) return false;
3171
2480
  return CSS.supports('-webkit-backdrop-filter', 'none');
3172
2481
  }
2482
+ const lastTraversableNodeNames = /*#__PURE__*/new Set(['html', 'body', '#document']);
3173
2483
  function isLastTraversableNode(node) {
3174
- return ['html', 'body', '#document'].includes(getNodeName(node));
2484
+ return lastTraversableNodeNames.has(getNodeName(node));
3175
2485
  }
3176
2486
  function getComputedStyle$1(element) {
3177
2487
  return getWindow(element).getComputedStyle(element);
@@ -3213,10 +2523,14 @@ function getOverflowAncestors(node, list, traverseIframes) {
3213
2523
  const isBody = scrollableAncestor === ((_node$ownerDocument2 = node.ownerDocument) == null ? void 0 : _node$ownerDocument2.body);
3214
2524
  const win = getWindow(scrollableAncestor);
3215
2525
  if (isBody) {
3216
- return list.concat(win, win.visualViewport || [], isOverflowElement(scrollableAncestor) ? scrollableAncestor : [], win.frameElement && traverseIframes ? getOverflowAncestors(win.frameElement) : []);
2526
+ const frameElement = getFrameElement(win);
2527
+ return list.concat(win, win.visualViewport || [], isOverflowElement(scrollableAncestor) ? scrollableAncestor : [], frameElement && traverseIframes ? getOverflowAncestors(frameElement) : []);
3217
2528
  }
3218
2529
  return list.concat(scrollableAncestor, getOverflowAncestors(scrollableAncestor, [], traverseIframes));
3219
2530
  }
2531
+ function getFrameElement(win) {
2532
+ return win.parent && Object.getPrototypeOf(win.parent) ? win.frameElement : null;
2533
+ }
3220
2534
 
3221
2535
  function getCssDimensions(element) {
3222
2536
  const css = getComputedStyle$1(element);
@@ -3319,8 +2633,9 @@ function getBoundingClientRect(element, includeScale, isFixedStrategy, offsetPar
3319
2633
  if (domElement) {
3320
2634
  const win = getWindow(domElement);
3321
2635
  const offsetWin = offsetParent && isElement(offsetParent) ? getWindow(offsetParent) : offsetParent;
3322
- let currentIFrame = win.frameElement;
3323
- while (currentIFrame && offsetParent && offsetWin !== win) {
2636
+ let currentWin = win;
2637
+ let currentIFrame = getFrameElement(currentWin);
2638
+ while (currentIFrame && offsetParent && offsetWin !== currentWin) {
3324
2639
  const iframeScale = getScale(currentIFrame);
3325
2640
  const iframeRect = currentIFrame.getBoundingClientRect();
3326
2641
  const css = getComputedStyle$1(currentIFrame);
@@ -3332,7 +2647,8 @@ function getBoundingClientRect(element, includeScale, isFixedStrategy, offsetPar
3332
2647
  height *= iframeScale.y;
3333
2648
  x += left;
3334
2649
  y += top;
3335
- currentIFrame = getWindow(currentIFrame).frameElement;
2650
+ currentWin = getWindow(currentIFrame);
2651
+ currentIFrame = getFrameElement(currentWin);
3336
2652
  }
3337
2653
  }
3338
2654
  return rectToClientRect({
@@ -3343,14 +2659,19 @@ function getBoundingClientRect(element, includeScale, isFixedStrategy, offsetPar
3343
2659
  });
3344
2660
  }
3345
2661
 
2662
+ function rectsAreEqual(a, b) {
2663
+ return a.x === b.x && a.y === b.y && a.width === b.width && a.height === b.height;
2664
+ }
2665
+
3346
2666
  // https://samthor.au/2021/observing-dom/
3347
2667
  function observeMove(element, onMove) {
3348
2668
  let io = null;
3349
2669
  let timeoutId;
3350
2670
  const root = getDocumentElement(element);
3351
2671
  function cleanup() {
2672
+ var _io;
3352
2673
  clearTimeout(timeoutId);
3353
- io && io.disconnect();
2674
+ (_io = io) == null || _io.disconnect();
3354
2675
  io = null;
3355
2676
  }
3356
2677
  function refresh(skip, threshold) {
@@ -3361,12 +2682,13 @@ function observeMove(element, onMove) {
3361
2682
  threshold = 1;
3362
2683
  }
3363
2684
  cleanup();
2685
+ const elementRectForRootMargin = element.getBoundingClientRect();
3364
2686
  const {
3365
2687
  left,
3366
2688
  top,
3367
2689
  width,
3368
2690
  height
3369
- } = element.getBoundingClientRect();
2691
+ } = elementRectForRootMargin;
3370
2692
  if (!skip) {
3371
2693
  onMove();
3372
2694
  }
@@ -3390,13 +2712,25 @@ function observeMove(element, onMove) {
3390
2712
  return refresh();
3391
2713
  }
3392
2714
  if (!ratio) {
2715
+ // If the reference is clipped, the ratio is 0. Throttle the refresh
2716
+ // to prevent an infinite loop of updates.
3393
2717
  timeoutId = setTimeout(() => {
3394
2718
  refresh(false, 1e-7);
3395
- }, 100);
2719
+ }, 1000);
3396
2720
  } else {
3397
2721
  refresh(false, ratio);
3398
2722
  }
3399
2723
  }
2724
+ if (ratio === 1 && !rectsAreEqual(elementRectForRootMargin, element.getBoundingClientRect())) {
2725
+ // It's possible that even though the ratio is reported as 1, the
2726
+ // element is not actually fully within the IntersectionObserver's root
2727
+ // area anymore. This can happen under performance constraints. This may
2728
+ // be a bug in the browser's IntersectionObserver implementation. To
2729
+ // work around this, we compare the element's bounding rect now with
2730
+ // what it was at the time we created the IntersectionObserver. If they
2731
+ // are not equal then the element moved, so we refresh.
2732
+ refresh();
2733
+ }
3400
2734
  isFirstUpdate = false;
3401
2735
  }
3402
2736
 
@@ -3408,7 +2742,7 @@ function observeMove(element, onMove) {
3408
2742
  // Handle <iframe>s
3409
2743
  root: root.ownerDocument
3410
2744
  });
3411
- } catch (e) {
2745
+ } catch (_e) {
3412
2746
  io = new IntersectionObserver(handleObserve, options);
3413
2747
  }
3414
2748
  io.observe(element);
@@ -3456,7 +2790,8 @@ function autoUpdate(reference, floating, update, options) {
3456
2790
  resizeObserver.unobserve(floating);
3457
2791
  cancelAnimationFrame(reobserveFrame);
3458
2792
  reobserveFrame = requestAnimationFrame(() => {
3459
- resizeObserver && resizeObserver.observe(floating);
2793
+ var _resizeObserver;
2794
+ (_resizeObserver = resizeObserver) == null || _resizeObserver.observe(floating);
3460
2795
  });
3461
2796
  }
3462
2797
  update();
@@ -3473,7 +2808,7 @@ function autoUpdate(reference, floating, update, options) {
3473
2808
  }
3474
2809
  function frameLoop() {
3475
2810
  const nextRefRect = getBoundingClientRect(reference);
3476
- if (prevRefRect && (nextRefRect.x !== prevRefRect.x || nextRefRect.y !== prevRefRect.y || nextRefRect.width !== prevRefRect.width || nextRefRect.height !== prevRefRect.height)) {
2811
+ if (prevRefRect && !rectsAreEqual(prevRefRect, nextRefRect)) {
3477
2812
  update();
3478
2813
  }
3479
2814
  prevRefRect = nextRefRect;
@@ -3481,12 +2816,13 @@ function autoUpdate(reference, floating, update, options) {
3481
2816
  }
3482
2817
  update();
3483
2818
  return () => {
2819
+ var _resizeObserver2;
3484
2820
  ancestors.forEach(ancestor => {
3485
2821
  ancestorScroll && ancestor.removeEventListener('scroll', update);
3486
2822
  ancestorResize && ancestor.removeEventListener('resize', update);
3487
2823
  });
3488
- cleanupIo && cleanupIo();
3489
- resizeObserver && resizeObserver.disconnect();
2824
+ cleanupIo == null || cleanupIo();
2825
+ (_resizeObserver2 = resizeObserver) == null || _resizeObserver2.disconnect();
3490
2826
  resizeObserver = null;
3491
2827
  if (animationFrame) {
3492
2828
  cancelAnimationFrame(frameId);
@@ -3494,7 +2830,10 @@ function autoUpdate(reference, floating, update, options) {
3494
2830
  };
3495
2831
  }
3496
2832
 
3497
- var index = typeof document !== 'undefined' ? React.useLayoutEffect : React.useEffect;
2833
+ var isClient = typeof document !== 'undefined';
2834
+
2835
+ var noop$1 = function noop() {};
2836
+ var index = isClient ? React.useLayoutEffect : noop$1;
3498
2837
 
3499
2838
  var _excluded$4 = ["className", "clearValue", "cx", "getStyles", "getClassNames", "getValue", "hasValue", "isMulti", "isRtl", "options", "selectOption", "selectProps", "setValue", "theme"];
3500
2839
  // ==============================
@@ -4293,7 +3632,7 @@ var _ref2$2 = process.env.NODE_ENV === "production" ? {
4293
3632
  } : {
4294
3633
  name: "tj5bde-Svg",
4295
3634
  styles: "display:inline-block;fill:currentColor;line-height:1;stroke:currentColor;stroke-width:0;label:Svg;",
4296
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["indicators.tsx"],"names":[],"mappings":"AAyBI","file":"indicators.tsx","sourcesContent":["/** @jsx jsx */\nimport { ReactNode } from 'react';\nimport { jsx, keyframes } from '@emotion/react';\n\nimport {\n  CommonPropsAndClassName,\n  CSSObjectWithLabel,\n  GroupBase,\n} from '../types';\nimport { getStyleProps } from '../utils';\n\n// ==============================\n// Dropdown & Clear Icons\n// ==============================\n\nconst Svg = ({\n  size,\n  ...props\n}: JSX.IntrinsicElements['svg'] & { size: number }) => (\n  <svg\n    height={size}\n    width={size}\n    viewBox=\"0 0 20 20\"\n    aria-hidden=\"true\"\n    focusable=\"false\"\n    css={{\n      display: 'inline-block',\n      fill: 'currentColor',\n      lineHeight: 1,\n      stroke: 'currentColor',\n      strokeWidth: 0,\n    }}\n    {...props}\n  />\n);\n\nexport type CrossIconProps = JSX.IntrinsicElements['svg'] & { size?: number };\nexport const CrossIcon = (props: CrossIconProps) => (\n  <Svg size={20} {...props}>\n    <path d=\"M14.348 14.849c-0.469 0.469-1.229 0.469-1.697 0l-2.651-3.030-2.651 3.029c-0.469 0.469-1.229 0.469-1.697 0-0.469-0.469-0.469-1.229 0-1.697l2.758-3.15-2.759-3.152c-0.469-0.469-0.469-1.228 0-1.697s1.228-0.469 1.697 0l2.652 3.031 2.651-3.031c0.469-0.469 1.228-0.469 1.697 0s0.469 1.229 0 1.697l-2.758 3.152 2.758 3.15c0.469 0.469 0.469 1.229 0 1.698z\" />\n  </Svg>\n);\nexport type DownChevronProps = JSX.IntrinsicElements['svg'] & { size?: number };\nexport const DownChevron = (props: DownChevronProps) => (\n  <Svg size={20} {...props}>\n    <path d=\"M4.516 7.548c0.436-0.446 1.043-0.481 1.576 0l3.908 3.747 3.908-3.747c0.533-0.481 1.141-0.446 1.574 0 0.436 0.445 0.408 1.197 0 1.615-0.406 0.418-4.695 4.502-4.695 4.502-0.217 0.223-0.502 0.335-0.787 0.335s-0.57-0.112-0.789-0.335c0 0-4.287-4.084-4.695-4.502s-0.436-1.17 0-1.615z\" />\n  </Svg>\n);\n\n// ==============================\n// Dropdown & Clear Buttons\n// ==============================\n\nexport interface DropdownIndicatorProps<\n  Option = unknown,\n  IsMulti extends boolean = boolean,\n  Group extends GroupBase<Option> = GroupBase<Option>\n> extends CommonPropsAndClassName<Option, IsMulti, Group> {\n  /** The children to be rendered inside the indicator. */\n  children?: ReactNode;\n  /** Props that will be passed on to the children. */\n  innerProps: JSX.IntrinsicElements['div'];\n  /** The focused state of the select. */\n  isFocused: boolean;\n  isDisabled: boolean;\n}\n\nconst baseCSS = <\n  Option,\n  IsMulti extends boolean,\n  Group extends GroupBase<Option>\n>(\n  {\n    isFocused,\n    theme: {\n      spacing: { baseUnit },\n      colors,\n    },\n  }:\n    | DropdownIndicatorProps<Option, IsMulti, Group>\n    | ClearIndicatorProps<Option, IsMulti, Group>,\n  unstyled: boolean\n): CSSObjectWithLabel => ({\n  label: 'indicatorContainer',\n  display: 'flex',\n  transition: 'color 150ms',\n  ...(unstyled\n    ? {}\n    : {\n        color: isFocused ? colors.neutral60 : colors.neutral20,\n        padding: baseUnit * 2,\n        ':hover': {\n          color: isFocused ? colors.neutral80 : colors.neutral40,\n        },\n      }),\n});\n\nexport const dropdownIndicatorCSS = baseCSS;\nexport const DropdownIndicator = <\n  Option,\n  IsMulti extends boolean,\n  Group extends GroupBase<Option>\n>(\n  props: DropdownIndicatorProps<Option, IsMulti, Group>\n) => {\n  const { children, innerProps } = props;\n  return (\n    <div\n      {...getStyleProps(props, 'dropdownIndicator', {\n        indicator: true,\n        'dropdown-indicator': true,\n      })}\n      {...innerProps}\n    >\n      {children || <DownChevron />}\n    </div>\n  );\n};\n\nexport interface ClearIndicatorProps<\n  Option = unknown,\n  IsMulti extends boolean = boolean,\n  Group extends GroupBase<Option> = GroupBase<Option>\n> extends CommonPropsAndClassName<Option, IsMulti, Group> {\n  /** The children to be rendered inside the indicator. */\n  children?: ReactNode;\n  /** Props that will be passed on to the children. */\n  innerProps: JSX.IntrinsicElements['div'];\n  /** The focused state of the select. */\n  isFocused: boolean;\n}\n\nexport const clearIndicatorCSS = baseCSS;\nexport const ClearIndicator = <\n  Option,\n  IsMulti extends boolean,\n  Group extends GroupBase<Option>\n>(\n  props: ClearIndicatorProps<Option, IsMulti, Group>\n) => {\n  const { children, innerProps } = props;\n  return (\n    <div\n      {...getStyleProps(props, 'clearIndicator', {\n        indicator: true,\n        'clear-indicator': true,\n      })}\n      {...innerProps}\n    >\n      {children || <CrossIcon />}\n    </div>\n  );\n};\n\n// ==============================\n// Separator\n// ==============================\n\nexport interface IndicatorSeparatorProps<\n  Option = unknown,\n  IsMulti extends boolean = boolean,\n  Group extends GroupBase<Option> = GroupBase<Option>\n> extends CommonPropsAndClassName<Option, IsMulti, Group> {\n  isDisabled: boolean;\n  isFocused: boolean;\n  innerProps?: JSX.IntrinsicElements['span'];\n}\n\nexport const indicatorSeparatorCSS = <\n  Option,\n  IsMulti extends boolean,\n  Group extends GroupBase<Option>\n>(\n  {\n    isDisabled,\n    theme: {\n      spacing: { baseUnit },\n      colors,\n    },\n  }: IndicatorSeparatorProps<Option, IsMulti, Group>,\n  unstyled: boolean\n): CSSObjectWithLabel => ({\n  label: 'indicatorSeparator',\n  alignSelf: 'stretch',\n  width: 1,\n  ...(unstyled\n    ? {}\n    : {\n        backgroundColor: isDisabled ? colors.neutral10 : colors.neutral20,\n        marginBottom: baseUnit * 2,\n        marginTop: baseUnit * 2,\n      }),\n});\n\nexport const IndicatorSeparator = <\n  Option,\n  IsMulti extends boolean,\n  Group extends GroupBase<Option>\n>(\n  props: IndicatorSeparatorProps<Option, IsMulti, Group>\n) => {\n  const { innerProps } = props;\n  return (\n    <span\n      {...innerProps}\n      {...getStyleProps(props, 'indicatorSeparator', {\n        'indicator-separator': true,\n      })}\n    />\n  );\n};\n\n// ==============================\n// Loading\n// ==============================\n\nconst loadingDotAnimations = keyframes`\n  0%, 80%, 100% { opacity: 0; }\n  40% { opacity: 1; }\n`;\n\nexport const loadingIndicatorCSS = <\n  Option,\n  IsMulti extends boolean,\n  Group extends GroupBase<Option>\n>(\n  {\n    isFocused,\n    size,\n    theme: {\n      colors,\n      spacing: { baseUnit },\n    },\n  }: LoadingIndicatorProps<Option, IsMulti, Group>,\n  unstyled: boolean\n): CSSObjectWithLabel => ({\n  label: 'loadingIndicator',\n  display: 'flex',\n  transition: 'color 150ms',\n  alignSelf: 'center',\n  fontSize: size,\n  lineHeight: 1,\n  marginRight: size,\n  textAlign: 'center',\n  verticalAlign: 'middle',\n  ...(unstyled\n    ? {}\n    : {\n        color: isFocused ? colors.neutral60 : colors.neutral20,\n        padding: baseUnit * 2,\n      }),\n});\n\ninterface LoadingDotProps {\n  delay: number;\n  offset: boolean;\n}\nconst LoadingDot = ({ delay, offset }: LoadingDotProps) => (\n  <span\n    css={{\n      animation: `${loadingDotAnimations} 1s ease-in-out ${delay}ms infinite;`,\n      backgroundColor: 'currentColor',\n      borderRadius: '1em',\n      display: 'inline-block',\n      marginLeft: offset ? '1em' : undefined,\n      height: '1em',\n      verticalAlign: 'top',\n      width: '1em',\n    }}\n  />\n);\n\nexport interface LoadingIndicatorProps<\n  Option = unknown,\n  IsMulti extends boolean = boolean,\n  Group extends GroupBase<Option> = GroupBase<Option>\n> extends CommonPropsAndClassName<Option, IsMulti, Group> {\n  /** Props that will be passed on to the children. */\n  innerProps: JSX.IntrinsicElements['div'];\n  /** The focused state of the select. */\n  isFocused: boolean;\n  isDisabled: boolean;\n  /** Set size of the container. */\n  size: number;\n}\nexport const LoadingIndicator = <\n  Option,\n  IsMulti extends boolean,\n  Group extends GroupBase<Option>\n>({\n  innerProps,\n  isRtl,\n  size = 4,\n  ...restProps\n}: LoadingIndicatorProps<Option, IsMulti, Group>) => {\n  return (\n    <div\n      {...getStyleProps(\n        { ...restProps, innerProps, isRtl, size },\n        'loadingIndicator',\n        {\n          indicator: true,\n          'loading-indicator': true,\n        }\n      )}\n      {...innerProps}\n    >\n      <LoadingDot delay={0} offset={isRtl} />\n      <LoadingDot delay={160} offset />\n      <LoadingDot delay={320} offset={!isRtl} />\n    </div>\n  );\n};\n"]} */",
3635
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["indicators.tsx"],"names":[],"mappings":"AAyBI","file":"indicators.tsx","sourcesContent":["/** @jsx jsx */\nimport { JSX, ReactNode } from 'react';\nimport { jsx, keyframes } from '@emotion/react';\n\nimport {\n  CommonPropsAndClassName,\n  CSSObjectWithLabel,\n  GroupBase,\n} from '../types';\nimport { getStyleProps } from '../utils';\n\n// ==============================\n// Dropdown & Clear Icons\n// ==============================\n\nconst Svg = ({\n  size,\n  ...props\n}: JSX.IntrinsicElements['svg'] & { size: number }) => (\n  <svg\n    height={size}\n    width={size}\n    viewBox=\"0 0 20 20\"\n    aria-hidden=\"true\"\n    focusable=\"false\"\n    css={{\n      display: 'inline-block',\n      fill: 'currentColor',\n      lineHeight: 1,\n      stroke: 'currentColor',\n      strokeWidth: 0,\n    }}\n    {...props}\n  />\n);\n\nexport type CrossIconProps = JSX.IntrinsicElements['svg'] & { size?: number };\nexport const CrossIcon = (props: CrossIconProps) => (\n  <Svg size={20} {...props}>\n    <path d=\"M14.348 14.849c-0.469 0.469-1.229 0.469-1.697 0l-2.651-3.030-2.651 3.029c-0.469 0.469-1.229 0.469-1.697 0-0.469-0.469-0.469-1.229 0-1.697l2.758-3.15-2.759-3.152c-0.469-0.469-0.469-1.228 0-1.697s1.228-0.469 1.697 0l2.652 3.031 2.651-3.031c0.469-0.469 1.228-0.469 1.697 0s0.469 1.229 0 1.697l-2.758 3.152 2.758 3.15c0.469 0.469 0.469 1.229 0 1.698z\" />\n  </Svg>\n);\nexport type DownChevronProps = JSX.IntrinsicElements['svg'] & { size?: number };\nexport const DownChevron = (props: DownChevronProps) => (\n  <Svg size={20} {...props}>\n    <path d=\"M4.516 7.548c0.436-0.446 1.043-0.481 1.576 0l3.908 3.747 3.908-3.747c0.533-0.481 1.141-0.446 1.574 0 0.436 0.445 0.408 1.197 0 1.615-0.406 0.418-4.695 4.502-4.695 4.502-0.217 0.223-0.502 0.335-0.787 0.335s-0.57-0.112-0.789-0.335c0 0-4.287-4.084-4.695-4.502s-0.436-1.17 0-1.615z\" />\n  </Svg>\n);\n\n// ==============================\n// Dropdown & Clear Buttons\n// ==============================\n\nexport interface DropdownIndicatorProps<\n  Option = unknown,\n  IsMulti extends boolean = boolean,\n  Group extends GroupBase<Option> = GroupBase<Option>\n> extends CommonPropsAndClassName<Option, IsMulti, Group> {\n  /** The children to be rendered inside the indicator. */\n  children?: ReactNode;\n  /** Props that will be passed on to the children. */\n  innerProps: JSX.IntrinsicElements['div'];\n  /** The focused state of the select. */\n  isFocused: boolean;\n  isDisabled: boolean;\n}\n\nconst baseCSS = <\n  Option,\n  IsMulti extends boolean,\n  Group extends GroupBase<Option>\n>(\n  {\n    isFocused,\n    theme: {\n      spacing: { baseUnit },\n      colors,\n    },\n  }:\n    | DropdownIndicatorProps<Option, IsMulti, Group>\n    | ClearIndicatorProps<Option, IsMulti, Group>,\n  unstyled: boolean\n): CSSObjectWithLabel => ({\n  label: 'indicatorContainer',\n  display: 'flex',\n  transition: 'color 150ms',\n  ...(unstyled\n    ? {}\n    : {\n        color: isFocused ? colors.neutral60 : colors.neutral20,\n        padding: baseUnit * 2,\n        ':hover': {\n          color: isFocused ? colors.neutral80 : colors.neutral40,\n        },\n      }),\n});\n\nexport const dropdownIndicatorCSS = baseCSS;\nexport const DropdownIndicator = <\n  Option,\n  IsMulti extends boolean,\n  Group extends GroupBase<Option>\n>(\n  props: DropdownIndicatorProps<Option, IsMulti, Group>\n) => {\n  const { children, innerProps } = props;\n  return (\n    <div\n      {...getStyleProps(props, 'dropdownIndicator', {\n        indicator: true,\n        'dropdown-indicator': true,\n      })}\n      {...innerProps}\n    >\n      {children || <DownChevron />}\n    </div>\n  );\n};\n\nexport interface ClearIndicatorProps<\n  Option = unknown,\n  IsMulti extends boolean = boolean,\n  Group extends GroupBase<Option> = GroupBase<Option>\n> extends CommonPropsAndClassName<Option, IsMulti, Group> {\n  /** The children to be rendered inside the indicator. */\n  children?: ReactNode;\n  /** Props that will be passed on to the children. */\n  innerProps: JSX.IntrinsicElements['div'];\n  /** The focused state of the select. */\n  isFocused: boolean;\n}\n\nexport const clearIndicatorCSS = baseCSS;\nexport const ClearIndicator = <\n  Option,\n  IsMulti extends boolean,\n  Group extends GroupBase<Option>\n>(\n  props: ClearIndicatorProps<Option, IsMulti, Group>\n) => {\n  const { children, innerProps } = props;\n  return (\n    <div\n      {...getStyleProps(props, 'clearIndicator', {\n        indicator: true,\n        'clear-indicator': true,\n      })}\n      {...innerProps}\n    >\n      {children || <CrossIcon />}\n    </div>\n  );\n};\n\n// ==============================\n// Separator\n// ==============================\n\nexport interface IndicatorSeparatorProps<\n  Option = unknown,\n  IsMulti extends boolean = boolean,\n  Group extends GroupBase<Option> = GroupBase<Option>\n> extends CommonPropsAndClassName<Option, IsMulti, Group> {\n  isDisabled: boolean;\n  isFocused: boolean;\n  innerProps?: JSX.IntrinsicElements['span'];\n}\n\nexport const indicatorSeparatorCSS = <\n  Option,\n  IsMulti extends boolean,\n  Group extends GroupBase<Option>\n>(\n  {\n    isDisabled,\n    theme: {\n      spacing: { baseUnit },\n      colors,\n    },\n  }: IndicatorSeparatorProps<Option, IsMulti, Group>,\n  unstyled: boolean\n): CSSObjectWithLabel => ({\n  label: 'indicatorSeparator',\n  alignSelf: 'stretch',\n  width: 1,\n  ...(unstyled\n    ? {}\n    : {\n        backgroundColor: isDisabled ? colors.neutral10 : colors.neutral20,\n        marginBottom: baseUnit * 2,\n        marginTop: baseUnit * 2,\n      }),\n});\n\nexport const IndicatorSeparator = <\n  Option,\n  IsMulti extends boolean,\n  Group extends GroupBase<Option>\n>(\n  props: IndicatorSeparatorProps<Option, IsMulti, Group>\n) => {\n  const { innerProps } = props;\n  return (\n    <span\n      {...innerProps}\n      {...getStyleProps(props, 'indicatorSeparator', {\n        'indicator-separator': true,\n      })}\n    />\n  );\n};\n\n// ==============================\n// Loading\n// ==============================\n\nconst loadingDotAnimations = keyframes`\n  0%, 80%, 100% { opacity: 0; }\n  40% { opacity: 1; }\n`;\n\nexport const loadingIndicatorCSS = <\n  Option,\n  IsMulti extends boolean,\n  Group extends GroupBase<Option>\n>(\n  {\n    isFocused,\n    size,\n    theme: {\n      colors,\n      spacing: { baseUnit },\n    },\n  }: LoadingIndicatorProps<Option, IsMulti, Group>,\n  unstyled: boolean\n): CSSObjectWithLabel => ({\n  label: 'loadingIndicator',\n  display: 'flex',\n  transition: 'color 150ms',\n  alignSelf: 'center',\n  fontSize: size,\n  lineHeight: 1,\n  marginRight: size,\n  textAlign: 'center',\n  verticalAlign: 'middle',\n  ...(unstyled\n    ? {}\n    : {\n        color: isFocused ? colors.neutral60 : colors.neutral20,\n        padding: baseUnit * 2,\n      }),\n});\n\ninterface LoadingDotProps {\n  delay: number;\n  offset: boolean;\n}\nconst LoadingDot = ({ delay, offset }: LoadingDotProps) => (\n  <span\n    css={{\n      animation: `${loadingDotAnimations} 1s ease-in-out ${delay}ms infinite;`,\n      backgroundColor: 'currentColor',\n      borderRadius: '1em',\n      display: 'inline-block',\n      marginLeft: offset ? '1em' : undefined,\n      height: '1em',\n      verticalAlign: 'top',\n      width: '1em',\n    }}\n  />\n);\n\nexport interface LoadingIndicatorProps<\n  Option = unknown,\n  IsMulti extends boolean = boolean,\n  Group extends GroupBase<Option> = GroupBase<Option>\n> extends CommonPropsAndClassName<Option, IsMulti, Group> {\n  /** Props that will be passed on to the children. */\n  innerProps: JSX.IntrinsicElements['div'];\n  /** The focused state of the select. */\n  isFocused: boolean;\n  isDisabled: boolean;\n  /** Set size of the container. */\n  size: number;\n}\nexport const LoadingIndicator = <\n  Option,\n  IsMulti extends boolean,\n  Group extends GroupBase<Option>\n>({\n  innerProps,\n  isRtl,\n  size = 4,\n  ...restProps\n}: LoadingIndicatorProps<Option, IsMulti, Group>) => {\n  return (\n    <div\n      {...getStyleProps(\n        { ...restProps, innerProps, isRtl, size },\n        'loadingIndicator',\n        {\n          indicator: true,\n          'loading-indicator': true,\n        }\n      )}\n      {...innerProps}\n    >\n      <LoadingDot delay={0} offset={isRtl} />\n      <LoadingDot delay={160} offset />\n      <LoadingDot delay={320} offset={!isRtl} />\n    </div>\n  );\n};\n"]} */",
4297
3636
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$3
4298
3637
  };
4299
3638
  var Svg = function Svg(_ref) {
@@ -4428,7 +3767,7 @@ var LoadingDot = function LoadingDot(_ref6) {
4428
3767
  height: '1em',
4429
3768
  verticalAlign: 'top',
4430
3769
  width: '1em'
4431
- }, process.env.NODE_ENV === "production" ? "" : ";label:LoadingDot;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["indicators.tsx"],"names":[],"mappings":"AAmQI","file":"indicators.tsx","sourcesContent":["/** @jsx jsx */\nimport { ReactNode } from 'react';\nimport { jsx, keyframes } from '@emotion/react';\n\nimport {\n  CommonPropsAndClassName,\n  CSSObjectWithLabel,\n  GroupBase,\n} from '../types';\nimport { getStyleProps } from '../utils';\n\n// ==============================\n// Dropdown & Clear Icons\n// ==============================\n\nconst Svg = ({\n  size,\n  ...props\n}: JSX.IntrinsicElements['svg'] & { size: number }) => (\n  <svg\n    height={size}\n    width={size}\n    viewBox=\"0 0 20 20\"\n    aria-hidden=\"true\"\n    focusable=\"false\"\n    css={{\n      display: 'inline-block',\n      fill: 'currentColor',\n      lineHeight: 1,\n      stroke: 'currentColor',\n      strokeWidth: 0,\n    }}\n    {...props}\n  />\n);\n\nexport type CrossIconProps = JSX.IntrinsicElements['svg'] & { size?: number };\nexport const CrossIcon = (props: CrossIconProps) => (\n  <Svg size={20} {...props}>\n    <path d=\"M14.348 14.849c-0.469 0.469-1.229 0.469-1.697 0l-2.651-3.030-2.651 3.029c-0.469 0.469-1.229 0.469-1.697 0-0.469-0.469-0.469-1.229 0-1.697l2.758-3.15-2.759-3.152c-0.469-0.469-0.469-1.228 0-1.697s1.228-0.469 1.697 0l2.652 3.031 2.651-3.031c0.469-0.469 1.228-0.469 1.697 0s0.469 1.229 0 1.697l-2.758 3.152 2.758 3.15c0.469 0.469 0.469 1.229 0 1.698z\" />\n  </Svg>\n);\nexport type DownChevronProps = JSX.IntrinsicElements['svg'] & { size?: number };\nexport const DownChevron = (props: DownChevronProps) => (\n  <Svg size={20} {...props}>\n    <path d=\"M4.516 7.548c0.436-0.446 1.043-0.481 1.576 0l3.908 3.747 3.908-3.747c0.533-0.481 1.141-0.446 1.574 0 0.436 0.445 0.408 1.197 0 1.615-0.406 0.418-4.695 4.502-4.695 4.502-0.217 0.223-0.502 0.335-0.787 0.335s-0.57-0.112-0.789-0.335c0 0-4.287-4.084-4.695-4.502s-0.436-1.17 0-1.615z\" />\n  </Svg>\n);\n\n// ==============================\n// Dropdown & Clear Buttons\n// ==============================\n\nexport interface DropdownIndicatorProps<\n  Option = unknown,\n  IsMulti extends boolean = boolean,\n  Group extends GroupBase<Option> = GroupBase<Option>\n> extends CommonPropsAndClassName<Option, IsMulti, Group> {\n  /** The children to be rendered inside the indicator. */\n  children?: ReactNode;\n  /** Props that will be passed on to the children. */\n  innerProps: JSX.IntrinsicElements['div'];\n  /** The focused state of the select. */\n  isFocused: boolean;\n  isDisabled: boolean;\n}\n\nconst baseCSS = <\n  Option,\n  IsMulti extends boolean,\n  Group extends GroupBase<Option>\n>(\n  {\n    isFocused,\n    theme: {\n      spacing: { baseUnit },\n      colors,\n    },\n  }:\n    | DropdownIndicatorProps<Option, IsMulti, Group>\n    | ClearIndicatorProps<Option, IsMulti, Group>,\n  unstyled: boolean\n): CSSObjectWithLabel => ({\n  label: 'indicatorContainer',\n  display: 'flex',\n  transition: 'color 150ms',\n  ...(unstyled\n    ? {}\n    : {\n        color: isFocused ? colors.neutral60 : colors.neutral20,\n        padding: baseUnit * 2,\n        ':hover': {\n          color: isFocused ? colors.neutral80 : colors.neutral40,\n        },\n      }),\n});\n\nexport const dropdownIndicatorCSS = baseCSS;\nexport const DropdownIndicator = <\n  Option,\n  IsMulti extends boolean,\n  Group extends GroupBase<Option>\n>(\n  props: DropdownIndicatorProps<Option, IsMulti, Group>\n) => {\n  const { children, innerProps } = props;\n  return (\n    <div\n      {...getStyleProps(props, 'dropdownIndicator', {\n        indicator: true,\n        'dropdown-indicator': true,\n      })}\n      {...innerProps}\n    >\n      {children || <DownChevron />}\n    </div>\n  );\n};\n\nexport interface ClearIndicatorProps<\n  Option = unknown,\n  IsMulti extends boolean = boolean,\n  Group extends GroupBase<Option> = GroupBase<Option>\n> extends CommonPropsAndClassName<Option, IsMulti, Group> {\n  /** The children to be rendered inside the indicator. */\n  children?: ReactNode;\n  /** Props that will be passed on to the children. */\n  innerProps: JSX.IntrinsicElements['div'];\n  /** The focused state of the select. */\n  isFocused: boolean;\n}\n\nexport const clearIndicatorCSS = baseCSS;\nexport const ClearIndicator = <\n  Option,\n  IsMulti extends boolean,\n  Group extends GroupBase<Option>\n>(\n  props: ClearIndicatorProps<Option, IsMulti, Group>\n) => {\n  const { children, innerProps } = props;\n  return (\n    <div\n      {...getStyleProps(props, 'clearIndicator', {\n        indicator: true,\n        'clear-indicator': true,\n      })}\n      {...innerProps}\n    >\n      {children || <CrossIcon />}\n    </div>\n  );\n};\n\n// ==============================\n// Separator\n// ==============================\n\nexport interface IndicatorSeparatorProps<\n  Option = unknown,\n  IsMulti extends boolean = boolean,\n  Group extends GroupBase<Option> = GroupBase<Option>\n> extends CommonPropsAndClassName<Option, IsMulti, Group> {\n  isDisabled: boolean;\n  isFocused: boolean;\n  innerProps?: JSX.IntrinsicElements['span'];\n}\n\nexport const indicatorSeparatorCSS = <\n  Option,\n  IsMulti extends boolean,\n  Group extends GroupBase<Option>\n>(\n  {\n    isDisabled,\n    theme: {\n      spacing: { baseUnit },\n      colors,\n    },\n  }: IndicatorSeparatorProps<Option, IsMulti, Group>,\n  unstyled: boolean\n): CSSObjectWithLabel => ({\n  label: 'indicatorSeparator',\n  alignSelf: 'stretch',\n  width: 1,\n  ...(unstyled\n    ? {}\n    : {\n        backgroundColor: isDisabled ? colors.neutral10 : colors.neutral20,\n        marginBottom: baseUnit * 2,\n        marginTop: baseUnit * 2,\n      }),\n});\n\nexport const IndicatorSeparator = <\n  Option,\n  IsMulti extends boolean,\n  Group extends GroupBase<Option>\n>(\n  props: IndicatorSeparatorProps<Option, IsMulti, Group>\n) => {\n  const { innerProps } = props;\n  return (\n    <span\n      {...innerProps}\n      {...getStyleProps(props, 'indicatorSeparator', {\n        'indicator-separator': true,\n      })}\n    />\n  );\n};\n\n// ==============================\n// Loading\n// ==============================\n\nconst loadingDotAnimations = keyframes`\n  0%, 80%, 100% { opacity: 0; }\n  40% { opacity: 1; }\n`;\n\nexport const loadingIndicatorCSS = <\n  Option,\n  IsMulti extends boolean,\n  Group extends GroupBase<Option>\n>(\n  {\n    isFocused,\n    size,\n    theme: {\n      colors,\n      spacing: { baseUnit },\n    },\n  }: LoadingIndicatorProps<Option, IsMulti, Group>,\n  unstyled: boolean\n): CSSObjectWithLabel => ({\n  label: 'loadingIndicator',\n  display: 'flex',\n  transition: 'color 150ms',\n  alignSelf: 'center',\n  fontSize: size,\n  lineHeight: 1,\n  marginRight: size,\n  textAlign: 'center',\n  verticalAlign: 'middle',\n  ...(unstyled\n    ? {}\n    : {\n        color: isFocused ? colors.neutral60 : colors.neutral20,\n        padding: baseUnit * 2,\n      }),\n});\n\ninterface LoadingDotProps {\n  delay: number;\n  offset: boolean;\n}\nconst LoadingDot = ({ delay, offset }: LoadingDotProps) => (\n  <span\n    css={{\n      animation: `${loadingDotAnimations} 1s ease-in-out ${delay}ms infinite;`,\n      backgroundColor: 'currentColor',\n      borderRadius: '1em',\n      display: 'inline-block',\n      marginLeft: offset ? '1em' : undefined,\n      height: '1em',\n      verticalAlign: 'top',\n      width: '1em',\n    }}\n  />\n);\n\nexport interface LoadingIndicatorProps<\n  Option = unknown,\n  IsMulti extends boolean = boolean,\n  Group extends GroupBase<Option> = GroupBase<Option>\n> extends CommonPropsAndClassName<Option, IsMulti, Group> {\n  /** Props that will be passed on to the children. */\n  innerProps: JSX.IntrinsicElements['div'];\n  /** The focused state of the select. */\n  isFocused: boolean;\n  isDisabled: boolean;\n  /** Set size of the container. */\n  size: number;\n}\nexport const LoadingIndicator = <\n  Option,\n  IsMulti extends boolean,\n  Group extends GroupBase<Option>\n>({\n  innerProps,\n  isRtl,\n  size = 4,\n  ...restProps\n}: LoadingIndicatorProps<Option, IsMulti, Group>) => {\n  return (\n    <div\n      {...getStyleProps(\n        { ...restProps, innerProps, isRtl, size },\n        'loadingIndicator',\n        {\n          indicator: true,\n          'loading-indicator': true,\n        }\n      )}\n      {...innerProps}\n    >\n      <LoadingDot delay={0} offset={isRtl} />\n      <LoadingDot delay={160} offset />\n      <LoadingDot delay={320} offset={!isRtl} />\n    </div>\n  );\n};\n"]} */")
3770
+ }, process.env.NODE_ENV === "production" ? "" : ";label:LoadingDot;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["indicators.tsx"],"names":[],"mappings":"AAmQI","file":"indicators.tsx","sourcesContent":["/** @jsx jsx */\nimport { JSX, ReactNode } from 'react';\nimport { jsx, keyframes } from '@emotion/react';\n\nimport {\n  CommonPropsAndClassName,\n  CSSObjectWithLabel,\n  GroupBase,\n} from '../types';\nimport { getStyleProps } from '../utils';\n\n// ==============================\n// Dropdown & Clear Icons\n// ==============================\n\nconst Svg = ({\n  size,\n  ...props\n}: JSX.IntrinsicElements['svg'] & { size: number }) => (\n  <svg\n    height={size}\n    width={size}\n    viewBox=\"0 0 20 20\"\n    aria-hidden=\"true\"\n    focusable=\"false\"\n    css={{\n      display: 'inline-block',\n      fill: 'currentColor',\n      lineHeight: 1,\n      stroke: 'currentColor',\n      strokeWidth: 0,\n    }}\n    {...props}\n  />\n);\n\nexport type CrossIconProps = JSX.IntrinsicElements['svg'] & { size?: number };\nexport const CrossIcon = (props: CrossIconProps) => (\n  <Svg size={20} {...props}>\n    <path d=\"M14.348 14.849c-0.469 0.469-1.229 0.469-1.697 0l-2.651-3.030-2.651 3.029c-0.469 0.469-1.229 0.469-1.697 0-0.469-0.469-0.469-1.229 0-1.697l2.758-3.15-2.759-3.152c-0.469-0.469-0.469-1.228 0-1.697s1.228-0.469 1.697 0l2.652 3.031 2.651-3.031c0.469-0.469 1.228-0.469 1.697 0s0.469 1.229 0 1.697l-2.758 3.152 2.758 3.15c0.469 0.469 0.469 1.229 0 1.698z\" />\n  </Svg>\n);\nexport type DownChevronProps = JSX.IntrinsicElements['svg'] & { size?: number };\nexport const DownChevron = (props: DownChevronProps) => (\n  <Svg size={20} {...props}>\n    <path d=\"M4.516 7.548c0.436-0.446 1.043-0.481 1.576 0l3.908 3.747 3.908-3.747c0.533-0.481 1.141-0.446 1.574 0 0.436 0.445 0.408 1.197 0 1.615-0.406 0.418-4.695 4.502-4.695 4.502-0.217 0.223-0.502 0.335-0.787 0.335s-0.57-0.112-0.789-0.335c0 0-4.287-4.084-4.695-4.502s-0.436-1.17 0-1.615z\" />\n  </Svg>\n);\n\n// ==============================\n// Dropdown & Clear Buttons\n// ==============================\n\nexport interface DropdownIndicatorProps<\n  Option = unknown,\n  IsMulti extends boolean = boolean,\n  Group extends GroupBase<Option> = GroupBase<Option>\n> extends CommonPropsAndClassName<Option, IsMulti, Group> {\n  /** The children to be rendered inside the indicator. */\n  children?: ReactNode;\n  /** Props that will be passed on to the children. */\n  innerProps: JSX.IntrinsicElements['div'];\n  /** The focused state of the select. */\n  isFocused: boolean;\n  isDisabled: boolean;\n}\n\nconst baseCSS = <\n  Option,\n  IsMulti extends boolean,\n  Group extends GroupBase<Option>\n>(\n  {\n    isFocused,\n    theme: {\n      spacing: { baseUnit },\n      colors,\n    },\n  }:\n    | DropdownIndicatorProps<Option, IsMulti, Group>\n    | ClearIndicatorProps<Option, IsMulti, Group>,\n  unstyled: boolean\n): CSSObjectWithLabel => ({\n  label: 'indicatorContainer',\n  display: 'flex',\n  transition: 'color 150ms',\n  ...(unstyled\n    ? {}\n    : {\n        color: isFocused ? colors.neutral60 : colors.neutral20,\n        padding: baseUnit * 2,\n        ':hover': {\n          color: isFocused ? colors.neutral80 : colors.neutral40,\n        },\n      }),\n});\n\nexport const dropdownIndicatorCSS = baseCSS;\nexport const DropdownIndicator = <\n  Option,\n  IsMulti extends boolean,\n  Group extends GroupBase<Option>\n>(\n  props: DropdownIndicatorProps<Option, IsMulti, Group>\n) => {\n  const { children, innerProps } = props;\n  return (\n    <div\n      {...getStyleProps(props, 'dropdownIndicator', {\n        indicator: true,\n        'dropdown-indicator': true,\n      })}\n      {...innerProps}\n    >\n      {children || <DownChevron />}\n    </div>\n  );\n};\n\nexport interface ClearIndicatorProps<\n  Option = unknown,\n  IsMulti extends boolean = boolean,\n  Group extends GroupBase<Option> = GroupBase<Option>\n> extends CommonPropsAndClassName<Option, IsMulti, Group> {\n  /** The children to be rendered inside the indicator. */\n  children?: ReactNode;\n  /** Props that will be passed on to the children. */\n  innerProps: JSX.IntrinsicElements['div'];\n  /** The focused state of the select. */\n  isFocused: boolean;\n}\n\nexport const clearIndicatorCSS = baseCSS;\nexport const ClearIndicator = <\n  Option,\n  IsMulti extends boolean,\n  Group extends GroupBase<Option>\n>(\n  props: ClearIndicatorProps<Option, IsMulti, Group>\n) => {\n  const { children, innerProps } = props;\n  return (\n    <div\n      {...getStyleProps(props, 'clearIndicator', {\n        indicator: true,\n        'clear-indicator': true,\n      })}\n      {...innerProps}\n    >\n      {children || <CrossIcon />}\n    </div>\n  );\n};\n\n// ==============================\n// Separator\n// ==============================\n\nexport interface IndicatorSeparatorProps<\n  Option = unknown,\n  IsMulti extends boolean = boolean,\n  Group extends GroupBase<Option> = GroupBase<Option>\n> extends CommonPropsAndClassName<Option, IsMulti, Group> {\n  isDisabled: boolean;\n  isFocused: boolean;\n  innerProps?: JSX.IntrinsicElements['span'];\n}\n\nexport const indicatorSeparatorCSS = <\n  Option,\n  IsMulti extends boolean,\n  Group extends GroupBase<Option>\n>(\n  {\n    isDisabled,\n    theme: {\n      spacing: { baseUnit },\n      colors,\n    },\n  }: IndicatorSeparatorProps<Option, IsMulti, Group>,\n  unstyled: boolean\n): CSSObjectWithLabel => ({\n  label: 'indicatorSeparator',\n  alignSelf: 'stretch',\n  width: 1,\n  ...(unstyled\n    ? {}\n    : {\n        backgroundColor: isDisabled ? colors.neutral10 : colors.neutral20,\n        marginBottom: baseUnit * 2,\n        marginTop: baseUnit * 2,\n      }),\n});\n\nexport const IndicatorSeparator = <\n  Option,\n  IsMulti extends boolean,\n  Group extends GroupBase<Option>\n>(\n  props: IndicatorSeparatorProps<Option, IsMulti, Group>\n) => {\n  const { innerProps } = props;\n  return (\n    <span\n      {...innerProps}\n      {...getStyleProps(props, 'indicatorSeparator', {\n        'indicator-separator': true,\n      })}\n    />\n  );\n};\n\n// ==============================\n// Loading\n// ==============================\n\nconst loadingDotAnimations = keyframes`\n  0%, 80%, 100% { opacity: 0; }\n  40% { opacity: 1; }\n`;\n\nexport const loadingIndicatorCSS = <\n  Option,\n  IsMulti extends boolean,\n  Group extends GroupBase<Option>\n>(\n  {\n    isFocused,\n    size,\n    theme: {\n      colors,\n      spacing: { baseUnit },\n    },\n  }: LoadingIndicatorProps<Option, IsMulti, Group>,\n  unstyled: boolean\n): CSSObjectWithLabel => ({\n  label: 'loadingIndicator',\n  display: 'flex',\n  transition: 'color 150ms',\n  alignSelf: 'center',\n  fontSize: size,\n  lineHeight: 1,\n  marginRight: size,\n  textAlign: 'center',\n  verticalAlign: 'middle',\n  ...(unstyled\n    ? {}\n    : {\n        color: isFocused ? colors.neutral60 : colors.neutral20,\n        padding: baseUnit * 2,\n      }),\n});\n\ninterface LoadingDotProps {\n  delay: number;\n  offset: boolean;\n}\nconst LoadingDot = ({ delay, offset }: LoadingDotProps) => (\n  <span\n    css={{\n      animation: `${loadingDotAnimations} 1s ease-in-out ${delay}ms infinite;`,\n      backgroundColor: 'currentColor',\n      borderRadius: '1em',\n      display: 'inline-block',\n      marginLeft: offset ? '1em' : undefined,\n      height: '1em',\n      verticalAlign: 'top',\n      width: '1em',\n    }}\n  />\n);\n\nexport interface LoadingIndicatorProps<\n  Option = unknown,\n  IsMulti extends boolean = boolean,\n  Group extends GroupBase<Option> = GroupBase<Option>\n> extends CommonPropsAndClassName<Option, IsMulti, Group> {\n  /** Props that will be passed on to the children. */\n  innerProps: JSX.IntrinsicElements['div'];\n  /** The focused state of the select. */\n  isFocused: boolean;\n  isDisabled: boolean;\n  /** Set size of the container. */\n  size: number;\n}\nexport const LoadingIndicator = <\n  Option,\n  IsMulti extends boolean,\n  Group extends GroupBase<Option>\n>({\n  innerProps,\n  isRtl,\n  size = 4,\n  ...restProps\n}: LoadingIndicatorProps<Option, IsMulti, Group>) => {\n  return (\n    <div\n      {...getStyleProps(\n        { ...restProps, innerProps, isRtl, size },\n        'loadingIndicator',\n        {\n          indicator: true,\n          'loading-indicator': true,\n        }\n      )}\n      {...innerProps}\n    >\n      <LoadingDot delay={0} offset={isRtl} />\n      <LoadingDot delay={160} offset />\n      <LoadingDot delay={320} offset={!isRtl} />\n    </div>\n  );\n};\n"]} */")
4432
3771
  });
4433
3772
  };
4434
3773
  var LoadingIndicator = function LoadingIndicator(_ref7) {
@@ -4924,7 +4263,7 @@ var _ref = process.env.NODE_ENV === "production" ? {
4924
4263
  } : {
4925
4264
  name: "1f43avz-a11yText-A11yText",
4926
4265
  styles: "label:a11yText;z-index:9999;border:0;clip:rect(1px, 1px, 1px, 1px);height:1px;width:1px;position:absolute;overflow:hidden;padding:0;white-space:nowrap;label:A11yText;",
4927
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkExMXlUZXh0LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFNSSIsImZpbGUiOiJBMTF5VGV4dC50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKiogQGpzeCBqc3ggKi9cbmltcG9ydCB7IGpzeCB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuLy8gQXNzaXN0aXZlIHRleHQgdG8gZGVzY3JpYmUgdmlzdWFsIGVsZW1lbnRzLiBIaWRkZW4gZm9yIHNpZ2h0ZWQgdXNlcnMuXG5jb25zdCBBMTF5VGV4dCA9IChwcm9wczogSlNYLkludHJpbnNpY0VsZW1lbnRzWydzcGFuJ10pID0+IChcbiAgPHNwYW5cbiAgICBjc3M9e3tcbiAgICAgIGxhYmVsOiAnYTExeVRleHQnLFxuICAgICAgekluZGV4OiA5OTk5LFxuICAgICAgYm9yZGVyOiAwLFxuICAgICAgY2xpcDogJ3JlY3QoMXB4LCAxcHgsIDFweCwgMXB4KScsXG4gICAgICBoZWlnaHQ6IDEsXG4gICAgICB3aWR0aDogMSxcbiAgICAgIHBvc2l0aW9uOiAnYWJzb2x1dGUnLFxuICAgICAgb3ZlcmZsb3c6ICdoaWRkZW4nLFxuICAgICAgcGFkZGluZzogMCxcbiAgICAgIHdoaXRlU3BhY2U6ICdub3dyYXAnLFxuICAgIH19XG4gICAgey4uLnByb3BzfVxuICAvPlxuKTtcblxuZXhwb3J0IGRlZmF1bHQgQTExeVRleHQ7XG4iXX0= */",
4266
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkExMXlUZXh0LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFPSSIsImZpbGUiOiJBMTF5VGV4dC50c3giLCJzb3VyY2VzQ29udGVudCI6WyIvKiogQGpzeCBqc3ggKi9cbmltcG9ydCB7IEpTWCB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IGpzeCB9IGZyb20gJ0BlbW90aW9uL3JlYWN0JztcblxuLy8gQXNzaXN0aXZlIHRleHQgdG8gZGVzY3JpYmUgdmlzdWFsIGVsZW1lbnRzLiBIaWRkZW4gZm9yIHNpZ2h0ZWQgdXNlcnMuXG5jb25zdCBBMTF5VGV4dCA9IChwcm9wczogSlNYLkludHJpbnNpY0VsZW1lbnRzWydzcGFuJ10pID0+IChcbiAgPHNwYW5cbiAgICBjc3M9e3tcbiAgICAgIGxhYmVsOiAnYTExeVRleHQnLFxuICAgICAgekluZGV4OiA5OTk5LFxuICAgICAgYm9yZGVyOiAwLFxuICAgICAgY2xpcDogJ3JlY3QoMXB4LCAxcHgsIDFweCwgMXB4KScsXG4gICAgICBoZWlnaHQ6IDEsXG4gICAgICB3aWR0aDogMSxcbiAgICAgIHBvc2l0aW9uOiAnYWJzb2x1dGUnLFxuICAgICAgb3ZlcmZsb3c6ICdoaWRkZW4nLFxuICAgICAgcGFkZGluZzogMCxcbiAgICAgIHdoaXRlU3BhY2U6ICdub3dyYXAnLFxuICAgIH19XG4gICAgey4uLnByb3BzfVxuICAvPlxuKTtcblxuZXhwb3J0IGRlZmF1bHQgQTExeVRleHQ7XG4iXX0= */",
4928
4267
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$2
4929
4268
  };
4930
4269
  var A11yText = function A11yText(props) {
@@ -5468,7 +4807,7 @@ function DummyInput(_ref) {
5468
4807
  opacity: 0,
5469
4808
  position: 'relative',
5470
4809
  transform: 'scale(.01)'
5471
- }, process.env.NODE_ENV === "production" ? "" : ";label:DummyInput;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkR1bW15SW5wdXQudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXlCTSIsImZpbGUiOiJEdW1teUlucHV0LnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKiBAanN4IGpzeCAqL1xuaW1wb3J0IHsgUmVmIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsganN4IH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHsgcmVtb3ZlUHJvcHMgfSBmcm9tICcuLi91dGlscyc7XG5cbmV4cG9ydCBkZWZhdWx0IGZ1bmN0aW9uIER1bW15SW5wdXQoe1xuICBpbm5lclJlZixcbiAgLi4ucHJvcHNcbn06IEpTWC5JbnRyaW5zaWNFbGVtZW50c1snaW5wdXQnXSAmIHtcbiAgcmVhZG9ubHkgaW5uZXJSZWY6IFJlZjxIVE1MSW5wdXRFbGVtZW50Pjtcbn0pIHtcbiAgLy8gUmVtb3ZlIGFuaW1hdGlvbiBwcm9wcyBub3QgbWVhbnQgZm9yIEhUTUwgZWxlbWVudHNcbiAgY29uc3QgZmlsdGVyZWRQcm9wcyA9IHJlbW92ZVByb3BzKFxuICAgIHByb3BzLFxuICAgICdvbkV4aXRlZCcsXG4gICAgJ2luJyxcbiAgICAnZW50ZXInLFxuICAgICdleGl0JyxcbiAgICAnYXBwZWFyJ1xuICApO1xuXG4gIHJldHVybiAoXG4gICAgPGlucHV0XG4gICAgICByZWY9e2lubmVyUmVmfVxuICAgICAgey4uLmZpbHRlcmVkUHJvcHN9XG4gICAgICBjc3M9e3tcbiAgICAgICAgbGFiZWw6ICdkdW1teUlucHV0JyxcbiAgICAgICAgLy8gZ2V0IHJpZCBvZiBhbnkgZGVmYXVsdCBzdHlsZXNcbiAgICAgICAgYmFja2dyb3VuZDogMCxcbiAgICAgICAgYm9yZGVyOiAwLFxuICAgICAgICAvLyBpbXBvcnRhbnQhIHRoaXMgaGlkZXMgdGhlIGZsYXNoaW5nIGN1cnNvclxuICAgICAgICBjYXJldENvbG9yOiAndHJhbnNwYXJlbnQnLFxuICAgICAgICBmb250U2l6ZTogJ2luaGVyaXQnLFxuICAgICAgICBncmlkQXJlYTogJzEgLyAxIC8gMiAvIDMnLFxuICAgICAgICBvdXRsaW5lOiAwLFxuICAgICAgICBwYWRkaW5nOiAwLFxuICAgICAgICAvLyBpbXBvcnRhbnQhIHdpdGhvdXQgYHdpZHRoYCBicm93c2VycyB3b24ndCBhbGxvdyBmb2N1c1xuICAgICAgICB3aWR0aDogMSxcblxuICAgICAgICAvLyByZW1vdmUgY3Vyc29yIG9uIGRlc2t0b3BcbiAgICAgICAgY29sb3I6ICd0cmFuc3BhcmVudCcsXG5cbiAgICAgICAgLy8gcmVtb3ZlIGN1cnNvciBvbiBtb2JpbGUgd2hpbHN0IG1haW50YWluaW5nIFwic2Nyb2xsIGludG8gdmlld1wiIGJlaGF2aW91clxuICAgICAgICBsZWZ0OiAtMTAwLFxuICAgICAgICBvcGFjaXR5OiAwLFxuICAgICAgICBwb3NpdGlvbjogJ3JlbGF0aXZlJyxcbiAgICAgICAgdHJhbnNmb3JtOiAnc2NhbGUoLjAxKScsXG4gICAgICB9fVxuICAgIC8+XG4gICk7XG59XG4iXX0= */")
4810
+ }, process.env.NODE_ENV === "production" ? "" : ";label:DummyInput;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkR1bW15SW5wdXQudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXlCTSIsImZpbGUiOiJEdW1teUlucHV0LnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8qKiBAanN4IGpzeCAqL1xuaW1wb3J0IHsgSlNYLCBSZWYgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgeyBqc3ggfSBmcm9tICdAZW1vdGlvbi9yZWFjdCc7XG5pbXBvcnQgeyByZW1vdmVQcm9wcyB9IGZyb20gJy4uL3V0aWxzJztcblxuZXhwb3J0IGRlZmF1bHQgZnVuY3Rpb24gRHVtbXlJbnB1dCh7XG4gIGlubmVyUmVmLFxuICAuLi5wcm9wc1xufTogSlNYLkludHJpbnNpY0VsZW1lbnRzWydpbnB1dCddICYge1xuICByZWFkb25seSBpbm5lclJlZjogUmVmPEhUTUxJbnB1dEVsZW1lbnQ+O1xufSkge1xuICAvLyBSZW1vdmUgYW5pbWF0aW9uIHByb3BzIG5vdCBtZWFudCBmb3IgSFRNTCBlbGVtZW50c1xuICBjb25zdCBmaWx0ZXJlZFByb3BzID0gcmVtb3ZlUHJvcHMoXG4gICAgcHJvcHMsXG4gICAgJ29uRXhpdGVkJyxcbiAgICAnaW4nLFxuICAgICdlbnRlcicsXG4gICAgJ2V4aXQnLFxuICAgICdhcHBlYXInXG4gICk7XG5cbiAgcmV0dXJuIChcbiAgICA8aW5wdXRcbiAgICAgIHJlZj17aW5uZXJSZWZ9XG4gICAgICB7Li4uZmlsdGVyZWRQcm9wc31cbiAgICAgIGNzcz17e1xuICAgICAgICBsYWJlbDogJ2R1bW15SW5wdXQnLFxuICAgICAgICAvLyBnZXQgcmlkIG9mIGFueSBkZWZhdWx0IHN0eWxlc1xuICAgICAgICBiYWNrZ3JvdW5kOiAwLFxuICAgICAgICBib3JkZXI6IDAsXG4gICAgICAgIC8vIGltcG9ydGFudCEgdGhpcyBoaWRlcyB0aGUgZmxhc2hpbmcgY3Vyc29yXG4gICAgICAgIGNhcmV0Q29sb3I6ICd0cmFuc3BhcmVudCcsXG4gICAgICAgIGZvbnRTaXplOiAnaW5oZXJpdCcsXG4gICAgICAgIGdyaWRBcmVhOiAnMSAvIDEgLyAyIC8gMycsXG4gICAgICAgIG91dGxpbmU6IDAsXG4gICAgICAgIHBhZGRpbmc6IDAsXG4gICAgICAgIC8vIGltcG9ydGFudCEgd2l0aG91dCBgd2lkdGhgIGJyb3dzZXJzIHdvbid0IGFsbG93IGZvY3VzXG4gICAgICAgIHdpZHRoOiAxLFxuXG4gICAgICAgIC8vIHJlbW92ZSBjdXJzb3Igb24gZGVza3RvcFxuICAgICAgICBjb2xvcjogJ3RyYW5zcGFyZW50JyxcblxuICAgICAgICAvLyByZW1vdmUgY3Vyc29yIG9uIG1vYmlsZSB3aGlsc3QgbWFpbnRhaW5pbmcgXCJzY3JvbGwgaW50byB2aWV3XCIgYmVoYXZpb3VyXG4gICAgICAgIGxlZnQ6IC0xMDAsXG4gICAgICAgIG9wYWNpdHk6IDAsXG4gICAgICAgIHBvc2l0aW9uOiAncmVsYXRpdmUnLFxuICAgICAgICB0cmFuc2Zvcm06ICdzY2FsZSguMDEpJyxcbiAgICAgIH19XG4gICAgLz5cbiAgKTtcbn1cbiJdfQ== */")
5472
4811
  }));
5473
4812
  }
5474
4813
 
@@ -5581,7 +4920,7 @@ var LOCK_STYLES = {
5581
4920
  height: '100%'
5582
4921
  };
5583
4922
  function preventTouchMove(e) {
5584
- e.preventDefault();
4923
+ if (e.cancelable) e.preventDefault();
5585
4924
  }
5586
4925
  function allowTouchMove(e) {
5587
4926
  e.stopPropagation();
@@ -6083,7 +5422,8 @@ var Select = /*#__PURE__*/function (_Component) {
6083
5422
  prevWasFocused: false,
6084
5423
  inputIsHiddenAfterUpdate: undefined,
6085
5424
  prevProps: undefined,
6086
- instancePrefix: ''
5425
+ instancePrefix: '',
5426
+ isAppleDevice: false
6087
5427
  };
6088
5428
  _this.blockOptionHover = false;
6089
5429
  _this.isComposing = false;
@@ -6093,7 +5433,6 @@ var Select = /*#__PURE__*/function (_Component) {
6093
5433
  _this.openAfterFocus = false;
6094
5434
  _this.scrollToFocusedOptionOnUpdate = false;
6095
5435
  _this.userIsDragging = void 0;
6096
- _this.isAppleDevice = isAppleDevice();
6097
5436
  _this.controlRef = null;
6098
5437
  _this.getControlRef = function (ref) {
6099
5438
  _this.controlRef = ref;
@@ -6203,10 +5542,12 @@ var Select = /*#__PURE__*/function (_Component) {
6203
5542
  var lastSelectedValue = selectValue[selectValue.length - 1];
6204
5543
  var newValueArray = selectValue.slice(0, selectValue.length - 1);
6205
5544
  var newValue = valueTernary(isMulti, newValueArray, newValueArray[0] || null);
6206
- _this.onChange(newValue, {
6207
- action: 'pop-value',
6208
- removedValue: lastSelectedValue
6209
- });
5545
+ if (lastSelectedValue) {
5546
+ _this.onChange(newValue, {
5547
+ action: 'pop-value',
5548
+ removedValue: lastSelectedValue
5549
+ });
5550
+ }
6210
5551
  };
6211
5552
  _this.getFocusedOptionId = function (focusedOption) {
6212
5553
  return getFocusedOptionId(_this.state.focusableOptionsWithIds, focusedOption);
@@ -6628,6 +5969,12 @@ var Select = /*#__PURE__*/function (_Component) {
6628
5969
  if (this.props.menuIsOpen && this.state.focusedOption && this.menuListRef && this.focusedOptionRef) {
6629
5970
  scrollIntoView(this.menuListRef, this.focusedOptionRef);
6630
5971
  }
5972
+ if (isAppleDevice()) {
5973
+ // eslint-disable-next-line react/no-did-mount-set-state
5974
+ this.setState({
5975
+ isAppleDevice: true
5976
+ });
5977
+ }
6631
5978
  }
6632
5979
  }, {
6633
5980
  key: "componentDidUpdate",
@@ -7007,7 +6354,7 @@ var Select = /*#__PURE__*/function (_Component) {
7007
6354
  'aria-labelledby': this.props['aria-labelledby'],
7008
6355
  'aria-required': required,
7009
6356
  role: 'combobox',
7010
- 'aria-activedescendant': this.isAppleDevice ? undefined : this.state.focusedOptionId || ''
6357
+ 'aria-activedescendant': this.state.isAppleDevice ? undefined : this.state.focusedOptionId || ''
7011
6358
  }, menuIsOpen && {
7012
6359
  'aria-controls': this.getElementId('listbox')
7013
6360
  }), !isSearchable && {
@@ -7256,7 +6603,7 @@ var Select = /*#__PURE__*/function (_Component) {
7256
6603
  onMouseOver: onHover,
7257
6604
  tabIndex: -1,
7258
6605
  role: 'option',
7259
- 'aria-selected': _this4.isAppleDevice ? undefined : isSelected // is not supported on Apple devices
6606
+ 'aria-selected': _this4.state.isAppleDevice ? undefined : isSelected // is not supported on Apple devices
7260
6607
  };
7261
6608
 
7262
6609
  return /*#__PURE__*/React__namespace.createElement(Option, _extends({}, commonProps, {
@@ -7435,7 +6782,7 @@ var Select = /*#__PURE__*/function (_Component) {
7435
6782
  isFocused: isFocused,
7436
6783
  selectValue: selectValue,
7437
6784
  focusableOptions: focusableOptions,
7438
- isAppleDevice: this.isAppleDevice
6785
+ isAppleDevice: this.state.isAppleDevice
7439
6786
  }));
7440
6787
  }
7441
6788
  }, {