@semcore/select 3.0.9 → 3.0.12

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/CHANGELOG.md CHANGED
@@ -2,6 +2,24 @@
2
2
 
3
3
  CHANGELOG.md standards are inspired by [keepachangelog.com](https://keepachangelog.com/en/1.0.0/).
4
4
 
5
+ ## [3.0.12] - 2022-07-14
6
+
7
+ ### Changed
8
+
9
+ - Version patch update due to children dependencies update (`@semcore/input` [3.0.7 ~> 3.0.8]).
10
+
11
+ ## [3.0.11] - 2022-07-13
12
+
13
+ ### Fixed
14
+
15
+ - Fixed color of Addon icons in `InputSearch`.
16
+
17
+ ## [3.0.10] - 2022-07-13
18
+
19
+ ### Changed
20
+
21
+ - Version patch update due to children dependencies update (`@semcore/dropdown-menu` [3.0.5 ~> 3.0.6]).
22
+
5
23
  ## [3.0.9] - 2022-07-07
6
24
 
7
25
  ### Changed
package/README.md CHANGED
@@ -42,12 +42,12 @@ of the components that is discussed below. There should only be one version of t
42
42
 
43
43
  You can use the package the same way but without `/ui/` in the import path.
44
44
 
45
- </details>
46
-
47
45
  ```jsx
48
46
  import Select, { InputSearch } from '@semcore/select';
49
47
  ```
50
48
 
49
+ </details>
50
+
51
51
  ## 👤 Author
52
52
 
53
53
  [UI-kit team](https://github.com/semrush/intergalactic/blob/master/MAINTAINERS) and [others ❤️](https://github.com/semrush/intergalactic/graphs/contributors)
@@ -9,8 +9,6 @@ Object.defineProperty(exports, "__esModule", {
9
9
  });
10
10
  exports["default"] = void 0;
11
11
 
12
- var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
13
-
14
12
  var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
15
13
 
16
14
  var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
@@ -29,20 +27,22 @@ var _core = _interopRequireWildcard(require("@semcore/core"));
29
27
 
30
28
  var _react = _interopRequireDefault(require("react"));
31
29
 
32
- var _flexBox = require("@semcore/flex-box");
33
-
34
- var _input = _interopRequireDefault(require("@semcore/input"));
35
-
36
30
  var _m = _interopRequireDefault(require("@semcore/icon/Search/m"));
37
31
 
38
32
  var _m2 = _interopRequireDefault(require("@semcore/icon/Close/m"));
39
33
 
34
+ var _input = _interopRequireDefault(require("@semcore/input"));
35
+
40
36
  var _context = require("./context");
41
37
 
42
38
  function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
43
39
 
44
40
  function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
45
41
 
42
+ function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
43
+
44
+ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { (0, _defineProperty2["default"])(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
45
+
46
46
  function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = (0, _getPrototypeOf2["default"])(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = (0, _getPrototypeOf2["default"])(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return (0, _possibleConstructorReturn2["default"])(this, result); }; }
47
47
 
48
48
  function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }
@@ -52,15 +52,16 @@ var style = (
52
52
  /*__reshadow_css_start__*/
53
53
  _core.sstyled.insert(
54
54
  /*__inner_css_start__*/
55
- ".___SInputSearch_qj5zn_gg_.__size_qj5zn_gg_{padding:0}.___SInputSearch_qj5zn_gg_>[data-ui-name=Input]:first-child>[data-ui-name=InputSearch]~div{top:-1px;left:-1px;width:100%;border-radius:6px 6px 0 0}.___SInputSearch_qj5zn_gg_._size_m_qj5zn_gg_>[data-ui-name=Input]:first-child{height:32px}.___SInputSearch_qj5zn_gg_ [data-ui-name=\"Input.Addon\"]:last-of-type{visibility:hidden}.___SInputSearch_qj5zn_gg_.__filled_qj5zn_gg_ [data-ui-name=\"Input.Addon\"]:last-of-type{visibility:visible}"
55
+ ".___SInputSearch_py0ps_gg_._size_m_py0ps_gg_{height:32px}.___SClose_py0ps_gg_.__hide_py0ps_gg_{visibility:hidden}.___SOutline_py0ps_gg_{top:-1px;left:-1px;width:100%;border-radius:6px 6px 0 0}"
56
56
  /*__inner_css_end__*/
57
- , "16lophm_gg_")
57
+ , "py0ps_gg_")
58
58
  /*__reshadow_css_end__*/
59
59
  , {
60
- "__SInputSearch": "___SInputSearch_qj5zn_gg_",
61
- "_size": "__size_qj5zn_gg_",
62
- "_size_m": "_size_m_qj5zn_gg_",
63
- "_filled": "__filled_qj5zn_gg_"
60
+ "__SInputSearch": "___SInputSearch_py0ps_gg_",
61
+ "_size_m": "_size_m_py0ps_gg_",
62
+ "__SClose": "___SClose_py0ps_gg_",
63
+ "_hide": "__hide_py0ps_gg_",
64
+ "__SOutline": "___SOutline_py0ps_gg_"
64
65
  });
65
66
  var MAP_SIZE_TO_ICON = {
66
67
  m: [_m["default"], _m2["default"]],
@@ -98,31 +99,32 @@ var InputSearch = /*#__PURE__*/function (_Component) {
98
99
  }, {
99
100
  key: "render",
100
101
  value: function render() {
101
- var _ref;
102
+ var _ref = this.asProps,
103
+ _ref2;
102
104
 
103
- var SInputSearch = _flexBox.Box;
105
+ var Value = _input["default"].Value;
106
+ var SInputSearch = _input["default"];
107
+ var SClose = _input["default"].Addon;
104
108
  var _this$asProps = this.asProps,
105
109
  size = _this$asProps.size,
106
110
  value = _this$asProps.value,
107
- forwardRef = _this$asProps.forwardRef,
108
111
  styles = _this$asProps.styles;
109
112
  var finalSize = size || this.context.size;
110
- return _ref = (0, _core.sstyled)(styles), /*#__PURE__*/_react["default"].createElement(SInputSearch, _ref.cn("SInputSearch", {
113
+ var hideClose = !value;
114
+ var IconClose = MAP_SIZE_TO_ICON[finalSize][1];
115
+ var IconSearch = MAP_SIZE_TO_ICON[finalSize][0];
116
+ return _ref2 = (0, _core.sstyled)(styles), /*#__PURE__*/_react["default"].createElement(SInputSearch, _ref2.cn("SInputSearch", {
111
117
  "size": finalSize,
112
- "use:filled": value
113
- }), /*#__PURE__*/_react["default"].createElement(_input["default"], _ref.cn("Input", {
114
- "size": finalSize
115
- }), /*#__PURE__*/_react["default"].createElement(_input["default"].Addon, {
116
- tag: MAP_SIZE_TO_ICON[finalSize][0]
117
- }), /*#__PURE__*/_react["default"].createElement(_input["default"].Value, (0, _extends2["default"])({
118
- ref: forwardRef,
119
- autoFocus: true
120
- }, this.asProps)), /*#__PURE__*/_react["default"].createElement(_input["default"].Addon, {
121
- tag: MAP_SIZE_TO_ICON[finalSize][1],
122
- role: "button",
123
- interactive: true,
124
- onClick: this.handleClear
125
- })));
118
+ "styles": styles
119
+ }), /*#__PURE__*/_react["default"].createElement(_input["default"].Addon, null, /*#__PURE__*/_react["default"].createElement(IconSearch, _ref2.cn("IconSearch", {}))), /*#__PURE__*/_react["default"].createElement(Value, _ref2.cn("Value", _objectSpread({}, (0, _core.assignProps)({
120
+ "autoFocus": true
121
+ }, _ref)))), /*#__PURE__*/_react["default"].createElement(SClose, _ref2.cn("SClose", {
122
+ "role": "button",
123
+ "hide": hideClose,
124
+ "aria-hidden": hideClose,
125
+ "interactive": true,
126
+ "onClick": this.handleClear
127
+ }), /*#__PURE__*/_react["default"].createElement(IconClose, _ref2.cn("IconClose", {}))));
126
128
  }
127
129
  }]);
128
130
  return InputSearch;
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/InputSearch.jsx"],"names":["MAP_SIZE_TO_ICON","m","SearchM","CloseM","l","InputSearch","e","handlers","value","SInputSearch","Box","asProps","size","forwardRef","styles","finalSize","context","handleClear","Component","style","defaultValue","selectContext"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;AACA;;AADA;;AAEA;;AACA;;AACA;;AACA;;AACA;;;;;;;;;;;;;;;;;;;;;;;;;AAIA,IAAMA,gBAAgB,GAAG;AACvBC,EAAAA,CAAC,EAAE,CAACC,aAAD,EAAUC,cAAV,CADoB;AAEvBC,EAAAA,CAAC,EAAE,CAACF,aAAD,EAAUC,cAAV;AAFoB,CAAzB;;IAKME,W;;;;;;;;;;;;;;;oGAiBU,UAACC,CAAD,EAAO;AACnB,YAAKC,QAAL,CAAcC,KAAd,CAAoB,EAApB,EAAwBF,CAAxB;AACD,K;;;;;;WARD,6BAAoB;AAClB,aAAO;AACLE,QAAAA,KAAK,EAAE;AADF,OAAP;AAGD;;;WAMD,kBAAS;AAAA;;AACP,UAAMC,YAAY,GAAGC,YAArB;AACA,0BAA4C,KAAKC,OAAjD;AAAA,UAAQC,IAAR,iBAAQA,IAAR;AAAA,UAAcJ,KAAd,iBAAcA,KAAd;AAAA,UAAqBK,UAArB,iBAAqBA,UAArB;AAAA,UAAiCC,MAAjC,iBAAiCA,MAAjC;AACA,UAAMC,SAAS,GAAGH,IAAI,IAAI,KAAKI,OAAL,CAAaJ,IAAvC;AAEA,oBAAO,mBAAQE,MAAR,CAAP,eACE,gCAAC,YAAD;AAAA,gBAAoBC,SAApB;AAAA,sBAA2CP;AAA3C,uBACE,gCAAC,iBAAD;AAAA,gBAAaO;AAAb,uBACE,gCAAC,iBAAD,CAAO,KAAP;AAAa,QAAA,GAAG,EAAEf,gBAAgB,CAACe,SAAD,CAAhB,CAA4B,CAA5B;AAAlB,QADF,eAEE,gCAAC,iBAAD,CAAO,KAAP;AAAa,QAAA,GAAG,EAAEF,UAAlB;AAA8B,QAAA,SAAS;AAAvC,SAA4C,KAAKF,OAAjD,EAFF,eAGE,gCAAC,iBAAD,CAAO,KAAP;AACE,QAAA,GAAG,EAAEX,gBAAgB,CAACe,SAAD,CAAhB,CAA4B,CAA5B,CADP;AAEE,QAAA,IAAI,EAAC,QAFP;AAGE,QAAA,WAAW,MAHb;AAIE,QAAA,OAAO,EAAE,KAAKE;AAJhB,QAHF,CADF,CADF;AAcD;;;EAxCuBC,e;;iCAApBb,W,iBACiB,a;iCADjBA,W,WAGWc,K;iCAHXd,W,kBAKkB;AACpBe,EAAAA,YAAY,EAAE;AADM,C;iCALlBf,W,iBASiBgB,sB;;eAkCR,sBAAgBhB,WAAhB,C","sourcesContent":["import React from 'react';\nimport createComponent, { Component, sstyled } from '@semcore/core';\nimport { Box } from '@semcore/flex-box';\nimport Input from '@semcore/input';\nimport SearchM from '@semcore/icon/Search/m';\nimport CloseM from '@semcore/icon/Close/m';\nimport { selectContext } from './context';\n\nimport style from './style/input-search.shadow.css';\n\nconst MAP_SIZE_TO_ICON = {\n m: [SearchM, CloseM],\n l: [SearchM, CloseM],\n};\n\nclass InputSearch extends Component {\n static displayName = 'InputSearch';\n\n static style = style;\n\n static defaultProps = {\n defaultValue: '',\n };\n\n static contextType = selectContext;\n\n uncontrolledProps() {\n return {\n value: null,\n };\n }\n\n handleClear = (e) => {\n this.handlers.value('', e);\n };\n\n render() {\n const SInputSearch = Box;\n const { size, value, forwardRef, styles } = this.asProps;\n const finalSize = size || this.context.size;\n\n return sstyled(styles)(\n <SInputSearch size={finalSize} use:filled={value}>\n <Input size={finalSize}>\n <Input.Addon tag={MAP_SIZE_TO_ICON[finalSize][0]} />\n <Input.Value ref={forwardRef} autoFocus {...this.asProps} />\n <Input.Addon\n tag={MAP_SIZE_TO_ICON[finalSize][1]}\n role=\"button\"\n interactive\n onClick={this.handleClear}\n />\n </Input>\n </SInputSearch>,\n );\n }\n}\n\nexport default createComponent(InputSearch);\n"],"file":"InputSearch.js"}
1
+ {"version":3,"sources":["../../src/InputSearch.jsx"],"names":["MAP_SIZE_TO_ICON","m","SearchM","CloseM","l","InputSearch","e","handlers","value","Value","Input","SInputSearch","SClose","Addon","asProps","size","styles","finalSize","context","hideClose","IconClose","IconSearch","handleClear","Component","style","defaultValue","selectContext"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;AACA;;AADA;;AAEA;;AACA;;AACA;;AACA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAIA,IAAMA,gBAAgB,GAAG;AACvBC,EAAAA,CAAC,EAAE,CAACC,aAAD,EAAUC,cAAV,CADoB;AAEvBC,EAAAA,CAAC,EAAE,CAACF,aAAD,EAAUC,cAAV;AAFoB,CAAzB;;IAKME,W;;;;;;;;;;;;;;;oGAiBU,UAACC,CAAD,EAAO;AACnB,YAAKC,QAAL,CAAcC,KAAd,CAAoB,EAApB,EAAwBF,CAAxB;AACD,K;;;;;;WARD,6BAAoB;AAClB,aAAO;AACLE,QAAAA,KAAK,EAAE;AADF,OAAP;AAGD;;;WAMD,kBAAS;AAAA;AAAA;;AACP,UAAMC,KAAK,GAcQC,kBAAMD,KAdzB;AACA,UAAME,YAAY,GAAGD,iBAArB;AACA,UAAME,MAAM,GAAGF,kBAAMG,KAArB;AACA,0BAAgC,KAAKC,OAArC;AAAA,UAAQC,IAAR,iBAAQA,IAAR;AAAA,UAAcP,KAAd,iBAAcA,KAAd;AAAA,UAAqBQ,MAArB,iBAAqBA,MAArB;AACA,UAAMC,SAAS,GAAGF,IAAI,IAAI,KAAKG,OAAL,CAAaH,IAAvC;AACA,UAAMI,SAAS,GAAG,CAACX,KAAnB;AACA,UAAMY,SAAS,GAAGpB,gBAAgB,CAACiB,SAAD,CAAhB,CAA4B,CAA5B,CAAlB;AACA,UAAMI,UAAU,GAAGrB,gBAAgB,CAACiB,SAAD,CAAhB,CAA4B,CAA5B,CAAnB;AAEA,qBAAO,mBAAQD,MAAR,CAAP,eACE,gCAAC,YAAD;AAAA,gBAAoBC,SAApB;AAAA,kBAAuCD;AAAvC,uBACE,gCAAC,iBAAD,CAAO,KAAP,qBACE,gCAAC,UAAD,6BADF,CADF,eAIE,gCAAC,KAAD;AAAA;AAAA,iBAJF,eAKE,gCAAC,MAAD;AAAA,gBACO,QADP;AAAA,gBAGQG,SAHR;AAAA,uBAIeA,SAJf;AAAA;AAAA,mBAMW,KAAKG;AANhB,uBAQE,gCAAC,SAAD,4BARF,CALF,CADF;AAkBD;;;EAjDuBC,e;;iCAApBlB,W,iBACiB,a;iCADjBA,W,WAGWmB,K;iCAHXnB,W,kBAKkB;AACpBoB,EAAAA,YAAY,EAAE;AADM,C;iCALlBpB,W,iBASiBqB,sB;;eA2CR,sBAAgBrB,WAAhB,C","sourcesContent":["import React from 'react';\nimport createComponent, { Component, sstyled, Root } from '@semcore/core';\nimport SearchM from '@semcore/icon/Search/m';\nimport CloseM from '@semcore/icon/Close/m';\nimport Input from '@semcore/input';\nimport { selectContext } from './context';\n\nimport style from './style/input-search.shadow.css';\n\nconst MAP_SIZE_TO_ICON = {\n m: [SearchM, CloseM],\n l: [SearchM, CloseM],\n};\n\nclass InputSearch extends Component {\n static displayName = 'InputSearch';\n\n static style = style;\n\n static defaultProps = {\n defaultValue: '',\n };\n\n static contextType = selectContext;\n\n uncontrolledProps() {\n return {\n value: null,\n };\n }\n\n handleClear = (e) => {\n this.handlers.value('', e);\n };\n\n render() {\n const Value = Root;\n const SInputSearch = Input;\n const SClose = Input.Addon;\n const { size, value, styles } = this.asProps;\n const finalSize = size || this.context.size;\n const hideClose = !value;\n const IconClose = MAP_SIZE_TO_ICON[finalSize][1];\n const IconSearch = MAP_SIZE_TO_ICON[finalSize][0];\n\n return sstyled(styles)(\n <SInputSearch size={finalSize} styles={styles}>\n <Input.Addon>\n <IconSearch />\n </Input.Addon>\n <Value render={Input.Value} autoFocus />\n <SClose\n role=\"button\"\n /* hide through css because the width of the input changes */\n hide={hideClose}\n aria-hidden={hideClose}\n interactive\n onClick={this.handleClear}\n >\n <IconClose />\n </SClose>\n </SInputSearch>,\n );\n }\n}\n\nexport default createComponent(InputSearch);\n"],"file":"InputSearch.js"}
package/lib/cjs/Select.js CHANGED
@@ -74,17 +74,17 @@ var style = (
74
74
  /*__reshadow_css_start__*/
75
75
  _core.sstyled.insert(
76
76
  /*__inner_css_start__*/
77
- ".___SOptionCheckbox_1sdhb_gg_{margin-top:2px;margin-right:8px;margin-bottom:auto;position:relative;flex-shrink:0}.___SOptionCheckbox_1sdhb_gg_:before{content:\"\";position:absolute;top:0;left:0;right:0;bottom:0;background:#fff;border:1px solid;border-radius:4px;border-color:#c4c7cf}.___SOptionCheckbox_1sdhb_gg_{width:16px;height:16px}.___SOptionCheckbox_1sdhb_gg_:after{content:\"\";position:absolute;top:0;left:0;right:0;bottom:0;margin:0 2px;background-repeat:no-repeat;background-position:50%;background-image:url(\"data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMTAiIGhlaWdodD0iNyIgZmlsbD0ibm9uZSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj48cGF0aCBkPSJNOC4yNSAxTDQgNS4yNSAxLjc1IDMiIHN0cm9rZT0iI2ZmZiIgc3Ryb2tlLXdpZHRoPSIyIiBzdHJva2UtbGluZWNhcD0icm91bmQiIHN0cm9rZS1saW5lam9pbj0icm91bmQiLz48L3N2Zz4=\")}.___SOptionCheckbox_1sdhb_gg_._size_l_1sdhb_gg_{width:20px;height:20px}.___SOptionCheckbox_1sdhb_gg_._size_l_1sdhb_gg_:after{background-image:url(\"data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMTIiIGhlaWdodD0iOSIgZmlsbD0ibm9uZSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj48cGF0aCBkPSJNMTEgMS41TDQuNzUgNy43NSAxIDQiIHN0cm9rZT0iI2ZmZiIgc3Ryb2tlLXdpZHRoPSIyIiBzdHJva2UtbGluZWNhcD0icm91bmQiIHN0cm9rZS1saW5lam9pbj0icm91bmQiLz48L3N2Zz4=\")}.___SOptionCheckbox_1sdhb_gg_.__checked_1sdhb_gg_:before{background-color:#008ff8;border-color:#008ff8}.___SOptionCheckbox_1sdhb_gg_.__theme_1sdhb_gg_:before{border-color:var(--theme_1lo3q1n)}.___SOptionCheckbox_1sdhb_gg_.__theme_1sdhb_gg_.__checked_1sdhb_gg_:before{background-color:var(--theme_1lo3q1n);border-color:var(--theme_1lo3q1n)}.___SOptionCheckbox_1sdhb_gg_.__selected_1sdhb_gg_{background-color:rgba(196,229,254,.7)}.___SOptionCheckbox_1sdhb_gg_.__selected_1sdhb_gg_:hover{background-color:rgba(196,229,254,.7)}"
77
+ ".___SOptionCheckbox_u1grt_gg_{margin-top:2px;margin-right:8px;margin-bottom:auto;position:relative;flex-shrink:0}.___SOptionCheckbox_u1grt_gg_:before{content:\"\";position:absolute;top:0;left:0;right:0;bottom:0;background:#fff;border:1px solid;border-radius:4px;border-color:#c4c7cf}.___SOptionCheckbox_u1grt_gg_{width:16px;height:16px}.___SOptionCheckbox_u1grt_gg_:after{content:\"\";position:absolute;top:0;left:0;right:0;bottom:0;margin:0 2px;background-repeat:no-repeat;background-position:50%;background-image:url(\"data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMTAiIGhlaWdodD0iNyIgZmlsbD0ibm9uZSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj48cGF0aCBkPSJNOC4yNSAxTDQgNS4yNSAxLjc1IDMiIHN0cm9rZT0iI2ZmZiIgc3Ryb2tlLXdpZHRoPSIyIiBzdHJva2UtbGluZWNhcD0icm91bmQiIHN0cm9rZS1saW5lam9pbj0icm91bmQiLz48L3N2Zz4=\")}.___SOptionCheckbox_u1grt_gg_._size_l_u1grt_gg_{width:20px;height:20px}.___SOptionCheckbox_u1grt_gg_._size_l_u1grt_gg_:after{background-image:url(\"data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMTIiIGhlaWdodD0iOSIgZmlsbD0ibm9uZSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj48cGF0aCBkPSJNMTEgMS41TDQuNzUgNy43NSAxIDQiIHN0cm9rZT0iI2ZmZiIgc3Ryb2tlLXdpZHRoPSIyIiBzdHJva2UtbGluZWNhcD0icm91bmQiIHN0cm9rZS1saW5lam9pbj0icm91bmQiLz48L3N2Zz4=\")}.___SOptionCheckbox_u1grt_gg_.__checked_u1grt_gg_:before{background-color:#008ff8;border-color:#008ff8}.___SOptionCheckbox_u1grt_gg_.__theme_u1grt_gg_:before{border-color:var(--theme_u1grt)}.___SOptionCheckbox_u1grt_gg_.__theme_u1grt_gg_.__checked_u1grt_gg_:before{background-color:var(--theme_u1grt);border-color:var(--theme_u1grt)}.___SOptionCheckbox_u1grt_gg_.__selected_u1grt_gg_{background-color:rgba(196,229,254,.7)}.___SOptionCheckbox_u1grt_gg_.__selected_u1grt_gg_:hover{background-color:rgba(196,229,254,.7)}"
78
78
  /*__inner_css_end__*/
79
- , "1lo3q1n_gg_")
79
+ , "u1grt_gg_")
80
80
  /*__reshadow_css_end__*/
81
81
  , {
82
- "__SOptionCheckbox": "___SOptionCheckbox_1sdhb_gg_",
83
- "_size_l": "_size_l_1sdhb_gg_",
84
- "_checked": "__checked_1sdhb_gg_",
85
- "_theme": "__theme_1sdhb_gg_",
86
- "--theme": "--theme_1lo3q1n",
87
- "_selected": "__selected_1sdhb_gg_"
82
+ "__SOptionCheckbox": "___SOptionCheckbox_u1grt_gg_",
83
+ "_size_l": "_size_l_u1grt_gg_",
84
+ "_checked": "__checked_u1grt_gg_",
85
+ "_theme": "__theme_u1grt_gg_",
86
+ "--theme": "--theme_u1grt",
87
+ "_selected": "__selected_u1grt_gg_"
88
88
  });
89
89
 
90
90
  function isSelectedOption(value, valueOption) {
@@ -1,24 +1,17 @@
1
1
  @import '@semcore/utils/style/var.css';
2
2
 
3
- SInputSearch[size] {
4
- padding: 0;
5
- }
6
-
7
- SInputSearch > [data-ui-name='Input']:first-child > [data-ui-name='InputSearch'] ~ div {
8
- top: -1px;
9
- left: -1px;
10
- width: 100%;
11
- border-radius: var(--rounded-m) var(--rounded-m) 0 0;
12
- }
13
-
14
- SInputSearch[size='m'] > [data-ui-name='Input']:first-child {
3
+ SInputSearch[size='m'] {
15
4
  height: 32px;
16
5
  }
17
6
 
18
- SInputSearch [data-ui-name='Input.Addon']:last-of-type {
7
+ SClose[hide] {
19
8
  visibility: hidden;
20
9
  }
21
10
 
22
- SInputSearch[filled] [data-ui-name='Input.Addon']:last-of-type {
23
- visibility: visible;
11
+ /* Style for Input */
12
+ SOutline {
13
+ top: -1px;
14
+ left: -1px;
15
+ width: 100%;
16
+ border-radius: var(--rounded-m) var(--rounded-m) 0 0;
24
17
  }
@@ -1,4 +1,3 @@
1
- import _extends from "@babel/runtime/helpers/extends";
2
1
  import _classCallCheck from "@babel/runtime/helpers/classCallCheck";
3
2
  import _createClass from "@babel/runtime/helpers/createClass";
4
3
  import _assertThisInitialized from "@babel/runtime/helpers/assertThisInitialized";
@@ -7,17 +6,21 @@ import _possibleConstructorReturn from "@babel/runtime/helpers/possibleConstruct
7
6
  import _getPrototypeOf from "@babel/runtime/helpers/getPrototypeOf";
8
7
  import _defineProperty from "@babel/runtime/helpers/defineProperty";
9
8
  import { sstyled as _sstyled } from "@semcore/core";
9
+ import { assignProps as _assignProps } from "@semcore/core";
10
+
11
+ function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); enumerableOnly && (symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
12
+
13
+ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? ownKeys(Object(source), !0).forEach(function (key) { _defineProperty(target, key, source[key]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)) : ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } return target; }
10
14
 
11
15
  function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }
12
16
 
13
17
  function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }
14
18
 
15
19
  import React from 'react';
16
- import createComponent, { Component, sstyled } from '@semcore/core';
17
- import { Box } from '@semcore/flex-box';
18
- import Input from '@semcore/input';
20
+ import createComponent, { Component, sstyled, Root } from '@semcore/core';
19
21
  import SearchM from '@semcore/icon/Search/m';
20
22
  import CloseM from '@semcore/icon/Close/m';
23
+ import Input from '@semcore/input';
21
24
  import { selectContext } from './context';
22
25
 
23
26
  /*__reshadow-styles__:"./style/input-search.shadow.css"*/
@@ -25,15 +28,16 @@ var style = (
25
28
  /*__reshadow_css_start__*/
26
29
  _sstyled.insert(
27
30
  /*__inner_css_start__*/
28
- ".___SInputSearch_qj5zn_gg_.__size_qj5zn_gg_{padding:0}.___SInputSearch_qj5zn_gg_>[data-ui-name=Input]:first-child>[data-ui-name=InputSearch]~div{top:-1px;left:-1px;width:100%;border-radius:6px 6px 0 0}.___SInputSearch_qj5zn_gg_._size_m_qj5zn_gg_>[data-ui-name=Input]:first-child{height:32px}.___SInputSearch_qj5zn_gg_ [data-ui-name=\"Input.Addon\"]:last-of-type{visibility:hidden}.___SInputSearch_qj5zn_gg_.__filled_qj5zn_gg_ [data-ui-name=\"Input.Addon\"]:last-of-type{visibility:visible}"
31
+ ".___SInputSearch_py0ps_gg_._size_m_py0ps_gg_{height:32px}.___SClose_py0ps_gg_.__hide_py0ps_gg_{visibility:hidden}.___SOutline_py0ps_gg_{top:-1px;left:-1px;width:100%;border-radius:6px 6px 0 0}"
29
32
  /*__inner_css_end__*/
30
- , "16lophm_gg_")
33
+ , "py0ps_gg_")
31
34
  /*__reshadow_css_end__*/
32
35
  , {
33
- "__SInputSearch": "___SInputSearch_qj5zn_gg_",
34
- "_size": "__size_qj5zn_gg_",
35
- "_size_m": "_size_m_qj5zn_gg_",
36
- "_filled": "__filled_qj5zn_gg_"
36
+ "__SInputSearch": "___SInputSearch_py0ps_gg_",
37
+ "_size_m": "_size_m_py0ps_gg_",
38
+ "__SClose": "___SClose_py0ps_gg_",
39
+ "_hide": "__hide_py0ps_gg_",
40
+ "__SOutline": "___SOutline_py0ps_gg_"
37
41
  });
38
42
  var MAP_SIZE_TO_ICON = {
39
43
  m: [SearchM, CloseM],
@@ -73,31 +77,32 @@ var InputSearch = /*#__PURE__*/function (_Component) {
73
77
  }, {
74
78
  key: "render",
75
79
  value: function render() {
76
- var _ref;
80
+ var _ref = this.asProps,
81
+ _ref2;
77
82
 
78
- var SInputSearch = Box;
83
+ var Value = Input.Value;
84
+ var SInputSearch = Input;
85
+ var SClose = Input.Addon;
79
86
  var _this$asProps = this.asProps,
80
87
  size = _this$asProps.size,
81
88
  value = _this$asProps.value,
82
- forwardRef = _this$asProps.forwardRef,
83
89
  styles = _this$asProps.styles;
84
90
  var finalSize = size || this.context.size;
85
- return _ref = sstyled(styles), /*#__PURE__*/React.createElement(SInputSearch, _ref.cn("SInputSearch", {
91
+ var hideClose = !value;
92
+ var IconClose = MAP_SIZE_TO_ICON[finalSize][1];
93
+ var IconSearch = MAP_SIZE_TO_ICON[finalSize][0];
94
+ return _ref2 = sstyled(styles), /*#__PURE__*/React.createElement(SInputSearch, _ref2.cn("SInputSearch", {
86
95
  "size": finalSize,
87
- "use:filled": value
88
- }), /*#__PURE__*/React.createElement(Input, _ref.cn("Input", {
89
- "size": finalSize
90
- }), /*#__PURE__*/React.createElement(Input.Addon, {
91
- tag: MAP_SIZE_TO_ICON[finalSize][0]
92
- }), /*#__PURE__*/React.createElement(Input.Value, _extends({
93
- ref: forwardRef,
94
- autoFocus: true
95
- }, this.asProps)), /*#__PURE__*/React.createElement(Input.Addon, {
96
- tag: MAP_SIZE_TO_ICON[finalSize][1],
97
- role: "button",
98
- interactive: true,
99
- onClick: this.handleClear
100
- })));
96
+ "styles": styles
97
+ }), /*#__PURE__*/React.createElement(Input.Addon, null, /*#__PURE__*/React.createElement(IconSearch, _ref2.cn("IconSearch", {}))), /*#__PURE__*/React.createElement(Value, _ref2.cn("Value", _objectSpread({}, _assignProps({
98
+ "autoFocus": true
99
+ }, _ref)))), /*#__PURE__*/React.createElement(SClose, _ref2.cn("SClose", {
100
+ "role": "button",
101
+ "hide": hideClose,
102
+ "aria-hidden": hideClose,
103
+ "interactive": true,
104
+ "onClick": this.handleClear
105
+ }), /*#__PURE__*/React.createElement(IconClose, _ref2.cn("IconClose", {}))));
101
106
  }
102
107
  }]);
103
108
 
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/InputSearch.jsx"],"names":["React","createComponent","Component","sstyled","Box","Input","SearchM","CloseM","selectContext","MAP_SIZE_TO_ICON","m","l","InputSearch","e","handlers","value","SInputSearch","asProps","size","forwardRef","styles","finalSize","context","handleClear","style","defaultValue"],"mappings":";;;;;;;;;;;;;;AAAA,OAAOA,KAAP,MAAkB,OAAlB;AACA,OAAOC,eAAP,IAA0BC,SAA1B,EAAqCC,OAArC,QAAoD,eAApD;AACA,SAASC,GAAT,QAAoB,mBAApB;AACA,OAAOC,KAAP,MAAkB,gBAAlB;AACA,OAAOC,OAAP,MAAoB,wBAApB;AACA,OAAOC,MAAP,MAAmB,uBAAnB;AACA,SAASC,aAAT,QAA8B,WAA9B;;;;;;;;;;;;;;;;;AAIA,IAAMC,gBAAgB,GAAG;AACvBC,EAAAA,CAAC,EAAE,CAACJ,OAAD,EAAUC,MAAV,CADoB;AAEvBI,EAAAA,CAAC,EAAE,CAACL,OAAD,EAAUC,MAAV;AAFoB,CAAzB;;IAKMK,W;;;;;;;;;;;;;;;;kEAiBU,UAACC,CAAD,EAAO;AACnB,YAAKC,QAAL,CAAcC,KAAd,CAAoB,EAApB,EAAwBF,CAAxB;AACD,K;;;;;;;WARD,6BAAoB;AAClB,aAAO;AACLE,QAAAA,KAAK,EAAE;AADF,OAAP;AAGD;;;WAMD,kBAAS;AAAA;;AACP,UAAMC,YAAY,GAAGZ,GAArB;AACA,0BAA4C,KAAKa,OAAjD;AAAA,UAAQC,IAAR,iBAAQA,IAAR;AAAA,UAAcH,KAAd,iBAAcA,KAAd;AAAA,UAAqBI,UAArB,iBAAqBA,UAArB;AAAA,UAAiCC,MAAjC,iBAAiCA,MAAjC;AACA,UAAMC,SAAS,GAAGH,IAAI,IAAI,KAAKI,OAAL,CAAaJ,IAAvC;AAEA,oBAAOf,OAAO,CAACiB,MAAD,CAAd,eACE,oBAAC,YAAD;AAAA,gBAAoBC,SAApB;AAAA,sBAA2CN;AAA3C,uBACE,oBAAC,KAAD;AAAA,gBAAaM;AAAb,uBACE,oBAAC,KAAD,CAAO,KAAP;AAAa,QAAA,GAAG,EAAEZ,gBAAgB,CAACY,SAAD,CAAhB,CAA4B,CAA5B;AAAlB,QADF,eAEE,oBAAC,KAAD,CAAO,KAAP;AAAa,QAAA,GAAG,EAAEF,UAAlB;AAA8B,QAAA,SAAS;AAAvC,SAA4C,KAAKF,OAAjD,EAFF,eAGE,oBAAC,KAAD,CAAO,KAAP;AACE,QAAA,GAAG,EAAER,gBAAgB,CAACY,SAAD,CAAhB,CAA4B,CAA5B,CADP;AAEE,QAAA,IAAI,EAAC,QAFP;AAGE,QAAA,WAAW,MAHb;AAIE,QAAA,OAAO,EAAE,KAAKE;AAJhB,QAHF,CADF,CADF;AAcD;;;;EAxCuBrB,S;;gBAApBU,W,iBACiB,a;;gBADjBA,W,WAGWY,K;;gBAHXZ,W,kBAKkB;AACpBa,EAAAA,YAAY,EAAE;AADM,C;;gBALlBb,W,iBASiBJ,a;;AAkCvB,eAAeP,eAAe,CAACW,WAAD,CAA9B","sourcesContent":["import React from 'react';\nimport createComponent, { Component, sstyled } from '@semcore/core';\nimport { Box } from '@semcore/flex-box';\nimport Input from '@semcore/input';\nimport SearchM from '@semcore/icon/Search/m';\nimport CloseM from '@semcore/icon/Close/m';\nimport { selectContext } from './context';\n\nimport style from './style/input-search.shadow.css';\n\nconst MAP_SIZE_TO_ICON = {\n m: [SearchM, CloseM],\n l: [SearchM, CloseM],\n};\n\nclass InputSearch extends Component {\n static displayName = 'InputSearch';\n\n static style = style;\n\n static defaultProps = {\n defaultValue: '',\n };\n\n static contextType = selectContext;\n\n uncontrolledProps() {\n return {\n value: null,\n };\n }\n\n handleClear = (e) => {\n this.handlers.value('', e);\n };\n\n render() {\n const SInputSearch = Box;\n const { size, value, forwardRef, styles } = this.asProps;\n const finalSize = size || this.context.size;\n\n return sstyled(styles)(\n <SInputSearch size={finalSize} use:filled={value}>\n <Input size={finalSize}>\n <Input.Addon tag={MAP_SIZE_TO_ICON[finalSize][0]} />\n <Input.Value ref={forwardRef} autoFocus {...this.asProps} />\n <Input.Addon\n tag={MAP_SIZE_TO_ICON[finalSize][1]}\n role=\"button\"\n interactive\n onClick={this.handleClear}\n />\n </Input>\n </SInputSearch>,\n );\n }\n}\n\nexport default createComponent(InputSearch);\n"],"file":"InputSearch.js"}
1
+ {"version":3,"sources":["../../src/InputSearch.jsx"],"names":["React","createComponent","Component","sstyled","Root","SearchM","CloseM","Input","selectContext","MAP_SIZE_TO_ICON","m","l","InputSearch","e","handlers","value","Value","SInputSearch","SClose","Addon","asProps","size","styles","finalSize","context","hideClose","IconClose","IconSearch","handleClear","style","defaultValue"],"mappings":";;;;;;;;;;;;;;;;;;AAAA,OAAOA,KAAP,MAAkB,OAAlB;AACA,OAAOC,eAAP,IAA0BC,SAA1B,EAAqCC,OAArC,EAA8CC,IAA9C,QAA0D,eAA1D;AACA,OAAOC,OAAP,MAAoB,wBAApB;AACA,OAAOC,MAAP,MAAmB,uBAAnB;AACA,OAAOC,KAAP,MAAkB,gBAAlB;AACA,SAASC,aAAT,QAA8B,WAA9B;;;;;;;;;;;;;;;;;;AAIA,IAAMC,gBAAgB,GAAG;AACvBC,EAAAA,CAAC,EAAE,CAACL,OAAD,EAAUC,MAAV,CADoB;AAEvBK,EAAAA,CAAC,EAAE,CAACN,OAAD,EAAUC,MAAV;AAFoB,CAAzB;;IAKMM,W;;;;;;;;;;;;;;;;kEAiBU,UAACC,CAAD,EAAO;AACnB,YAAKC,QAAL,CAAcC,KAAd,CAAoB,EAApB,EAAwBF,CAAxB;AACD,K;;;;;;;WARD,6BAAoB;AAClB,aAAO;AACLE,QAAAA,KAAK,EAAE;AADF,OAAP;AAGD;;;WAMD,kBAAS;AAAA;AAAA;;AACP,UAAMC,KAAK,GAcQT,KAAK,CAACS,KAdzB;AACA,UAAMC,YAAY,GAAGV,KAArB;AACA,UAAMW,MAAM,GAAGX,KAAK,CAACY,KAArB;AACA,0BAAgC,KAAKC,OAArC;AAAA,UAAQC,IAAR,iBAAQA,IAAR;AAAA,UAAcN,KAAd,iBAAcA,KAAd;AAAA,UAAqBO,MAArB,iBAAqBA,MAArB;AACA,UAAMC,SAAS,GAAGF,IAAI,IAAI,KAAKG,OAAL,CAAaH,IAAvC;AACA,UAAMI,SAAS,GAAG,CAACV,KAAnB;AACA,UAAMW,SAAS,GAAGjB,gBAAgB,CAACc,SAAD,CAAhB,CAA4B,CAA5B,CAAlB;AACA,UAAMI,UAAU,GAAGlB,gBAAgB,CAACc,SAAD,CAAhB,CAA4B,CAA5B,CAAnB;AAEA,qBAAOpB,OAAO,CAACmB,MAAD,CAAd,eACE,oBAAC,YAAD;AAAA,gBAAoBC,SAApB;AAAA,kBAAuCD;AAAvC,uBACE,oBAAC,KAAD,CAAO,KAAP,qBACE,oBAAC,UAAD,6BADF,CADF,eAIE,oBAAC,KAAD;AAAA;AAAA,iBAJF,eAKE,oBAAC,MAAD;AAAA,gBACO,QADP;AAAA,gBAGQG,SAHR;AAAA,uBAIeA,SAJf;AAAA;AAAA,mBAMW,KAAKG;AANhB,uBAQE,oBAAC,SAAD,4BARF,CALF,CADF;AAkBD;;;;EAjDuB1B,S;;gBAApBU,W,iBACiB,a;;gBADjBA,W,WAGWiB,K;;gBAHXjB,W,kBAKkB;AACpBkB,EAAAA,YAAY,EAAE;AADM,C;;gBALlBlB,W,iBASiBJ,a;;AA2CvB,eAAeP,eAAe,CAACW,WAAD,CAA9B","sourcesContent":["import React from 'react';\nimport createComponent, { Component, sstyled, Root } from '@semcore/core';\nimport SearchM from '@semcore/icon/Search/m';\nimport CloseM from '@semcore/icon/Close/m';\nimport Input from '@semcore/input';\nimport { selectContext } from './context';\n\nimport style from './style/input-search.shadow.css';\n\nconst MAP_SIZE_TO_ICON = {\n m: [SearchM, CloseM],\n l: [SearchM, CloseM],\n};\n\nclass InputSearch extends Component {\n static displayName = 'InputSearch';\n\n static style = style;\n\n static defaultProps = {\n defaultValue: '',\n };\n\n static contextType = selectContext;\n\n uncontrolledProps() {\n return {\n value: null,\n };\n }\n\n handleClear = (e) => {\n this.handlers.value('', e);\n };\n\n render() {\n const Value = Root;\n const SInputSearch = Input;\n const SClose = Input.Addon;\n const { size, value, styles } = this.asProps;\n const finalSize = size || this.context.size;\n const hideClose = !value;\n const IconClose = MAP_SIZE_TO_ICON[finalSize][1];\n const IconSearch = MAP_SIZE_TO_ICON[finalSize][0];\n\n return sstyled(styles)(\n <SInputSearch size={finalSize} styles={styles}>\n <Input.Addon>\n <IconSearch />\n </Input.Addon>\n <Value render={Input.Value} autoFocus />\n <SClose\n role=\"button\"\n /* hide through css because the width of the input changes */\n hide={hideClose}\n aria-hidden={hideClose}\n interactive\n onClick={this.handleClear}\n >\n <IconClose />\n </SClose>\n </SInputSearch>,\n );\n }\n}\n\nexport default createComponent(InputSearch);\n"],"file":"InputSearch.js"}
package/lib/es6/Select.js CHANGED
@@ -42,17 +42,17 @@ var style = (
42
42
  /*__reshadow_css_start__*/
43
43
  _sstyled.insert(
44
44
  /*__inner_css_start__*/
45
- ".___SOptionCheckbox_1sdhb_gg_{margin-top:2px;margin-right:8px;margin-bottom:auto;position:relative;flex-shrink:0}.___SOptionCheckbox_1sdhb_gg_:before{content:\"\";position:absolute;top:0;left:0;right:0;bottom:0;background:#fff;border:1px solid;border-radius:4px;border-color:#c4c7cf}.___SOptionCheckbox_1sdhb_gg_{width:16px;height:16px}.___SOptionCheckbox_1sdhb_gg_:after{content:\"\";position:absolute;top:0;left:0;right:0;bottom:0;margin:0 2px;background-repeat:no-repeat;background-position:50%;background-image:url(\"data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMTAiIGhlaWdodD0iNyIgZmlsbD0ibm9uZSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj48cGF0aCBkPSJNOC4yNSAxTDQgNS4yNSAxLjc1IDMiIHN0cm9rZT0iI2ZmZiIgc3Ryb2tlLXdpZHRoPSIyIiBzdHJva2UtbGluZWNhcD0icm91bmQiIHN0cm9rZS1saW5lam9pbj0icm91bmQiLz48L3N2Zz4=\")}.___SOptionCheckbox_1sdhb_gg_._size_l_1sdhb_gg_{width:20px;height:20px}.___SOptionCheckbox_1sdhb_gg_._size_l_1sdhb_gg_:after{background-image:url(\"data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMTIiIGhlaWdodD0iOSIgZmlsbD0ibm9uZSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj48cGF0aCBkPSJNMTEgMS41TDQuNzUgNy43NSAxIDQiIHN0cm9rZT0iI2ZmZiIgc3Ryb2tlLXdpZHRoPSIyIiBzdHJva2UtbGluZWNhcD0icm91bmQiIHN0cm9rZS1saW5lam9pbj0icm91bmQiLz48L3N2Zz4=\")}.___SOptionCheckbox_1sdhb_gg_.__checked_1sdhb_gg_:before{background-color:#008ff8;border-color:#008ff8}.___SOptionCheckbox_1sdhb_gg_.__theme_1sdhb_gg_:before{border-color:var(--theme_1lo3q1n)}.___SOptionCheckbox_1sdhb_gg_.__theme_1sdhb_gg_.__checked_1sdhb_gg_:before{background-color:var(--theme_1lo3q1n);border-color:var(--theme_1lo3q1n)}.___SOptionCheckbox_1sdhb_gg_.__selected_1sdhb_gg_{background-color:rgba(196,229,254,.7)}.___SOptionCheckbox_1sdhb_gg_.__selected_1sdhb_gg_:hover{background-color:rgba(196,229,254,.7)}"
45
+ ".___SOptionCheckbox_u1grt_gg_{margin-top:2px;margin-right:8px;margin-bottom:auto;position:relative;flex-shrink:0}.___SOptionCheckbox_u1grt_gg_:before{content:\"\";position:absolute;top:0;left:0;right:0;bottom:0;background:#fff;border:1px solid;border-radius:4px;border-color:#c4c7cf}.___SOptionCheckbox_u1grt_gg_{width:16px;height:16px}.___SOptionCheckbox_u1grt_gg_:after{content:\"\";position:absolute;top:0;left:0;right:0;bottom:0;margin:0 2px;background-repeat:no-repeat;background-position:50%;background-image:url(\"data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMTAiIGhlaWdodD0iNyIgZmlsbD0ibm9uZSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj48cGF0aCBkPSJNOC4yNSAxTDQgNS4yNSAxLjc1IDMiIHN0cm9rZT0iI2ZmZiIgc3Ryb2tlLXdpZHRoPSIyIiBzdHJva2UtbGluZWNhcD0icm91bmQiIHN0cm9rZS1saW5lam9pbj0icm91bmQiLz48L3N2Zz4=\")}.___SOptionCheckbox_u1grt_gg_._size_l_u1grt_gg_{width:20px;height:20px}.___SOptionCheckbox_u1grt_gg_._size_l_u1grt_gg_:after{background-image:url(\"data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMTIiIGhlaWdodD0iOSIgZmlsbD0ibm9uZSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj48cGF0aCBkPSJNMTEgMS41TDQuNzUgNy43NSAxIDQiIHN0cm9rZT0iI2ZmZiIgc3Ryb2tlLXdpZHRoPSIyIiBzdHJva2UtbGluZWNhcD0icm91bmQiIHN0cm9rZS1saW5lam9pbj0icm91bmQiLz48L3N2Zz4=\")}.___SOptionCheckbox_u1grt_gg_.__checked_u1grt_gg_:before{background-color:#008ff8;border-color:#008ff8}.___SOptionCheckbox_u1grt_gg_.__theme_u1grt_gg_:before{border-color:var(--theme_u1grt)}.___SOptionCheckbox_u1grt_gg_.__theme_u1grt_gg_.__checked_u1grt_gg_:before{background-color:var(--theme_u1grt);border-color:var(--theme_u1grt)}.___SOptionCheckbox_u1grt_gg_.__selected_u1grt_gg_{background-color:rgba(196,229,254,.7)}.___SOptionCheckbox_u1grt_gg_.__selected_u1grt_gg_:hover{background-color:rgba(196,229,254,.7)}"
46
46
  /*__inner_css_end__*/
47
- , "1lo3q1n_gg_")
47
+ , "u1grt_gg_")
48
48
  /*__reshadow_css_end__*/
49
49
  , {
50
- "__SOptionCheckbox": "___SOptionCheckbox_1sdhb_gg_",
51
- "_size_l": "_size_l_1sdhb_gg_",
52
- "_checked": "__checked_1sdhb_gg_",
53
- "_theme": "__theme_1sdhb_gg_",
54
- "--theme": "--theme_1lo3q1n",
55
- "_selected": "__selected_1sdhb_gg_"
50
+ "__SOptionCheckbox": "___SOptionCheckbox_u1grt_gg_",
51
+ "_size_l": "_size_l_u1grt_gg_",
52
+ "_checked": "__checked_u1grt_gg_",
53
+ "_theme": "__theme_u1grt_gg_",
54
+ "--theme": "--theme_u1grt",
55
+ "_selected": "__selected_u1grt_gg_"
56
56
  });
57
57
 
58
58
  function isSelectedOption(value, valueOption) {
@@ -1,24 +1,17 @@
1
1
  @import '@semcore/utils/style/var.css';
2
2
 
3
- SInputSearch[size] {
4
- padding: 0;
5
- }
6
-
7
- SInputSearch > [data-ui-name='Input']:first-child > [data-ui-name='InputSearch'] ~ div {
8
- top: -1px;
9
- left: -1px;
10
- width: 100%;
11
- border-radius: var(--rounded-m) var(--rounded-m) 0 0;
12
- }
13
-
14
- SInputSearch[size='m'] > [data-ui-name='Input']:first-child {
3
+ SInputSearch[size='m'] {
15
4
  height: 32px;
16
5
  }
17
6
 
18
- SInputSearch [data-ui-name='Input.Addon']:last-of-type {
7
+ SClose[hide] {
19
8
  visibility: hidden;
20
9
  }
21
10
 
22
- SInputSearch[filled] [data-ui-name='Input.Addon']:last-of-type {
23
- visibility: visible;
11
+ /* Style for Input */
12
+ SOutline {
13
+ top: -1px;
14
+ left: -1px;
15
+ width: 100%;
16
+ border-radius: var(--rounded-m) var(--rounded-m) 0 0;
24
17
  }
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@semcore/select",
3
3
  "description": "SEMRush Select Component",
4
- "version": "3.0.9",
4
+ "version": "3.0.12",
5
5
  "main": "lib/cjs/index.js",
6
6
  "module": "lib/es6/index.js",
7
7
  "typings": "lib/types/index.d.ts",
@@ -1,9 +1,8 @@
1
1
  import React from 'react';
2
- import createComponent, { Component, sstyled } from '@semcore/core';
3
- import { Box } from '@semcore/flex-box';
4
- import Input from '@semcore/input';
2
+ import createComponent, { Component, sstyled, Root } from '@semcore/core';
5
3
  import SearchM from '@semcore/icon/Search/m';
6
4
  import CloseM from '@semcore/icon/Close/m';
5
+ import Input from '@semcore/input';
7
6
  import { selectContext } from './context';
8
7
 
9
8
  import style from './style/input-search.shadow.css';
@@ -35,22 +34,31 @@ class InputSearch extends Component {
35
34
  };
36
35
 
37
36
  render() {
38
- const SInputSearch = Box;
39
- const { size, value, forwardRef, styles } = this.asProps;
37
+ const Value = Root;
38
+ const SInputSearch = Input;
39
+ const SClose = Input.Addon;
40
+ const { size, value, styles } = this.asProps;
40
41
  const finalSize = size || this.context.size;
42
+ const hideClose = !value;
43
+ const IconClose = MAP_SIZE_TO_ICON[finalSize][1];
44
+ const IconSearch = MAP_SIZE_TO_ICON[finalSize][0];
41
45
 
42
46
  return sstyled(styles)(
43
- <SInputSearch size={finalSize} use:filled={value}>
44
- <Input size={finalSize}>
45
- <Input.Addon tag={MAP_SIZE_TO_ICON[finalSize][0]} />
46
- <Input.Value ref={forwardRef} autoFocus {...this.asProps} />
47
- <Input.Addon
48
- tag={MAP_SIZE_TO_ICON[finalSize][1]}
49
- role="button"
50
- interactive
51
- onClick={this.handleClear}
52
- />
53
- </Input>
47
+ <SInputSearch size={finalSize} styles={styles}>
48
+ <Input.Addon>
49
+ <IconSearch />
50
+ </Input.Addon>
51
+ <Value render={Input.Value} autoFocus />
52
+ <SClose
53
+ role="button"
54
+ /* hide through css because the width of the input changes */
55
+ hide={hideClose}
56
+ aria-hidden={hideClose}
57
+ interactive
58
+ onClick={this.handleClear}
59
+ >
60
+ <IconClose />
61
+ </SClose>
54
62
  </SInputSearch>,
55
63
  );
56
64
  }
@@ -1,24 +1,17 @@
1
1
  @import '@semcore/utils/style/var.css';
2
2
 
3
- SInputSearch[size] {
4
- padding: 0;
5
- }
6
-
7
- SInputSearch > [data-ui-name='Input']:first-child > [data-ui-name='InputSearch'] ~ div {
8
- top: -1px;
9
- left: -1px;
10
- width: 100%;
11
- border-radius: var(--rounded-m) var(--rounded-m) 0 0;
12
- }
13
-
14
- SInputSearch[size='m'] > [data-ui-name='Input']:first-child {
3
+ SInputSearch[size='m'] {
15
4
  height: 32px;
16
5
  }
17
6
 
18
- SInputSearch [data-ui-name='Input.Addon']:last-of-type {
7
+ SClose[hide] {
19
8
  visibility: hidden;
20
9
  }
21
10
 
22
- SInputSearch[filled] [data-ui-name='Input.Addon']:last-of-type {
23
- visibility: visible;
11
+ /* Style for Input */
12
+ SOutline {
13
+ top: -1px;
14
+ left: -1px;
15
+ width: 100%;
16
+ border-radius: var(--rounded-m) var(--rounded-m) 0 0;
24
17
  }