@ably/ui 8.7.0-dev.6ce15a7 → 8.7.0-dev.8be09a5

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 (45) hide show
  1. package/README.md +1 -1
  2. package/core/Code/component.css +3 -3
  3. package/core/Code/component.js +1 -1
  4. package/core/Code.jsx +328 -7145
  5. package/core/DropdownMenu/component.js +1 -0
  6. package/core/DropdownMenu.jsx +317 -0
  7. package/core/Meganav.jsx +14 -2
  8. package/core/MeganavContentDevelopers.jsx +13 -1
  9. package/core/MeganavContentUseCases.jsx +1 -1
  10. package/core/MeganavContentWhyAbly/component.js +21 -5
  11. package/core/MeganavContentWhyAbly.jsx +3276 -3
  12. package/core/Notice/component.js.LICENSE.txt +0 -15
  13. package/core/sprites.svg +21 -0
  14. package/core/styles.css +2 -0
  15. package/package.json +3 -1
  16. package/src/core/Code/component.css +1 -67
  17. package/src/core/Code/component.js +11 -46
  18. package/src/core/Code/component.jsx +7 -3
  19. package/{preview/vendor/bundle/ruby/3.0.0/bundler/gems/ably-ui-abffd210ec0f/preview/log/.keep → src/core/DropdownMenu/component.js} +0 -0
  20. package/src/core/DropdownMenu/component.jsx +114 -0
  21. package/src/core/FeatureFooter/component.html.erb +1 -1
  22. package/src/core/MeganavContentDevelopers/component.html.erb +9 -0
  23. package/src/core/MeganavContentDevelopers/component.jsx +9 -0
  24. package/src/core/MeganavContentUseCases/component.html.erb +1 -1
  25. package/src/core/MeganavContentUseCases/component.jsx +1 -1
  26. package/src/core/MeganavSearchSuggestions/component.html.erb +1 -1
  27. package/src/core/icons/google.svg +3 -0
  28. package/src/core/icons/icon-display-integrations-col.svg +8 -0
  29. package/src/core/icons/stackoverflow.svg +3 -0
  30. package/src/core/icons/youtube.svg +11 -0
  31. package/src/core/styles/properties.css +2 -0
  32. package/src/core/utils/syntax-highlighter-registry.js +61 -0
  33. package/src/core/utils/syntax-highlighter.css +69 -0
  34. package/src/core/utils/syntax-highlighter.js +98 -0
  35. package/core/.DS_Store +0 -0
  36. package/core/fonts/.DS_Store +0 -0
  37. package/core/images/.DS_Store +0 -0
  38. package/core/scripts.js.LICENSE.txt +0 -32
  39. package/preview/vendor/bundle/ruby/3.0.0/bundler/gems/ably-ui-abffd210ec0f/preview/tmp/.keep +0 -0
  40. package/preview/vendor/bundle/ruby/3.0.0/bundler/gems/ably-ui-abffd210ec0f/preview/tmp/pids/.keep +0 -0
  41. package/src/.DS_Store +0 -0
  42. package/src/core/.DS_Store +0 -0
  43. package/src/core/fonts/.DS_Store +0 -0
  44. package/src/core/images/.DS_Store +0 -0
  45. package/src/reset/.DS_Store +0 -0
@@ -0,0 +1 @@
1
+ !function(e,o){"object"==typeof exports&&"object"==typeof module?module.exports=o():"function"==typeof define&&define.amd?define([],o):"object"==typeof exports?exports.AblyUi=o():(e.AblyUi=e.AblyUi||{},e.AblyUi.Core=e.AblyUi.Core||{},e.AblyUi.Core.DropdownMenu=o())}(this,(function(){return{}.default}));
@@ -0,0 +1,317 @@
1
+ (function webpackUniversalModuleDefinition(root, factory) {
2
+ if(typeof exports === 'object' && typeof module === 'object')
3
+ module.exports = factory(require("react"), require("prop-types"));
4
+ else if(typeof define === 'function' && define.amd)
5
+ define([, ], factory);
6
+ else {
7
+ var a = typeof exports === 'object' ? factory(require("react"), require("prop-types")) : factory(root[undefined], root[undefined]);
8
+ for(var i in a) (typeof exports === 'object' ? exports : root)[i] = a[i];
9
+ }
10
+ })(this, function(__WEBPACK_EXTERNAL_MODULE__9281__, __WEBPACK_EXTERNAL_MODULE__3474__) {
11
+ return /******/ (() => { // webpackBootstrap
12
+ /******/ "use strict";
13
+ /******/ var __webpack_modules__ = ({
14
+
15
+ /***/ 9008:
16
+ /***/ ((__unused_webpack_module, __webpack_exports__, __webpack_require__) => {
17
+
18
+ /* harmony export */ __webpack_require__.d(__webpack_exports__, {
19
+ /* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__)
20
+ /* harmony export */ });
21
+ /* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(9281);
22
+ /* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(react__WEBPACK_IMPORTED_MODULE_0__);
23
+ /* harmony import */ var prop_types__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(3474);
24
+ /* harmony import */ var prop_types__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(prop_types__WEBPACK_IMPORTED_MODULE_1__);
25
+ var _excluded = ["name", "size", "color", "additionalCSS"];
26
+
27
+ function _extends() { _extends = Object.assign || 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); }
28
+
29
+ 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; }
30
+
31
+ 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; }
32
+
33
+
34
+
35
+
36
+ var Icon = function Icon(_ref) {
37
+ var name = _ref.name,
38
+ _ref$size = _ref.size,
39
+ size = _ref$size === void 0 ? "0.75rem" : _ref$size,
40
+ _ref$color = _ref.color,
41
+ color = _ref$color === void 0 ? "" : _ref$color,
42
+ _ref$additionalCSS = _ref.additionalCSS,
43
+ additionalCSS = _ref$additionalCSS === void 0 ? "" : _ref$additionalCSS,
44
+ additionalAttributes = _objectWithoutProperties(_ref, _excluded);
45
+
46
+ return /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0___default().createElement("svg", _extends({
47
+ className: "".concat(color, " ").concat(additionalCSS),
48
+ style: {
49
+ width: size,
50
+ height: size
51
+ }
52
+ }, additionalAttributes), /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0___default().createElement("use", {
53
+ xlinkHref: "#sprite-".concat(name)
54
+ }));
55
+ };
56
+
57
+ Icon.propTypes = {
58
+ name: (prop_types__WEBPACK_IMPORTED_MODULE_1___default().string.isRequired),
59
+ size: (prop_types__WEBPACK_IMPORTED_MODULE_1___default().string),
60
+ color: (prop_types__WEBPACK_IMPORTED_MODULE_1___default().string),
61
+ additionalCSS: (prop_types__WEBPACK_IMPORTED_MODULE_1___default().string)
62
+ };
63
+ /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (Icon);
64
+
65
+ /***/ }),
66
+
67
+ /***/ 3474:
68
+ /***/ ((module) => {
69
+
70
+ module.exports = __WEBPACK_EXTERNAL_MODULE__3474__;
71
+
72
+ /***/ }),
73
+
74
+ /***/ 9281:
75
+ /***/ ((module) => {
76
+
77
+ module.exports = __WEBPACK_EXTERNAL_MODULE__9281__;
78
+
79
+ /***/ })
80
+
81
+ /******/ });
82
+ /************************************************************************/
83
+ /******/ // The module cache
84
+ /******/ var __webpack_module_cache__ = {};
85
+ /******/
86
+ /******/ // The require function
87
+ /******/ function __webpack_require__(moduleId) {
88
+ /******/ // Check if module is in cache
89
+ /******/ var cachedModule = __webpack_module_cache__[moduleId];
90
+ /******/ if (cachedModule !== undefined) {
91
+ /******/ return cachedModule.exports;
92
+ /******/ }
93
+ /******/ // Create a new module (and put it into the cache)
94
+ /******/ var module = __webpack_module_cache__[moduleId] = {
95
+ /******/ // no module.id needed
96
+ /******/ // no module.loaded needed
97
+ /******/ exports: {}
98
+ /******/ };
99
+ /******/
100
+ /******/ // Execute the module function
101
+ /******/ __webpack_modules__[moduleId](module, module.exports, __webpack_require__);
102
+ /******/
103
+ /******/ // Return the exports of the module
104
+ /******/ return module.exports;
105
+ /******/ }
106
+ /******/
107
+ /************************************************************************/
108
+ /******/ /* webpack/runtime/compat get default export */
109
+ /******/ (() => {
110
+ /******/ // getDefaultExport function for compatibility with non-harmony modules
111
+ /******/ __webpack_require__.n = (module) => {
112
+ /******/ var getter = module && module.__esModule ?
113
+ /******/ () => (module['default']) :
114
+ /******/ () => (module);
115
+ /******/ __webpack_require__.d(getter, { a: getter });
116
+ /******/ return getter;
117
+ /******/ };
118
+ /******/ })();
119
+ /******/
120
+ /******/ /* webpack/runtime/define property getters */
121
+ /******/ (() => {
122
+ /******/ // define getter functions for harmony exports
123
+ /******/ __webpack_require__.d = (exports, definition) => {
124
+ /******/ for(var key in definition) {
125
+ /******/ if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {
126
+ /******/ Object.defineProperty(exports, key, { enumerable: true, get: definition[key] });
127
+ /******/ }
128
+ /******/ }
129
+ /******/ };
130
+ /******/ })();
131
+ /******/
132
+ /******/ /* webpack/runtime/hasOwnProperty shorthand */
133
+ /******/ (() => {
134
+ /******/ __webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))
135
+ /******/ })();
136
+ /******/
137
+ /******/ /* webpack/runtime/make namespace object */
138
+ /******/ (() => {
139
+ /******/ // define __esModule on exports
140
+ /******/ __webpack_require__.r = (exports) => {
141
+ /******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
142
+ /******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
143
+ /******/ }
144
+ /******/ Object.defineProperty(exports, '__esModule', { value: true });
145
+ /******/ };
146
+ /******/ })();
147
+ /******/
148
+ /************************************************************************/
149
+ var __webpack_exports__ = {};
150
+ // This entry need to be wrapped in an IIFE because it need to be isolated against other modules in the chunk.
151
+ (() => {
152
+ __webpack_require__.r(__webpack_exports__);
153
+ /* harmony export */ __webpack_require__.d(__webpack_exports__, {
154
+ /* harmony export */ "default": () => (__WEBPACK_DEFAULT_EXPORT__)
155
+ /* harmony export */ });
156
+ /* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(9281);
157
+ /* harmony import */ var react__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(react__WEBPACK_IMPORTED_MODULE_0__);
158
+ /* harmony import */ var prop_types__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(3474);
159
+ /* harmony import */ var prop_types__WEBPACK_IMPORTED_MODULE_1___default = /*#__PURE__*/__webpack_require__.n(prop_types__WEBPACK_IMPORTED_MODULE_1__);
160
+ /* harmony import */ var _Icon_component_jsx__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(9008);
161
+ function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
162
+
163
+ function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
164
+
165
+ function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
166
+
167
+ function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
168
+
169
+ function _iterableToArrayLimit(arr, i) { var _i = arr && (typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"]); if (_i == null) return; var _arr = []; var _n = true; var _d = false; var _s, _e; try { for (_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"] != null) _i["return"](); } finally { if (_d) throw _e; } } return _arr; }
170
+
171
+ function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
172
+
173
+
174
+
175
+
176
+ var DropdownMenuContext = /*#__PURE__*/(0,react__WEBPACK_IMPORTED_MODULE_0__.createContext)();
177
+
178
+ var DropdownMenu = function DropdownMenu(_ref) {
179
+ var children = _ref.children;
180
+
181
+ var _useState = (0,react__WEBPACK_IMPORTED_MODULE_0__.useState)(false),
182
+ _useState2 = _slicedToArray(_useState, 2),
183
+ isOpen = _useState2[0],
184
+ setOpen = _useState2[1];
185
+
186
+ var ref = (0,react__WEBPACK_IMPORTED_MODULE_0__.useRef)(null);
187
+ (0,react__WEBPACK_IMPORTED_MODULE_0__.useEffect)(function () {
188
+ var clickHandler = function clickHandler(e) {
189
+ var _ref$current;
190
+
191
+ if (ref !== null && ref !== void 0 && (_ref$current = ref.current) !== null && _ref$current !== void 0 && _ref$current.contains(e.target)) return;
192
+ setOpen(false);
193
+ };
194
+
195
+ document.addEventListener("click", clickHandler);
196
+ return function () {
197
+ document.removeEventListener("click", clickHandler);
198
+ };
199
+ }, []);
200
+ return /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0___default().createElement(DropdownMenuContext.Provider, {
201
+ value: {
202
+ isOpen: isOpen,
203
+ setOpen: setOpen
204
+ }
205
+ }, /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0___default().createElement("div", {
206
+ id: "dropdown-menu",
207
+ className: "relative",
208
+ ref: ref
209
+ }, children));
210
+ };
211
+
212
+ DropdownMenu.propTypes = {
213
+ children: (prop_types__WEBPACK_IMPORTED_MODULE_1___default().node)
214
+ };
215
+
216
+ var Trigger = function Trigger(_ref2) {
217
+ var children = _ref2.children,
218
+ _ref2$additionalTrigg = _ref2.additionalTriggerCSS,
219
+ additionalTriggerCSS = _ref2$additionalTrigg === void 0 ? "" : _ref2$additionalTrigg;
220
+
221
+ var _useContext = (0,react__WEBPACK_IMPORTED_MODULE_0__.useContext)(DropdownMenuContext),
222
+ isOpen = _useContext.isOpen,
223
+ setOpen = _useContext.setOpen;
224
+
225
+ return /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0___default().createElement("button", {
226
+ id: "menu-trigger",
227
+ onClick: function onClick() {
228
+ return setOpen(!isOpen);
229
+ },
230
+ className: "".concat(additionalTriggerCSS, " flex items-center p-8 ml-8 group hover:text-gui-hover hover:bg-light-grey active:text-gui-active focus:text-gui-focus focus:outline-none rounded-lg")
231
+ }, /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0___default().createElement("span", {
232
+ className: "leading-normal"
233
+ }, children), /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_Icon_component_jsx__WEBPACK_IMPORTED_MODULE_2__.default, {
234
+ name: "icon-gui-disclosure-arrow",
235
+ color: "text-cool-black",
236
+ size: "1.25rem",
237
+ additionalCSS: "transform rotate-90 group-hover:text-gui-hover group-active:text-gui-active group-focus:text-gui-focus"
238
+ }));
239
+ };
240
+
241
+ /*#__PURE__*/
242
+ react__WEBPACK_IMPORTED_MODULE_0___default().createElement(DropdownMenu.Trigger, {
243
+ className: "list of names"
244
+ }, "Click me");
245
+ Trigger.propTypes = {
246
+ children: (prop_types__WEBPACK_IMPORTED_MODULE_1___default().node),
247
+ additionalTriggerCSS: (prop_types__WEBPACK_IMPORTED_MODULE_1___default().string)
248
+ };
249
+
250
+ var Content = function Content(_ref3) {
251
+ var children = _ref3.children,
252
+ _ref3$anchorPosition = _ref3.anchorPosition,
253
+ anchorPosition = _ref3$anchorPosition === void 0 ? "right" : _ref3$anchorPosition,
254
+ additionalContentCSS = _ref3.additionalContentCSS;
255
+
256
+ var _useContext2 = (0,react__WEBPACK_IMPORTED_MODULE_0__.useContext)(DropdownMenuContext),
257
+ isOpen = _useContext2.isOpen;
258
+
259
+ if (!isOpen) {
260
+ return null;
261
+ }
262
+
263
+ var anchorPositionClasses = anchorPosition === "right" ? "right-0" : "left-0";
264
+ return /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0___default().createElement("div", {
265
+ id: "menu-content",
266
+ className: "".concat(additionalContentCSS, " absolute p-8 z-10 border border-mid-grey bg-white rounded shadow-container ").concat(anchorPositionClasses),
267
+ style: {
268
+ minWidth: 275,
269
+ top: 44
270
+ }
271
+ }, children);
272
+ };
273
+
274
+ Content.propTypes = {
275
+ children: (prop_types__WEBPACK_IMPORTED_MODULE_1___default().node),
276
+ anchorPosition: (prop_types__WEBPACK_IMPORTED_MODULE_1___default().string),
277
+ additionalContentCSS: (prop_types__WEBPACK_IMPORTED_MODULE_1___default().string)
278
+ };
279
+
280
+ var Link = function Link(_ref4) {
281
+ var url = _ref4.url,
282
+ title = _ref4.title,
283
+ subtitle = _ref4.subtitle,
284
+ iconName = _ref4.iconName,
285
+ children = _ref4.children;
286
+ return /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0___default().createElement("a", {
287
+ href: url,
288
+ className: "menu-link group block p-8 hover:bg-light-grey hover:text-cool-black rounded"
289
+ }, /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0___default().createElement("p", {
290
+ className: "mb-4"
291
+ }, title, iconName ? /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_Icon_component_jsx__WEBPACK_IMPORTED_MODULE_2__.default, {
292
+ name: iconName,
293
+ size: "1rem",
294
+ color: "text-cool-black",
295
+ additionalCSS: "align-middle ml-8 relative -top-1 -left-4"
296
+ }) : null), subtitle ? /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0___default().createElement("p", {
297
+ className: "text-p3 mb-16 text-dark-grey"
298
+ }, subtitle) : null, children);
299
+ };
300
+
301
+ Link.propTypes = {
302
+ url: (prop_types__WEBPACK_IMPORTED_MODULE_1___default().string),
303
+ title: (prop_types__WEBPACK_IMPORTED_MODULE_1___default().string),
304
+ subtitle: (prop_types__WEBPACK_IMPORTED_MODULE_1___default().string),
305
+ iconName: (prop_types__WEBPACK_IMPORTED_MODULE_1___default().string),
306
+ children: (prop_types__WEBPACK_IMPORTED_MODULE_1___default().node)
307
+ };
308
+ DropdownMenu.Trigger = Trigger;
309
+ DropdownMenu.Content = Content;
310
+ DropdownMenu.Link = Link;
311
+ /* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (DropdownMenu);
312
+ })();
313
+
314
+ /******/ return __webpack_exports__;
315
+ /******/ })()
316
+ ;
317
+ });
package/core/Meganav.jsx CHANGED
@@ -1013,7 +1013,19 @@ var MeganavContentDevelopers = function MeganavContentDevelopers(_ref) {
1013
1013
  className: "ui-meganav-media-heading"
1014
1014
  }, "Tutorials & Demos"), /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0___default().createElement("p", {
1015
1015
  className: "ui-meganav-media-copy"
1016
- }, "Get stuck in with our hands-on resources. ")))))), /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0___default().createElement("div", {
1016
+ }, "Get stuck in with our hands-on resources. ")))), /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0___default().createElement("li", null, /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0___default().createElement("a", {
1017
+ href: absUrl("/integrations"),
1018
+ className: "ui-meganav-media-with-image group"
1019
+ }, /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_Icon_component_jsx__WEBPACK_IMPORTED_MODULE_2__.default, {
1020
+ name: "icon-display-integrations-col",
1021
+ size: "2.5rem"
1022
+ }), /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0___default().createElement("div", {
1023
+ className: "flex flex-col justify-center"
1024
+ }, /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0___default().createElement("p", {
1025
+ className: "ui-meganav-media-heading"
1026
+ }, "Integrations"), /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0___default().createElement("p", {
1027
+ className: "ui-meganav-media-copy"
1028
+ }, "Find out more about Ably integrations. ")))))), /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0___default().createElement("div", {
1017
1029
  className: "col-span-full md:col-span-4 pt-8 pb-24 md:py-24 lg:py-32 px-24 sm:px-32 md:px-0"
1018
1030
  }, /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0___default().createElement("h3", {
1019
1031
  className: "ui-meganav-overline uppercase",
@@ -1318,7 +1330,7 @@ var MeganavContentUseCases = function MeganavContentUseCases(_ref) {
1318
1330
  className: "ui-meganav-media group"
1319
1331
  }, /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0___default().createElement("p", {
1320
1332
  className: "ui-meganav-media-heading"
1321
- }, "Fintech"), /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0___default().createElement("p", {
1333
+ }, "FinTech"), /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0___default().createElement("p", {
1322
1334
  className: "ui-meganav-media-copy"
1323
1335
  }, "Deliver personalised financial data in realtime."))), /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0___default().createElement("li", null, /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0___default().createElement("a", {
1324
1336
  href: absUrl("/solutions/automotive-logistics-and-mobility"),
@@ -242,7 +242,19 @@ var MeganavContentDevelopers = function MeganavContentDevelopers(_ref) {
242
242
  className: "ui-meganav-media-heading"
243
243
  }, "Tutorials & Demos"), /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0___default().createElement("p", {
244
244
  className: "ui-meganav-media-copy"
245
- }, "Get stuck in with our hands-on resources. ")))))), /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0___default().createElement("div", {
245
+ }, "Get stuck in with our hands-on resources. ")))), /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0___default().createElement("li", null, /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0___default().createElement("a", {
246
+ href: absUrl("/integrations"),
247
+ className: "ui-meganav-media-with-image group"
248
+ }, /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0___default().createElement(_Icon_component_jsx__WEBPACK_IMPORTED_MODULE_2__.default, {
249
+ name: "icon-display-integrations-col",
250
+ size: "2.5rem"
251
+ }), /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0___default().createElement("div", {
252
+ className: "flex flex-col justify-center"
253
+ }, /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0___default().createElement("p", {
254
+ className: "ui-meganav-media-heading"
255
+ }, "Integrations"), /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0___default().createElement("p", {
256
+ className: "ui-meganav-media-copy"
257
+ }, "Find out more about Ably integrations. ")))))), /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0___default().createElement("div", {
246
258
  className: "col-span-full md:col-span-4 pt-8 pb-24 md:py-24 lg:py-32 px-24 sm:px-32 md:px-0"
247
259
  }, /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0___default().createElement("h3", {
248
260
  className: "ui-meganav-overline uppercase",
@@ -244,7 +244,7 @@ var MeganavContentUseCases = function MeganavContentUseCases(_ref) {
244
244
  className: "ui-meganav-media group"
245
245
  }, /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0___default().createElement("p", {
246
246
  className: "ui-meganav-media-heading"
247
- }, "Fintech"), /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0___default().createElement("p", {
247
+ }, "FinTech"), /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0___default().createElement("p", {
248
248
  className: "ui-meganav-media-copy"
249
249
  }, "Deliver personalised financial data in realtime."))), /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0___default().createElement("li", null, /*#__PURE__*/react__WEBPACK_IMPORTED_MODULE_0___default().createElement("a", {
250
250
  href: absUrl("/solutions/automotive-logistics-and-mobility"),
@@ -1,6 +1,22 @@
1
- /******/ (() => { // webpackBootstrap
2
- /******/ "use strict";
3
- /******/
4
- /******/
1
+ (function webpackUniversalModuleDefinition(root, factory) {
2
+ if(typeof exports === 'object' && typeof module === 'object')
3
+ module.exports = factory();
4
+ else if(typeof define === 'function' && define.amd)
5
+ define([], factory);
6
+ else if(typeof exports === 'object')
7
+ exports["AblyUi"] = factory();
8
+ else
9
+ root["AblyUi"] = root["AblyUi"] || {}, root["AblyUi"]["Core"] = root["AblyUi"]["Core"] || {}, root["AblyUi"]["Core"]["MeganavContentWhyAbly"] = factory();
10
+ })(this, function() {
11
+ return /******/ (() => { // webpackBootstrap
12
+ var __webpack_exports__ = {};
13
+ /*!*****************************************************!*\
14
+ !*** ./src/core/MeganavContentWhyAbly/component.js ***!
15
+ \*****************************************************/
16
+
17
+ __webpack_exports__ = __webpack_exports__.default;
18
+ /******/ return __webpack_exports__;
5
19
  /******/ })()
6
- ;
20
+ ;
21
+ });
22
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIndlYnBhY2s6Ly9BYmx5VWkuQ29yZS5bbmFtZV0vd2VicGFjay91bml2ZXJzYWxNb2R1bGVEZWZpbml0aW9uIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQSx1Q0FBdUMsdURBQXVEO0FBQzlGLENBQUM7QUFDRCxPIiwiZmlsZSI6ImNvcmUvTWVnYW5hdkNvbnRlbnRXaHlBYmx5L2NvbXBvbmVudC5qcyIsInNvdXJjZXNDb250ZW50IjpbIihmdW5jdGlvbiB3ZWJwYWNrVW5pdmVyc2FsTW9kdWxlRGVmaW5pdGlvbihyb290LCBmYWN0b3J5KSB7XG5cdGlmKHR5cGVvZiBleHBvcnRzID09PSAnb2JqZWN0JyAmJiB0eXBlb2YgbW9kdWxlID09PSAnb2JqZWN0Jylcblx0XHRtb2R1bGUuZXhwb3J0cyA9IGZhY3RvcnkoKTtcblx0ZWxzZSBpZih0eXBlb2YgZGVmaW5lID09PSAnZnVuY3Rpb24nICYmIGRlZmluZS5hbWQpXG5cdFx0ZGVmaW5lKFtdLCBmYWN0b3J5KTtcblx0ZWxzZSBpZih0eXBlb2YgZXhwb3J0cyA9PT0gJ29iamVjdCcpXG5cdFx0ZXhwb3J0c1tcIkFibHlVaVwiXSA9IGZhY3RvcnkoKTtcblx0ZWxzZVxuXHRcdHJvb3RbXCJBYmx5VWlcIl0gPSByb290W1wiQWJseVVpXCJdIHx8IHt9LCByb290W1wiQWJseVVpXCJdW1wiQ29yZVwiXSA9IHJvb3RbXCJBYmx5VWlcIl1bXCJDb3JlXCJdIHx8IHt9LCByb290W1wiQWJseVVpXCJdW1wiQ29yZVwiXVtcIk1lZ2FuYXZDb250ZW50V2h5QWJseVwiXSA9IGZhY3RvcnkoKTtcbn0pKHRoaXMsIGZ1bmN0aW9uKCkge1xucmV0dXJuICJdLCJzb3VyY2VSb290IjoiIn0=