@zohodesk/components 1.0.0-alpha-237 → 1.0.0-alpha-238

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 (27) hide show
  1. package/README.md +9 -0
  2. package/assets/Appearance/dark/mode/darkMode.module.css +1 -1
  3. package/assets/Appearance/dark/themes/blue/blueDarkComponentTheme.module.css +1 -1
  4. package/assets/Appearance/default/mode/defaultMode.module.css +1 -1
  5. package/assets/Appearance/default/themes/blue/blueDefaultComponentTheme.module.css +1 -1
  6. package/assets/Appearance/pureDark/mode/pureDarkMode.module.css +358 -0
  7. package/assets/Appearance/pureDark/themes/blue/bluePureDarkCTATheme.module.css +34 -0
  8. package/assets/Appearance/pureDark/themes/blue/bluePureDarkComponentTheme.module.css +42 -0
  9. package/assets/Appearance/pureDark/themes/green/greenPureDarkCTATheme.module.css +34 -0
  10. package/assets/Appearance/pureDark/themes/green/greenPureDarkComponentTheme.module.css +42 -0
  11. package/assets/Appearance/pureDark/themes/orange/orangePureDarkCTATheme.module.css +34 -0
  12. package/assets/Appearance/pureDark/themes/orange/orangePureDarkComponentTheme.module.css +42 -0
  13. package/assets/Appearance/pureDark/themes/red/redPureDarkCTATheme.module.css +34 -0
  14. package/assets/Appearance/pureDark/themes/red/redPureDarkComponentTheme.module.css +42 -0
  15. package/assets/Appearance/pureDark/themes/yellow/yellowPureDarkCTATheme.module.css +34 -0
  16. package/assets/Appearance/pureDark/themes/yellow/yellowPureDarkComponentTheme.module.css +42 -0
  17. package/es/AppContainer/AppContainer.js +6 -1
  18. package/es/Provider/Config.js +1 -2
  19. package/es/Provider.js +72 -35
  20. package/es/Tooltip/Tooltip.js +40 -2
  21. package/es/common/docStyle.module.css +6 -2
  22. package/lib/AppContainer/AppContainer.js +7 -0
  23. package/lib/Provider/Config.js +1 -2
  24. package/lib/Provider.js +88 -37
  25. package/lib/Tooltip/Tooltip.js +47 -2
  26. package/lib/common/docStyle.module.css +6 -2
  27. package/package.json +5 -5
@@ -15,6 +15,8 @@ var _Config = require("../Provider/Config");
15
15
 
16
16
  var _TooltipModule = _interopRequireDefault(require("./Tooltip.module.css"));
17
17
 
18
+ var _ResizeObserver = _interopRequireDefault(require("../Responsive/ResizeObserver"));
19
+
18
20
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
19
21
 
20
22
  function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
@@ -62,10 +64,53 @@ var Tooltip = /*#__PURE__*/function (_React$Component) {
62
64
  _this.getDirection = document.getElementsByTagName('html')[0];
63
65
  _this.leftRightScreenEdge = _this.leftRightScreenEdge.bind(_assertThisInitialized(_this));
64
66
  _this.topBottomScreenEdge = _this.topBottomScreenEdge.bind(_assertThisInitialized(_this));
67
+ _this.observer = new _ResizeObserver["default"](_this.onResize);
68
+ _this.isResized = true;
69
+ _this.tooltipContainerClientRect = {};
70
+ _this.tooltipContainerEl = {};
65
71
  return _this;
66
72
  }
67
73
 
68
74
  _createClass(Tooltip, [{
75
+ key: "onResize",
76
+ value: function onResize(sizeOfObservedEl, observedEl) {
77
+ this.isResized = true;
78
+ }
79
+ }, {
80
+ key: "observeElement",
81
+ value: function observeElement() {
82
+ this.tooltipContainerEl = this.getToolTipContainerEl();
83
+ this.observer.observe(this.tooltipContainerEl);
84
+ }
85
+ }, {
86
+ key: "unObserveElement",
87
+ value: function unObserveElement() {
88
+ this.observer.unobserve(this.tooltipContainerEl);
89
+ }
90
+ }, {
91
+ key: "getClientRectOfContEl",
92
+ value: function getClientRectOfContEl(el) {
93
+ if (this.isResized) {
94
+ return this.setClientRectOfContEl(el);
95
+ }
96
+
97
+ return this.tooltipContainerClientRect;
98
+ }
99
+ }, {
100
+ key: "setClientRectOfContEl",
101
+ value: function setClientRectOfContEl(containerEl) {
102
+ this.isResized = false;
103
+ this.tooltipContainerClientRect = containerEl.getBoundingClientRect();
104
+ return this.tooltipContainerClientRect;
105
+ }
106
+ }, {
107
+ key: "getToolTipContainerEl",
108
+ value: function getToolTipContainerEl() {
109
+ var getTooltipContainer = (0, _Config.getLibraryConfig)('getTooltipContainer');
110
+ var tooltipContainer = typeof getTooltipContainer === 'function' ? getTooltipContainer() : null;
111
+ return tooltipContainer ? tooltipContainer : document.body;
112
+ }
113
+ }, {
69
114
  key: "getToolTipDOM",
70
115
  value: function getToolTipDOM(el) {
71
116
  this.toolTip = el;
@@ -142,7 +187,7 @@ var Tooltip = /*#__PURE__*/function (_React$Component) {
142
187
  value: function handleOver(e, targetElement) {
143
188
  var _this2 = this;
144
189
 
145
- var containerElement = (0, _Config.getLibraryConfig)('tooltipContainer') === 'root' && targetElement ? targetElement : document.body;
190
+ var containerElement = this.tooltipContainerEl;
146
191
  var element = e.target;
147
192
  var titleDiv = element.hasAttribute('data-title') || element.hasAttribute('title') ? element : element.closest('[data-title]') || element.closest('[title]');
148
193
 
@@ -200,7 +245,7 @@ var Tooltip = /*#__PURE__*/function (_React$Component) {
200
245
  var dataTooltipnoArrow = titleDiv.getAttribute('data-tooltip-noarrow') === 'true' ? true : false;
201
246
  var dataTooltipWrap = titleDiv.getAttribute('data-title-wrap') === 'true' ? true : false;
202
247
  var clientRect = titleDiv.getBoundingClientRect();
203
- var boxLayout = containerElement.getBoundingClientRect();
248
+ var boxLayout = this.getClientRectOfContEl(containerElement);
204
249
  this.setState({
205
250
  title: title,
206
251
  isHtml: isHtml,
@@ -260,8 +260,12 @@
260
260
  background: #fff;
261
261
  }
262
262
  [data-mode='dark'] {
263
- color: #E2E4E6;
264
- background: #232B38;
263
+ color: #e2e4e6;
264
+ background: #232b38;
265
+ }
266
+ [data-mode='pureDark'] {
267
+ color: #e2e4e6;
268
+ background: #212121;
265
269
  }
266
270
 
267
271
  .baseHue {
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@zohodesk/components",
3
- "version": "1.0.0-alpha-237",
3
+ "version": "1.0.0-alpha-238",
4
4
  "main": "lib/index.js",
5
5
  "module": "es/index.js",
6
6
  "jsnext:main": "es/index.js",
@@ -37,11 +37,11 @@
37
37
  "devDependencies": {
38
38
  "@zohodesk/docstool": "1.0.0-alpha-2",
39
39
  "@zohodesk/variables": "1.0.0-beta.29",
40
- "@zohodesk/icons": "1.0.0-beta.98",
40
+ "@zohodesk/icons": "1.0.0-beta.105",
41
41
  "@zohodesk/virtualizer": "1.0.3",
42
42
  "velocity-react": "1.4.3",
43
43
  "react-sortable-hoc": "^0.8.3",
44
- "@zohodesk/svg": "1.0.0-beta.42"
44
+ "@zohodesk/svg": "1.0.0-beta.47"
45
45
  },
46
46
  "dependencies": {
47
47
  "hoist-non-react-statics": "3.0.1",
@@ -50,9 +50,9 @@
50
50
  "selectn": "1.1.2"
51
51
  },
52
52
  "peerDependencies": {
53
- "@zohodesk/icons": "1.0.0-beta.98",
53
+ "@zohodesk/icons": "1.0.0-beta.105",
54
54
  "@zohodesk/variables": "1.0.0-beta.29",
55
- "@zohodesk/svg": "1.0.0-beta.42",
55
+ "@zohodesk/svg": "1.0.0-beta.47",
56
56
  "@zohodesk/virtualizer": "1.0.3",
57
57
  "velocity-react": "1.4.3",
58
58
  "react-sortable-hoc": "^0.8.3"