@mirai/core 0.4.49 → 0.4.51
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/build/components/Booking/Booking.js +4 -6
- package/build/components/Booking/Booking.js.map +1 -1
- package/build/components/Chat/Chat.ButtonAvatar.js +97 -0
- package/build/components/Chat/Chat.ButtonAvatar.js.map +1 -0
- package/build/components/Chat/Chat.Header.js +63 -0
- package/build/components/Chat/Chat.Header.js.map +1 -0
- package/build/components/Chat/Chat.constants.js +12 -15
- package/build/components/Chat/Chat.constants.js.map +1 -1
- package/build/components/Chat/Chat.js +50 -88
- package/build/components/Chat/Chat.js.map +1 -1
- package/build/components/Chat/Chat.module.css +52 -11
- package/build/components/Chat/components/InputRich/InputRich.js +2 -3
- package/build/components/Chat/components/InputRich/InputRich.js.map +1 -1
- package/build/components/Chat/components/InputRich/InputRich.module.css +9 -2
- package/build/components/Chat/components/Message/Message.constants.js +7 -3
- package/build/components/Chat/components/Message/Message.constants.js.map +1 -1
- package/build/components/Chat/components/Message/Message.module.css +1 -0
- package/build/components/Chat/components/Message/components/Booking.js +11 -18
- package/build/components/Chat/components/Message/components/Booking.js.map +1 -1
- package/build/components/Chat/components/Message/components/Booking.module.css +1 -9
- package/build/components/Chat/components/Message/components/Typewriter.js +51 -0
- package/build/components/Chat/components/Message/components/Typewriter.js.map +1 -0
- package/build/components/Chat/components/Message/intents/index.js +2 -13
- package/build/components/Chat/components/Message/intents/index.js.map +1 -1
- package/build/components/Chat/components/index.js +2 -13
- package/build/components/Chat/components/index.js.map +1 -1
- package/build/components/Chat/helpers/audioNotification.js +13 -0
- package/build/components/Chat/helpers/audioNotification.js.map +1 -0
- package/build/components/Chat/helpers/index.js +13 -2
- package/build/components/Chat/helpers/index.js.map +1 -1
- package/build/components/Session/Session.Login.js +12 -2
- package/build/components/Session/Session.Login.js.map +1 -1
- package/build/contexts/PerformanceManager/helpers/dataLayerPush.js +3 -2
- package/build/contexts/PerformanceManager/helpers/dataLayerPush.js.map +1 -1
- package/build/helpers/loadSentry.js +9 -4
- package/build/helpers/loadSentry.js.map +1 -1
- package/build/theme.css +5 -4
- package/package.json +1 -1
- package/build/components/Chat/components/Message/components/Booking.l10n.js +0 -15
- package/build/components/Chat/components/Message/components/Booking.l10n.js.map +0 -1
- package/build/components/Chat/components/Message/intents/Book.js +0 -62
- package/build/components/Chat/components/Message/intents/Book.js.map +0 -1
- package/build/components/Chat/components/Offline/Offline.js +0 -26
- package/build/components/Chat/components/Offline/Offline.js.map +0 -1
- package/build/components/Chat/components/Offline/Offline.module.css +0 -3
- package/build/components/Chat/components/Offline/index.js +0 -20
- package/build/components/Chat/components/Offline/index.js.map +0 -1
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
!function(){try{var e="undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof self?self:{},n=(new e.Error).stack;n&&(e._sentryDebugIds=e._sentryDebugIds||{},e._sentryDebugIds[n]="
|
|
2
|
+
!function(){try{var e="undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof self?self:{},n=(new e.Error).stack;n&&(e._sentryDebugIds=e._sentryDebugIds||{},e._sentryDebugIds[n]="593861ff-dfcb-5742-baa4-0e1dde8ba4f9")}catch(e){}}();
|
|
3
3
|
|
|
4
4
|
|
|
5
5
|
Object.defineProperty(exports, "__esModule", {
|
|
@@ -92,11 +92,9 @@ const Booking = _ref => {
|
|
|
92
92
|
};
|
|
93
93
|
const handleBackHome = () => {
|
|
94
94
|
const {
|
|
95
|
-
payload
|
|
96
|
-
hotelUrl
|
|
97
|
-
} = {}
|
|
95
|
+
payload
|
|
98
96
|
} = responseError;
|
|
99
|
-
window.location = hotelUrl || window.location.origin;
|
|
97
|
+
window.location.href = (payload === null || payload === void 0 ? void 0 : payload.hotelUrl) || window.location.origin;
|
|
100
98
|
};
|
|
101
99
|
const {
|
|
102
100
|
payment,
|
|
@@ -191,4 +189,4 @@ Booking.propTypes = {
|
|
|
191
189
|
skeleton: _propTypes.default.bool
|
|
192
190
|
};
|
|
193
191
|
//# sourceMappingURL=Booking.js.map
|
|
194
|
-
//# debugId=
|
|
192
|
+
//# debugId=593861ff-dfcb-5742-baa4-0e1dde8ba4f9
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Booking.js","sources":["../../../src/components/Booking/Booking.jsx"],"sourcesContent":["import { Event, useStore } from '@mirai/data-sources';\nimport { useLocale } from '@mirai/locale';\nimport { ServiceBooking } from '@mirai/services';\nimport { Action, Notification, Progress, styles, useDevice, View } from '@mirai/ui';\nimport PropTypes from 'prop-types';\nimport React, { useEffect, useState } from 'react';\n\nimport { ACTION, ERROR, STATE } from './Booking.constants';\nimport { L10N } from './Booking.l10n';\nimport * as style from './Booking.module.css';\nimport Skeleton from './Booking.skeleton';\nimport { Hotelverse } from './components';\nimport { Information, Menu, Modal } from './partials';\nimport { BookingPayment } from './partials/Booking.Payment';\nimport { BookingDetails, BookingSummary, BookingTerms, Footer } from '../__shared__';\nimport { Header } from '../Header';\nimport { EVENT } from '../helpers';\n\nconst Booking = ({ skeleton, ...others }) => {\n const { isDesktop, isMobile } = useDevice();\n const { locale, translate } = useLocale();\n const {\n value: { hotel: { url } = {}, urlParams: { code: token, reservationCode: id, hasToTracking: tracking } = {} },\n } = useStore();\n\n const [action, setAction] = useState();\n const [dataSource, setDataSource] = useState();\n const [expanded, setExpanded] = useState(false);\n const [responseError, setResponseError] = useState();\n\n useEffect(() => Event.publish(EVENT.METRICS, { id: 'BOOKING:RENDER' }), []);\n\n useEffect(() => {\n if (skeleton || !id || !token) return;\n\n (async () => {\n setDataSource(\n await ServiceBooking.get({ id, locale, token, tracking, url }).catch((error) => setResponseError(error)),\n );\n setAction();\n })();\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [id, locale]);\n\n useEffect(() => {\n if (!dataSource || !dataSource.tracking) return;\n\n const event = dataSource.state === STATE.CANCELLED ? EVENT.BOOKING_CANCEL : EVENT.BOOKING_RESPONSE;\n Event.publish(event, { event, response: { ...dataSource } });\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [dataSource?.state]);\n\n const handleMenuPress = (action) => {\n if (action === ACTION.PRINT) {\n setExpanded(true);\n setTimeout(window.print, 10);\n } else {\n setAction(action);\n }\n };\n\n const handleBackHome = () => {\n const { payload: { hotelUrl } = {} } = responseError;\n\n window.location = hotelUrl || window.location.origin;\n };\n\n const { payment, state } = dataSource || {};\n const response = dataSource !== undefined;\n const isCancelled = state === STATE.CANCELLED;\n\n return (\n <>\n <Header />\n\n <View role=\"booking\" testId={others.testId} className={styles(style.container, others.className)}>\n <Progress indeterminate visible={!response && !responseError} className={style.progress} />\n {response ? (\n <>\n <View row={isDesktop} className={style.content}>\n <View>\n {state !== STATE.POS_ERROR && (\n <Notification\n error={isCancelled}\n info={state === STATE.COMPLETED}\n small={isMobile}\n success={state === STATE.CONFIRMED}\n warning={state === STATE.POSTPONED}\n wide\n >\n {translate(L10N.NOTIFICATION[state])}\n <Hotelverse {...dataSource} />\n </Notification>\n )}\n\n {payment && !isCancelled && <BookingPayment {...{ dataSource, onError: setResponseError }} />}\n\n <BookingSummary\n box={!isDesktop}\n dataSource={{ ...dataSource, showBasePrice: true }}\n className={styles(isDesktop && style.print)}\n />\n\n <Information dataSource={dataSource} />\n <BookingDetails {...{ dataSource, expanded }} expanded={isMobile} className={style.box} />\n <BookingTerms dataSource={dataSource} small />\n </View>\n\n <View className={style.side}>\n {isDesktop && (\n <BookingSummary box dataSource={{ ...dataSource, showBasePrice: true }} className={style.noPrint} />\n )}\n\n <Menu dataSource={dataSource} onPress={handleMenuPress} />\n </View>\n </View>\n\n <Modal\n {...{ action, dataSource: { ...dataSource, token } }}\n onChange={({ response: { tracking } = {}, state }) =>\n state && setDataSource({ ...dataSource, tracking, state })\n }\n onClose={() => setAction()}\n />\n </>\n ) : responseError ? (\n <Notification error large className={style.error}>\n {translate(L10N.NOTIFICATION_ERROR[responseError.code] || L10N.NOTIFICATION_ERROR[ERROR.GENERIC])}\n <Action paragraph underline wide onPress={handleBackHome}>\n {translate(L10N.ACTION_BACK_HOME)}\n </Action>\n </Notification>\n ) : (\n <Skeleton />\n )}\n </View>\n\n <Footer />\n </>\n );\n};\n\nBooking.displayName = 'Mirai:Core:Booking';\n\nBooking.propTypes = {\n skeleton: PropTypes.bool,\n};\n\nexport { Booking };\n"],"names":["_dataSources","require","_locale","_services","_ui","_propTypes","_interopRequireDefault","_react","_interopRequireWildcard","_Booking","_Booking2","style","_Booking3","_components","_partials","_Booking4","_shared__","_Header","_helpers","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","prototype","hasOwnProperty","call","i","set","obj","Booking","_ref","skeleton","others","isDesktop","isMobile","useDevice","locale","translate","useLocale","value","hotel","url","urlParams","code","token","reservationCode","id","hasToTracking","tracking","useStore","action","setAction","useState","dataSource","setDataSource","expanded","setExpanded","responseError","setResponseError","useEffect","Event","publish","EVENT","METRICS","ServiceBooking","catch","error","event","state","STATE","CANCELLED","BOOKING_CANCEL","BOOKING_RESPONSE","response","handleMenuPress","ACTION","PRINT","setTimeout","window","print","handleBackHome","payload","hotelUrl","location","origin","payment","undefined","isCancelled","createElement","Fragment","Header","View","role","testId","className","styles","container","Progress","indeterminate","visible","progress","row","content","POS_ERROR","Notification","info","COMPLETED","small","success","CONFIRMED","warning","POSTPONED","wide","L10N","NOTIFICATION","Hotelverse","BookingPayment","onError","BookingSummary","box","showBasePrice","Information","BookingDetails","BookingTerms","side","noPrint","Menu","onPress","Modal","onChange","_ref2","onClose","large","NOTIFICATION_ERROR","ERROR","GENERIC","Action","paragraph","underline","ACTION_BACK_HOME","Footer","exports","displayName","propTypes","PropTypes","bool"],"mappings":"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","debug_id":"b1f44c9c-8cd8-5662-b048-9010e9cdd8f7"}
|
|
1
|
+
{"version":3,"file":"Booking.js","sources":["../../../src/components/Booking/Booking.jsx"],"sourcesContent":["import { Event, useStore } from '@mirai/data-sources';\nimport { useLocale } from '@mirai/locale';\nimport { ServiceBooking } from '@mirai/services';\nimport { Action, Notification, Progress, styles, useDevice, View } from '@mirai/ui';\nimport PropTypes from 'prop-types';\nimport React, { useEffect, useState } from 'react';\n\nimport { ACTION, ERROR, STATE } from './Booking.constants';\nimport { L10N } from './Booking.l10n';\nimport * as style from './Booking.module.css';\nimport Skeleton from './Booking.skeleton';\nimport { Hotelverse } from './components';\nimport { Information, Menu, Modal } from './partials';\nimport { BookingPayment } from './partials/Booking.Payment';\nimport { BookingDetails, BookingSummary, BookingTerms, Footer } from '../__shared__';\nimport { Header } from '../Header';\nimport { EVENT } from '../helpers';\n\nconst Booking = ({ skeleton, ...others }) => {\n const { isDesktop, isMobile } = useDevice();\n const { locale, translate } = useLocale();\n const {\n value: { hotel: { url } = {}, urlParams: { code: token, reservationCode: id, hasToTracking: tracking } = {} },\n } = useStore();\n\n const [action, setAction] = useState();\n const [dataSource, setDataSource] = useState();\n const [expanded, setExpanded] = useState(false);\n const [responseError, setResponseError] = useState();\n\n useEffect(() => Event.publish(EVENT.METRICS, { id: 'BOOKING:RENDER' }), []);\n\n useEffect(() => {\n if (skeleton || !id || !token) return;\n\n (async () => {\n setDataSource(\n await ServiceBooking.get({ id, locale, token, tracking, url }).catch((error) => setResponseError(error)),\n );\n setAction();\n })();\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [id, locale]);\n\n useEffect(() => {\n if (!dataSource || !dataSource.tracking) return;\n\n const event = dataSource.state === STATE.CANCELLED ? EVENT.BOOKING_CANCEL : EVENT.BOOKING_RESPONSE;\n Event.publish(event, { event, response: { ...dataSource } });\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [dataSource?.state]);\n\n const handleMenuPress = (action) => {\n if (action === ACTION.PRINT) {\n setExpanded(true);\n setTimeout(window.print, 10);\n } else {\n setAction(action);\n }\n };\n\n const handleBackHome = () => {\n const { payload } = responseError;\n\n window.location.href = payload?.hotelUrl || window.location.origin;\n };\n\n const { payment, state } = dataSource || {};\n const response = dataSource !== undefined;\n const isCancelled = state === STATE.CANCELLED;\n\n return (\n <>\n <Header />\n\n <View role=\"booking\" testId={others.testId} className={styles(style.container, others.className)}>\n <Progress indeterminate visible={!response && !responseError} className={style.progress} />\n {response ? (\n <>\n <View row={isDesktop} className={style.content}>\n <View>\n {state !== STATE.POS_ERROR && (\n <Notification\n error={isCancelled}\n info={state === STATE.COMPLETED}\n small={isMobile}\n success={state === STATE.CONFIRMED}\n warning={state === STATE.POSTPONED}\n wide\n >\n {translate(L10N.NOTIFICATION[state])}\n <Hotelverse {...dataSource} />\n </Notification>\n )}\n\n {payment && !isCancelled && <BookingPayment {...{ dataSource, onError: setResponseError }} />}\n\n <BookingSummary\n box={!isDesktop}\n dataSource={{ ...dataSource, showBasePrice: true }}\n className={styles(isDesktop && style.print)}\n />\n\n <Information dataSource={dataSource} />\n <BookingDetails {...{ dataSource, expanded }} expanded={isMobile} className={style.box} />\n <BookingTerms dataSource={dataSource} small />\n </View>\n\n <View className={style.side}>\n {isDesktop && (\n <BookingSummary box dataSource={{ ...dataSource, showBasePrice: true }} className={style.noPrint} />\n )}\n\n <Menu dataSource={dataSource} onPress={handleMenuPress} />\n </View>\n </View>\n\n <Modal\n {...{ action, dataSource: { ...dataSource, token } }}\n onChange={({ response: { tracking } = {}, state }) =>\n state && setDataSource({ ...dataSource, tracking, state })\n }\n onClose={() => setAction()}\n />\n </>\n ) : responseError ? (\n <Notification error large className={style.error}>\n {translate(L10N.NOTIFICATION_ERROR[responseError.code] || L10N.NOTIFICATION_ERROR[ERROR.GENERIC])}\n <Action paragraph underline wide onPress={handleBackHome}>\n {translate(L10N.ACTION_BACK_HOME)}\n </Action>\n </Notification>\n ) : (\n <Skeleton />\n )}\n </View>\n\n <Footer />\n </>\n );\n};\n\nBooking.displayName = 'Mirai:Core:Booking';\n\nBooking.propTypes = {\n skeleton: PropTypes.bool,\n};\n\nexport { Booking };\n"],"names":["_dataSources","require","_locale","_services","_ui","_propTypes","_interopRequireDefault","_react","_interopRequireWildcard","_Booking","_Booking2","style","_Booking3","_components","_partials","_Booking4","_shared__","_Header","_helpers","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","prototype","hasOwnProperty","call","i","set","obj","Booking","_ref","skeleton","others","isDesktop","isMobile","useDevice","locale","translate","useLocale","value","hotel","url","urlParams","code","token","reservationCode","id","hasToTracking","tracking","useStore","action","setAction","useState","dataSource","setDataSource","expanded","setExpanded","responseError","setResponseError","useEffect","Event","publish","EVENT","METRICS","ServiceBooking","catch","error","event","state","STATE","CANCELLED","BOOKING_CANCEL","BOOKING_RESPONSE","response","handleMenuPress","ACTION","PRINT","setTimeout","window","print","handleBackHome","payload","location","href","hotelUrl","origin","payment","undefined","isCancelled","createElement","Fragment","Header","View","role","testId","className","styles","container","Progress","indeterminate","visible","progress","row","content","POS_ERROR","Notification","info","COMPLETED","small","success","CONFIRMED","warning","POSTPONED","wide","L10N","NOTIFICATION","Hotelverse","BookingPayment","onError","BookingSummary","box","showBasePrice","Information","BookingDetails","BookingTerms","side","noPrint","Menu","onPress","Modal","onChange","_ref2","onClose","large","NOTIFICATION_ERROR","ERROR","GENERIC","Action","paragraph","underline","ACTION_BACK_HOME","Footer","exports","displayName","propTypes","PropTypes","bool"],"mappings":"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","debug_id":"593861ff-dfcb-5742-baa4-0e1dde8ba4f9"}
|
|
@@ -0,0 +1,97 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
!function(){try{var e="undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof self?self:{},n=(new e.Error).stack;n&&(e._sentryDebugIds=e._sentryDebugIds||{},e._sentryDebugIds[n]="dc03230e-8c11-5303-8a75-5e4e32840a54")}catch(e){}}();
|
|
3
|
+
|
|
4
|
+
|
|
5
|
+
Object.defineProperty(exports, "__esModule", {
|
|
6
|
+
value: true
|
|
7
|
+
});
|
|
8
|
+
exports.ButtonAvatar = void 0;
|
|
9
|
+
var _dataSources = require("@mirai/data-sources");
|
|
10
|
+
var _ui = require("@mirai/ui");
|
|
11
|
+
var _propTypes = _interopRequireDefault(require("prop-types"));
|
|
12
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
13
|
+
var style = _interopRequireWildcard(require("./Chat.module.css"));
|
|
14
|
+
var _components = require("./components");
|
|
15
|
+
var _helpers = require("./helpers");
|
|
16
|
+
var _helpers2 = require("../helpers");
|
|
17
|
+
function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function (e) { return e ? t : r; })(e); }
|
|
18
|
+
function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != typeof e && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && Object.prototype.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; }
|
|
19
|
+
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
20
|
+
const DELAY_WELCOME = 10000;
|
|
21
|
+
let focused = false;
|
|
22
|
+
const ButtonAvatar = _ref => {
|
|
23
|
+
let {
|
|
24
|
+
message: {
|
|
25
|
+
response: {
|
|
26
|
+
text
|
|
27
|
+
} = {}
|
|
28
|
+
} = {},
|
|
29
|
+
visible,
|
|
30
|
+
onPress
|
|
31
|
+
} = _ref;
|
|
32
|
+
const [focus, setFocus] = (0, _react.useState)(false);
|
|
33
|
+
const [hide, setHide] = (0, _react.useState)(false);
|
|
34
|
+
(0, _react.useEffect)(() => {
|
|
35
|
+
const callback = _ref2 => {
|
|
36
|
+
let {
|
|
37
|
+
visible: modalVisible
|
|
38
|
+
} = _ref2;
|
|
39
|
+
return setHide(modalVisible);
|
|
40
|
+
};
|
|
41
|
+
_dataSources.Event.subscribe(_helpers2.EVENT.MODAL_VISIBLE, callback);
|
|
42
|
+
return () => _dataSources.Event.unsubscribe(_helpers2.EVENT.MODAL_VISIBLE, callback);
|
|
43
|
+
}, []);
|
|
44
|
+
(0, _react.useEffect)(() => {
|
|
45
|
+
if (!text || focused) return;
|
|
46
|
+
let inactivityTimer;
|
|
47
|
+
const resetTimer = () => {
|
|
48
|
+
console.log('::::::');
|
|
49
|
+
clearTimeout(inactivityTimer);
|
|
50
|
+
if (focused) return;
|
|
51
|
+
inactivityTimer = setTimeout(() => {
|
|
52
|
+
setFocus(true);
|
|
53
|
+
(0, _helpers.audioNotification)();
|
|
54
|
+
clearTimeout(inactivityTimer);
|
|
55
|
+
}, DELAY_WELCOME);
|
|
56
|
+
};
|
|
57
|
+
document.addEventListener('mousemove', resetTimer);
|
|
58
|
+
document.addEventListener('scroll', resetTimer);
|
|
59
|
+
resetTimer();
|
|
60
|
+
return () => {
|
|
61
|
+
clearTimeout(inactivityTimer.current);
|
|
62
|
+
document.removeEventListener('mousemove', resetTimer);
|
|
63
|
+
document.removeEventListener('scroll', resetTimer);
|
|
64
|
+
};
|
|
65
|
+
}, [text]);
|
|
66
|
+
(0, _react.useEffect)(() => {
|
|
67
|
+
if (focus) focused = true;
|
|
68
|
+
}, [focus]);
|
|
69
|
+
return /*#__PURE__*/_react.default.createElement(_ui.View, {
|
|
70
|
+
className: (0, _ui.styles)(style.buttonAvatar, !!text && !visible && !hide && style.visible)
|
|
71
|
+
}, /*#__PURE__*/_react.default.createElement(_ui.View, {
|
|
72
|
+
className: (0, _ui.styles)(style.welcome, focus && !visible && style.visible)
|
|
73
|
+
}, /*#__PURE__*/_react.default.createElement(_ui.Text, {
|
|
74
|
+
action: true,
|
|
75
|
+
medium: true
|
|
76
|
+
}, text)), /*#__PURE__*/_react.default.createElement(_ui.Pressable, {
|
|
77
|
+
onEnter: () => setFocus(true),
|
|
78
|
+
onLeave: () => setFocus(false),
|
|
79
|
+
onPress: onPress
|
|
80
|
+
}, /*#__PURE__*/_react.default.createElement(_components.Avatar, {
|
|
81
|
+
disabled: visible,
|
|
82
|
+
className: style.avatar
|
|
83
|
+
})));
|
|
84
|
+
};
|
|
85
|
+
exports.ButtonAvatar = ButtonAvatar;
|
|
86
|
+
ButtonAvatar.displayName = 'Mirai:Core:Chat.ButtonAvatar';
|
|
87
|
+
ButtonAvatar.propTypes = {
|
|
88
|
+
message: _propTypes.default.shape({
|
|
89
|
+
response: _propTypes.default.shape({
|
|
90
|
+
text: _propTypes.default.string
|
|
91
|
+
})
|
|
92
|
+
}),
|
|
93
|
+
visible: _propTypes.default.bool,
|
|
94
|
+
onPress: _propTypes.default.func
|
|
95
|
+
};
|
|
96
|
+
//# sourceMappingURL=Chat.ButtonAvatar.js.map
|
|
97
|
+
//# debugId=dc03230e-8c11-5303-8a75-5e4e32840a54
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Chat.ButtonAvatar.js","sources":["../../../src/components/Chat/Chat.ButtonAvatar.js"],"sourcesContent":["import { Event } from '@mirai/data-sources';\nimport { Pressable, styles, Text, View } from '@mirai/ui';\nimport PropTypes from 'prop-types';\nimport React, { useEffect, useState } from 'react';\n\nimport * as style from './Chat.module.css';\nimport { Avatar } from './components';\nimport { audioNotification } from './helpers';\nimport { EVENT } from '../helpers';\n\nconst DELAY_WELCOME = 10000;\nlet focused = false;\n\nconst ButtonAvatar = ({ message: { response: { text } = {} } = {}, visible, onPress }) => {\n const [focus, setFocus] = useState(false);\n const [hide, setHide] = useState(false);\n\n useEffect(() => {\n const callback = ({ visible: modalVisible }) => setHide(modalVisible);\n\n Event.subscribe(EVENT.MODAL_VISIBLE, callback);\n return () => Event.unsubscribe(EVENT.MODAL_VISIBLE, callback);\n }, []);\n\n useEffect(() => {\n if (!text || focused) return;\n let inactivityTimer;\n\n const resetTimer = () => {\n console.log('::::::');\n clearTimeout(inactivityTimer);\n if (focused) return;\n inactivityTimer = setTimeout(() => {\n setFocus(true);\n audioNotification();\n clearTimeout(inactivityTimer);\n }, DELAY_WELCOME);\n };\n\n document.addEventListener('mousemove', resetTimer);\n document.addEventListener('scroll', resetTimer);\n\n resetTimer();\n\n return () => {\n clearTimeout(inactivityTimer.current);\n document.removeEventListener('mousemove', resetTimer);\n document.removeEventListener('scroll', resetTimer);\n };\n }, [text]);\n\n useEffect(() => {\n if (focus) focused = true;\n }, [focus]);\n\n return (\n <View className={styles(style.buttonAvatar, !!text && !visible && !hide && style.visible)}>\n <View className={styles(style.welcome, focus && !visible && style.visible)}>\n <Text action medium>\n {text}\n </Text>\n </View>\n\n <Pressable onEnter={() => setFocus(true)} onLeave={() => setFocus(false)} onPress={onPress}>\n <Avatar disabled={visible} className={style.avatar} />\n </Pressable>\n </View>\n );\n};\n\nButtonAvatar.displayName = 'Mirai:Core:Chat.ButtonAvatar';\n\nButtonAvatar.propTypes = {\n message: PropTypes.shape({\n response: PropTypes.shape({\n text: PropTypes.string,\n }),\n }),\n visible: PropTypes.bool,\n onPress: PropTypes.func,\n};\n\nexport { ButtonAvatar };\n"],"names":["_dataSources","require","_ui","_propTypes","_interopRequireDefault","_react","_interopRequireWildcard","style","_components","_helpers","_helpers2","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","prototype","hasOwnProperty","call","i","set","obj","DELAY_WELCOME","focused","ButtonAvatar","_ref","message","response","text","visible","onPress","focus","setFocus","useState","hide","setHide","useEffect","callback","_ref2","modalVisible","Event","subscribe","EVENT","MODAL_VISIBLE","unsubscribe","inactivityTimer","resetTimer","console","log","clearTimeout","setTimeout","audioNotification","document","addEventListener","current","removeEventListener","createElement","View","className","styles","buttonAvatar","welcome","Text","action","medium","Pressable","onEnter","onLeave","Avatar","disabled","avatar","exports","displayName","propTypes","PropTypes","shape","string","bool","func"],"mappings":"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","debug_id":"dc03230e-8c11-5303-8a75-5e4e32840a54"}
|
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
!function(){try{var e="undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof self?self:{},n=(new e.Error).stack;n&&(e._sentryDebugIds=e._sentryDebugIds||{},e._sentryDebugIds[n]="18afe559-c956-5674-b33b-6f07203a29dd")}catch(e){}}();
|
|
3
|
+
|
|
4
|
+
|
|
5
|
+
Object.defineProperty(exports, "__esModule", {
|
|
6
|
+
value: true
|
|
7
|
+
});
|
|
8
|
+
exports.Header = void 0;
|
|
9
|
+
var _locale = require("@mirai/locale");
|
|
10
|
+
var _ui = require("@mirai/ui");
|
|
11
|
+
var _propTypes = _interopRequireDefault(require("prop-types"));
|
|
12
|
+
var _react = _interopRequireDefault(require("react"));
|
|
13
|
+
var _Chat = require("./Chat.l10n");
|
|
14
|
+
var style = _interopRequireWildcard(require("./Chat.module.css"));
|
|
15
|
+
var _components = require("./components");
|
|
16
|
+
var _helpers = require("../helpers");
|
|
17
|
+
function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function (e) { return e ? t : r; })(e); }
|
|
18
|
+
function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != typeof e && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && Object.prototype.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; }
|
|
19
|
+
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
20
|
+
const Header = _ref => {
|
|
21
|
+
let {
|
|
22
|
+
online,
|
|
23
|
+
onClose
|
|
24
|
+
} = _ref;
|
|
25
|
+
const {
|
|
26
|
+
translate
|
|
27
|
+
} = (0, _locale.useLocale)();
|
|
28
|
+
return /*#__PURE__*/_react.default.createElement(_ui.View, {
|
|
29
|
+
row: true,
|
|
30
|
+
className: style.header
|
|
31
|
+
}, /*#__PURE__*/_react.default.createElement(_components.Avatar, {
|
|
32
|
+
small: true
|
|
33
|
+
}), /*#__PURE__*/_react.default.createElement(_ui.View, {
|
|
34
|
+
wide: true
|
|
35
|
+
}, /*#__PURE__*/_react.default.createElement(_ui.Text, {
|
|
36
|
+
bold: true
|
|
37
|
+
}, translate(_Chat.L10N.LABEL_ASSISTANT)), /*#__PURE__*/_react.default.createElement(_ui.View, {
|
|
38
|
+
row: true
|
|
39
|
+
}, /*#__PURE__*/_react.default.createElement(_ui.View, {
|
|
40
|
+
className: (0, _ui.styles)(style.bullet, online ? style.online : style.offline)
|
|
41
|
+
}), /*#__PURE__*/_react.default.createElement(_ui.Text, {
|
|
42
|
+
small: true,
|
|
43
|
+
light: true
|
|
44
|
+
}, translate(online ? _Chat.L10N.LABEL_ONLINE : _Chat.L10N.LABEL_OFFLINE)))), /*#__PURE__*/_react.default.createElement(_ui.View, {
|
|
45
|
+
row: true
|
|
46
|
+
}, /*#__PURE__*/_react.default.createElement(_ui.Button, {
|
|
47
|
+
small: true,
|
|
48
|
+
squared: true,
|
|
49
|
+
tooltip: translate(_Chat.L10N.ACTION_CLOSE),
|
|
50
|
+
transparent: true,
|
|
51
|
+
onPress: onClose
|
|
52
|
+
}, /*#__PURE__*/_react.default.createElement(_ui.Icon, {
|
|
53
|
+
value: _helpers.ICON.CLOSE
|
|
54
|
+
}))));
|
|
55
|
+
};
|
|
56
|
+
exports.Header = Header;
|
|
57
|
+
Header.displayName = 'Mirai:Core:Chat.Header';
|
|
58
|
+
Header.propTypes = {
|
|
59
|
+
online: _propTypes.default.bool,
|
|
60
|
+
onClose: _propTypes.default.func
|
|
61
|
+
};
|
|
62
|
+
//# sourceMappingURL=Chat.Header.js.map
|
|
63
|
+
//# debugId=18afe559-c956-5674-b33b-6f07203a29dd
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Chat.Header.js","sources":["../../../src/components/Chat/Chat.Header.js"],"sourcesContent":["import { useLocale } from '@mirai/locale';\nimport { Button, Icon, styles, Text, View } from '@mirai/ui';\nimport PropTypes from 'prop-types';\nimport React from 'react';\n\nimport { L10N } from './Chat.l10n';\nimport * as style from './Chat.module.css';\nimport { Avatar } from './components';\nimport { ICON } from '../helpers';\n\nconst Header = ({ online, onClose }) => {\n const { translate } = useLocale();\n\n return (\n <View row className={style.header}>\n <Avatar small />\n <View wide>\n <Text bold>{translate(L10N.LABEL_ASSISTANT)}</Text>\n <View row>\n <View className={styles(style.bullet, online ? style.online : style.offline)} />\n <Text small light>\n {translate(online ? L10N.LABEL_ONLINE : L10N.LABEL_OFFLINE)}\n </Text>\n </View>\n </View>\n\n <View row>\n <Button small squared tooltip={translate(L10N.ACTION_CLOSE)} transparent onPress={onClose}>\n <Icon value={ICON.CLOSE} />\n </Button>\n </View>\n </View>\n );\n};\n\nHeader.displayName = 'Mirai:Core:Chat.Header';\n\nHeader.propTypes = {\n online: PropTypes.bool,\n onClose: PropTypes.func,\n};\n\nexport { Header };\n"],"names":["_locale","require","_ui","_propTypes","_interopRequireDefault","_react","_Chat","style","_interopRequireWildcard","_components","_helpers","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","prototype","hasOwnProperty","call","i","set","obj","Header","_ref","online","onClose","translate","useLocale","createElement","View","row","className","header","Avatar","small","wide","Text","bold","L10N","LABEL_ASSISTANT","styles","bullet","offline","light","LABEL_ONLINE","LABEL_OFFLINE","Button","squared","tooltip","ACTION_CLOSE","transparent","onPress","Icon","value","ICON","CLOSE","exports","displayName","propTypes","PropTypes","bool","func"],"mappings":"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","debug_id":"18afe559-c956-5674-b33b-6f07203a29dd"}
|
|
@@ -1,28 +1,25 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
!function(){try{var e="undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof self?self:{},n=(new e.Error).stack;n&&(e._sentryDebugIds=e._sentryDebugIds||{},e._sentryDebugIds[n]="
|
|
2
|
+
!function(){try{var e="undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof self?self:{},n=(new e.Error).stack;n&&(e._sentryDebugIds=e._sentryDebugIds||{},e._sentryDebugIds[n]="b0de7cae-b29e-592a-8191-77f7137bd553")}catch(e){}}();
|
|
3
3
|
|
|
4
4
|
|
|
5
5
|
Object.defineProperty(exports, "__esModule", {
|
|
6
6
|
value: true
|
|
7
7
|
});
|
|
8
|
-
exports.VERBOSE_DATE_FORMAT = exports.NAME = exports.INTENT = exports.EVENT = exports.DELAY_RESPONSE =
|
|
8
|
+
exports.VERBOSE_DATE_FORMAT = exports.NAME = exports.INTENT = exports.EVENT = exports.DELAY_RESPONSE = void 0;
|
|
9
9
|
const DELAY_RESPONSE = exports.DELAY_RESPONSE = 500;
|
|
10
10
|
const EVENT = exports.EVENT = {
|
|
11
11
|
INPUT_COMPONENT: 'EVENT_INPUT_COMPONENT'
|
|
12
12
|
};
|
|
13
13
|
const INTENT = exports.INTENT = {
|
|
14
|
-
BOOK: '
|
|
15
|
-
BOOKING_CANCEL: '
|
|
16
|
-
BOOKING_QUERY: '
|
|
17
|
-
BOOKING_VIEW: '
|
|
18
|
-
BOOKING_SEND: '
|
|
19
|
-
OFFERS: '
|
|
20
|
-
HOTEL_INFO: '
|
|
21
|
-
GREETINGS: '
|
|
22
|
-
FAREWELLS: '
|
|
23
|
-
};
|
|
24
|
-
const ACTION = exports.ACTION = {
|
|
25
|
-
ACTION_LOGIN: 'ACTION_LOGIN'
|
|
14
|
+
BOOK: 'BOOK',
|
|
15
|
+
BOOKING_CANCEL: 'BOOKING_CANCEL',
|
|
16
|
+
BOOKING_QUERY: 'BOOKING_QUERY',
|
|
17
|
+
BOOKING_VIEW: 'BOOKING_VIEW',
|
|
18
|
+
BOOKING_SEND: 'BOOKING_SEND',
|
|
19
|
+
OFFERS: 'OFFERS',
|
|
20
|
+
HOTEL_INFO: 'HOTEL_INFO',
|
|
21
|
+
GREETINGS: 'GREETINGS',
|
|
22
|
+
FAREWELLS: 'FAREWELLS'
|
|
26
23
|
};
|
|
27
24
|
const NAME = exports.NAME = 'Lisa';
|
|
28
25
|
const VERBOSE_DATE_FORMAT = exports.VERBOSE_DATE_FORMAT = {
|
|
@@ -31,4 +28,4 @@ const VERBOSE_DATE_FORMAT = exports.VERBOSE_DATE_FORMAT = {
|
|
|
31
28
|
day: 'numeric'
|
|
32
29
|
};
|
|
33
30
|
//# sourceMappingURL=Chat.constants.js.map
|
|
34
|
-
//# debugId=
|
|
31
|
+
//# debugId=b0de7cae-b29e-592a-8191-77f7137bd553
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Chat.constants.js","sources":["../../../src/components/Chat/Chat.constants.js"],"sourcesContent":["const DELAY_RESPONSE = 500;\n\nconst EVENT = {\n INPUT_COMPONENT: 'EVENT_INPUT_COMPONENT',\n};\n\nconst INTENT = {\n BOOK: '
|
|
1
|
+
{"version":3,"file":"Chat.constants.js","sources":["../../../src/components/Chat/Chat.constants.js"],"sourcesContent":["const DELAY_RESPONSE = 500;\n\nconst EVENT = {\n INPUT_COMPONENT: 'EVENT_INPUT_COMPONENT',\n};\n\nconst INTENT = {\n BOOK: 'BOOK',\n BOOKING_CANCEL: 'BOOKING_CANCEL',\n BOOKING_QUERY: 'BOOKING_QUERY',\n BOOKING_VIEW: 'BOOKING_VIEW',\n BOOKING_SEND: 'BOOKING_SEND',\n OFFERS: 'OFFERS',\n HOTEL_INFO: 'HOTEL_INFO',\n GREETINGS: 'GREETINGS',\n FAREWELLS: 'FAREWELLS',\n};\n\nconst NAME = 'Lisa';\n\nconst VERBOSE_DATE_FORMAT = { weekday: 'short', month: 'short', day: 'numeric' };\n\nexport { DELAY_RESPONSE, EVENT, INTENT, NAME, VERBOSE_DATE_FORMAT };\n"],"names":["DELAY_RESPONSE","exports","EVENT","INPUT_COMPONENT","INTENT","BOOK","BOOKING_CANCEL","BOOKING_QUERY","BOOKING_VIEW","BOOKING_SEND","OFFERS","HOTEL_INFO","GREETINGS","FAREWELLS","NAME","VERBOSE_DATE_FORMAT","weekday","month","day"],"mappings":";;;;;;;;AAAA,MAAMA,cAAc,GAAAC,OAAA,CAAAD,cAAA,GAAG,GAAG;AAE1B,MAAME,KAAK,GAAAD,OAAA,CAAAC,KAAA,GAAG;EACZC,eAAe,EAAE;AACnB,CAAC;AAED,MAAMC,MAAM,GAAAH,OAAA,CAAAG,MAAA,GAAG;EACbC,IAAI,EAAE,MAAM;EACZC,cAAc,EAAE,gBAAgB;EAChCC,aAAa,EAAE,eAAe;EAC9BC,YAAY,EAAE,cAAc;EAC5BC,YAAY,EAAE,cAAc;EAC5BC,MAAM,EAAE,QAAQ;EAChBC,UAAU,EAAE,YAAY;EACxBC,SAAS,EAAE,WAAW;EACtBC,SAAS,EAAE;AACb,CAAC;AAED,MAAMC,IAAI,GAAAb,OAAA,CAAAa,IAAA,GAAG,MAAM;AAEnB,MAAMC,mBAAmB,GAAAd,OAAA,CAAAc,mBAAA,GAAG;EAAEC,OAAO,EAAE,OAAO;EAAEC,KAAK,EAAE,OAAO;EAAEC,GAAG,EAAE;AAAU,CAAC","debug_id":"b0de7cae-b29e-592a-8191-77f7137bd553"}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
!function(){try{var e="undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof self?self:{},n=(new e.Error).stack;n&&(e._sentryDebugIds=e._sentryDebugIds||{},e._sentryDebugIds[n]="
|
|
2
|
+
!function(){try{var e="undefined"!=typeof window?window:"undefined"!=typeof global?global:"undefined"!=typeof self?self:{},n=(new e.Error).stack;n&&(e._sentryDebugIds=e._sentryDebugIds||{},e._sentryDebugIds[n]="969720d8-c6bf-57eb-b3b3-144a88815a6a")}catch(e){}}();
|
|
3
3
|
|
|
4
4
|
|
|
5
5
|
Object.defineProperty(exports, "__esModule", {
|
|
@@ -7,38 +7,35 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
7
7
|
});
|
|
8
8
|
exports.Chat = void 0;
|
|
9
9
|
var _dataSources = require("@mirai/data-sources");
|
|
10
|
-
var _locale = require("@mirai/locale");
|
|
11
10
|
var _services = require("@mirai/services");
|
|
12
11
|
var _ui = require("@mirai/ui");
|
|
13
12
|
var _propTypes = _interopRequireDefault(require("prop-types"));
|
|
14
13
|
var _react = _interopRequireWildcard(require("react"));
|
|
15
|
-
var _Chat = require("./Chat.
|
|
16
|
-
var _Chat2 = require("./Chat.
|
|
14
|
+
var _Chat = require("./Chat.ButtonAvatar");
|
|
15
|
+
var _Chat2 = require("./Chat.constants");
|
|
16
|
+
var _Chat3 = require("./Chat.Header");
|
|
17
17
|
var style = _interopRequireWildcard(require("./Chat.module.css"));
|
|
18
18
|
var _components = require("./components");
|
|
19
|
-
var _helpers = require("
|
|
19
|
+
var _helpers = require("./helpers");
|
|
20
|
+
var _helpers2 = require("../helpers");
|
|
20
21
|
function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function (e) { return e ? t : r; })(e); }
|
|
21
22
|
function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != typeof e && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && Object.prototype.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; }
|
|
22
23
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
23
24
|
function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
|
|
24
|
-
let
|
|
25
|
+
let connectionInterval;
|
|
25
26
|
const Chat = _ref => {
|
|
26
27
|
let {
|
|
27
28
|
skeleton,
|
|
28
|
-
name = _Chat.NAME,
|
|
29
29
|
...others
|
|
30
30
|
} = _ref;
|
|
31
31
|
const {
|
|
32
|
-
mobile,
|
|
33
32
|
isMobile
|
|
34
33
|
} = (0, _ui.useDevice)();
|
|
35
|
-
const {
|
|
36
|
-
translate
|
|
37
|
-
} = (0, _locale.useLocale)();
|
|
38
34
|
const {
|
|
39
35
|
set,
|
|
40
36
|
value: {
|
|
41
37
|
calendar,
|
|
38
|
+
components,
|
|
42
39
|
currency,
|
|
43
40
|
hotel,
|
|
44
41
|
locale,
|
|
@@ -50,47 +47,33 @@ const Chat = _ref => {
|
|
|
50
47
|
}
|
|
51
48
|
} = (0, _dataSources.useStore)();
|
|
52
49
|
const [busy, setBusy] = (0, _react.useState)(false);
|
|
53
|
-
const [hide, setHide] = (0, _react.useState)(false);
|
|
54
50
|
const [messages, setMessages] = (0, _react.useState)([]);
|
|
55
51
|
const [online, setOnline] = (0, _react.useState)(false);
|
|
56
52
|
const [scrollTo, setScrollTo] = (0, _react.useState)();
|
|
57
53
|
const [visible, setVisible] = (0, _react.useState)(false);
|
|
58
|
-
(0, _react.useEffect)(() => {
|
|
59
|
-
const callback = _ref2 => {
|
|
60
|
-
let {
|
|
61
|
-
visible: modalVisible
|
|
62
|
-
} = _ref2;
|
|
63
|
-
return setHide(modalVisible);
|
|
64
|
-
};
|
|
65
|
-
_dataSources.Event.subscribe(_helpers.EVENT.MODAL_VISIBLE, callback);
|
|
66
|
-
return () => _dataSources.Event.unsubscribe(_helpers.EVENT.MODAL_VISIBLE, callback);
|
|
67
|
-
}, []);
|
|
68
54
|
(0, _react.useEffect)(() => {
|
|
69
55
|
if (skeleton) return;
|
|
70
56
|
(async () => {
|
|
71
|
-
|
|
57
|
+
if (!(await handleOnline())) return;
|
|
72
58
|
const response = await _services.ServiceLisa.welcome({
|
|
73
59
|
locale,
|
|
74
60
|
session
|
|
75
61
|
}).catch(handleError);
|
|
76
62
|
if (response) addMessage(response, messages);
|
|
77
|
-
setBusy(false);
|
|
78
63
|
})();
|
|
79
64
|
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
80
65
|
}, [skeleton]);
|
|
81
66
|
(0, _react.useEffect)(() => {
|
|
82
|
-
if (
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
return () =>
|
|
90
|
-
|
|
91
|
-
};
|
|
67
|
+
if (visible) setScrollTo(new Date().getTime());
|
|
68
|
+
}, [busy, messages, visible]);
|
|
69
|
+
(0, _react.useEffect)(() => {
|
|
70
|
+
// // ! TODO: It's just a demo
|
|
71
|
+
// if (visible && !messages.length) handleInput('Quiero ver la proxima reserva que tengo.');
|
|
72
|
+
if (!visible) return clearInterval(connectionInterval);
|
|
73
|
+
connectionInterval = setInterval(handleOnline, online ? 60000 : 10000);
|
|
74
|
+
return () => clearInterval(connectionInterval);
|
|
75
|
+
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
92
76
|
}, [online, visible]);
|
|
93
|
-
(0, _react.useEffect)(() => visible && setScrollTo(new Date().getTime()), [busy, messages, visible]);
|
|
94
77
|
const storeContext = {
|
|
95
78
|
calendar,
|
|
96
79
|
currency,
|
|
@@ -100,9 +83,15 @@ const Chat = _ref => {
|
|
|
100
83
|
tags,
|
|
101
84
|
type
|
|
102
85
|
};
|
|
103
|
-
const
|
|
104
|
-
|
|
105
|
-
|
|
86
|
+
const handleOnline = async () => {
|
|
87
|
+
if (!(components.finder || components.rates)) return;
|
|
88
|
+
let next = false;
|
|
89
|
+
const response = await _services.ServiceLisa.status().catch(() => setOnline(next));
|
|
90
|
+
if (response && !online) {
|
|
91
|
+
next = true;
|
|
92
|
+
setOnline(next);
|
|
93
|
+
}
|
|
94
|
+
return next;
|
|
106
95
|
};
|
|
107
96
|
const handleInput = input => {
|
|
108
97
|
const nextMessages = [...messages, {
|
|
@@ -117,11 +106,14 @@ const Chat = _ref => {
|
|
|
117
106
|
...storeContext
|
|
118
107
|
},
|
|
119
108
|
input,
|
|
120
|
-
|
|
109
|
+
session
|
|
121
110
|
}).catch(handleError);
|
|
122
|
-
if (response)
|
|
111
|
+
if (response) {
|
|
112
|
+
addMessage(response, nextMessages);
|
|
113
|
+
(0, _helpers.audioNotification)();
|
|
114
|
+
}
|
|
123
115
|
setBusy(false);
|
|
124
|
-
},
|
|
116
|
+
}, _Chat2.DELAY_RESPONSE);
|
|
125
117
|
};
|
|
126
118
|
const handleAction = function () {
|
|
127
119
|
let {
|
|
@@ -129,7 +121,7 @@ const Chat = _ref => {
|
|
|
129
121
|
form,
|
|
130
122
|
intent
|
|
131
123
|
} = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
|
|
132
|
-
if (intent ===
|
|
124
|
+
if (intent === 'ACTION_LOGIN') return _dataSources.Event.publish(_helpers2.EVENT.LOGIN, {
|
|
133
125
|
visible: true
|
|
134
126
|
});
|
|
135
127
|
setBusy(true);
|
|
@@ -142,7 +134,7 @@ const Chat = _ref => {
|
|
|
142
134
|
},
|
|
143
135
|
intent,
|
|
144
136
|
locale,
|
|
145
|
-
|
|
137
|
+
session
|
|
146
138
|
}).catch(handleError);
|
|
147
139
|
if (response) {
|
|
148
140
|
set({
|
|
@@ -152,9 +144,10 @@ const Chat = _ref => {
|
|
|
152
144
|
auto: true,
|
|
153
145
|
...response
|
|
154
146
|
}]);
|
|
147
|
+
(0, _helpers.audioNotification)();
|
|
155
148
|
}
|
|
156
149
|
setBusy(false);
|
|
157
|
-
},
|
|
150
|
+
}, _Chat2.DELAY_RESPONSE);
|
|
158
151
|
};
|
|
159
152
|
const handleError = error => {
|
|
160
153
|
// eslint-disable-next-line no-console
|
|
@@ -171,7 +164,7 @@ const Chat = _ref => {
|
|
|
171
164
|
auto: true,
|
|
172
165
|
...response
|
|
173
166
|
}]);
|
|
174
|
-
if (response.locale !== locale) _dataSources.Event.publish(
|
|
167
|
+
if (response.locale !== locale) _dataSources.Event.publish(_helpers2.EVENT.INTENT_LOCALE, {
|
|
175
168
|
locale: response.locale
|
|
176
169
|
});
|
|
177
170
|
};
|
|
@@ -181,35 +174,12 @@ const Chat = _ref => {
|
|
|
181
174
|
className: (0, _ui.styles)(style.container, others.className)
|
|
182
175
|
} : {
|
|
183
176
|
...others,
|
|
184
|
-
className: (0, _ui.styles)(style.container, visible &&
|
|
177
|
+
className: (0, _ui.styles)(style.container, visible && style.visible, others.className),
|
|
185
178
|
'aria-hidden': visible ? 'false' : 'true'
|
|
186
|
-
}, /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement(
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
}, /*#__PURE__*/_react.default.createElement(
|
|
190
|
-
small: true
|
|
191
|
-
}), /*#__PURE__*/_react.default.createElement(_ui.View, {
|
|
192
|
-
wide: true
|
|
193
|
-
}, /*#__PURE__*/_react.default.createElement(_ui.Text, {
|
|
194
|
-
bold: true
|
|
195
|
-
}, translate(_Chat2.L10N.LABEL_ASSISTANT)), /*#__PURE__*/_react.default.createElement(_ui.View, {
|
|
196
|
-
row: true
|
|
197
|
-
}, /*#__PURE__*/_react.default.createElement(_ui.View, {
|
|
198
|
-
className: (0, _ui.styles)(style.bullet, online ? style.online : style.offline)
|
|
199
|
-
}), /*#__PURE__*/_react.default.createElement(_ui.Text, {
|
|
200
|
-
small: true,
|
|
201
|
-
light: true
|
|
202
|
-
}, translate(online ? _Chat2.L10N.LABEL_ONLINE : _Chat2.L10N.LABEL_OFFLINE)))), /*#__PURE__*/_react.default.createElement(_ui.View, {
|
|
203
|
-
row: true
|
|
204
|
-
}, /*#__PURE__*/_react.default.createElement(_ui.Button, {
|
|
205
|
-
small: true,
|
|
206
|
-
squared: true,
|
|
207
|
-
tooltip: translate(_Chat2.L10N.ACTION_CLOSE),
|
|
208
|
-
transparent: true,
|
|
209
|
-
onPress: () => setVisible(false)
|
|
210
|
-
}, /*#__PURE__*/_react.default.createElement(_ui.Icon, {
|
|
211
|
-
value: _helpers.ICON.CLOSE
|
|
212
|
-
})))), /*#__PURE__*/_react.default.createElement(_ui.ScrollView, {
|
|
179
|
+
}, /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement(_Chat3.Header, {
|
|
180
|
+
online,
|
|
181
|
+
onClose: () => setVisible(false)
|
|
182
|
+
}), /*#__PURE__*/_react.default.createElement(_ui.ScrollView, {
|
|
213
183
|
scrollTo: scrollTo,
|
|
214
184
|
snap: false,
|
|
215
185
|
className: style.messages
|
|
@@ -220,24 +190,16 @@ const Chat = _ref => {
|
|
|
220
190
|
}))), busy && /*#__PURE__*/_react.default.createElement(_components.Message, {
|
|
221
191
|
auto: true,
|
|
222
192
|
busy: true
|
|
223
|
-
})), online
|
|
193
|
+
})), online && /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement(_components.Input, {
|
|
224
194
|
disabled: busy,
|
|
225
195
|
onValue: handleInput
|
|
226
196
|
}), /*#__PURE__*/_react.default.createElement(_components.InputRich, {
|
|
227
197
|
onValue: handleAction
|
|
228
|
-
}))
|
|
229
|
-
|
|
230
|
-
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
}, /*#__PURE__*/_react.default.createElement(_ui.Pressable, {
|
|
234
|
-
disabled: busy,
|
|
235
|
-
onPress: () => setVisible(true),
|
|
236
|
-
className: (0, _ui.styles)(style.buttonExtend, (hide || visible) && style.hide)
|
|
237
|
-
}, /*#__PURE__*/_react.default.createElement(_components.Avatar, {
|
|
238
|
-
disabled: visible,
|
|
239
|
-
className: style.avatar
|
|
240
|
-
})))) : null;
|
|
198
|
+
})))), /*#__PURE__*/_react.default.createElement(_Chat.ButtonAvatar, {
|
|
199
|
+
message: messages[0],
|
|
200
|
+
visible: visible,
|
|
201
|
+
onPress: () => setVisible(true)
|
|
202
|
+
})) : null;
|
|
241
203
|
};
|
|
242
204
|
exports.Chat = Chat;
|
|
243
205
|
Chat.displayName = 'Mirai:Core:Chat';
|
|
@@ -246,4 +208,4 @@ Chat.propTypes = {
|
|
|
246
208
|
skeleton: _propTypes.default.bool
|
|
247
209
|
};
|
|
248
210
|
//# sourceMappingURL=Chat.js.map
|
|
249
|
-
//# debugId=
|
|
211
|
+
//# debugId=969720d8-c6bf-57eb-b3b3-144a88815a6a
|