ordering-ui-admin-external 1.6.1 → 1.6.3

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 (175) hide show
  1. package/_bundles/main.css +134 -129
  2. package/_bundles/{ordering-ui-admin.47d189a0568d6b5734d5.js → ordering-ui-admin.3ebe4d4f772eaeb4f851.js} +2 -2
  3. package/_bundles/{ordering-ui-admin.47d189a0568d6b5734d5.js.LICENSE.txt → ordering-ui-admin.3ebe4d4f772eaeb4f851.js.LICENSE.txt} +4 -4
  4. package/_modules/components/BusinessIntelligence/Reports/index.js +1 -1
  5. package/_modules/components/CartRecovery/OpenCartsFilterGroup/index.js +1 -1
  6. package/_modules/components/CartRecovery/RecoveryActionHeader/index.js +1 -1
  7. package/_modules/components/Delivery/AddressForm/index.js +1 -1
  8. package/_modules/components/Delivery/DriversCompaniesListing/index.js +1 -1
  9. package/_modules/components/Delivery/DriversGroupLogs/index.js +2 -2
  10. package/_modules/components/Delivery/DriversGroupsListing/index.js +1 -1
  11. package/_modules/components/Home/HomePage/index.js +29 -6
  12. package/_modules/components/Home/HomePage/styles.js +27 -5
  13. package/_modules/components/LanguageSelector/index.js +1 -1
  14. package/_modules/components/Login/LoginForm/index.js +119 -20
  15. package/_modules/components/Login/LoginForm/styles.js +60 -30
  16. package/_modules/components/Loyalty/RewardsPrograms/index.js +1 -1
  17. package/_modules/components/Marketing/CampaignSignUpOption/index.js +1 -1
  18. package/_modules/components/Marketing/EnterprisePromotionListing/index.js +1 -1
  19. package/_modules/components/Messages/MessagesListing/styles.js +1 -1
  20. package/_modules/components/MyProducts/AppLayout/index.js +75 -0
  21. package/_modules/components/MyProducts/AppLayout/styles.js +41 -0
  22. package/_modules/components/MyProducts/CallCenterApp/index.js +42 -0
  23. package/_modules/components/MyProducts/ContentForm/index.js +236 -0
  24. package/_modules/components/MyProducts/ContentForm/styles.js +32 -0
  25. package/_modules/components/MyProducts/CustomerApp/index.js +18 -25
  26. package/_modules/components/MyProducts/DriverApp/index.js +18 -45
  27. package/_modules/components/MyProducts/KioskApp/index.js +42 -0
  28. package/_modules/components/MyProducts/OrderingWebsite/index.js +351 -3
  29. package/_modules/components/MyProducts/OrderingWebsite/styles.js +54 -3
  30. package/_modules/components/MyProducts/PosApp/index.js +42 -0
  31. package/_modules/components/MyProducts/StoreApp/index.js +18 -45
  32. package/_modules/components/MyProducts/index.js +22 -1
  33. package/_modules/components/OrderingProducts/OrderingProductDetails/index.js +6 -8
  34. package/_modules/components/OrderingProducts/SiteTheme/index.js +13 -4
  35. package/_modules/components/Orders/DeliveriesManager/index.js +6 -0
  36. package/_modules/components/Orders/DriversManager/index.js +7 -1
  37. package/_modules/components/Orders/GoogleMapsApiKeySettingButton/index.js +110 -0
  38. package/_modules/components/{MyProducts/CustomerApp/styles.js → Orders/GoogleMapsApiKeySettingButton/style.js} +9 -13
  39. package/_modules/components/Orders/Messages/styles.js +3 -3
  40. package/_modules/components/Orders/OrderContactInformation/index.js +7 -7
  41. package/_modules/components/Orders/OrdersContentHeader/index.js +4 -2
  42. package/_modules/components/Orders/OrdersManager/index.js +3 -2
  43. package/_modules/components/Profile/ProfilePage/index.js +2 -1
  44. package/_modules/components/Profile/ProfilePage/styles.js +2 -2
  45. package/_modules/components/Profile/Sessions/index.js +209 -0
  46. package/_modules/components/Profile/Sessions/styles.js +46 -0
  47. package/_modules/components/Profile/index.js +8 -1
  48. package/_modules/components/Settings/EmailSetting/index.js +2 -29
  49. package/_modules/components/Settings/PageForm/index.js +6 -1
  50. package/_modules/components/Settings/Settings/index.js +0 -62
  51. package/_modules/components/Shared/CitySelector/index.js +9 -1
  52. package/_modules/components/Shared/Modal/index.js +5 -3
  53. package/_modules/components/Shared/Modal/styles.js +25 -23
  54. package/_modules/components/SidebarMenu/index.js +117 -76
  55. package/_modules/components/SidebarMenu/styles.js +4 -2
  56. package/_modules/components/Stores/AddBusinessForm/index.js +22 -8
  57. package/_modules/components/Stores/BusinessBrandGENDetail/index.js +6 -1
  58. package/_modules/components/Stores/BusinessProductList/styles.js +1 -1
  59. package/_modules/components/Stores/BusinessProductsCategories/styles.js +1 -1
  60. package/_modules/components/Stores/BusinessProductsCategoyInfo/index.js +6 -1
  61. package/_modules/components/Stores/BusinessProductsListing/index.js +35 -8
  62. package/_modules/components/Stores/BusinessProductsListing/styles.js +6 -4
  63. package/_modules/components/Stores/BusinessSelectHeader/index.js +17 -9
  64. package/_modules/components/Stores/BusinessSelectHeader/styles.js +1 -1
  65. package/_modules/components/Stores/BusinessSummary/index.js +21 -8
  66. package/_modules/components/Stores/BusinessSummary/styles.js +5 -3
  67. package/_modules/components/Stores/BusinessSync/index.js +6 -2
  68. package/_modules/components/Stores/BusinessSyncItsaCheckmate/index.js +52 -0
  69. package/_modules/components/Stores/BusinessSyncItsaCheckmate/styles.js +31 -0
  70. package/_modules/components/Support/index.js +1 -1
  71. package/_modules/hooks/useCountdownTimer.js +40 -0
  72. package/_modules/index.js +18 -0
  73. package/_modules/utils/index.js +65 -4
  74. package/index-template.js +49 -8
  75. package/package.json +3 -2
  76. package/src/components/BusinessIntelligence/Reports/index.js +1 -1
  77. package/src/components/CartRecovery/OpenCartsFilterGroup/index.js +1 -1
  78. package/src/components/CartRecovery/RecoveryActionHeader/index.js +1 -1
  79. package/src/components/Delivery/AddressForm/index.js +1 -1
  80. package/src/components/Delivery/DriversCompaniesListing/index.js +1 -1
  81. package/src/components/Delivery/DriversGroupLogs/index.js +1 -1
  82. package/src/components/Delivery/DriversGroupsListing/index.js +1 -1
  83. package/src/components/Home/HomePage/index.js +62 -6
  84. package/src/components/Home/HomePage/styles.js +48 -1
  85. package/src/components/LanguageSelector/index.js +1 -1
  86. package/src/components/Login/LoginForm/index.js +211 -94
  87. package/src/components/Login/LoginForm/styles.js +74 -8
  88. package/src/components/Loyalty/RewardsPrograms/index.js +1 -1
  89. package/src/components/Marketing/CampaignSignUpOption/index.js +1 -1
  90. package/src/components/Marketing/EnterprisePromotionListing/index.js +1 -1
  91. package/src/components/Messages/MessagesListing/styles.js +3 -5
  92. package/src/components/MyProducts/AppLayout/index.js +97 -0
  93. package/src/components/MyProducts/AppLayout/styles.js +145 -0
  94. package/src/components/MyProducts/CallCenterApp/index.js +29 -0
  95. package/src/components/MyProducts/ContentForm/index.js +230 -0
  96. package/src/components/MyProducts/ContentForm/styles.js +67 -0
  97. package/src/components/MyProducts/CustomerApp/index.js +17 -41
  98. package/src/components/MyProducts/DriverApp/index.js +16 -70
  99. package/src/components/MyProducts/KioskApp/index.js +29 -0
  100. package/src/components/MyProducts/OrderingWebsite/index.js +452 -25
  101. package/src/components/MyProducts/OrderingWebsite/styles.js +244 -0
  102. package/src/components/MyProducts/PosApp/index.js +29 -0
  103. package/src/components/MyProducts/StoreApp/index.js +16 -70
  104. package/src/components/MyProducts/index.js +7 -1
  105. package/src/components/OrderingProducts/OrderingProductDetails/index.js +4 -4
  106. package/src/components/OrderingProducts/SiteTheme/index.js +8 -0
  107. package/src/components/Orders/DeliveriesManager/index.js +5 -1
  108. package/src/components/Orders/DriversManager/index.js +7 -1
  109. package/src/components/Orders/GoogleMapsApiKeySettingButton/index.js +94 -0
  110. package/src/components/Orders/GoogleMapsApiKeySettingButton/style.js +38 -0
  111. package/src/components/Orders/Messages/styles.js +6 -0
  112. package/src/components/Orders/OrderContactInformation/index.js +1 -1
  113. package/src/components/Orders/OrdersContentHeader/index.js +6 -1
  114. package/src/components/Orders/OrdersManager/index.js +2 -1
  115. package/src/components/Profile/ProfilePage/index.js +2 -0
  116. package/src/components/Profile/ProfilePage/styles.js +2 -1
  117. package/src/components/Profile/Sessions/index.js +209 -0
  118. package/src/components/Profile/Sessions/styles.js +132 -0
  119. package/src/components/Profile/index.js +3 -1
  120. package/src/components/Settings/EmailSetting/index.js +0 -32
  121. package/src/components/Settings/PageForm/index.js +3 -0
  122. package/src/components/Settings/Settings/index.js +0 -65
  123. package/src/components/Shared/CitySelector/index.js +8 -0
  124. package/src/components/Shared/Modal/index.js +32 -26
  125. package/src/components/Shared/Modal/styles.js +11 -3
  126. package/src/components/SidebarMenu/index.js +90 -68
  127. package/src/components/SidebarMenu/styles.js +8 -1
  128. package/src/components/Stores/AddBusinessForm/index.js +10 -8
  129. package/src/components/Stores/BusinessBrandGENDetail/index.js +3 -0
  130. package/src/components/Stores/BusinessProductList/styles.js +1 -1
  131. package/src/components/Stores/BusinessProductsCategories/styles.js +1 -1
  132. package/src/components/Stores/BusinessProductsCategoyInfo/index.js +3 -0
  133. package/src/components/Stores/BusinessProductsListing/index.js +35 -1
  134. package/src/components/Stores/BusinessProductsListing/styles.js +9 -1
  135. package/src/components/Stores/BusinessSelectHeader/index.js +14 -2
  136. package/src/components/Stores/BusinessSelectHeader/styles.js +5 -0
  137. package/src/components/Stores/BusinessSummary/index.js +27 -10
  138. package/src/components/Stores/BusinessSummary/styles.js +7 -0
  139. package/src/components/Stores/BusinessSync/index.js +7 -2
  140. package/src/components/Stores/BusinessSyncItsaCheckmate/index.js +63 -0
  141. package/src/components/Stores/BusinessSyncItsaCheckmate/styles.js +88 -0
  142. package/src/components/Support/index.js +1 -1
  143. package/src/hooks/useCountdownTimer.js +26 -0
  144. package/src/index.js +7 -1
  145. package/src/utils/index.js +61 -0
  146. package/template/app.js +14 -12
  147. package/template/assets/images/ItsaCheckmateLogo.png +0 -0
  148. package/template/assets/images/door-dash.png +0 -0
  149. package/template/assets/images/myProducts/driver-app-brand.png +0 -0
  150. package/template/assets/images/myProducts/driver-app-free.png +0 -0
  151. package/template/assets/images/myProducts/multi-store-customer-app.png +0 -0
  152. package/template/assets/images/myProducts/my-callcenter-app-brand.png +0 -0
  153. package/template/assets/images/myProducts/my-callcenter-app-live.png +0 -0
  154. package/template/assets/images/myProducts/my-kiosk-app-brand.png +0 -0
  155. package/template/assets/images/myProducts/my-kiosk-app-live.png +0 -0
  156. package/template/assets/images/myProducts/my-pos-app-brand.png +0 -0
  157. package/template/assets/images/myProducts/my-pos-app-live.png +0 -0
  158. package/template/assets/images/myProducts/single-store-customer-app.png +0 -0
  159. package/template/assets/images/myProducts/store-app-brand.png +0 -0
  160. package/template/assets/images/myProducts/store-app-free.png +0 -0
  161. package/template/assets/images/projectStatuses/project-active.png +0 -0
  162. package/template/assets/images/projectStatuses/project-past-due-payment.png +0 -0
  163. package/template/components/AutologinParams/index.js +79 -0
  164. package/template/components/ListenPageChanges/index.js +3 -2
  165. package/template/config.json +1 -0
  166. package/template/helmetdata.json +21 -0
  167. package/template/pages/CallCenterApp/index.js +12 -0
  168. package/template/pages/KioskApp/index.js +12 -0
  169. package/template/pages/PosApp/index.js +12 -0
  170. package/template/theme.json +3 -0
  171. package/_modules/components/MyProducts/DriverApp/styles.js +0 -29
  172. package/_modules/components/MyProducts/StoreApp/styles.js +0 -29
  173. package/src/components/MyProducts/CustomerApp/styles.js +0 -59
  174. package/src/components/MyProducts/DriverApp/styles.js +0 -104
  175. package/src/components/MyProducts/StoreApp/styles.js +0 -104
@@ -0,0 +1,31 @@
1
+ "use strict";
2
+
3
+ function _typeof(obj) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (obj) { return typeof obj; } : function (obj) { return obj && "function" == typeof Symbol && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }, _typeof(obj); }
4
+ Object.defineProperty(exports, "__esModule", {
5
+ value: true
6
+ });
7
+ exports.YoutubeVideoWrapper = exports.YoutubeVideoInner = exports.LogoWrapper = exports.GetStarted = exports.Description = exports.Container = void 0;
8
+ var _styledComponents = _interopRequireWildcard(require("styled-components"));
9
+ var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5, _templateObject6, _templateObject7, _templateObject8;
10
+ 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); }
11
+ 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; }
12
+ function _taggedTemplateLiteral(strings, raw) { if (!raw) { raw = strings.slice(0); } return Object.freeze(Object.defineProperties(strings, { raw: { value: Object.freeze(raw) } })); }
13
+ var Container = _styledComponents.default.div(_templateObject || (_templateObject = _taggedTemplateLiteral([""])));
14
+ exports.Container = Container;
15
+ var LogoWrapper = _styledComponents.default.div(_templateObject2 || (_templateObject2 = _taggedTemplateLiteral(["\n width: 216px;\n height: 216px;\n box-shadow: 0px 1px 4px rgba(0, 0, 0, 0.1);\n border-radius: 7.6px;\n margin: 0 auto;\n display: flex;\n align-items: center;\n\n > img {\n width: 100%;\n }\n"])));
16
+ exports.LogoWrapper = LogoWrapper;
17
+ var Description = _styledComponents.default.div(_templateObject3 || (_templateObject3 = _taggedTemplateLiteral(["\n margin-top: 36px;\n margin-bottom: 50px;\n div.sub-header {\n font-size: 14px;\n margin-bottom: 10px;\n }\n div.menu-item {\n display: flex;\n align-items: center;\n svg {\n ", "\n }\n > p {\n font-weight: 400;\n font-size: 14px;\n line-height: 24px;\n margin: 0px;\n }\n }\n"])), function (props) {
18
+ var _props$theme;
19
+ return (_props$theme = props.theme) !== null && _props$theme !== void 0 && _props$theme.rtl ? (0, _styledComponents.css)(_templateObject4 || (_templateObject4 = _taggedTemplateLiteral(["\n margin-left: 8px;\n "]))) : (0, _styledComponents.css)(_templateObject5 || (_templateObject5 = _taggedTemplateLiteral(["\n margin-right: 8px;\n "])));
20
+ });
21
+ exports.Description = Description;
22
+ var GetStarted = _styledComponents.default.div(_templateObject6 || (_templateObject6 = _taggedTemplateLiteral(["\n h2 {\n font-weight: 500;\n font-size: 14px;\n line-height: 24px;\n margin-top: 0px;\n margin-bottom: 10px;\n }\n p {\n font-weight: 400;\n font-size: 14px;\n line-height: 24px;\n margin-top: 0px;\n margin-bottom: 8px;\n color: ", ";\n }\n button {\n border-radius: 8px;\n height: 44px;\n }\n"])), function (props) {
23
+ return props.theme.colors.lightGray;
24
+ });
25
+ exports.GetStarted = GetStarted;
26
+ var YoutubeVideoWrapper = _styledComponents.default.div(_templateObject7 || (_templateObject7 = _taggedTemplateLiteral(["\n margin-top: 50px;\n padding-bottom: 30px;\n"])));
27
+ exports.YoutubeVideoWrapper = YoutubeVideoWrapper;
28
+ var YoutubeVideoInner = _styledComponents.default.div(_templateObject8 || (_templateObject8 = _taggedTemplateLiteral(["\n position: relative;\n width: 100%;\n padding-bottom: 56.25%;\n box-shadow: 0px 1px 4px rgba(0, 0, 0, 0.1);\n border-radius: 7.6px;\n background-color: ", ";\n\n iframe {\n position: absolute;\n top: 0;\n left: 0;\n width: 100%;\n height: 100%;\n border: 0;\n }\n"])), function (props) {
29
+ return props.theme.colors.secundaryDarkContrast;
30
+ });
31
+ exports.YoutubeVideoInner = YoutubeVideoInner;
@@ -44,7 +44,7 @@ var Support = function Support(props) {
44
44
  borderRadius: "7.6px",
45
45
  color: "primary",
46
46
  onClick: function onClick() {
47
- return handleGoToLink('https://www.ordering.co/ordering-support');
47
+ return handleGoToLink('https://support.ordering.co');
48
48
  },
49
49
  outline: true
50
50
  }, t('TECH_SUPPORT', 'Tech Support'))))));
@@ -0,0 +1,40 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.useCountdownTimer = useCountdownTimer;
7
+ var _react = require("react");
8
+ function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
9
+ 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."); }
10
+ 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); }
11
+ 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; }
12
+ function _iterableToArrayLimit(arr, i) { var _i = arr == null ? null : 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; }
13
+ function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
14
+ /**
15
+ * Hook for countdown seconds
16
+ * @param {int} initialCount
17
+ * @param {boolean} start
18
+ */
19
+ function useCountdownTimer(initialCount, start) {
20
+ var _useState = (0, _react.useState)(initialCount),
21
+ _useState2 = _slicedToArray(_useState, 2),
22
+ count = _useState2[0],
23
+ setCount = _useState2[1];
24
+ (0, _react.useEffect)(function () {
25
+ if (start) {
26
+ var secondsLeft = setInterval(function () {
27
+ setCount(function (c) {
28
+ return c - (c === 0 ? 0 : 1);
29
+ });
30
+ }, 1000);
31
+ return function () {
32
+ return clearInterval(secondsLeft);
33
+ };
34
+ }
35
+ }, [start]);
36
+ return [count, setCount, /** reset */
37
+ function () {
38
+ setCount(initialCount);
39
+ }];
40
+ }
package/_modules/index.js CHANGED
@@ -549,6 +549,12 @@ Object.defineProperty(exports, "Button", {
549
549
  return _Buttons.Button;
550
550
  }
551
551
  });
552
+ Object.defineProperty(exports, "CallCenterApp", {
553
+ enumerable: true,
554
+ get: function get() {
555
+ return _MyProducts.CallCenterApp;
556
+ }
557
+ });
552
558
  Object.defineProperty(exports, "CampaignAmountOption", {
553
559
  enumerable: true,
554
560
  get: function get() {
@@ -1233,6 +1239,12 @@ Object.defineProperty(exports, "InvoiceManager", {
1233
1239
  return _BusinessIntelligence.InvoiceManager;
1234
1240
  }
1235
1241
  });
1242
+ Object.defineProperty(exports, "KioskApp", {
1243
+ enumerable: true,
1244
+ get: function get() {
1245
+ return _MyProducts.KioskApp;
1246
+ }
1247
+ });
1236
1248
  Object.defineProperty(exports, "LanguageManager", {
1237
1249
  enumerable: true,
1238
1250
  get: function get() {
@@ -1605,6 +1617,12 @@ Object.defineProperty(exports, "PointsWalletLevels", {
1605
1617
  return _Loyalty.PointsWalletLevels;
1606
1618
  }
1607
1619
  });
1620
+ Object.defineProperty(exports, "PosApp", {
1621
+ enumerable: true,
1622
+ get: function get() {
1623
+ return _MyProducts.PosApp;
1624
+ }
1625
+ });
1608
1626
  Object.defineProperty(exports, "ProductDesktopPreview", {
1609
1627
  enumerable: true,
1610
1628
  get: function get() {
@@ -3,7 +3,7 @@
3
3
  Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
- exports.widgetURL = exports.verifyDecimals = exports.sortInputFields = exports.shape = exports.setStorageItem = exports.scrollTo = exports.ribbonValues = exports.reviewCommentList = exports.removeStorageItem = exports.orderRejectCommentList = exports.optimizeImage = exports.getStorageItem = exports.getStarWidth = exports.getSeconds = exports.getMinutes = exports.getIconCard = exports.getHours = exports.getAgoMinutes = exports.formatUrlVideo = exports.fieldsToSort = exports.convertHoursToMinutes = exports.convertHMS = exports.checkSiteUrl = exports.capitalize = exports.bytesConverter = exports.DriverTipsOptions = void 0;
6
+ exports.widgetURL = exports.verifyDecimals = exports.stringToSlug = exports.sortInputFields = exports.shape = exports.setStorageItem = exports.scrollTo = exports.ribbonValues = exports.reviewCommentList = exports.removeStorageItem = exports.orderRejectCommentList = exports.optimizeImage = exports.getStorageItem = exports.getStarWidth = exports.getSeconds = exports.getMinutes = exports.getIconCard = exports.getHours = exports.getCurrentDiffDays = exports.getAgoMinutes = exports.formatUrlVideo = exports.formatSeconds = exports.firstLetterCapital = exports.fieldsToSort = exports.convertHoursToMinutes = exports.convertHMS = exports.checkSiteUrl = exports.checkPreSiteUrl = exports.capitalize = exports.bytesConverter = exports.DriverTipsOptions = void 0;
7
7
  var _react = _interopRequireDefault(require("react"));
8
8
  var _FaCcMastercard = _interopRequireDefault(require("@meronex/icons/fa/FaCcMastercard"));
9
9
  var _FaCcVisa = _interopRequireDefault(require("@meronex/icons/fa/FaCcVisa"));
@@ -344,22 +344,53 @@ var shape = {
344
344
  };
345
345
 
346
346
  /**
347
- * default value for bitton
347
+ * Function to check URL
348
+ * @param {string} url URL of page
349
+ * @param {string} fallback default URL
348
350
  */
349
351
  exports.shape = shape;
352
+ var checkPreSiteUrl = function checkPreSiteUrl(url, fallback) {
353
+ if (!url) return fallback;
354
+ return url[0] === '/' ? url : "/".concat(url);
355
+ };
356
+
357
+ /**
358
+ * default value for bitton
359
+ */
360
+ exports.checkPreSiteUrl = checkPreSiteUrl;
350
361
  var ribbonValues = {
351
362
  color: '#0083FE',
352
363
  text: 'ribbon',
353
364
  shape: 'rectangle',
354
365
  enabled: false
355
366
  };
367
+ /**
368
+ * Format seconds to hh:mm:ss
369
+ * @param {number} seconds
370
+ */
371
+ exports.ribbonValues = ribbonValues;
372
+ var formatSeconds = function formatSeconds(seconds) {
373
+ // Hours, minutes and seconds
374
+ var hrs = Math.floor(seconds / 3600);
375
+ var mins = Math.floor(seconds % 3600 / 60);
376
+ var secs = Math.floor(seconds % 60);
377
+
378
+ // Output like '1:01' or '4:03:59' or '123:03:59'
379
+ var ret = '';
380
+ if (hrs > 0) {
381
+ ret += '' + hrs + ':' + (mins < 10 ? '0' : '');
382
+ }
383
+ ret += '' + mins + ':' + (secs < 10 ? '0' : '');
384
+ ret += '' + secs;
385
+ return ret;
386
+ };
356
387
 
357
388
  /**
358
389
  * Function to check URL
359
390
  * @param {string} url URL of page
360
391
  * @param {string} fallback default URL
361
392
  */
362
- exports.ribbonValues = ribbonValues;
393
+ exports.formatSeconds = formatSeconds;
363
394
  var checkSiteUrl = function checkSiteUrl(url, fallback) {
364
395
  if (!url) return fallback;
365
396
  return url[(url === null || url === void 0 ? void 0 : url.length) - 1] === '/' ? url : "".concat(url, "/");
@@ -522,4 +553,34 @@ var orderRejectCommentList = function orderRejectCommentList(status) {
522
553
  };
523
554
  exports.orderRejectCommentList = orderRejectCommentList;
524
555
  var widgetURL = 'https://orderingweb.ordering.co/';
525
- exports.widgetURL = widgetURL;
556
+ exports.widgetURL = widgetURL;
557
+ var getCurrentDiffDays = function getCurrentDiffDays(time) {
558
+ var current = (0, _moment.default)().utc();
559
+ var compared = (0, _moment.default)(time);
560
+ return compared.diff(current, 'days');
561
+ };
562
+ exports.getCurrentDiffDays = getCurrentDiffDays;
563
+ var firstLetterCapital = function firstLetterCapital(text) {
564
+ return text.charAt(0).toUpperCase() + text.slice(1).toLowerCase();
565
+ };
566
+ exports.firstLetterCapital = firstLetterCapital;
567
+ var stringToSlug = function stringToSlug(str) {
568
+ var _str;
569
+ str = str.replace(/^\s+|\s+$/g, ''); // trim
570
+ str = (_str = str) === null || _str === void 0 ? void 0 : _str.toLowerCase();
571
+
572
+ // remove accents, swap ñ for n, etc
573
+ var from = 'åàáãäâèéëêìíïîòóöôùúüûñç·/_,:;';
574
+ var to = 'aaaaaaeeeeiiiioooouuuunc------';
575
+ for (var i = 0, l = from.length; i < l; i++) {
576
+ str = str.replace(new RegExp(from.charAt(i), 'g'), to.charAt(i));
577
+ }
578
+ str = str.replace(/[^a-z0-9 -]/g, '') // remove invalid chars
579
+ .replace(/\s+/g, '_') // collapse whitespace and replace by -
580
+ .replace(/-+/g, '_') // collapse dashes
581
+ .replace(/^-+/, '') // trim - from start of text
582
+ .replace(/-+$/, ''); // trim - from end of text
583
+
584
+ return str;
585
+ };
586
+ exports.stringToSlug = stringToSlug;
package/index-template.js CHANGED
@@ -36,6 +36,13 @@ import whatsappHeader from './template/assets/images/whatsapp-header.png'
36
36
  import appStore from './template/assets/images/app-store.png'
37
37
  import googlePlay from './template/assets/images/google-play.png'
38
38
  import deliverect from './template/assets/images/deliverect.png'
39
+ import ItsaCheckmateLogo from './template/assets/images/ItsaCheckmateLogo.png'
40
+ import doordash from './template/assets/images/door-dash.png'
41
+ /**
42
+ * project statuses
43
+ */
44
+ import projectActive from './template/assets/images/projectStatuses/project-active.png'
45
+ import projectPastDuePayment from './template/assets/images/projectStatuses/project-past-due-payment.png'
39
46
 
40
47
  /**
41
48
  * Theme apps
@@ -148,6 +155,20 @@ import myCustomerApp from './template/assets/images/myProducts/customer-app.png'
148
155
  import myStoreApp from './template/assets/images/myProducts/store-app.png'
149
156
  import myDriverApp from './template/assets/images/myProducts/driver-app.png'
150
157
  import orderingWebsite from './template/assets/images/myProducts/ordering-website.png'
158
+ import myCallcenterAppBrand from './template/assets/images/myProducts/my-callcenter-app-brand.png'
159
+ import myCallcenterAppLive from './template/assets/images/myProducts/my-callcenter-app-live.png'
160
+ import myKioskAppBrand from './template/assets/images/myProducts/my-kiosk-app-brand.png'
161
+ import myKioskAppLive from './template/assets/images/myProducts/my-kiosk-app-live.png'
162
+ import myPosAppBrand from './template/assets/images/myProducts/my-pos-app-brand.png'
163
+ import myPosAppLive from './template/assets/images/myProducts/my-pos-app-live.png'
164
+ import storeAppFree from './template/assets/images/myProducts/store-app-free.png'
165
+ import storeAppBrand from './template/assets/images/myProducts/store-app-brand.png'
166
+ import driverAppFree from './template/assets/images/myProducts/driver-app-free.png'
167
+ import driverAppBrand from './template/assets/images/myProducts/driver-app-brand.png'
168
+ import multiStoreCustomerApp from './template/assets/images/myProducts/multi-store-customer-app.png'
169
+ import singleStoreCustomerApp from './template/assets/images/myProducts/single-store-customer-app.png'
170
+
171
+ import { AutologinParams } from './template/components/AutologinParams'
151
172
 
152
173
  if (!(window?.location?.hostname === 'localhost')) {
153
174
  Sentry.init({
@@ -197,7 +218,13 @@ theme.images = {
197
218
  whatsappHeader,
198
219
  appStore,
199
220
  googlePlay,
200
- deliverect
221
+ deliverect,
222
+ ItsaCheckmateLogo,
223
+ doordash
224
+ },
225
+ project: {
226
+ active: projectActive,
227
+ pastDuePayment: projectPastDuePayment
201
228
  },
202
229
  apps: {
203
230
  storeApp,
@@ -243,7 +270,19 @@ theme.images = {
243
270
  customerApp: myCustomerApp,
244
271
  storeApp: myStoreApp,
245
272
  driverApp: myDriverApp,
246
- orderingWebsite: orderingWebsite
273
+ orderingWebsite: orderingWebsite,
274
+ myCallcenterAppBrand,
275
+ myCallcenterAppLive,
276
+ myKioskAppBrand,
277
+ myKioskAppLive,
278
+ myPosAppBrand,
279
+ myPosAppLive,
280
+ storeAppFree,
281
+ storeAppBrand,
282
+ driverAppFree,
283
+ driverAppBrand,
284
+ multiStoreCustomerApp,
285
+ singleStoreCustomerApp
247
286
  },
248
287
  icons: {
249
288
  ordersList: ordersList,
@@ -324,12 +363,14 @@ const RouteApp = () => {
324
363
  return (
325
364
  <ConfigFileContext.Provider value={[configFile, setConfigFile]}>
326
365
  <ThemeProvider theme={theme}>
327
- <OrderingProvider Alert={Alert} settings={configFile}>
328
- <InfoShareProvider>
329
- <Router />
330
- <Toast />
331
- </InfoShareProvider>
332
- </OrderingProvider>
366
+ <AutologinParams configFile={configFile}>
367
+ <OrderingProvider Alert={Alert}>
368
+ <InfoShareProvider>
369
+ <Router />
370
+ <Toast />
371
+ </InfoShareProvider>
372
+ </OrderingProvider>
373
+ </AutologinParams>
333
374
  </ThemeProvider>
334
375
  </ConfigFileContext.Provider>
335
376
  )
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "ordering-ui-admin-external",
3
- "version": "1.6.1",
3
+ "version": "1.6.3",
4
4
  "description": "Ordering UI Admin Components",
5
5
  "main": "./_modules/index.js",
6
6
  "exports": {
@@ -83,7 +83,7 @@
83
83
  "lodash": "^4.17.20",
84
84
  "moment": "^2.29.1",
85
85
  "moment-range": "^4.0.2",
86
- "ordering-components-admin-external": "1.6.0",
86
+ "ordering-components-admin-external": "1.6.2",
87
87
  "polished": "^3.6.7",
88
88
  "prop-types": "^15.7.2",
89
89
  "react-big-calendar": "^1.4.2",
@@ -97,6 +97,7 @@
97
97
  "react-hook-form": "^6.11.3",
98
98
  "react-loading-skeleton": "^2.1.1",
99
99
  "react-numeric-input": "^2.2.3",
100
+ "react-otp-input": "^2.4.0",
100
101
  "react-phone-number-input": "^3.1.23",
101
102
  "react-popper": "^2.3.0",
102
103
  "react-summernote": "^2.0.2",
@@ -107,7 +107,7 @@ export const Reports = (props) => {
107
107
  <MenuIcon />
108
108
  </IconButton>
109
109
  )}
110
- <h1>{t('ADVANCED_REPORTS', 'Advanced Reports')}</h1>
110
+ <h1>{t('ENTERPRISE_REPORTS', 'Enterprise reports')}</h1>
111
111
  </HeaderTitleContainer>
112
112
  <ReportsList className='row'>
113
113
  {advancedReportsList && advancedReportsList.map((report, i) => (
@@ -46,7 +46,7 @@ const OpenCartsFilterGroupUI = (props) => {
46
46
  const scrollDown = (e) => {
47
47
  if (!e.target.closest('.ordering-calendar-btn')) return
48
48
 
49
- const el = document.querySelector('.popup-dialog')
49
+ const el = document.querySelector('.dialog-inner')
50
50
  if (el?.scrollHeight > el?.clientHeight) {
51
51
  const top = contentEndRef.current.offsetTop
52
52
  el.scrollTo({
@@ -36,7 +36,7 @@ export const RecoveryActionHeader = (props) => {
36
36
  <MenuIcon />
37
37
  </IconButton>
38
38
  )}
39
- <HeaderTitle>{t('RECOVERY_ACTIONS', 'Recovery actions')}</HeaderTitle>
39
+ <HeaderTitle>{t('CART_RECOVERY_AUTOMATION', 'Cart recovery automation')}</HeaderTitle>
40
40
  <InfoWrapper>
41
41
  <IconButton
42
42
  color='primary'
@@ -428,7 +428,7 @@ const AddressFormUI = (props) => {
428
428
  setAddressValue(e.target.value)
429
429
  }}
430
430
  value={addressValue}
431
- autoComplete='new-field'
431
+ autoComplete='new-password'
432
432
  countryCode={configState?.configs?.country_autocomplete?.value || '*'}
433
433
  />
434
434
  </WrapAddressInput>
@@ -75,7 +75,7 @@ const DriversCompaniesListingUI = (props) => {
75
75
  <MenuIcon />
76
76
  </IconButton>
77
77
  )}
78
- <h1>{t('DRIVERS_COMPANIES', 'Drivers companies')}</h1>
78
+ <h1>{t('DELIVERY_COMPANIES', 'Delivery companies')}</h1>
79
79
  </HeaderLeftContainer>
80
80
  <HeaderRightContainer>
81
81
  <Button
@@ -128,7 +128,7 @@ const DriversGroupLogsUI = (props) => {
128
128
  </td>
129
129
  <td>
130
130
  <DataListTable>
131
- {log?.data.map((item, i) => (
131
+ {(typeof log?.data === 'object' ? Object.values(log?.data) : log?.data).map((item, i) => (
132
132
  <tbody key={i}>
133
133
  <tr>
134
134
  <td>{getAttributeName(item?.attribute)}</td>
@@ -128,7 +128,7 @@ const DriversGroupsListingUI = (props) => {
128
128
  <MenuIcon />
129
129
  </IconButton>
130
130
  )}
131
- <h1>{t('DRIVERS_GROUPS', 'Drivers groups')}</h1>
131
+ <h1>{t('DELIVERY_AUTOMATION', 'Delivery automation')}</h1>
132
132
  <OverlayTrigger
133
133
  placement='bottom'
134
134
  overlay={
@@ -6,6 +6,8 @@ import { IconButton, Button } from '../../../styles/Buttons'
6
6
  import { useInfoShare } from '../../../contexts/InfoShareContext'
7
7
  import Skeleton from 'react-loading-skeleton'
8
8
  import { useWindowSize } from '../../../hooks/useWindowSize'
9
+ import { useTheme } from 'styled-components'
10
+ import { getCurrentDiffDays } from '../../../utils'
9
11
  import {
10
12
  List as MenuIcon,
11
13
  Basket as OrdersIcon,
@@ -31,16 +33,24 @@ import {
31
33
  WidgeBlock,
32
34
  FeedbackWidgets,
33
35
  FeedbackContainer,
34
- ButtonWrapper
36
+ ButtonWrapper,
37
+ ProjectStatusContainer,
38
+ ProjectInfoWrapper,
39
+ GreetingText,
40
+ ProjectStatusDescription,
41
+ ProjectCurrentStatus
35
42
  } from './styles'
36
43
 
37
44
  const HomeUI = (props) => {
38
45
  const {
46
+ projectStatus,
39
47
  ordersList,
40
48
  todaySalelsList,
41
49
  monthSalesList,
42
50
  getCurrentDateRange
43
51
  } = props
52
+
53
+ const theme = useTheme()
44
54
  const [, t] = useLanguage()
45
55
  const [{ isCollapse }, { handleMenuCollapse }] = useInfoShare()
46
56
  const [timeAxes, setTimeAxes] = useState([])
@@ -49,12 +59,25 @@ const HomeUI = (props) => {
49
59
  const [{ parsePrice }] = useUtils()
50
60
  const [sessionState] = useSession()
51
61
 
62
+ const project = {
63
+ active: {
64
+ description: t('ORDERING_GUIDE_MSG', 'Our guide helps you to configure your Ordering products.'),
65
+ status: t('PROJECT_ACTIVE', 'Project Active'),
66
+ image: theme.images.project.active
67
+ },
68
+ past_due: {
69
+ description: t('PROJECT_PAST_DUE_PAYMENT', 'Your account will be suspended in the next _days_ days due to your billing status, please check it to avoid any issues.'),
70
+ status: t('PROJECT_PAST_DUE_PAYMENT', 'Project Past Due Payment'),
71
+ image: theme.images.project.pastDuePayment
72
+ }
73
+ }
74
+
52
75
  const goToLink = (location) => {
53
76
  if (location === 'sales') {
54
77
  window.open('https://www.ordering.co/ordering-sales', '_blank')
55
78
  }
56
79
  if (location === 'tech') {
57
- window.open('https://www.ordering.co/ordering-support', '_blank')
80
+ window.open('https://support.ordering.co', '_blank')
58
81
  }
59
82
  if (location === 'canny') {
60
83
  window.open('https://feedback.ordering.co', '_blank')
@@ -193,10 +216,43 @@ const HomeUI = (props) => {
193
216
  )}
194
217
  <h1>{t('HOME', 'Home')}</h1>
195
218
  </Breadcrumb>
196
- <HeaderContainer>
197
- <WelcomeMsg>{t('WELCOME_TO_ORDERING', 'Welcome to Ordering')}!</WelcomeMsg>
198
- <GuideMsg>{t('ORDERING_GUIDE_MSG', 'Our guide helps you to configure your Ordering products.')}</GuideMsg>
199
- </HeaderContainer>
219
+
220
+ {projectStatus.loading && (
221
+ <HeaderContainer>
222
+ <Skeleton height={150} />
223
+ </HeaderContainer>
224
+ )}
225
+
226
+ {!projectStatus.loading && (
227
+ <>
228
+ {!projectStatus.project?.current_status ? (
229
+ <HeaderContainer>
230
+ <WelcomeMsg>{t('WELCOME_TO_ORDERING', 'Welcome to Ordering')}!</WelcomeMsg>
231
+ <GuideMsg>{t('ORDERING_GUIDE_MSG', 'Our guide helps you to configure your Ordering products.')}</GuideMsg>
232
+ </HeaderContainer>
233
+ ) : (
234
+ <ProjectStatusContainer>
235
+ <ProjectInfoWrapper>
236
+ <GreetingText>{t('WELCOME', 'Welcome')} {sessionState?.user?.name}!</GreetingText>
237
+ <ProjectStatusDescription>
238
+ {
239
+ (projectStatus.project?.current_status_until && projectStatus.project?.current_status === 'past_due')
240
+ ? project[projectStatus.project?.current_status]?.description.replace('_days_', getCurrentDiffDays(projectStatus.project?.current_status_until))
241
+ : project[projectStatus.project?.current_status]?.description
242
+ }
243
+ </ProjectStatusDescription>
244
+ <ProjectCurrentStatus
245
+ isActive={projectStatus.project?.current_status === 'active'}
246
+ >
247
+ {project[projectStatus.project?.current_status]?.status}
248
+ </ProjectCurrentStatus>
249
+ </ProjectInfoWrapper>
250
+ <img src={project[projectStatus.project?.current_status]?.image} alt='' />
251
+ </ProjectStatusContainer>
252
+ )}
253
+ </>
254
+ )}
255
+
200
256
  <ParagraphHeaders>
201
257
  <p>{t('REPORTS', 'Reports')}</p>
202
258
  <Button
@@ -1,4 +1,6 @@
1
1
  import styled, { css } from 'styled-components'
2
+ import { lighten } from 'polished'
3
+
2
4
  export const HomeContainer = styled.div`
3
5
  flex: 1;
4
6
  padding: 20px;
@@ -52,6 +54,7 @@ export const Breadcrumb = styled.div`
52
54
  }
53
55
  `
54
56
  export const HeaderContainer = styled.div`
57
+ margin-bottom: 25px;
55
58
  `
56
59
  export const WelcomeMsg = styled.h1`
57
60
  font-weight: bold;
@@ -64,7 +67,6 @@ export const WelcomeMsg = styled.h1`
64
67
  export const GuideMsg = styled.p`
65
68
  font-size: 16px;
66
69
  color: ${props => props.theme.colors.headingColor};
67
- margin-bottom: 25px;
68
70
  `
69
71
  export const Reports = styled.div`
70
72
  display: flex;
@@ -422,3 +424,48 @@ export const ButtonWrapper = styled.div`
422
424
  justify-content: center;
423
425
  margin-top: 20px;
424
426
  `
427
+
428
+ export const ProjectStatusContainer = styled.div`
429
+ box-shadow: 0px 1px 4px rgba(0, 0, 0, 0.1);
430
+ border-radius: 8px;
431
+ display: flex;
432
+ flex-direction: column;
433
+ align-items: center;
434
+ margin-bottom: 60px;
435
+
436
+ > img {
437
+ max-height: 250px;
438
+ }
439
+
440
+ @media (min-width: 768px) {
441
+ flex-direction: row;
442
+ justify-content: space-between;
443
+ }
444
+ `
445
+ export const ProjectInfoWrapper = styled.div`
446
+ padding: 20px 30px;
447
+ `
448
+ export const GreetingText = styled.h1`
449
+ font-size: 32px;
450
+ font-weight: 700;
451
+ line-height: 48px;
452
+ margin: 0;
453
+ `
454
+ export const ProjectStatusDescription = styled.p`
455
+ font-size: 16px;
456
+ line-height: 24px;
457
+ `
458
+ export const ProjectCurrentStatus = styled.div`
459
+ width: fit-content;
460
+ margin-top: 15px;
461
+ padding: 10px 16px;
462
+ border-radius: 8px;
463
+ font-size: 14px;
464
+ line-height: 24px;
465
+ color: ${props => props.theme.colors.warning};
466
+ background-color: ${(props) => lighten(0.4, props.theme.colors.warning)};
467
+ ${({ isActive }) => isActive && css`
468
+ color: ${props => props.theme.colors.success};
469
+ background-color: ${(props) => lighten(0.5, props.theme.colors.success)};
470
+ `}
471
+ `
@@ -30,7 +30,7 @@ const LanguageSelectorUI = (props) => {
30
30
  <SelectWrapper>
31
31
  <Globe2 />
32
32
  <Select
33
- optionInnerMaxHeight='60vh'
33
+ optionInnerMaxHeight='300px'
34
34
  options={languagesState?.loading ? defaultLanguages : _languages}
35
35
  defaultValue={languagesState?.loading ? defaultCurrentLanguage : currentLanguage}
36
36
  onChange={(languageId) => handleChangeLanguage(languageId, true)}