ordering-ui-admin-external 1.17.0 → 1.19.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/_bundles/{ordering-ui-admin.6c1919d6b0356a2f522f.js → ordering-ui-admin.661a37246ac77dcc4edf.js} +2 -2
- package/_modules/components/Delivery/DeliveryUsersListing/index.js +4 -2
- package/_modules/components/Delivery/DriversGroupLogistics/index.js +1 -1
- package/_modules/components/Delivery/DriversGroupLogs/index.js +1 -0
- package/_modules/components/Delivery/UsersList/index.js +47 -51
- package/_modules/components/Delivery/UsersList/styles.js +6 -4
- package/_modules/components/Home/HomePage/index.js +7 -1
- package/_modules/components/Login/LoginForm/index.js +7 -1
- package/_modules/components/Marketing/EnterprisePromotionListing/index.js +1 -1
- package/_modules/components/Messages/MessagesListing/index.js +1 -1
- package/_modules/components/MyProducts/AdvancedSettings/ButtonShadow.js +98 -0
- package/_modules/components/MyProducts/AdvancedSettings/FontStyleGroup.js +28 -7
- package/_modules/components/MyProducts/AdvancedSettings/HideCheckBox.js +47 -0
- package/_modules/components/MyProducts/AdvancedSettings/ImageBox.js +12 -3
- package/_modules/components/MyProducts/AdvancedSettings/SettingComponent.js +15 -15
- package/_modules/components/MyProducts/AdvancedSettings/index.js +102 -117
- package/_modules/components/MyProducts/AppResources/index.js +132 -0
- package/_modules/components/MyProducts/OrderingWebsite/index.js +47 -2
- package/_modules/components/MyProducts/OrderingWebsite/styles.js +13 -3
- package/_modules/components/OrderingProducts/SiteTheme/index.js +13 -9
- package/_modules/components/Orders/DeliveriesManager/index.js +1 -1
- package/_modules/components/Orders/Messages/index.js +25 -94
- package/_modules/components/Orders/OrderBill/index.js +3 -3
- package/_modules/components/Orders/OrderNotification/index.js +4 -2
- package/_modules/components/Orders/OrdersManager/index.js +3 -1
- package/_modules/components/SidebarMenu/index.js +34 -33
- package/_modules/components/Stores/BusinessAdd/DeliveryZone/index.js +1 -1
- package/_modules/components/Stores/BusinessDeliveryZoneInformation/index.js +1 -1
- package/_modules/components/Stores/BusinessDetails/index.js +27 -8
- package/_modules/components/Stores/BusinessLocation/index.js +8 -7
- package/_modules/components/Stores/BusinessPlace/index.js +127 -0
- package/_modules/components/Stores/BusinessPlace/styles.js +55 -0
- package/_modules/components/Stores/BusinessPlaceGroup/index.js +258 -0
- package/_modules/components/Stores/BusinessPlaceGroup/styles.js +102 -0
- package/_modules/components/Stores/BusinessProductList/index.js +3 -3
- package/_modules/components/Stores/BusinessProductsListing/index.js +2 -1
- package/_modules/components/Stores/BusinessSummary/index.js +12 -3
- package/_modules/components/Stores/ProductStep/index.js +15 -3
- package/_modules/components/Stores/SpoonityApiKey/index.js +97 -0
- package/_modules/components/Stores/SpoonityApiKey/styles.js +47 -0
- package/_modules/components/Stores/UploadMenuGuide/index.js +8 -0
- package/_modules/components/Users/CustomerPointsWallet/index.js +126 -9
- package/_modules/components/Users/CustomerPointsWallet/styles.js +8 -4
- package/package.json +2 -2
- package/src/components/Delivery/DeliveryUsersListing/index.js +3 -1
- package/src/components/Delivery/DriversGroupLogistics/index.js +1 -1
- package/src/components/Delivery/DriversGroupLogs/index.js +2 -0
- package/src/components/Delivery/UsersList/index.js +79 -61
- package/src/components/Delivery/UsersList/styles.js +4 -12
- package/src/components/Home/HomePage/index.js +2 -2
- package/src/components/Login/LoginForm/index.js +4 -1
- package/src/components/Marketing/EnterprisePromotionListing/index.js +1 -1
- package/src/components/Messages/MessagesListing/index.js +1 -1
- package/src/components/MyProducts/AdvancedSettings/ButtonShadow.js +102 -0
- package/src/components/MyProducts/AdvancedSettings/FontStyleGroup.js +23 -5
- package/src/components/MyProducts/AdvancedSettings/HideCheckBox.js +33 -0
- package/src/components/MyProducts/AdvancedSettings/ImageBox.js +10 -3
- package/src/components/MyProducts/AdvancedSettings/SettingComponent.js +10 -15
- package/src/components/MyProducts/AdvancedSettings/index.js +119 -149
- package/src/components/MyProducts/AppResources/index.js +167 -0
- package/src/components/MyProducts/OrderingWebsite/index.js +66 -2
- package/src/components/MyProducts/OrderingWebsite/styles.js +37 -0
- package/src/components/OrderingProducts/SiteTheme/index.js +7 -3
- package/src/components/Orders/DeliveriesManager/index.js +1 -1
- package/src/components/Orders/Messages/index.js +56 -216
- package/src/components/Orders/OrderBill/index.js +6 -2
- package/src/components/Orders/OrderNotification/index.js +6 -2
- package/src/components/Orders/OrdersManager/index.js +1 -1
- package/src/components/SidebarMenu/index.js +8 -8
- package/src/components/Stores/BusinessAdd/DeliveryZone/index.js +1 -1
- package/src/components/Stores/BusinessDeliveryZoneInformation/index.js +1 -1
- package/src/components/Stores/BusinessDetails/index.js +24 -1
- package/src/components/Stores/BusinessLocation/index.js +2 -1
- package/src/components/Stores/BusinessPlace/index.js +137 -0
- package/src/components/Stores/BusinessPlace/styles.js +132 -0
- package/src/components/Stores/BusinessPlaceGroup/index.js +272 -0
- package/src/components/Stores/BusinessPlaceGroup/styles.js +248 -0
- package/src/components/Stores/BusinessProductList/index.js +9 -1
- package/src/components/Stores/BusinessProductsListing/index.js +1 -0
- package/src/components/Stores/BusinessSummary/index.js +16 -5
- package/src/components/Stores/ProductStep/index.js +19 -2
- package/src/components/Stores/SpoonityApiKey/index.js +87 -0
- package/src/components/Stores/SpoonityApiKey/styles.js +68 -0
- package/src/components/Stores/UploadMenuGuide/index.js +10 -1
- package/src/components/Users/CustomerPointsWallet/index.js +130 -2
- package/src/components/Users/CustomerPointsWallet/styles.js +40 -1
- /package/_bundles/{ordering-ui-admin.6c1919d6b0356a2f522f.js.LICENSE.txt → ordering-ui-admin.661a37246ac77dcc4edf.js.LICENSE.txt} +0 -0
|
@@ -34,7 +34,7 @@ function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len
|
|
|
34
34
|
function _iterableToArrayLimit(arr, i) { var _i = null == arr ? null : "undefined" != typeof Symbol && arr[Symbol.iterator] || arr["@@iterator"]; if (null != _i) { var _s, _e, _x, _r, _arr = [], _n = !0, _d = !1; try { if (_x = (_i = _i.call(arr)).next, 0 === i) { if (Object(_i) !== _i) return; _n = !1; } else for (; !(_n = (_s = _x.call(_i)).done) && (_arr.push(_s.value), _arr.length !== i); _n = !0); } catch (err) { _d = !0, _e = err; } finally { try { if (!_n && null != _i.return && (_r = _i.return(), Object(_r) !== _r)) return; } finally { if (_d) throw _e; } } return _arr; } }
|
|
35
35
|
function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
|
|
36
36
|
var SidebarMenuUI = function SidebarMenuUI(props) {
|
|
37
|
-
var _configs$powered_by_o, _configs$appointments, _sessionState$user, _sessionState$user2, _sessionState$user3, _sessionState$user4, _sessionState$user5, _sessionState$user6, _sessionState$user7, _configs$dashboard_lo, _theme$images, _theme$images$logos, _sessionState$user8, _sessionState$user9, _sessionState$user10, _sessionState$
|
|
37
|
+
var _configs$powered_by_o, _configs$appointments, _sessionState$user, _sessionState$user2, _sessionState$user3, _sessionState$user4, _sessionState$user5, _sessionState$user6, _sessionState$user7, _configs$dashboard_lo, _theme$images, _theme$images$logos, _sessionState$user8, _sessionState$user9, _sessionState$user10, _sessionState$user11, _sessionState$user14, _sessionState$user15, _sessionState$user16, _sessionState$user17, _sessionState$user19, _sessionState$user20, _sessionState$user21, _sessionState$user22, _sessionState$user23, _sessionState$user24, _sessionState$user25, _sessionState$user26, _sessionState$user27, _sessionState$user28, _sessionState$user29, _sessionState$user30, _sessionState$user31, _sessionState$user32, _sessionState$user33, _sessionState$user34, _sessionState$user35, _sessionState$user36, _sessionState$user37;
|
|
38
38
|
var getBillingToken = props.getBillingToken,
|
|
39
39
|
billingUrl = props.billingUrl;
|
|
40
40
|
var location = (0, _reactRouterDom.useLocation)();
|
|
@@ -316,15 +316,12 @@ var SidebarMenuUI = function SidebarMenuUI(props) {
|
|
|
316
316
|
}
|
|
317
317
|
events.emit('go_to_page', data);
|
|
318
318
|
};
|
|
319
|
-
|
|
320
|
-
|
|
321
|
-
|
|
322
|
-
|
|
323
|
-
|
|
324
|
-
|
|
325
|
-
// handleGoToLink(`https://${ordering.project}.tryordering.com`)
|
|
326
|
-
// }
|
|
327
|
-
|
|
319
|
+
var handleGoToLink = function handleGoToLink(link) {
|
|
320
|
+
window.open(link, '_blank');
|
|
321
|
+
};
|
|
322
|
+
var handleOpenSite = function handleOpenSite() {
|
|
323
|
+
handleGoToLink("https://".concat(ordering.project, ".tryordering.com"));
|
|
324
|
+
};
|
|
328
325
|
(0, _react.useEffect)(function () {
|
|
329
326
|
if (windowSize.width < 1024) {
|
|
330
327
|
handleMenuCollapse(true);
|
|
@@ -393,19 +390,23 @@ var SidebarMenuUI = function SidebarMenuUI(props) {
|
|
|
393
390
|
className: "d-flex flex-column justify-content-between p-1 pt-0"
|
|
394
391
|
}, /*#__PURE__*/_react.default.createElement("div", {
|
|
395
392
|
className: "d-flex flex-column"
|
|
396
|
-
},
|
|
393
|
+
}, (sessionState === null || sessionState === void 0 ? void 0 : (_sessionState$user8 = sessionState.user) === null || _sessionState$user8 === void 0 ? void 0 : _sessionState$user8.level) === 0 && /*#__PURE__*/_react.default.createElement(_reactBootstrap.Button, {
|
|
394
|
+
className: "d-flex align-items-center",
|
|
395
|
+
variant: false,
|
|
396
|
+
onClick: handleOpenSite
|
|
397
|
+
}, /*#__PURE__*/_react.default.createElement(_reactBootstrapIcons.BoxArrowUpRight, null), /*#__PURE__*/_react.default.createElement("span", null, t('MY_WEBSITE', 'My Website'))), /*#__PURE__*/_react.default.createElement(_reactBootstrap.Accordion, null, (sessionState === null || sessionState === void 0 ? void 0 : (_sessionState$user9 = sessionState.user) === null || _sessionState$user9 === void 0 ? void 0 : _sessionState$user9.level) !== 5 && (sessionState === null || sessionState === void 0 ? void 0 : (_sessionState$user10 = sessionState.user) === null || _sessionState$user10 === void 0 ? void 0 : _sessionState$user10.level) !== 8 && /*#__PURE__*/_react.default.createElement(_styles.MenuContainer, null, /*#__PURE__*/_react.default.createElement(ContextAwareToggle, {
|
|
397
398
|
eventKey: "0",
|
|
398
399
|
active: location.pathname === '/home',
|
|
399
400
|
page: "home",
|
|
400
401
|
handleGoToPage: handleGoToPage
|
|
401
|
-
}, /*#__PURE__*/_react.default.createElement(_reactBootstrapIcons.HouseDoor, null), /*#__PURE__*/_react.default.createElement("span", null, t('HOME', 'Home')))), (sessionState === null || sessionState === void 0 ? void 0 : (_sessionState$
|
|
402
|
+
}, /*#__PURE__*/_react.default.createElement(_reactBootstrapIcons.HouseDoor, null), /*#__PURE__*/_react.default.createElement("span", null, t('HOME', 'Home')))), (sessionState === null || sessionState === void 0 ? void 0 : (_sessionState$user11 = sessionState.user) === null || _sessionState$user11 === void 0 ? void 0 : _sessionState$user11.level) !== 8 && /*#__PURE__*/_react.default.createElement(_styles.MenuContainer, null, /*#__PURE__*/_react.default.createElement(ContextAwareToggle, {
|
|
402
403
|
eventKey: "1",
|
|
403
404
|
active: location.pathname === '/orders' || location.pathname === '/deliveries' || location.pathname === '/drivers' || location.pathname === '/appointments' || location.pathname === '/gift-cards'
|
|
404
405
|
}, /*#__PURE__*/_react.default.createElement(_reactBootstrapIcons.ListCheck, null), /*#__PURE__*/_react.default.createElement("span", null, t('ORDERS', 'Orders'))), /*#__PURE__*/_react.default.createElement(_reactBootstrap.Accordion.Collapse, {
|
|
405
406
|
eventKey: "1"
|
|
406
407
|
}, /*#__PURE__*/_react.default.createElement(_styles.MenuContent, null, ordersSubMenus.map(function (item) {
|
|
407
|
-
var _sessionState$
|
|
408
|
-
return !((sessionState === null || sessionState === void 0 ? void 0 : (_sessionState$
|
|
408
|
+
var _sessionState$user12, _sessionState$user13;
|
|
409
|
+
return !((sessionState === null || sessionState === void 0 ? void 0 : (_sessionState$user12 = sessionState.user) === null || _sessionState$user12 === void 0 ? void 0 : _sessionState$user12.level) === 2 && item.pageName === 'drivers') && !((sessionState === null || sessionState === void 0 ? void 0 : (_sessionState$user13 = sessionState.user) === null || _sessionState$user13 === void 0 ? void 0 : _sessionState$user13.level) === 5 && item.pageName === 'appointments') && (item.pageName === 'appointments' ? isEnabledAppointmentsFeature && /*#__PURE__*/_react.default.createElement(_styles.SubMenu, {
|
|
409
410
|
key: item.id,
|
|
410
411
|
active: location.pathname.includes(item.url),
|
|
411
412
|
onClick: function onClick() {
|
|
@@ -422,19 +423,19 @@ var SidebarMenuUI = function SidebarMenuUI(props) {
|
|
|
422
423
|
});
|
|
423
424
|
}
|
|
424
425
|
}, (0, _utils.firstLetterCapital)(item.title)));
|
|
425
|
-
})))), (sessionState === null || sessionState === void 0 ? void 0 : (_sessionState$
|
|
426
|
+
})))), (sessionState === null || sessionState === void 0 ? void 0 : (_sessionState$user14 = sessionState.user) === null || _sessionState$user14 === void 0 ? void 0 : _sessionState$user14.level) !== 5 && (sessionState === null || sessionState === void 0 ? void 0 : (_sessionState$user15 = sessionState.user) === null || _sessionState$user15 === void 0 ? void 0 : _sessionState$user15.level) !== 8 && /*#__PURE__*/_react.default.createElement(_styles.MenuContainer, null, /*#__PURE__*/_react.default.createElement(ContextAwareToggle, {
|
|
426
427
|
eventKey: "2",
|
|
427
428
|
page: "messages",
|
|
428
429
|
handleGoToPage: handleGoToPage,
|
|
429
430
|
active: location.pathname === '/messages'
|
|
430
|
-
}, /*#__PURE__*/_react.default.createElement(_reactBootstrapIcons.Chat, null), /*#__PURE__*/_react.default.createElement("span", null, t('MESSAGES', 'Messages')))), (sessionState === null || sessionState === void 0 ? void 0 : (_sessionState$
|
|
431
|
+
}, /*#__PURE__*/_react.default.createElement(_reactBootstrapIcons.Chat, null), /*#__PURE__*/_react.default.createElement("span", null, t('MESSAGES', 'Messages')))), (sessionState === null || sessionState === void 0 ? void 0 : (_sessionState$user16 = sessionState.user) === null || _sessionState$user16 === void 0 ? void 0 : _sessionState$user16.level) !== 5 && (sessionState === null || sessionState === void 0 ? void 0 : (_sessionState$user17 = sessionState.user) === null || _sessionState$user17 === void 0 ? void 0 : _sessionState$user17.level) !== 8 && /*#__PURE__*/_react.default.createElement(_styles.MenuContainer, null, /*#__PURE__*/_react.default.createElement(ContextAwareToggle, {
|
|
431
432
|
eventKey: "3",
|
|
432
433
|
active: location.pathname.includes('stores')
|
|
433
434
|
}, /*#__PURE__*/_react.default.createElement(_reactBootstrapIcons.Shop, null), /*#__PURE__*/_react.default.createElement("span", null, t('STORES', 'Stores'))), /*#__PURE__*/_react.default.createElement(_reactBootstrap.Accordion.Collapse, {
|
|
434
435
|
eventKey: "3"
|
|
435
436
|
}, /*#__PURE__*/_react.default.createElement(_styles.MenuContent, null, storesSubMenus.map(function (item) {
|
|
436
|
-
var _sessionState$
|
|
437
|
-
return !((sessionState === null || sessionState === void 0 ? void 0 : (_sessionState$
|
|
437
|
+
var _sessionState$user18;
|
|
438
|
+
return !((sessionState === null || sessionState === void 0 ? void 0 : (_sessionState$user18 = sessionState.user) === null || _sessionState$user18 === void 0 ? void 0 : _sessionState$user18.level) === 2 && item.pageName === 'brand') && /*#__PURE__*/_react.default.createElement(_styles.SubMenu, {
|
|
438
439
|
key: item.id,
|
|
439
440
|
active: location.pathname.includes(item === null || item === void 0 ? void 0 : item.url),
|
|
440
441
|
onClick: function onClick() {
|
|
@@ -443,12 +444,12 @@ var SidebarMenuUI = function SidebarMenuUI(props) {
|
|
|
443
444
|
});
|
|
444
445
|
}
|
|
445
446
|
}, item.title);
|
|
446
|
-
})))), ((sessionState === null || sessionState === void 0 ? void 0 : (_sessionState$
|
|
447
|
+
})))), ((sessionState === null || sessionState === void 0 ? void 0 : (_sessionState$user19 = sessionState.user) === null || _sessionState$user19 === void 0 ? void 0 : _sessionState$user19.level) === 0 || (sessionState === null || sessionState === void 0 ? void 0 : (_sessionState$user20 = sessionState.user) === null || _sessionState$user20 === void 0 ? void 0 : _sessionState$user20.level) === 2) && /*#__PURE__*/_react.default.createElement(_styles.MenuContainer, null, /*#__PURE__*/_react.default.createElement(ContextAwareToggle, {
|
|
447
448
|
eventKey: "4",
|
|
448
449
|
active: location.pathname === '/users/customers' || location.pathname === '/users/managers' || location.pathname === '/users/operation' || location.pathname === '/users/professionals'
|
|
449
450
|
}, /*#__PURE__*/_react.default.createElement(_reactBootstrapIcons.People, null), /*#__PURE__*/_react.default.createElement("span", null, t('USERS', 'Users'))), /*#__PURE__*/_react.default.createElement(_reactBootstrap.Accordion.Collapse, {
|
|
450
451
|
eventKey: "4"
|
|
451
|
-
}, /*#__PURE__*/_react.default.createElement(_styles.MenuContent, null, ((sessionState === null || sessionState === void 0 ? void 0 : (_sessionState$
|
|
452
|
+
}, /*#__PURE__*/_react.default.createElement(_styles.MenuContent, null, ((sessionState === null || sessionState === void 0 ? void 0 : (_sessionState$user21 = sessionState.user) === null || _sessionState$user21 === void 0 ? void 0 : _sessionState$user21.level) === 2 ? usersSubMenus.filter(function (menu) {
|
|
452
453
|
return buisnessOwnerUsersMenuIncluded.includes(menu.id);
|
|
453
454
|
}) : usersSubMenus).map(function (item) {
|
|
454
455
|
return item.pageName === 'professionals' ? isEnabledAppointmentsFeature && /*#__PURE__*/_react.default.createElement(_styles.SubMenu, {
|
|
@@ -468,12 +469,12 @@ var SidebarMenuUI = function SidebarMenuUI(props) {
|
|
|
468
469
|
});
|
|
469
470
|
}
|
|
470
471
|
}, item.title);
|
|
471
|
-
})))), (sessionState === null || sessionState === void 0 ? void 0 : (_sessionState$
|
|
472
|
+
})))), (sessionState === null || sessionState === void 0 ? void 0 : (_sessionState$user22 = sessionState.user) === null || _sessionState$user22 === void 0 ? void 0 : _sessionState$user22.level) !== 5 && (sessionState === null || sessionState === void 0 ? void 0 : (_sessionState$user23 = sessionState.user) === null || _sessionState$user23 === void 0 ? void 0 : _sessionState$user23.level) !== 8 && /*#__PURE__*/_react.default.createElement(_styles.MenuContainer, null, /*#__PURE__*/_react.default.createElement(ContextAwareToggle, {
|
|
472
473
|
eventKey: "5",
|
|
473
474
|
active: location.pathname === '/intelligence/business' || location.pathname === '/intelligence/drivers' || location.pathname.includes('/intelligence/reviews') || location.pathname === '/intelligence/invoice' || location.pathname === '/intelligence/reports'
|
|
474
475
|
}, /*#__PURE__*/_react.default.createElement(_reactBootstrapIcons.BarChartLine, null), /*#__PURE__*/_react.default.createElement("span", null, (0, _utils.firstLetterCapital)(t('BUSINESS_INTELLIGENCE', 'Business Intelligence')))), /*#__PURE__*/_react.default.createElement(_reactBootstrap.Accordion.Collapse, {
|
|
475
476
|
eventKey: "5"
|
|
476
|
-
}, /*#__PURE__*/_react.default.createElement(_styles.MenuContent, null, ((sessionState === null || sessionState === void 0 ? void 0 : (_sessionState$
|
|
477
|
+
}, /*#__PURE__*/_react.default.createElement(_styles.MenuContent, null, ((sessionState === null || sessionState === void 0 ? void 0 : (_sessionState$user24 = sessionState.user) === null || _sessionState$user24 === void 0 ? void 0 : _sessionState$user24.level) === 2 ? businessIntelligenceSubMenus.filter(function (menu) {
|
|
477
478
|
return businessOwnerIntelligencesIncluded.includes(menu.id);
|
|
478
479
|
}) : businessIntelligenceSubMenus).map(function (item) {
|
|
479
480
|
return /*#__PURE__*/_react.default.createElement(_styles.SubMenu, {
|
|
@@ -485,7 +486,7 @@ var SidebarMenuUI = function SidebarMenuUI(props) {
|
|
|
485
486
|
});
|
|
486
487
|
}
|
|
487
488
|
}, (0, _utils.firstLetterCapital)(item.title));
|
|
488
|
-
})))), ((sessionState === null || sessionState === void 0 ? void 0 : (_sessionState$
|
|
489
|
+
})))), ((sessionState === null || sessionState === void 0 ? void 0 : (_sessionState$user25 = sessionState.user) === null || _sessionState$user25 === void 0 ? void 0 : _sessionState$user25.level) === 0 || (sessionState === null || sessionState === void 0 ? void 0 : (_sessionState$user26 = sessionState.user) === null || _sessionState$user26 === void 0 ? void 0 : _sessionState$user26.level) === 5) && /*#__PURE__*/_react.default.createElement(_styles.MenuContainer, null, /*#__PURE__*/_react.default.createElement(ContextAwareToggle, {
|
|
489
490
|
eventKey: "7",
|
|
490
491
|
active: location.pathname === '/delivery/drivers-list' || location.pathname === '/delivery/drivers-managers' || location.pathname === '/delivery/drivers-companies' || location.pathname === '/delivery/drivers-groups'
|
|
491
492
|
}, /*#__PURE__*/_react.default.createElement(_reactBootstrapIcons.Truck, null), /*#__PURE__*/_react.default.createElement("span", null, t('DELIVERY', 'Delivery'))), /*#__PURE__*/_react.default.createElement(_reactBootstrap.Accordion.Collapse, {
|
|
@@ -500,7 +501,7 @@ var SidebarMenuUI = function SidebarMenuUI(props) {
|
|
|
500
501
|
});
|
|
501
502
|
}
|
|
502
503
|
}, (0, _utils.firstLetterCapital)(item.title));
|
|
503
|
-
})))), (sessionState === null || sessionState === void 0 ? void 0 : (_sessionState$
|
|
504
|
+
})))), (sessionState === null || sessionState === void 0 ? void 0 : (_sessionState$user27 = sessionState.user) === null || _sessionState$user27 === void 0 ? void 0 : _sessionState$user27.level) === 0 && /*#__PURE__*/_react.default.createElement(_styles.MenuContainer, null, /*#__PURE__*/_react.default.createElement(ContextAwareToggle, {
|
|
504
505
|
eventKey: "8",
|
|
505
506
|
active: location.pathname === '/marketing/promotions-enterprise' || location.pathname === '/marketing/campaign' || location.pathname === '/marketing/ad-banners'
|
|
506
507
|
}, /*#__PURE__*/_react.default.createElement(_reactBootstrapIcons.GraphUp, null), /*#__PURE__*/_react.default.createElement("span", null, t('MARKETING', 'Marketing'))), /*#__PURE__*/_react.default.createElement(_reactBootstrap.Accordion.Collapse, {
|
|
@@ -515,7 +516,7 @@ var SidebarMenuUI = function SidebarMenuUI(props) {
|
|
|
515
516
|
});
|
|
516
517
|
}
|
|
517
518
|
}, (0, _utils.firstLetterCapital)(item.title));
|
|
518
|
-
})))), (sessionState === null || sessionState === void 0 ? void 0 : (_sessionState$
|
|
519
|
+
})))), (sessionState === null || sessionState === void 0 ? void 0 : (_sessionState$user28 = sessionState.user) === null || _sessionState$user28 === void 0 ? void 0 : _sessionState$user28.level) === 0 && /*#__PURE__*/_react.default.createElement(_styles.MenuContainer, null, /*#__PURE__*/_react.default.createElement(ContextAwareToggle, {
|
|
519
520
|
eventKey: "9",
|
|
520
521
|
active: location.pathname === '/loyalty/rewards-programs' || location.pathname === '/loyalty/levels' || location.pathname === '/loyalty/reports'
|
|
521
522
|
}, /*#__PURE__*/_react.default.createElement(_reactBootstrapIcons.Award, null), /*#__PURE__*/_react.default.createElement("span", null, t('LOYALTY', 'Loyalty'))), /*#__PURE__*/_react.default.createElement(_reactBootstrap.Accordion.Collapse, {
|
|
@@ -530,7 +531,7 @@ var SidebarMenuUI = function SidebarMenuUI(props) {
|
|
|
530
531
|
});
|
|
531
532
|
}
|
|
532
533
|
}, (0, _utils.firstLetterCapital)(item.title));
|
|
533
|
-
})))), (sessionState === null || sessionState === void 0 ? void 0 : (_sessionState$
|
|
534
|
+
})))), (sessionState === null || sessionState === void 0 ? void 0 : (_sessionState$user29 = sessionState.user) === null || _sessionState$user29 === void 0 ? void 0 : _sessionState$user29.level) === 0 && /*#__PURE__*/_react.default.createElement(_styles.MenuContainer, null, /*#__PURE__*/_react.default.createElement(ContextAwareToggle, {
|
|
534
535
|
eventKey: "10",
|
|
535
536
|
active: location.pathname === '/cart-recovery/open-carts' || location.pathname === '/cart-recovery/recovery-actions'
|
|
536
537
|
}, /*#__PURE__*/_react.default.createElement(_reactBootstrapIcons.Cart3, null), /*#__PURE__*/_react.default.createElement("span", null, t('CART_RECOVERY', 'Cart recovery'))), /*#__PURE__*/_react.default.createElement(_reactBootstrap.Accordion.Collapse, {
|
|
@@ -545,7 +546,7 @@ var SidebarMenuUI = function SidebarMenuUI(props) {
|
|
|
545
546
|
});
|
|
546
547
|
}
|
|
547
548
|
}, (0, _utils.firstLetterCapital)(item.title));
|
|
548
|
-
})))), (sessionState === null || sessionState === void 0 ? void 0 : (_sessionState$
|
|
549
|
+
})))), (sessionState === null || sessionState === void 0 ? void 0 : (_sessionState$user30 = sessionState.user) === null || _sessionState$user30 === void 0 ? void 0 : _sessionState$user30.level) === 0 && /*#__PURE__*/_react.default.createElement(_styles.MenuContainer, null, /*#__PURE__*/_react.default.createElement("span", null, t('SALES_CHANNELS_AND_PRODUCTS', 'Sales channels and products')), /*#__PURE__*/_react.default.createElement(ContextAwareToggle, {
|
|
549
550
|
eventKey: "12",
|
|
550
551
|
active: location.pathname === '/my-products/ordering-website' || location.pathname === '/my-products/customer-app' || location.pathname === '/my-products/store-app' || location.pathname === '/my-products/driver-app' || location.pathname === '/my-products/pos-app' || location.pathname === '/my-products/call-center-app' || location.pathname === '/my-products/kiosk-app' || location.pathname === '/my-products/custom-project'
|
|
551
552
|
}, /*#__PURE__*/_react.default.createElement(_reactBootstrapIcons.BagCheck, null), /*#__PURE__*/_react.default.createElement("span", null, t('MY_PRODUCTS', 'My products'))), /*#__PURE__*/_react.default.createElement(_reactBootstrap.Accordion.Collapse, {
|
|
@@ -562,7 +563,7 @@ var SidebarMenuUI = function SidebarMenuUI(props) {
|
|
|
562
563
|
}, item.title);
|
|
563
564
|
})))))), /*#__PURE__*/_react.default.createElement("div", {
|
|
564
565
|
className: "d-flex flex-column mt-4"
|
|
565
|
-
}, /*#__PURE__*/_react.default.createElement(_styles.LanguageSelectorContainer, null, /*#__PURE__*/_react.default.createElement(_LanguageSelector.LanguageSelector, null)), (sessionState === null || sessionState === void 0 ? void 0 : (_sessionState$
|
|
566
|
+
}, /*#__PURE__*/_react.default.createElement(_styles.LanguageSelectorContainer, null, /*#__PURE__*/_react.default.createElement(_LanguageSelector.LanguageSelector, null)), (sessionState === null || sessionState === void 0 ? void 0 : (_sessionState$user31 = sessionState.user) === null || _sessionState$user31 === void 0 ? void 0 : _sessionState$user31.level) === 0 && /*#__PURE__*/_react.default.createElement(_reactBootstrap.Accordion, null, /*#__PURE__*/_react.default.createElement(_styles.MenuContainer, null, /*#__PURE__*/_react.default.createElement(ContextAwareToggle, {
|
|
566
567
|
eventKey: "5",
|
|
567
568
|
active: location.pathname === '/settings/basic' || location.pathname === '/settings/operation' || location.pathname === '/settings/plugin' || location.pathname === '/settings/pages' || location.pathname === '/settings/integrations' || location.pathname === '/settings/places' || location.pathname === '/settings/advanced' || location.pathname === '/settings/language'
|
|
568
569
|
}, /*#__PURE__*/_react.default.createElement(_reactBootstrapIcons.Gear, null), /*#__PURE__*/_react.default.createElement("span", null, t('SETTINGS', 'Settings'))), /*#__PURE__*/_react.default.createElement(_reactBootstrap.Accordion.Collapse, {
|
|
@@ -577,7 +578,7 @@ var SidebarMenuUI = function SidebarMenuUI(props) {
|
|
|
577
578
|
});
|
|
578
579
|
}
|
|
579
580
|
}, (0, _utils.firstLetterCapital)(item.title));
|
|
580
|
-
}))))), (sessionState === null || sessionState === void 0 ? void 0 : (_sessionState$
|
|
581
|
+
}))))), (sessionState === null || sessionState === void 0 ? void 0 : (_sessionState$user32 = sessionState.user) === null || _sessionState$user32 === void 0 ? void 0 : _sessionState$user32.level) === 0 && /*#__PURE__*/_react.default.createElement(_reactBootstrap.Button, {
|
|
581
582
|
className: "d-flex align-items-center",
|
|
582
583
|
variant: location.pathname === '/support' && 'primary',
|
|
583
584
|
onClick: function onClick() {
|
|
@@ -585,7 +586,7 @@ var SidebarMenuUI = function SidebarMenuUI(props) {
|
|
|
585
586
|
page: 'support'
|
|
586
587
|
});
|
|
587
588
|
}
|
|
588
|
-
}, /*#__PURE__*/_react.default.createElement(_reactBootstrapIcons.Headset, null), /*#__PURE__*/_react.default.createElement("span", null, t('SUPPORT', 'Support'))), (sessionState === null || sessionState === void 0 ? void 0 : (_sessionState$
|
|
589
|
+
}, /*#__PURE__*/_react.default.createElement(_reactBootstrapIcons.Headset, null), /*#__PURE__*/_react.default.createElement("span", null, t('SUPPORT', 'Support'))), (sessionState === null || sessionState === void 0 ? void 0 : (_sessionState$user33 = sessionState.user) === null || _sessionState$user33 === void 0 ? void 0 : _sessionState$user33.level) === 0 && /*#__PURE__*/_react.default.createElement(_reactBootstrap.Button, {
|
|
589
590
|
className: "d-flex align-items-center",
|
|
590
591
|
variant: false,
|
|
591
592
|
onClick: function onClick() {
|
|
@@ -602,12 +603,12 @@ var SidebarMenuUI = function SidebarMenuUI(props) {
|
|
|
602
603
|
page: 'profile'
|
|
603
604
|
});
|
|
604
605
|
}
|
|
605
|
-
}, sessionState !== null && sessionState !== void 0 && (_sessionState$
|
|
606
|
-
src: sessionState === null || sessionState === void 0 ? void 0 : (_sessionState$
|
|
606
|
+
}, sessionState !== null && sessionState !== void 0 && (_sessionState$user34 = sessionState.user) !== null && _sessionState$user34 !== void 0 && _sessionState$user34.photo ? /*#__PURE__*/_react.default.createElement(_reactBootstrap.Image, {
|
|
607
|
+
src: sessionState === null || sessionState === void 0 ? void 0 : (_sessionState$user35 = sessionState.user) === null || _sessionState$user35 === void 0 ? void 0 : _sessionState$user35.photo,
|
|
607
608
|
width: "30px",
|
|
608
609
|
height: "30px",
|
|
609
610
|
roundedCircle: true
|
|
610
|
-
}) : /*#__PURE__*/_react.default.createElement(_reactBootstrapIcons.PersonFill, null), /*#__PURE__*/_react.default.createElement("span", null, sessionState === null || sessionState === void 0 ? void 0 : (_sessionState$
|
|
611
|
+
}) : /*#__PURE__*/_react.default.createElement(_reactBootstrapIcons.PersonFill, null), /*#__PURE__*/_react.default.createElement("span", null, sessionState === null || sessionState === void 0 ? void 0 : (_sessionState$user36 = sessionState.user) === null || _sessionState$user36 === void 0 ? void 0 : _sessionState$user36.name, " ", sessionState === null || sessionState === void 0 ? void 0 : (_sessionState$user37 = sessionState.user) === null || _sessionState$user37 === void 0 ? void 0 : _sessionState$user37.lastname)), /*#__PURE__*/_react.default.createElement(_LogoutButton.LogoutButton, null))))));
|
|
611
612
|
};
|
|
612
613
|
var ContextAwareToggle = function ContextAwareToggle(_ref2) {
|
|
613
614
|
var children = _ref2.children,
|
|
@@ -196,7 +196,7 @@ var DeliveryZone = function DeliveryZone(props) {
|
|
|
196
196
|
maxLength: 2,
|
|
197
197
|
value: (_zoneState$data$dista = zoneState === null || zoneState === void 0 ? void 0 : (_zoneState$data = zoneState.data) === null || _zoneState$data === void 0 ? void 0 : _zoneState$data.distance) !== null && _zoneState$data$dista !== void 0 ? _zoneState$data$dista : '',
|
|
198
198
|
onInput: function onInput(e) {
|
|
199
|
-
e.target.value = e.target.value.match(
|
|
199
|
+
e.target.value = e.target.value.match("^[".concat(e.target.value === '0' ? '1' : '0', "-9]{1,2}$"));
|
|
200
200
|
},
|
|
201
201
|
onChange: function onChange(e) {
|
|
202
202
|
var _configState$configs4, _configState$configs5;
|
|
@@ -228,7 +228,7 @@ var BusinessDeliveryZoneInformation = function BusinessDeliveryZoneInformation(p
|
|
|
228
228
|
maxLength: 2,
|
|
229
229
|
value: (_ref4 = (_formState$changes$da = (_formState$changes6 = formState.changes) === null || _formState$changes6 === void 0 ? void 0 : (_formState$changes6$d = _formState$changes6.data) === null || _formState$changes6$d === void 0 ? void 0 : _formState$changes6$d.distance) !== null && _formState$changes$da !== void 0 ? _formState$changes$da : zone === null || zone === void 0 ? void 0 : (_zone$data = zone.data) === null || _zone$data === void 0 ? void 0 : _zone$data.distance) !== null && _ref4 !== void 0 ? _ref4 : '',
|
|
230
230
|
onInput: function onInput(e) {
|
|
231
|
-
e.target.value = e.target.value.match(
|
|
231
|
+
e.target.value = e.target.value.match("^[".concat(e.target.value === '0' ? '1' : '0', "-9]{1,2}$"));
|
|
232
232
|
},
|
|
233
233
|
onChange: function onChange(e) {
|
|
234
234
|
var _configState$configs4, _configState$configs5;
|
|
@@ -24,6 +24,8 @@ var _BusinessWebhooks = require("../BusinessWebhooks");
|
|
|
24
24
|
var _BusinessNotifications = require("../BusinessNotifications");
|
|
25
25
|
var _BusinessOrderingChannels = require("../BusinessOrderingChannels");
|
|
26
26
|
var _BusinessFrontLayout = require("../BusinessFrontLayout");
|
|
27
|
+
var _BusinessPlaceGroupList = require("../BusinessPlaceGroupList");
|
|
28
|
+
var _SpoonityApiKey = require("../SpoonityApiKey");
|
|
27
29
|
var _Shared = require("../../Shared");
|
|
28
30
|
var _styles = require("./styles");
|
|
29
31
|
var _BusinessSalesChannel = require("../BusinessSalesChannel");
|
|
@@ -41,7 +43,7 @@ function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len
|
|
|
41
43
|
function _iterableToArrayLimit(arr, i) { var _i = null == arr ? null : "undefined" != typeof Symbol && arr[Symbol.iterator] || arr["@@iterator"]; if (null != _i) { var _s, _e, _x, _r, _arr = [], _n = !0, _d = !1; try { if (_x = (_i = _i.call(arr)).next, 0 === i) { if (Object(_i) !== _i) return; _n = !1; } else for (; !(_n = (_s = _x.call(_i)).done) && (_arr.push(_s.value), _arr.length !== i); _n = !0); } catch (err) { _d = !0, _e = err; } finally { try { if (!_n && null != _i.return && (_r = _i.return(), Object(_r) !== _r)) return; } finally { if (_d) throw _e; } } return _arr; } }
|
|
42
44
|
function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
|
|
43
45
|
var BusinessDetailsUI = function BusinessDetailsUI(props) {
|
|
44
|
-
var _businessState$busine, _businessState$busine2, _businessState$busine3, _businessState$busine4, _businessState$busine5;
|
|
46
|
+
var _businessState$busine, _businessState$busine2, _businessState$busine3, _businessState$busine4, _businessState$busine5, _businessState$busine6, _businessState$busine7;
|
|
45
47
|
var open = props.open,
|
|
46
48
|
businessId = props.businessId,
|
|
47
49
|
businessState = props.businessState,
|
|
@@ -60,7 +62,9 @@ var BusinessDetailsUI = function BusinessDetailsUI(props) {
|
|
|
60
62
|
handleDuplicateBusiness = props.handleDuplicateBusiness,
|
|
61
63
|
handleDeleteBusiness = props.handleDeleteBusiness,
|
|
62
64
|
actionStatus = props.actionStatus,
|
|
63
|
-
handleUpdatePreorderConfigs = props.handleUpdatePreorderConfigs
|
|
65
|
+
handleUpdatePreorderConfigs = props.handleUpdatePreorderConfigs,
|
|
66
|
+
handleUpdateSpoonityKey = props.handleUpdateSpoonityKey,
|
|
67
|
+
spoonityKeyState = props.spoonityKeyState;
|
|
64
68
|
var history = (0, _reactRouterDom.useHistory)();
|
|
65
69
|
var query = new URLSearchParams((0, _reactRouterDom.useLocation)().search);
|
|
66
70
|
var _useLanguage = (0, _orderingComponentsAdminExternal.useLanguage)(),
|
|
@@ -90,6 +94,9 @@ var BusinessDetailsUI = function BusinessDetailsUI(props) {
|
|
|
90
94
|
_useState8 = _slicedToArray(_useState7, 2),
|
|
91
95
|
alertState = _useState8[0],
|
|
92
96
|
setAlertState = _useState8[1];
|
|
97
|
+
var spoonityConfig = businessState === null || businessState === void 0 ? void 0 : (_businessState$busine = businessState.business) === null || _businessState$busine === void 0 ? void 0 : (_businessState$busine2 = _businessState$busine.configs) === null || _businessState$busine2 === void 0 ? void 0 : _businessState$busine2.find(function (config) {
|
|
98
|
+
return config.key === 'spoonity_integration_api_key';
|
|
99
|
+
});
|
|
93
100
|
var isAdmin = (user === null || user === void 0 ? void 0 : user.level) === 0;
|
|
94
101
|
var _useState9 = (0, _react.useState)(null),
|
|
95
102
|
_useState10 = _slicedToArray(_useState9, 2),
|
|
@@ -197,7 +204,8 @@ var BusinessDetailsUI = function BusinessDetailsUI(props) {
|
|
|
197
204
|
handleSucessUpdateBusiness: handleSucessUpdateBusiness,
|
|
198
205
|
handleDuplicateBusiness: handleDuplicateBusiness,
|
|
199
206
|
handleDeleteBusiness: handleDeleteBusiness,
|
|
200
|
-
extraOpen: extraOpen
|
|
207
|
+
extraOpen: extraOpen,
|
|
208
|
+
spoonityConfig: spoonityConfig
|
|
201
209
|
}), extraOpen && /*#__PURE__*/_react.default.createElement(_Shared.MoreSidebarLayout, {
|
|
202
210
|
isExtendExtraOpen: isExtendExtraOpen,
|
|
203
211
|
onClose: handleCloseExtraOpen
|
|
@@ -209,7 +217,7 @@ var BusinessDetailsUI = function BusinessDetailsUI(props) {
|
|
|
209
217
|
handleAddBusinessOwner: handleAddBusinessOwner,
|
|
210
218
|
formState: formState,
|
|
211
219
|
setFormState: setFormState,
|
|
212
|
-
businessTypes: businessTypes || (businessState === null || businessState === void 0 ? void 0 : (_businessState$
|
|
220
|
+
businessTypes: businessTypes || (businessState === null || businessState === void 0 ? void 0 : (_businessState$busine3 = businessState.business) === null || _businessState$busine3 === void 0 ? void 0 : _businessState$busine3.types),
|
|
213
221
|
handleUpdateBusinessClick: handleUpdateBusinessClick,
|
|
214
222
|
setBusinessTypes: setBusinessTypes,
|
|
215
223
|
handleSuccessAddBusinessItem: handleSuccessAddBusinessItem,
|
|
@@ -245,8 +253,8 @@ var BusinessDetailsUI = function BusinessDetailsUI(props) {
|
|
|
245
253
|
business: businessState === null || businessState === void 0 ? void 0 : businessState.business,
|
|
246
254
|
handleUpdateBusinessClick: handleUpdateBusinessClick
|
|
247
255
|
}), selectedItem === 'promotions' && /*#__PURE__*/_react.default.createElement(_BusinessPromotionList.BusinessPromotionList, {
|
|
248
|
-
promotions: businessState === null || businessState === void 0 ? void 0 : (_businessState$
|
|
249
|
-
businessId: businessState === null || businessState === void 0 ? void 0 : (_businessState$
|
|
256
|
+
promotions: businessState === null || businessState === void 0 ? void 0 : (_businessState$busine4 = businessState.business) === null || _businessState$busine4 === void 0 ? void 0 : _businessState$busine4.offers,
|
|
257
|
+
businessId: businessState === null || businessState === void 0 ? void 0 : (_businessState$busine5 = businessState.business) === null || _businessState$busine5 === void 0 ? void 0 : _businessState$busine5.id,
|
|
250
258
|
business: businessState === null || businessState === void 0 ? void 0 : businessState.business,
|
|
251
259
|
setIsExtendExtraOpen: setIsExtendExtraOpen,
|
|
252
260
|
handleSuccessUpdate: handleUpdateBusinessState
|
|
@@ -258,8 +266,8 @@ var BusinessDetailsUI = function BusinessDetailsUI(props) {
|
|
|
258
266
|
handleUpdateBusinessClick: handleUpdateBusinessClick,
|
|
259
267
|
handleUpdatePreorderConfigs: handleUpdatePreorderConfigs
|
|
260
268
|
}), selectedItem === 'custom_fields' && /*#__PURE__*/_react.default.createElement(_BusinessCustomFields.BusinessCustomFields, {
|
|
261
|
-
businessId: businessState === null || businessState === void 0 ? void 0 : (_businessState$
|
|
262
|
-
metafields: businessState === null || businessState === void 0 ? void 0 : (_businessState$
|
|
269
|
+
businessId: businessState === null || businessState === void 0 ? void 0 : (_businessState$busine6 = businessState.business) === null || _businessState$busine6 === void 0 ? void 0 : _businessState$busine6.id,
|
|
270
|
+
metafields: businessState === null || businessState === void 0 ? void 0 : (_businessState$busine7 = businessState.business) === null || _businessState$busine7 === void 0 ? void 0 : _businessState$busine7.metafields,
|
|
263
271
|
handleSuccessAddMetaFields: function handleSuccessAddMetaFields(result) {
|
|
264
272
|
return handleSuccessAddBusinessItem('metafields', result);
|
|
265
273
|
},
|
|
@@ -286,6 +294,17 @@ var BusinessDetailsUI = function BusinessDetailsUI(props) {
|
|
|
286
294
|
}), selectedItem === 'webhooks' && /*#__PURE__*/_react.default.createElement(_BusinessWebhooks.BusinessWebhooks, {
|
|
287
295
|
business: businessState === null || businessState === void 0 ? void 0 : businessState.business,
|
|
288
296
|
handleSuccessUpdate: handleUpdateBusinessState
|
|
297
|
+
}), selectedItem === 'places' && /*#__PURE__*/_react.default.createElement(_BusinessPlaceGroupList.BusinessPlaceGroupList, {
|
|
298
|
+
business: businessState === null || businessState === void 0 ? void 0 : businessState.business,
|
|
299
|
+
handleSuccessUpdate: handleUpdateBusinessState,
|
|
300
|
+
setIsExtendExtraOpen: setIsExtendExtraOpen
|
|
301
|
+
}), selectedItem === 'spoonity_key' && /*#__PURE__*/_react.default.createElement(_SpoonityApiKey.SpoonityApiKey, {
|
|
302
|
+
business: businessState === null || businessState === void 0 ? void 0 : businessState.business,
|
|
303
|
+
handleSuccessUpdate: handleUpdateBusinessState,
|
|
304
|
+
handleUpdateBusinessClick: handleUpdateBusinessClick,
|
|
305
|
+
spoonityConfig: spoonityConfig,
|
|
306
|
+
handleUpdateSpoonityKey: handleUpdateSpoonityKey,
|
|
307
|
+
spoonityKeyState: spoonityKeyState
|
|
289
308
|
})), /*#__PURE__*/_react.default.createElement(_Shared.Alert, {
|
|
290
309
|
title: t('WEB_APPNAME', 'Ordering'),
|
|
291
310
|
content: alertState.content,
|
|
@@ -89,22 +89,23 @@ var BusinessLocation = function BusinessLocation(props) {
|
|
|
89
89
|
var getTimeZone = /*#__PURE__*/function () {
|
|
90
90
|
var _ref = _asyncToGenerator( /*#__PURE__*/_regeneratorRuntime().mark(function _callee(address) {
|
|
91
91
|
var _address$location, _address$location2;
|
|
92
|
-
var date, timestamp, url, response, result;
|
|
92
|
+
var date, timestamp, timezoneApiKey, url, response, result;
|
|
93
93
|
return _regeneratorRuntime().wrap(function _callee$(_context) {
|
|
94
94
|
while (1) switch (_context.prev = _context.next) {
|
|
95
95
|
case 0:
|
|
96
96
|
date = new Date();
|
|
97
97
|
timestamp = Math.floor(date.getTime() / 1000);
|
|
98
|
-
|
|
99
|
-
|
|
98
|
+
timezoneApiKey = googleMapsApiKey === 'AIzaSyBvsSkMYPSDSkdk7YFrSf5FoGonIzr6fJ0' ? 'AIzaSyCYPCOfiTo9jxuxLWnWTup6mmICPxfLegI' : googleMapsApiKey;
|
|
99
|
+
url = "https://maps.googleapis.com/maps/api/timezone/json?location=".concat(address === null || address === void 0 ? void 0 : (_address$location = address.location) === null || _address$location === void 0 ? void 0 : _address$location.lat, ",").concat(address === null || address === void 0 ? void 0 : (_address$location2 = address.location) === null || _address$location2 === void 0 ? void 0 : _address$location2.lng, "×tamp=").concat(timestamp, "&key=").concat(timezoneApiKey);
|
|
100
|
+
_context.next = 6;
|
|
100
101
|
return fetch(url, {
|
|
101
102
|
method: 'GET'
|
|
102
103
|
});
|
|
103
|
-
case
|
|
104
|
+
case 6:
|
|
104
105
|
response = _context.sent;
|
|
105
|
-
_context.next =
|
|
106
|
+
_context.next = 9;
|
|
106
107
|
return response.json();
|
|
107
|
-
case
|
|
108
|
+
case 9:
|
|
108
109
|
result = _context.sent;
|
|
109
110
|
setFormState(function (prevState) {
|
|
110
111
|
return _objectSpread(_objectSpread({}, prevState), {}, {
|
|
@@ -118,7 +119,7 @@ var BusinessLocation = function BusinessLocation(props) {
|
|
|
118
119
|
})
|
|
119
120
|
});
|
|
120
121
|
});
|
|
121
|
-
case
|
|
122
|
+
case 11:
|
|
122
123
|
case "end":
|
|
123
124
|
return _context.stop();
|
|
124
125
|
}
|
|
@@ -0,0 +1,127 @@
|
|
|
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.BusinessPlaceUI = exports.BusinessPlace = void 0;
|
|
8
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
9
|
+
var _orderingComponentsAdminExternal = require("ordering-components-admin-external");
|
|
10
|
+
var _reactBootstrap = require("react-bootstrap");
|
|
11
|
+
var _reactBootstrapIcons = require("react-bootstrap-icons");
|
|
12
|
+
var _styledComponents = require("styled-components");
|
|
13
|
+
var _styles = require("../../../styles");
|
|
14
|
+
var _reactHookForm = require("react-hook-form");
|
|
15
|
+
var _Shared = require("../../Shared");
|
|
16
|
+
var _styles2 = require("./styles");
|
|
17
|
+
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); }
|
|
18
|
+
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; }
|
|
19
|
+
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; }
|
|
20
|
+
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; }
|
|
21
|
+
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; }
|
|
22
|
+
function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return _typeof(key) === "symbol" ? key : String(key); }
|
|
23
|
+
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); }
|
|
24
|
+
function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
|
|
25
|
+
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."); }
|
|
26
|
+
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); }
|
|
27
|
+
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; }
|
|
28
|
+
function _iterableToArrayLimit(arr, i) { var _i = null == arr ? null : "undefined" != typeof Symbol && arr[Symbol.iterator] || arr["@@iterator"]; if (null != _i) { var _s, _e, _x, _r, _arr = [], _n = !0, _d = !1; try { if (_x = (_i = _i.call(arr)).next, 0 === i) { if (Object(_i) !== _i) return; _n = !1; } else for (; !(_n = (_s = _x.call(_i)).done) && (_arr.push(_s.value), _arr.length !== i); _n = !0); } catch (err) { _d = !0, _e = err; } finally { try { if (!_n && null != _i.return && (_r = _i.return(), Object(_r) !== _r)) return; } finally { if (_d) throw _e; } } return _arr; } }
|
|
29
|
+
function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
|
|
30
|
+
var BusinessPlaceUI = function BusinessPlaceUI(props) {
|
|
31
|
+
var _ref, _formState$changes$na, _formState$changes;
|
|
32
|
+
var onClose = props.onClose,
|
|
33
|
+
place = props.place,
|
|
34
|
+
formState = props.formState,
|
|
35
|
+
handleChangeInput = props.handleChangeInput,
|
|
36
|
+
handleAddPlace = props.handleAddPlace,
|
|
37
|
+
handleUpdatePlace = props.handleUpdatePlace,
|
|
38
|
+
handleDeletePlace = props.handleDeletePlace;
|
|
39
|
+
var theme = (0, _styledComponents.useTheme)();
|
|
40
|
+
var _useLanguage = (0, _orderingComponentsAdminExternal.useLanguage)(),
|
|
41
|
+
_useLanguage2 = _slicedToArray(_useLanguage, 2),
|
|
42
|
+
t = _useLanguage2[1];
|
|
43
|
+
var formMethods = (0, _reactHookForm.useForm)();
|
|
44
|
+
var _useState = (0, _react.useState)({
|
|
45
|
+
open: false,
|
|
46
|
+
content: []
|
|
47
|
+
}),
|
|
48
|
+
_useState2 = _slicedToArray(_useState, 2),
|
|
49
|
+
alertState = _useState2[0],
|
|
50
|
+
setAlertState = _useState2[1];
|
|
51
|
+
var buttonRef = (0, _react.useRef)(null);
|
|
52
|
+
var closeAlert = function closeAlert() {
|
|
53
|
+
setAlertState({
|
|
54
|
+
open: false,
|
|
55
|
+
content: []
|
|
56
|
+
});
|
|
57
|
+
};
|
|
58
|
+
var onSubmit = function onSubmit() {
|
|
59
|
+
if (place) handleUpdatePlace();else handleAddPlace();
|
|
60
|
+
};
|
|
61
|
+
(0, _react.useEffect)(function () {
|
|
62
|
+
if (Object.keys(formMethods.errors).length > 0) {
|
|
63
|
+
setAlertState({
|
|
64
|
+
open: true,
|
|
65
|
+
content: Object.values(formMethods.errors).map(function (error) {
|
|
66
|
+
return error.message;
|
|
67
|
+
})
|
|
68
|
+
});
|
|
69
|
+
}
|
|
70
|
+
}, [formMethods.errors]);
|
|
71
|
+
return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement(_styles2.Container, null, /*#__PURE__*/_react.default.createElement(_styles2.Header, null, /*#__PURE__*/_react.default.createElement("h1", null, place ? place === null || place === void 0 ? void 0 : place.name : t('NEW_OPTION', 'New option')), /*#__PURE__*/_react.default.createElement(_styles2.ActionBlock, null, place && /*#__PURE__*/_react.default.createElement(_styles2.ActionSelectorWrapper, null, /*#__PURE__*/_react.default.createElement(_reactBootstrap.DropdownButton, {
|
|
72
|
+
className: "product_actions",
|
|
73
|
+
menuAlign: theme !== null && theme !== void 0 && theme.rtl ? 'left' : 'right',
|
|
74
|
+
title: /*#__PURE__*/_react.default.createElement(_reactBootstrapIcons.ThreeDots, null),
|
|
75
|
+
id: theme !== null && theme !== void 0 && theme.rtl ? 'dropdown-menu-align-left' : 'dropdown-menu-align-right'
|
|
76
|
+
}, /*#__PURE__*/_react.default.createElement(_reactBootstrap.Dropdown.Item, {
|
|
77
|
+
onClick: function onClick() {
|
|
78
|
+
return handleDeletePlace();
|
|
79
|
+
}
|
|
80
|
+
}, t('DELETE', 'Delete')))), /*#__PURE__*/_react.default.createElement(_styles.IconButton, {
|
|
81
|
+
color: "black",
|
|
82
|
+
onClick: function onClick() {
|
|
83
|
+
return onClose();
|
|
84
|
+
}
|
|
85
|
+
}, /*#__PURE__*/_react.default.createElement(_reactBootstrapIcons.XLg, null)))), /*#__PURE__*/_react.default.createElement(_styles2.Content, {
|
|
86
|
+
onSubmit: formMethods.handleSubmit(onSubmit)
|
|
87
|
+
}, /*#__PURE__*/_react.default.createElement("label", null, t('NAME', 'Name')), /*#__PURE__*/_react.default.createElement(_styles.Input, {
|
|
88
|
+
placeholder: t('NAME', 'Name'),
|
|
89
|
+
name: "name",
|
|
90
|
+
autoComplete: "off",
|
|
91
|
+
onChange: handleChangeInput,
|
|
92
|
+
value: (_ref = (_formState$changes$na = formState === null || formState === void 0 ? void 0 : (_formState$changes = formState.changes) === null || _formState$changes === void 0 ? void 0 : _formState$changes.name) !== null && _formState$changes$na !== void 0 ? _formState$changes$na : place === null || place === void 0 ? void 0 : place.name) !== null && _ref !== void 0 ? _ref : '',
|
|
93
|
+
ref: formMethods.register({
|
|
94
|
+
required: t('VALIDATION_ERROR_REQUIRED', 'Name is required').replace('_attribute_', t('NAME', 'Name'))
|
|
95
|
+
})
|
|
96
|
+
}), /*#__PURE__*/_react.default.createElement(_styles2.HideSubmitBtn, {
|
|
97
|
+
type: "submit",
|
|
98
|
+
ref: buttonRef
|
|
99
|
+
})), /*#__PURE__*/_react.default.createElement(_styles2.ButtonWrapper, null, /*#__PURE__*/_react.default.createElement(_styles.Button, {
|
|
100
|
+
color: "primary",
|
|
101
|
+
borderRadius: "8px",
|
|
102
|
+
disabled: Object.keys(formState === null || formState === void 0 ? void 0 : formState.changes).length === 0,
|
|
103
|
+
onClick: function onClick() {
|
|
104
|
+
return buttonRef.current.click();
|
|
105
|
+
}
|
|
106
|
+
}, place ? t('SAVE', 'Save') : t('ADD', 'Add')))), /*#__PURE__*/_react.default.createElement(_Shared.Alert, {
|
|
107
|
+
title: t('PLACES', 'Places'),
|
|
108
|
+
content: alertState.content,
|
|
109
|
+
acceptText: t('ACCEPT', 'Accept'),
|
|
110
|
+
open: alertState.open,
|
|
111
|
+
onClose: function onClose() {
|
|
112
|
+
return closeAlert();
|
|
113
|
+
},
|
|
114
|
+
onAccept: function onAccept() {
|
|
115
|
+
return closeAlert();
|
|
116
|
+
},
|
|
117
|
+
closeOnBackdrop: false
|
|
118
|
+
}));
|
|
119
|
+
};
|
|
120
|
+
exports.BusinessPlaceUI = BusinessPlaceUI;
|
|
121
|
+
var BusinessPlace = function BusinessPlace(props) {
|
|
122
|
+
var businessPlaceProps = _objectSpread(_objectSpread({}, props), {}, {
|
|
123
|
+
UIComponent: BusinessPlaceUI
|
|
124
|
+
});
|
|
125
|
+
return /*#__PURE__*/_react.default.createElement(_orderingComponentsAdminExternal.BusinessPlace, businessPlaceProps);
|
|
126
|
+
};
|
|
127
|
+
exports.BusinessPlace = BusinessPlace;
|
|
@@ -0,0 +1,55 @@
|
|
|
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.HideSubmitBtn = exports.Header = exports.Content = exports.Container = exports.ButtonWrapper = exports.ActionSelectorWrapper = exports.ActionBlock = void 0;
|
|
8
|
+
var _styledComponents = _interopRequireWildcard(require("styled-components"));
|
|
9
|
+
var _polished = require("polished");
|
|
10
|
+
var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5, _templateObject6, _templateObject7, _templateObject8, _templateObject9, _templateObject10, _templateObject11, _templateObject12, _templateObject13;
|
|
11
|
+
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); }
|
|
12
|
+
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; }
|
|
13
|
+
function _taggedTemplateLiteral(strings, raw) { if (!raw) { raw = strings.slice(0); } return Object.freeze(Object.defineProperties(strings, { raw: { value: Object.freeze(raw) } })); }
|
|
14
|
+
var Container = _styledComponents.default.div(_templateObject || (_templateObject = _taggedTemplateLiteral(["\n transition: 0.3s;\n height: 100%;\n \n > button {\n height: 42px;\n width: 100%;\n margin-top: 20px;\n }\n"])));
|
|
15
|
+
exports.Container = Container;
|
|
16
|
+
var Header = _styledComponents.default.div(_templateObject2 || (_templateObject2 = _taggedTemplateLiteral(["\n display: flex;\n align-items: center;\n justify-content: space-between;\n position: relative;\n h1 {\n font-size: 20px;\n font-weight: 700;\n margin: 5px 0;\n color: ", ";\n ", "\n }\n"])), function (props) {
|
|
17
|
+
return props.theme.colors.headingColor;
|
|
18
|
+
}, function (props) {
|
|
19
|
+
var _props$theme;
|
|
20
|
+
return (_props$theme = props.theme) !== null && _props$theme !== void 0 && _props$theme.rtl ? (0, _styledComponents.css)(_templateObject3 || (_templateObject3 = _taggedTemplateLiteral(["\n margin-left: 80px;\n "]))) : (0, _styledComponents.css)(_templateObject4 || (_templateObject4 = _taggedTemplateLiteral(["\n margin-right: 80px;\n "])));
|
|
21
|
+
});
|
|
22
|
+
exports.Header = Header;
|
|
23
|
+
var ActionBlock = _styledComponents.default.div(_templateObject5 || (_templateObject5 = _taggedTemplateLiteral(["\n background: ", ";\n position: absolute;\n z-index: 1000;\n display: flex;\n align-items: center;\n > button {\n display: none;\n }\n ", "\n @media (min-width: 1000px) {\n > button {\n display: block;\n ", "\n }\n }\n"])), function (props) {
|
|
24
|
+
var _props$theme$colors;
|
|
25
|
+
return ((_props$theme$colors = props.theme.colors) === null || _props$theme$colors === void 0 ? void 0 : _props$theme$colors.backgroundPage) || '#FFF';
|
|
26
|
+
}, function (props) {
|
|
27
|
+
var _props$theme2;
|
|
28
|
+
return (_props$theme2 = props.theme) !== null && _props$theme2 !== void 0 && _props$theme2.rtl ? (0, _styledComponents.css)(_templateObject6 || (_templateObject6 = _taggedTemplateLiteral(["\n left: 0px;\n "]))) : (0, _styledComponents.css)(_templateObject7 || (_templateObject7 = _taggedTemplateLiteral(["\n right: 0px;\n "])));
|
|
29
|
+
}, function (props) {
|
|
30
|
+
var _props$theme3;
|
|
31
|
+
return (_props$theme3 = props.theme) !== null && _props$theme3 !== void 0 && _props$theme3.rtl ? (0, _styledComponents.css)(_templateObject8 || (_templateObject8 = _taggedTemplateLiteral(["\n margin-right: 10px;\n "]))) : (0, _styledComponents.css)(_templateObject9 || (_templateObject9 = _taggedTemplateLiteral(["\n margin-left: 10px;\n "])));
|
|
32
|
+
});
|
|
33
|
+
exports.ActionBlock = ActionBlock;
|
|
34
|
+
var ActionSelectorWrapper = _styledComponents.default.div(_templateObject10 || (_templateObject10 = _taggedTemplateLiteral(["\n button {\n display: flex;\n background: transparent !important;\n border: none;\n padding: 5px;\n border-radius: 8px;\n &:active,\n &:focus {\n border-color: unset !important;\n box-shadow: none !important;\n }\n svg {\n color: ", ";\n font-size: 20px;\n }\n &:after {\n display: none;\n }\n &:hover {\n background: ", " !important;\n }\n &:active {\n background: ", " !important;\n }\n }\n .show {\n >div {\n border: 1px solid ", ";\n box-shadow: 0px 4px 10px rgba(0, 0, 0, 0.12);\n }\n }\n > div {\n > div {\n border-radius: 8px;\n .dropdown-item {\n font-size: 12px;\n color: ", ";\n padding: 7px 20px;\n &:active {\n background: ", " !important;\n }\n }\n .dropdown-item:last-child {\n color: ", ";\n }\n }\n }\n"])), function (props) {
|
|
35
|
+
return props.theme.colors.headingColor;
|
|
36
|
+
}, function (props) {
|
|
37
|
+
return (0, _polished.darken)(0.04, props.theme.colors.secundary);
|
|
38
|
+
}, function (props) {
|
|
39
|
+
return (0, _polished.darken)(0.1, props.theme.colors.secundaryDarkContrast);
|
|
40
|
+
}, function (props) {
|
|
41
|
+
return props.theme.colors.borderColor;
|
|
42
|
+
}, function (props) {
|
|
43
|
+
return props.theme.colors.headingColor;
|
|
44
|
+
}, function (props) {
|
|
45
|
+
return (0, _polished.darken)(0.1, props.theme.colors.secundary);
|
|
46
|
+
}, function (props) {
|
|
47
|
+
return props.theme.colors.danger;
|
|
48
|
+
});
|
|
49
|
+
exports.ActionSelectorWrapper = ActionSelectorWrapper;
|
|
50
|
+
var Content = _styledComponents.default.form(_templateObject11 || (_templateObject11 = _taggedTemplateLiteral(["\n margin-top: 30px;\n label {\n font-weight: 400;\n font-size: 14px;\n margin-bottom: 10px;\n }\n input {\n height: 44px;\n width: 100%;\n }\n"])));
|
|
51
|
+
exports.Content = Content;
|
|
52
|
+
var ButtonWrapper = _styledComponents.default.div(_templateObject12 || (_templateObject12 = _taggedTemplateLiteral(["\n position: sticky;\n top: 100%;\n button {\n height: 44px;\n }\n"])));
|
|
53
|
+
exports.ButtonWrapper = ButtonWrapper;
|
|
54
|
+
var HideSubmitBtn = _styledComponents.default.button(_templateObject13 || (_templateObject13 = _taggedTemplateLiteral(["\n display: none;\n"])));
|
|
55
|
+
exports.HideSubmitBtn = HideSubmitBtn;
|