@bento-core/tab 1.0.0 → 1.0.1-CDS.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.
package/dist/Tabs.js CHANGED
@@ -5,14 +5,20 @@ Object.defineProperty(exports, "__esModule", {
5
5
  });
6
6
  exports.default = void 0;
7
7
  var _react = _interopRequireDefault(require("react"));
8
+ var _ToolTip = _interopRequireDefault(require("@bento-core/tool-tip/src/ToolTip"));
8
9
  var _core = require("@material-ui/core");
9
10
  var _defaultTheme = require("./defaultTheme");
11
+ var _generateStyle = _interopRequireDefault(require("./utils/generateStyle"));
12
+ const _excluded = ["title"];
10
13
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
14
+ function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
11
15
  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
16
  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; }
13
17
  function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
14
18
  function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return typeof key === "symbol" ? key : String(key); }
15
19
  function _toPrimitive(input, hint) { if (typeof input !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (typeof res !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); }
20
+ function _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }
21
+ function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }
16
22
  const TabItems = _ref => {
17
23
  let {
18
24
  tabItems,
@@ -21,7 +27,10 @@ const TabItems = _ref => {
21
27
  orientation,
22
28
  customTheme = {}
23
29
  } = _ref;
24
- const getTabLalbel = _ref2 => {
30
+ const generatedStyle = (0, _generateStyle.default)();
31
+ const useStyles = (0, _core.makeStyles)(generatedStyle);
32
+ const classes = useStyles();
33
+ const getTabLabel = _ref2 => {
25
34
  let {
26
35
  name,
27
36
  count,
@@ -32,15 +41,28 @@ const TabItems = _ref => {
32
41
  className: "index_".concat(index, " ").concat(clsName, "_count")
33
42
  }, count)));
34
43
  };
35
- const TABs = tabItems.map((tab, index) => /*#__PURE__*/_react.default.createElement(_core.Tab, {
36
- index: index,
37
- label: getTabLalbel(_objectSpread(_objectSpread({}, tab), {}, {
38
- index
39
- })),
40
- key: index,
41
- className: tab.clsName,
42
- disableRipple: true
43
- }));
44
+ const CustomTab = tabItems.map((tab, index) => {
45
+ const _ref3 = tab.tooltipConfig || {},
46
+ {
47
+ title: tooltipTitle
48
+ } = _ref3,
49
+ tooltipProps = _objectWithoutProperties(_ref3, _excluded);
50
+ return /*#__PURE__*/_react.default.createElement(_ToolTip.default, _extends({
51
+ key: "tab_".concat(index, "_").concat(tab.name),
52
+ title: tooltipTitle || '',
53
+ classes: {
54
+ tooltip: classes.customTooltip,
55
+ arrow: classes.customArrow
56
+ }
57
+ }, tooltipProps), /*#__PURE__*/_react.default.createElement(_core.Tab, {
58
+ index: index,
59
+ label: getTabLabel(_objectSpread(_objectSpread({}, tab), {}, {
60
+ index
61
+ })),
62
+ className: tab.clsName,
63
+ disableRipple: true
64
+ }));
65
+ });
44
66
  const themeConfig = (0, _core.createTheme)({
45
67
  overrides: _objectSpread(_objectSpread({}, (0, _defaultTheme.defaultTheme)()), customTheme)
46
68
  });
@@ -55,7 +77,7 @@ const TabItems = _ref => {
55
77
  }
56
78
  },
57
79
  orientation: orientation
58
- }, TABs));
80
+ }, CustomTab));
59
81
  };
60
82
  var _default = TabItems;
61
83
  exports.default = _default;
package/dist/tabsStyle.js CHANGED
@@ -6,45 +6,18 @@ Object.defineProperty(exports, "__esModule", {
6
6
  exports.default = void 0;
7
7
  const tabsStyle = {
8
8
  tabsContainer: {},
9
- muiTabs: {
10
- root: {
11
- marginTop: '15px'
12
- },
13
- flexContainer: {
14
- borderBottom: '10px solid #40789C',
15
- overflow: 'visible !important'
16
- },
17
- indicator: {
18
- display: 'none'
19
- }
9
+ muiTabs: {},
10
+ muiTab: {},
11
+ tabsLabel: {},
12
+ tabsPanel: {},
13
+ customTooltip: {
14
+ border: '#03A383 1px solid'
20
15
  },
21
- muiTab: {
22
- root: {
23
- width: '250px',
24
- height: '45px',
25
- minHeight: '40px',
26
- marginRight: '10px',
27
- background: '#EAEAEA',
28
- fontSize: '18px',
29
- fontFamily: 'Raleway',
30
- fontWeight: '400',
31
- lineHeight: '18px',
32
- paddingLeft: '5px',
33
- letterSpacing: '0.25px',
34
- borderTop: '1px solid black',
35
- borderLeft: '1px solid black',
36
- borderRight: '1px solid black',
37
- '&$selected': {
38
- fontWeight: 'bolder'
39
- }
16
+ customArrow: {
17
+ '&::before': {
18
+ border: '#03A383 1px solid'
40
19
  }
41
- },
42
- tabsLabel: {
43
- fontFamily: 'Lato',
44
- textTransform: 'capitalize',
45
- fontSize: '21px'
46
- },
47
- tabsPanel: {}
20
+ }
48
21
  };
49
22
  var _default = tabsStyle;
50
23
  exports.default = _default;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@bento-core/tab",
3
- "version": "1.0.0",
3
+ "version": "1.0.1-CDS.0",
4
4
  "description": "",
5
5
  "main": "dist/index.js",
6
6
  "scripts": {
@@ -12,6 +12,9 @@
12
12
  "publishConfig": {
13
13
  "access": "public"
14
14
  },
15
+ "dependencies": {
16
+ "@bento-core/tool-tip": "^1.0.0"
17
+ },
15
18
  "peerDependencies": {
16
19
  "@material-ui/core": "^4.12.4",
17
20
  "react": "^17.0.2",
@@ -20,5 +23,5 @@
20
23
  },
21
24
  "author": "CTOS Bento Team",
22
25
  "license": "ISC",
23
- "gitHead": "4493c4a5fa666211345fea022ec06841a323d446"
26
+ "gitHead": "12ceec27794b24a5ab2870e421cbb6ff5970b438"
24
27
  }
package/src/Tabs.js CHANGED
@@ -1,11 +1,14 @@
1
1
  import React from 'react';
2
+ import ToolTip from '@bento-core/tool-tip/src/ToolTip';
2
3
  import {
3
4
  Tab,
4
5
  Tabs,
5
6
  createTheme,
6
7
  ThemeProvider,
8
+ makeStyles,
7
9
  } from '@material-ui/core';
8
10
  import { defaultTheme } from './defaultTheme';
11
+ import generateStyle from './utils/generateStyle';
9
12
 
10
13
  const TabItems = ({
11
14
  tabItems,
@@ -14,7 +17,11 @@ const TabItems = ({
14
17
  orientation,
15
18
  customTheme = {},
16
19
  }) => {
17
- const getTabLalbel = ({
20
+ const generatedStyle = generateStyle();
21
+ const useStyles = makeStyles(generatedStyle);
22
+ const classes = useStyles();
23
+
24
+ const getTabLabel = ({
18
25
  name, count, clsName, index,
19
26
  }) => (
20
27
  <>
@@ -31,17 +38,30 @@ const TabItems = ({
31
38
  </>
32
39
  );
33
40
 
34
- const TABs = tabItems.map((tab, index) => (
35
- <Tab
36
- index={index}
37
- label={
38
- getTabLalbel({ ...tab, index })
39
- }
40
- key={index}
41
- className={tab.clsName}
42
- disableRipple
43
- />
44
- ));
41
+ const CustomTab = tabItems.map((tab, index) => {
42
+ const { title: tooltipTitle, ...tooltipProps } = tab.tooltipConfig || {};
43
+
44
+ return (
45
+ (
46
+ <ToolTip
47
+ key={`tab_${index}_${tab.name}`}
48
+ title={tooltipTitle || ''}
49
+ classes={{
50
+ tooltip: classes.customTooltip,
51
+ arrow: classes.customArrow,
52
+ }}
53
+ {...tooltipProps}
54
+ >
55
+ <Tab
56
+ index={index}
57
+ label={getTabLabel({ ...tab, index })}
58
+ className={tab.clsName}
59
+ disableRipple
60
+ />
61
+ </ToolTip>
62
+ )
63
+ );
64
+ });
45
65
 
46
66
  const themeConfig = createTheme({ overrides: { ...defaultTheme(), ...customTheme } });
47
67
  return (
@@ -52,7 +72,7 @@ const TabItems = ({
52
72
  TabIndicatorProps={{ style: { background: 'none' } }}
53
73
  orientation={orientation}
54
74
  >
55
- {TABs}
75
+ {CustomTab}
56
76
  </Tabs>
57
77
  </ThemeProvider>
58
78
  );
package/src/tabsStyle.js CHANGED
@@ -1,44 +1,17 @@
1
1
  const tabsStyle = {
2
2
  tabsContainer: {},
3
- muiTabs: {
4
- root: {
5
- marginTop: '15px',
6
- },
7
- flexContainer: {
8
- borderBottom: '10px solid #40789C',
9
- overflow: 'visible !important',
10
- },
11
- indicator: {
12
- display: 'none',
13
- },
3
+ muiTabs: {},
4
+ muiTab: {},
5
+ tabsLabel: {},
6
+ tabsPanel: {},
7
+ customTooltip: {
8
+ border: '#03A383 1px solid',
14
9
  },
15
- muiTab: {
16
- root: {
17
- width: '250px',
18
- height: '45px',
19
- minHeight: '40px',
20
- marginRight: '10px',
21
- background: '#EAEAEA',
22
- fontSize: '18px',
23
- fontFamily: 'Raleway',
24
- fontWeight: '400',
25
- lineHeight: '18px',
26
- paddingLeft: '5px',
27
- letterSpacing: '0.25px',
28
- borderTop: '1px solid black',
29
- borderLeft: '1px solid black',
30
- borderRight: '1px solid black',
31
- '&$selected': {
32
- fontWeight: 'bolder',
33
- },
10
+ customArrow: {
11
+ '&::before': {
12
+ border: '#03A383 1px solid',
34
13
  },
35
14
  },
36
- tabsLabel: {
37
- fontFamily: 'Lato',
38
- textTransform: 'capitalize',
39
- fontSize: '21px',
40
- },
41
- tabsPanel: {},
42
15
  };
43
16
 
44
17
  export default tabsStyle;