@splunk/react-ui 4.12.0 → 4.13.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (99) hide show
  1. package/Accordion.js +4 -4
  2. package/Anchor.js +2 -2
  3. package/Animation.js +4 -4
  4. package/AnimationToggle.js +2 -2
  5. package/Box.js +2 -2
  6. package/Button.js +11 -11
  7. package/ButtonGroup.js +2 -2
  8. package/ButtonSimple.js +7 -7
  9. package/CHANGELOG.md +25 -0
  10. package/Calendar.js +33 -33
  11. package/Card.js +13 -13
  12. package/CardLayout.js +2 -2
  13. package/Chip.js +11 -11
  14. package/Clickable.js +7 -7
  15. package/CloseButton.js +11 -11
  16. package/Code.js +4 -4
  17. package/CollapsiblePanel.js +6 -6
  18. package/Color.js +21 -21
  19. package/ColumnLayout.js +4 -4
  20. package/ComboBox.js +4 -4
  21. package/Concertina.js +2 -2
  22. package/ControlGroup.js +4 -4
  23. package/Date.js +4 -4
  24. package/DefinitionList.js +2 -2
  25. package/Dropdown.js +6 -2
  26. package/EventListener.js +4 -4
  27. package/File.js +15 -15
  28. package/FormRows.js +4 -4
  29. package/Heading.js +3 -3
  30. package/Image.js +15 -15
  31. package/JSONTree.js +2 -2
  32. package/Layer.js +4 -4
  33. package/Link.js +9 -9
  34. package/List.js +2 -2
  35. package/Markdown.js +21 -21
  36. package/Menu.js +32 -33
  37. package/Message.js +22 -22
  38. package/MessageBar.js +15 -15
  39. package/Modal.js +4 -4
  40. package/ModalLayer.js +8 -8
  41. package/Monogram.js +2 -2
  42. package/Multiselect.js +112 -103
  43. package/Number.js +2 -2
  44. package/Paginator.js +41 -41
  45. package/Paragraph.js +2 -2
  46. package/Popover.js +18 -9
  47. package/Progress.js +4 -4
  48. package/RadioBar.js +2 -2
  49. package/RadioList.js +2 -2
  50. package/Resize.js +2 -2
  51. package/ResultsMenu.js +12 -12
  52. package/ScreenReaderContent.js +2 -2
  53. package/Scroll.js +6 -6
  54. package/ScrollContainerContext.js +2 -2
  55. package/Search.js +13 -13
  56. package/Select.js +109 -100
  57. package/SidePanel.js +4 -4
  58. package/Slider.js +4 -4
  59. package/SlidingPanels.js +6 -6
  60. package/SplitButton.js +511 -0
  61. package/StaticContent.js +2 -2
  62. package/StepBar.js +6 -6
  63. package/Switch.js +2 -2
  64. package/TabBar.js +2 -2
  65. package/TabLayout.js +4 -4
  66. package/Table.js +60 -43
  67. package/Text.js +105 -101
  68. package/TextArea.js +83 -72
  69. package/Tooltip.js +2 -2
  70. package/TransitionOpen.js +8 -8
  71. package/Typography.js +4 -4
  72. package/WaitSpinner.js +68 -2
  73. package/package.json +4 -3
  74. package/types/src/Button/Button.d.ts +1 -1
  75. package/types/src/Dropdown/Dropdown.d.ts +11 -3
  76. package/types/src/Popover/Popover.d.ts +5 -1
  77. package/types/src/Popover/getPlacement.d.ts +1 -1
  78. package/types/src/SplitButton/Item.d.ts +45 -0
  79. package/types/src/SplitButton/SplitButton.d.ts +41 -0
  80. package/types/src/SplitButton/docs/examples/Basic.d.ts +1 -0
  81. package/types/src/SplitButton/docs/examples/ChangeLabel.d.ts +1 -0
  82. package/types/src/SplitButton/docs/examples/Disabled.d.ts +1 -0
  83. package/types/src/SplitButton/docs/examples/prisma/Basic.d.ts +1 -0
  84. package/types/src/SplitButton/docs/examples/prisma/Disabled.d.ts +1 -0
  85. package/types/src/SplitButton/index.d.ts +2 -0
  86. package/types/src/Table/HeadCell.d.ts +4 -1
  87. package/types/src/Table/HeadDropdownCell.d.ts +10 -3
  88. package/types/src/Text/Text.d.ts +5 -1
  89. package/types/src/TextArea/TextArea.d.ts +5 -1
  90. package/types/src/WaitSpinner/WaitSpinner.d.ts +1 -1
  91. package/types/src/useForceUpdate/index.d.ts +2 -0
  92. package/types/src/useForceUpdate/useForceUpdate.d.ts +9 -0
  93. package/types/src/useIsSsr/index.d.ts +2 -0
  94. package/types/src/useIsSsr/useIsSsr.d.ts +8 -0
  95. package/useForceUpdate.js +151 -0
  96. package/useIsSsr.js +153 -0
  97. package/usePrevious.js +2 -2
  98. package/types/src/Text/docs/examples/prisma/Multiline.d.ts +0 -10
  99. package/types/src/Text/docs/examples/prisma/Search.d.ts +0 -10
package/Table.js CHANGED
@@ -82,7 +82,7 @@ module.exports =
82
82
  /******/
83
83
  /******/
84
84
  /******/ // Load entry module and return exports
85
- /******/ return __webpack_require__(__webpack_require__.s = 110);
85
+ /******/ return __webpack_require__(__webpack_require__.s = 112);
86
86
  /******/ })
87
87
  /************************************************************************/
88
88
  /******/ ([
@@ -328,14 +328,14 @@ module.exports = require("@splunk/react-ui/Button");
328
328
  module.exports = require("@splunk/react-ui/Popover");
329
329
 
330
330
  /***/ }),
331
- /* 18 */,
332
- /* 19 */,
333
- /* 20 */
331
+ /* 18 */
334
332
  /***/ (function(module, exports) {
335
333
 
336
334
  module.exports = require("@splunk/react-ui/Dropdown");
337
335
 
338
336
  /***/ }),
337
+ /* 19 */,
338
+ /* 20 */,
339
339
  /* 21 */,
340
340
  /* 22 */,
341
341
  /* 23 */,
@@ -349,7 +349,7 @@ module.exports = require("@splunk/react-ui/Dropdown");
349
349
  /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return ChevronRight; });
350
350
  /* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(2);
351
351
  /* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(react__WEBPACK_IMPORTED_MODULE_0__);
352
- /* harmony import */ var _splunk_react_icons_ChevronRight__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(32);
352
+ /* harmony import */ var _splunk_react_icons_ChevronRight__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(33);
353
353
  /* harmony import */ var _splunk_react_icons_ChevronRight__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_splunk_react_icons_ChevronRight__WEBPACK_IMPORTED_MODULE_1__);
354
354
  /* harmony import */ var _ThemedIcon__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(7);
355
355
  /* harmony import */ var _SVG__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(6);
@@ -395,13 +395,13 @@ function ChevronRight(props) {
395
395
  /* 29 */,
396
396
  /* 30 */,
397
397
  /* 31 */,
398
- /* 32 */
398
+ /* 32 */,
399
+ /* 33 */
399
400
  /***/ (function(module, exports) {
400
401
 
401
402
  module.exports = require("@splunk/react-icons/ChevronRight");
402
403
 
403
404
  /***/ }),
404
- /* 33 */,
405
405
  /* 34 */,
406
406
  /* 35 */,
407
407
  /* 36 */,
@@ -466,14 +466,20 @@ module.exports = require("@splunk/react-icons/Caret");
466
466
  /* 49 */
467
467
  /***/ (function(module, exports) {
468
468
 
469
+ module.exports = require("@splunk/react-icons/ChevronDown");
470
+
471
+ /***/ }),
472
+ /* 50 */
473
+ /***/ (function(module, exports) {
474
+
469
475
  module.exports = require("@splunk/react-ui/Tooltip");
470
476
 
471
477
  /***/ }),
472
- /* 50 */,
473
478
  /* 51 */,
474
479
  /* 52 */,
475
480
  /* 53 */,
476
- /* 54 */
481
+ /* 54 */,
482
+ /* 55 */
477
483
  /***/ (function(module, __webpack_exports__, __webpack_require__) {
478
484
 
479
485
  "use strict";
@@ -496,21 +502,21 @@ function assertDefined(val, msg) {
496
502
 
497
503
 
498
504
  /***/ }),
499
- /* 55 */,
500
505
  /* 56 */,
501
506
  /* 57 */,
502
507
  /* 58 */,
503
508
  /* 59 */,
504
509
  /* 60 */,
505
510
  /* 61 */,
506
- /* 62 */
511
+ /* 62 */,
512
+ /* 63 */
507
513
  /***/ (function(module, __webpack_exports__, __webpack_require__) {
508
514
 
509
515
  "use strict";
510
516
  /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return MoreVertical; });
511
517
  /* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(2);
512
518
  /* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(react__WEBPACK_IMPORTED_MODULE_0__);
513
- /* harmony import */ var _splunk_react_icons_MoreVertical__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(63);
519
+ /* harmony import */ var _splunk_react_icons_MoreVertical__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(64);
514
520
  /* harmony import */ var _splunk_react_icons_MoreVertical__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_splunk_react_icons_MoreVertical__WEBPACK_IMPORTED_MODULE_1__);
515
521
  /* harmony import */ var _ThemedIcon__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(7);
516
522
  /* harmony import */ var _SVG__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(6);
@@ -540,20 +546,20 @@ function MoreVertical(props) {
540
546
  }
541
547
 
542
548
  /***/ }),
543
- /* 63 */
549
+ /* 64 */
544
550
  /***/ (function(module, exports) {
545
551
 
546
552
  module.exports = require("@splunk/react-icons/MoreVertical");
547
553
 
548
554
  /***/ }),
549
- /* 64 */
555
+ /* 65 */
550
556
  /***/ (function(module, __webpack_exports__, __webpack_require__) {
551
557
 
552
558
  "use strict";
553
559
  /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return ChevronDown; });
554
560
  /* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(2);
555
561
  /* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(react__WEBPACK_IMPORTED_MODULE_0__);
556
- /* harmony import */ var _splunk_react_icons_ChevronDown__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(65);
562
+ /* harmony import */ var _splunk_react_icons_ChevronDown__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(49);
557
563
  /* harmony import */ var _splunk_react_icons_ChevronDown__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(_splunk_react_icons_ChevronDown__WEBPACK_IMPORTED_MODULE_1__);
558
564
  /* harmony import */ var _ThemedIcon__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(7);
559
565
  /* harmony import */ var _SVG__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(6);
@@ -594,12 +600,6 @@ function ChevronDown(props) {
594
600
  }, props));
595
601
  }
596
602
 
597
- /***/ }),
598
- /* 65 */
599
- /***/ (function(module, exports) {
600
-
601
- module.exports = require("@splunk/react-icons/ChevronDown");
602
-
603
603
  /***/ }),
604
604
  /* 66 */,
605
605
  /* 67 */,
@@ -643,39 +643,41 @@ module.exports = require("@splunk/react-ui/Switch");
643
643
  /* 100 */,
644
644
  /* 101 */,
645
645
  /* 102 */,
646
- /* 103 */
646
+ /* 103 */,
647
+ /* 104 */,
648
+ /* 105 */
647
649
  /***/ (function(module, exports) {
648
650
 
649
651
  module.exports = require("react-resize-detector");
650
652
 
651
653
  /***/ }),
652
- /* 104 */
654
+ /* 106 */
653
655
  /***/ (function(module, exports) {
654
656
 
655
657
  module.exports = require("@splunk/react-icons/SortedDown");
656
658
 
657
659
  /***/ }),
658
- /* 105 */
660
+ /* 107 */
659
661
  /***/ (function(module, exports) {
660
662
 
661
663
  module.exports = require("@splunk/react-icons/SortedUp");
662
664
 
663
665
  /***/ }),
664
- /* 106 */
666
+ /* 108 */
665
667
  /***/ (function(module, exports) {
666
668
 
667
669
  module.exports = require("@splunk/react-icons/Sort");
668
670
 
669
671
  /***/ }),
670
- /* 107 */
672
+ /* 109 */
671
673
  /***/ (function(module, exports) {
672
674
 
673
675
  module.exports = require("@splunk/react-icons/Info");
674
676
 
675
677
  /***/ }),
676
- /* 108 */,
677
- /* 109 */,
678
- /* 110 */
678
+ /* 110 */,
679
+ /* 111 */,
680
+ /* 112 */
679
681
  /***/ (function(module, __webpack_exports__, __webpack_require__) {
680
682
 
681
683
  "use strict";
@@ -704,7 +706,7 @@ var external_prop_types_default = /*#__PURE__*/__webpack_require__.n(external_pr
704
706
  var external_lodash_ = __webpack_require__(4);
705
707
 
706
708
  // EXTERNAL MODULE: external "react-resize-detector"
707
- var external_react_resize_detector_ = __webpack_require__(103);
709
+ var external_react_resize_detector_ = __webpack_require__(105);
708
710
  var external_react_resize_detector_default = /*#__PURE__*/__webpack_require__.n(external_react_resize_detector_);
709
711
 
710
712
  // EXTERNAL MODULE: external "@splunk/react-ui/EventListener"
@@ -1408,7 +1410,7 @@ Cell_defineProperty(Cell_Cell, "defaultProps", Cell_defaultProps);
1408
1410
  var i18n_ = __webpack_require__(5);
1409
1411
 
1410
1412
  // EXTERNAL MODULE: external "@splunk/react-icons/SortedDown"
1411
- var SortedDown_ = __webpack_require__(104);
1413
+ var SortedDown_ = __webpack_require__(106);
1412
1414
  var SortedDown_default = /*#__PURE__*/__webpack_require__.n(SortedDown_);
1413
1415
 
1414
1416
  // EXTERNAL MODULE: ./src/icons/ThemedIcon.tsx
@@ -1455,7 +1457,7 @@ function SortedDown(props) {
1455
1457
  }, props));
1456
1458
  }
1457
1459
  // EXTERNAL MODULE: external "@splunk/react-icons/SortedUp"
1458
- var SortedUp_ = __webpack_require__(105);
1460
+ var SortedUp_ = __webpack_require__(107);
1459
1461
  var SortedUp_default = /*#__PURE__*/__webpack_require__.n(SortedUp_);
1460
1462
 
1461
1463
  // CONCATENATED MODULE: ./src/icons/SortedUp.tsx
@@ -1496,7 +1498,7 @@ function SortedUp(props) {
1496
1498
  }, props));
1497
1499
  }
1498
1500
  // EXTERNAL MODULE: external "@splunk/react-icons/Sort"
1499
- var Sort_ = __webpack_require__(106);
1501
+ var Sort_ = __webpack_require__(108);
1500
1502
  var Sort_default = /*#__PURE__*/__webpack_require__.n(Sort_);
1501
1503
 
1502
1504
  // CONCATENATED MODULE: ./src/icons/Sort.tsx
@@ -2275,6 +2277,8 @@ var HeadCell_propTypes = {
2275
2277
 
2276
2278
  /** @private. */
2277
2279
  variant: external_prop_types_default.a.oneOf(['toggleAll', 'info', 'actions']),
2280
+
2281
+ /** @private. */
2278
2282
  zIndex: external_prop_types_default.a.number
2279
2283
  };
2280
2284
  var HeadCell_defaultProps = {
@@ -2472,7 +2476,7 @@ HeadCell_defineProperty(HeadCell_HeadCell, "contextType", Table_TableContext);
2472
2476
 
2473
2477
  /* harmony default export */ var Table_HeadCell = (HeadCell_HeadCell);
2474
2478
  // EXTERNAL MODULE: external "@splunk/react-icons/Info"
2475
- var Info_ = __webpack_require__(107);
2479
+ var Info_ = __webpack_require__(109);
2476
2480
  var Info_default = /*#__PURE__*/__webpack_require__.n(Info_);
2477
2481
 
2478
2482
  // EXTERNAL MODULE: ./src/icons/ChevronRight.tsx
@@ -2504,18 +2508,18 @@ var Button_ = __webpack_require__(16);
2504
2508
  var Button_default = /*#__PURE__*/__webpack_require__.n(Button_);
2505
2509
 
2506
2510
  // EXTERNAL MODULE: external "@splunk/react-ui/Dropdown"
2507
- var Dropdown_ = __webpack_require__(20);
2511
+ var Dropdown_ = __webpack_require__(18);
2508
2512
  var Dropdown_default = /*#__PURE__*/__webpack_require__.n(Dropdown_);
2509
2513
 
2510
2514
  // EXTERNAL MODULE: external "@splunk/react-ui/Tooltip"
2511
- var Tooltip_ = __webpack_require__(49);
2515
+ var Tooltip_ = __webpack_require__(50);
2512
2516
  var Tooltip_default = /*#__PURE__*/__webpack_require__.n(Tooltip_);
2513
2517
 
2514
2518
  // EXTERNAL MODULE: ./src/icons/ChevronDown.tsx
2515
- var ChevronDown = __webpack_require__(64);
2519
+ var ChevronDown = __webpack_require__(65);
2516
2520
 
2517
2521
  // EXTERNAL MODULE: ./src/icons/MoreVertical.tsx
2518
- var MoreVertical = __webpack_require__(62);
2522
+ var MoreVertical = __webpack_require__(63);
2519
2523
 
2520
2524
  // CONCATENATED MODULE: ./src/Table/RowDragCell.tsx
2521
2525
  function RowDragCell_typeof(obj) { "@babel/helpers - typeof"; if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { RowDragCell_typeof = function _typeof(obj) { return typeof obj; }; } else { RowDragCell_typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return RowDragCell_typeof(obj); }
@@ -3681,6 +3685,9 @@ function HeadDropdownCell_defineProperty(obj, key, value) { if (key in obj) { Ob
3681
3685
 
3682
3686
 
3683
3687
 
3688
+
3689
+ /** @public */
3690
+
3684
3691
  var possibleCloseReasons = ['clickAway', 'contentClick', 'escapeKey', 'offScreen', 'tabKey', 'toggleClick'];
3685
3692
  var HeadDropdownCell_propTypes = {
3686
3693
  align: external_prop_types_default.a.oneOf(['left', 'center', 'right']),
@@ -3733,7 +3740,10 @@ var HeadDropdownCell_propTypes = {
3733
3740
  width: external_prop_types_default.a.number,
3734
3741
 
3735
3742
  /** @private. */
3736
- variant: external_prop_types_default.a.oneOf(['toggleAll', 'info', 'actions'])
3743
+ variant: external_prop_types_default.a.oneOf(['toggleAll', 'info', 'actions']),
3744
+
3745
+ /** @private. */
3746
+ zIndex: external_prop_types_default.a.number
3737
3747
  };
3738
3748
  var HeadDropdownCell_defaultProps = {
3739
3749
  align: 'left',
@@ -3746,7 +3756,8 @@ var HeadDropdownCell_defaultProps = {
3746
3756
  retainFocus: false,
3747
3757
  takeFocus: true,
3748
3758
  truncate: true,
3749
- visible: true
3759
+ visible: true,
3760
+ zIndex: 1
3750
3761
  };
3751
3762
 
3752
3763
  var HeadDropdownCell_HeadDropdownCell = /*#__PURE__*/function (_Component) {
@@ -3991,11 +4002,13 @@ var HeadDropdownCell_HeadDropdownCell = /*#__PURE__*/function (_Component) {
3991
4002
  truncate = _this$props6.truncate,
3992
4003
  variant = _this$props6.variant,
3993
4004
  visible = _this$props6.visible,
3994
- width = _this$props6.width;
4005
+ width = _this$props6.width,
4006
+ zIndex = _this$props6.zIndex;
3995
4007
  var _this$state = this.state,
3996
4008
  el = _this$state.el,
3997
4009
  clientX = _this$state.clientX;
3998
4010
  var cellId = id || this.cellId;
4011
+ var headType = this.context.headType;
3999
4012
  return /*#__PURE__*/external_react_default.a.createElement(HeadCellStyles_Styled, HeadDropdownCell_extends({
4000
4013
  style: Object(external_lodash_["merge"])(style, {
4001
4014
  width: width
@@ -4012,7 +4025,9 @@ var HeadDropdownCell_HeadDropdownCell = /*#__PURE__*/function (_Component) {
4012
4025
  onKeyDown: this.handleKeyDown,
4013
4026
  "aria-haspopup": true,
4014
4027
  "aria-owns": this.popoverId,
4015
- "aria-expanded": this.isOpen()
4028
+ "aria-expanded": this.isOpen(),
4029
+ $isFixed: headType === 'fixed',
4030
+ $zIndex: zIndex
4016
4031
  }), /*#__PURE__*/external_react_default.a.createElement(Table_HeadInner, {
4017
4032
  label: label,
4018
4033
  align: align,
@@ -4073,6 +4088,8 @@ HeadDropdownCell_defineProperty(HeadDropdownCell_HeadDropdownCell, "propTypes",
4073
4088
 
4074
4089
  HeadDropdownCell_defineProperty(HeadDropdownCell_HeadDropdownCell, "defaultProps", HeadDropdownCell_defaultProps);
4075
4090
 
4091
+ HeadDropdownCell_defineProperty(HeadDropdownCell_HeadDropdownCell, "contextType", Table_TableContext);
4092
+
4076
4093
  /* harmony default export */ var Table_HeadDropdownCell = (HeadDropdownCell_HeadDropdownCell);
4077
4094
  // CONCATENATED MODULE: ./src/Table/HeadTableStyles.ts
4078
4095
 
@@ -4259,7 +4276,7 @@ HeadTable_defineProperty(HeadTable_HeadTable, "defaultProps", HeadTable_defaultP
4259
4276
 
4260
4277
  /* harmony default export */ var Table_HeadTable = (HeadTable_HeadTable);
4261
4278
  // EXTERNAL MODULE: ./src/utils/types.ts
4262
- var types = __webpack_require__(54);
4279
+ var types = __webpack_require__(55);
4263
4280
 
4264
4281
  // CONCATENATED MODULE: ./src/Table/Table.tsx
4265
4282
  function Table_typeof(obj) { "@babel/helpers - typeof"; if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { Table_typeof = function _typeof(obj) { return typeof obj; }; } else { Table_typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return Table_typeof(obj); }