@mirai/core 0.3.175 → 0.3.176

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (189) hide show
  1. package/.env +7 -4
  2. package/build/components/Booking/Booking.js +1 -1
  3. package/build/components/Booking/Booking.js.map +1 -1
  4. package/build/components/Booking/Booking.l10n.js +0 -15
  5. package/build/components/Booking/Booking.l10n.js.map +1 -1
  6. package/build/components/Booking/Booking.module.css +0 -9
  7. package/build/components/Booking/components/Hotelverse/Hotelverse.js +1 -1
  8. package/build/components/Booking/components/Hotelverse/Hotelverse.js.map +1 -1
  9. package/build/components/Booking/partials/index.js +2 -13
  10. package/build/components/Booking/partials/index.js.map +1 -1
  11. package/build/components/Chat/Chat.constants.js +28 -0
  12. package/build/components/Chat/Chat.constants.js.map +1 -0
  13. package/build/components/Chat/Chat.js +231 -0
  14. package/build/components/Chat/Chat.js.map +1 -0
  15. package/build/components/Chat/Chat.l10n.js +24 -0
  16. package/build/components/Chat/Chat.l10n.js.map +1 -0
  17. package/build/components/Chat/Chat.module.css +90 -0
  18. package/build/components/Chat/Chat.theme.module.css +49 -0
  19. package/build/components/Chat/components/Avatar/Avatar.js +68 -0
  20. package/build/components/Chat/components/Avatar/Avatar.js.map +1 -0
  21. package/build/components/Chat/components/Avatar/Avatar.module.css +81 -0
  22. package/build/components/Chat/components/Avatar/__tests__/__snapshots__/Avatar.test.jsx.snap +97 -0
  23. package/build/components/Chat/components/Avatar/index.js +17 -0
  24. package/build/components/Chat/components/Avatar/index.js.map +1 -0
  25. package/build/components/Chat/components/Input/Input.js +72 -0
  26. package/build/components/Chat/components/Input/Input.js.map +1 -0
  27. package/build/components/Chat/components/Input/Input.l10n.js +15 -0
  28. package/build/components/Chat/components/Input/Input.l10n.js.map +1 -0
  29. package/build/components/Chat/components/Input/Input.module.css +19 -0
  30. package/build/components/Chat/components/Input/__tests__/__snapshots__/Input.test.jsx.snap +175 -0
  31. package/build/components/Chat/components/Input/index.js +17 -0
  32. package/build/components/Chat/components/Input/index.js.map +1 -0
  33. package/build/components/Chat/components/InputRich/InputRich.List.js +52 -0
  34. package/build/components/Chat/components/InputRich/InputRich.List.js.map +1 -0
  35. package/build/components/Chat/components/InputRich/InputRich.js +182 -0
  36. package/build/components/Chat/components/InputRich/InputRich.js.map +1 -0
  37. package/build/components/Chat/components/InputRich/InputRich.l10n.js +12 -0
  38. package/build/components/Chat/components/InputRich/InputRich.l10n.js.map +1 -0
  39. package/build/components/Chat/components/InputRich/InputRich.module.css +73 -0
  40. package/build/components/Chat/components/InputRich/__tests__/__snapshots__/InputRich.test.jsx.snap +275 -0
  41. package/build/components/Chat/components/InputRich/helpers/getVerboseList.js +20 -0
  42. package/build/components/Chat/components/InputRich/helpers/getVerboseList.js.map +1 -0
  43. package/build/components/Chat/components/InputRich/helpers/getVerboseOccupation.js +27 -0
  44. package/build/components/Chat/components/InputRich/helpers/getVerboseOccupation.js.map +1 -0
  45. package/build/components/Chat/components/InputRich/helpers/index.js +28 -0
  46. package/build/components/Chat/components/InputRich/helpers/index.js.map +1 -0
  47. package/build/components/Chat/components/InputRich/index.js +17 -0
  48. package/build/components/Chat/components/InputRich/index.js.map +1 -0
  49. package/build/components/Chat/components/Message/Message.constants.js +18 -0
  50. package/build/components/Chat/components/Message/Message.constants.js.map +1 -0
  51. package/build/components/Chat/components/Message/Message.js +104 -0
  52. package/build/components/Chat/components/Message/Message.js.map +1 -0
  53. package/build/components/Chat/components/Message/Message.module.css +126 -0
  54. package/build/components/Chat/components/Message/__tests__/__snapshots__/Message.test.jsx.snap +211 -0
  55. package/build/components/Chat/components/Message/components/Booking.js +63 -0
  56. package/build/components/Chat/components/Message/components/Booking.js.map +1 -0
  57. package/build/components/Chat/components/Message/components/Card.js +67 -0
  58. package/build/components/Chat/components/Message/components/Card.js.map +1 -0
  59. package/build/components/Chat/components/Message/components/Card.module.css +41 -0
  60. package/build/components/Chat/components/Message/components/Environment.js +58 -0
  61. package/build/components/Chat/components/Message/components/Environment.js.map +1 -0
  62. package/build/components/Chat/components/Message/components/Environment.module.css +22 -0
  63. package/build/components/Chat/components/Message/components/index.js +39 -0
  64. package/build/components/Chat/components/Message/components/index.js.map +1 -0
  65. package/build/components/Chat/components/Message/helpers/getActionIcon.js +13 -0
  66. package/build/components/Chat/components/Message/helpers/getActionIcon.js.map +1 -0
  67. package/build/components/Chat/components/Message/helpers/getTime.js +28 -0
  68. package/build/components/Chat/components/Message/helpers/getTime.js.map +1 -0
  69. package/build/components/Chat/components/Message/helpers/index.js +28 -0
  70. package/build/components/Chat/components/Message/helpers/index.js.map +1 -0
  71. package/build/components/Chat/components/Message/index.js +17 -0
  72. package/build/components/Chat/components/Message/index.js.map +1 -0
  73. package/build/components/Chat/components/Message/intents/BookingQuery.js +66 -0
  74. package/build/components/Chat/components/Message/intents/BookingQuery.js.map +1 -0
  75. package/build/components/Chat/components/Message/intents/HotelInfo.js +73 -0
  76. package/build/components/Chat/components/Message/intents/HotelInfo.js.map +1 -0
  77. package/build/components/Chat/components/Message/intents/Offers.js +57 -0
  78. package/build/components/Chat/components/Message/intents/Offers.js.map +1 -0
  79. package/build/components/Chat/components/Message/intents/Unknown.js +67 -0
  80. package/build/components/Chat/components/Message/intents/Unknown.js.map +1 -0
  81. package/build/components/Chat/components/Message/intents/index.js +50 -0
  82. package/build/components/Chat/components/Message/intents/index.js.map +1 -0
  83. package/build/components/Chat/components/Offline/Offline.js +22 -0
  84. package/build/components/Chat/components/Offline/Offline.js.map +1 -0
  85. package/build/components/Chat/components/Offline/Offline.module.css +3 -0
  86. package/build/components/Chat/components/Offline/index.js +17 -0
  87. package/build/components/Chat/components/Offline/index.js.map +1 -0
  88. package/build/components/Chat/components/index.js +61 -0
  89. package/build/components/Chat/components/index.js.map +1 -0
  90. package/build/components/Chat/helpers/getVerboseDate.js +18 -0
  91. package/build/components/Chat/helpers/getVerboseDate.js.map +1 -0
  92. package/build/components/Chat/helpers/index.js +17 -0
  93. package/build/components/Chat/helpers/index.js.map +1 -0
  94. package/build/components/Chat/index.js +17 -0
  95. package/build/components/Chat/index.js.map +1 -0
  96. package/build/components/Checkout/Checkout.js +20 -5
  97. package/build/components/Checkout/Checkout.js.map +1 -1
  98. package/build/components/Checkout/Checkout.module.css +14 -0
  99. package/build/components/Checkout/helpers/getFieldProps.js +3 -1
  100. package/build/components/Checkout/helpers/getFieldProps.js.map +1 -1
  101. package/build/components/Checkout/partials/Checkout.Confirmation.js +11 -7
  102. package/build/components/Checkout/partials/Checkout.Confirmation.js.map +1 -1
  103. package/build/components/Checkout/partials/Checkout.Form.js +23 -4
  104. package/build/components/Checkout/partials/Checkout.Form.js.map +1 -1
  105. package/build/components/Checkout/partials/__tests__/__snapshots__/Checkout.Form.test.js.snap +932 -16
  106. package/build/components/Profile/components/Settings/Settings.Account.js +26 -8
  107. package/build/components/Profile/components/Settings/Settings.Account.js.map +1 -1
  108. package/build/components/Profile/components/Settings/Settings.module.css +4 -0
  109. package/build/components/Rates/Rates.constants.js +1 -0
  110. package/build/components/Rates/Rates.constants.js.map +1 -1
  111. package/build/components/Rates/Rates.js +2 -0
  112. package/build/components/Rates/Rates.js.map +1 -1
  113. package/build/components/Rates/components/Hotelverse/Hotelverse.js +1 -1
  114. package/build/components/Rates/components/Hotelverse/Hotelverse.js.map +1 -1
  115. package/build/components/Rates/components/Item/components/Features/Features.js +27 -2
  116. package/build/components/Rates/components/Item/components/Features/Features.js.map +1 -1
  117. package/build/components/Rates/components/Item/components/ModalInfo/ModalInfo.js +5 -1
  118. package/build/components/Rates/components/Item/components/ModalInfo/ModalInfo.js.map +1 -1
  119. package/build/components/Rates/components/Item/components/ModalRateInfo/ModalRateInfo.js +1 -1
  120. package/build/components/Rates/components/Item/components/ModalRateInfo/ModalRateInfo.js.map +1 -1
  121. package/build/components/Signup/Signup.js +24 -6
  122. package/build/components/Signup/Signup.js.map +1 -1
  123. package/build/components/Signup/Signup.module.css +4 -0
  124. package/build/components/Signup/__tests__/__snapshots__/Signup.test.js.snap +24 -9
  125. package/build/components/{Booking/partials/Booking.Others.js → __shared__/BookingTerms/BookingTerms.js} +17 -18
  126. package/build/components/__shared__/BookingTerms/BookingTerms.js.map +1 -0
  127. package/build/components/__shared__/BookingTerms/BookingTerms.l10n.js +27 -0
  128. package/build/components/__shared__/BookingTerms/BookingTerms.l10n.js.map +1 -0
  129. package/build/components/__shared__/BookingTerms/BookingTerms.module.css +42 -0
  130. package/build/components/{Booking/partials/__tests__/__snapshots__/Booking.Others.test.js.snap → __shared__/BookingTerms/__tests__/__snapshots__/BookingTerms.test.js.snap} +4 -8
  131. package/build/components/__shared__/BookingTerms/index.js +17 -0
  132. package/build/components/__shared__/BookingTerms/index.js.map +1 -0
  133. package/build/components/__shared__/NotificationRequiredFields/NotificationRequiredFields.js +52 -0
  134. package/build/components/__shared__/NotificationRequiredFields/NotificationRequiredFields.js.map +1 -0
  135. package/build/components/__shared__/NotificationRequiredFields/NotificationRequiredFields.l10n.js +62 -0
  136. package/build/components/__shared__/NotificationRequiredFields/NotificationRequiredFields.l10n.js.map +1 -0
  137. package/build/components/__shared__/NotificationRequiredFields/NotificationRequiredFields.module.css +8 -0
  138. package/build/components/__shared__/NotificationRequiredFields/index.js +17 -0
  139. package/build/components/__shared__/NotificationRequiredFields/index.js.map +1 -0
  140. package/build/components/__shared__/Payment/Payment.js +1 -1
  141. package/build/components/__shared__/Payment/Payment.js.map +1 -1
  142. package/build/components/__shared__/Payment/__tests__/__snapshots__/Payment.test.js.snap +302 -8
  143. package/build/components/__shared__/Payment/components/Card/Card.js +4 -0
  144. package/build/components/__shared__/Payment/components/Card/Card.js.map +1 -1
  145. package/build/components/__shared__/Payment/components/Card/__tests__/__snapshots__/Card.test.js.snap +23 -0
  146. package/build/components/__shared__/Payment/components/Card/helpers/formatValues.js +2 -0
  147. package/build/components/__shared__/Payment/components/Card/helpers/formatValues.js.map +1 -1
  148. package/build/components/__shared__/Payment/components/PCI/PCI.constants.js +1 -2
  149. package/build/components/__shared__/Payment/components/PCI/PCI.constants.js.map +1 -1
  150. package/build/components/__shared__/Payment/components/PCI/PCI.js +59 -56
  151. package/build/components/__shared__/Payment/components/PCI/PCI.js.map +1 -1
  152. package/build/components/__shared__/Payment/components/PCI/__tests__/__snapshots__/PCI.test.js.snap +15 -0
  153. package/build/components/__shared__/Payment/components/PCI/helpers/formatValues.js +2 -0
  154. package/build/components/__shared__/Payment/components/PCI/helpers/formatValues.js.map +1 -1
  155. package/build/components/__shared__/Payment/helpers/formatExpire.js +15 -0
  156. package/build/components/__shared__/Payment/helpers/formatExpire.js.map +1 -0
  157. package/build/components/__shared__/Payment/helpers/index.js +11 -0
  158. package/build/components/__shared__/Payment/helpers/index.js.map +1 -1
  159. package/build/components/__shared__/index.js +22 -0
  160. package/build/components/__shared__/index.js.map +1 -1
  161. package/build/components/helpers/ICON.js +13 -0
  162. package/build/components/helpers/ICON.js.map +1 -1
  163. package/build/components/index.js +2 -0
  164. package/build/components/index.js.map +1 -1
  165. package/build/services/Lisa/action.js +28 -0
  166. package/build/services/Lisa/action.js.map +1 -0
  167. package/build/services/Lisa/index.js +17 -0
  168. package/build/services/Lisa/index.js.map +1 -0
  169. package/build/services/Lisa/message.js +26 -0
  170. package/build/services/Lisa/message.js.map +1 -0
  171. package/build/services/Lisa/status.js +13 -0
  172. package/build/services/Lisa/status.js.map +1 -0
  173. package/build/services/Lisa/welcome.js +25 -0
  174. package/build/services/Lisa/welcome.js.map +1 -0
  175. package/build/services/Rates/__tests__/__mocks__/rates-response-cancel-types.json +21 -0
  176. package/build/services/Rates/__tests__/__mocks__/rates-response-no-taxes-no-local.json +6 -0
  177. package/build/services/Rates/__tests__/__mocks__/rates-response-no-taxes.json +4 -0
  178. package/build/services/Rates/__tests__/__mocks__/rates-response.json +6 -0
  179. package/build/services/Rates/extras.js +1 -1
  180. package/build/services/Rates/extras.js.map +1 -1
  181. package/build/services/Rates/helpers/getItems.js +1 -1
  182. package/build/services/Rates/helpers/getItems.js.map +1 -1
  183. package/build/services/Rates/helpers/parseBoards.js +1 -0
  184. package/build/services/Rates/helpers/parseBoards.js.map +1 -1
  185. package/build/services/index.js +11 -0
  186. package/build/services/index.js.map +1 -1
  187. package/package.json +1 -1
  188. package/public/App.Container.jsx +2 -0
  189. package/build/components/Booking/partials/Booking.Others.js.map +0 -1
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Chat.js","names":["_dataSources","require","_locale","_ui","_propTypes","_interopRequireDefault","_react","_interopRequireWildcard","_Chat","_Chat2","style","_components","_services","_helpers","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","prototype","hasOwnProperty","call","i","set","obj","_extends","assign","bind","target","arguments","length","source","key","apply","onlineInterval","Chat","_ref","skeleton","name","NAME","isMobile","useDevice","translate","useLocale","value","calendar","currency","hotel","locale","occupation","origin","session","tags","type","useStore","busy","setBusy","useState","messages","setMessages","online","setOnline","scrollTo","setScrollTo","visible","setVisible","useEffect","response","ServiceLisa","welcome","catch","handleError","lisa","auto","clearInterval","callback","status","setInterval","Date","getTime","storeContext","handleInput","input","nextMessages","text","timestamp","setTimeout","message","context","DELAY_RESPONSE","handleAction","form","intent","undefined","action","error","console","createElement","Fragment","React","Modal","View","className","container","styles","row","header","Avatar","small","wide","Text","bold","L10N","LABEL_ASSISTANT","tiny","bullet","offline","lighten","LABEL_ONLINE","LABEL_OFFLINE","Button","squared","tooltip","ACTION_CLOSE","transparent","onPress","Icon","ICON","CLOSE","ScrollView","snap","map","index","Message","disabled","onAction","Input","onValue","InputRich","Offline","Tooltip","right","LABEL_GREETINGS","Pressable","buttonExtend","hide","avatar","exports","displayName","propTypes","PropTypes","string","bool"],"sources":["../../../src/components/Chat/Chat.jsx"],"sourcesContent":["import { useStore } from '@mirai/data-sources';\nimport { useLocale } from '@mirai/locale';\nimport { Button, Icon, Modal, Pressable, ScrollView, styles, Text, Tooltip, useDevice, View } from '@mirai/ui';\nimport PropTypes from 'prop-types';\nimport React, { useEffect, useState } from 'react';\n\nimport { DELAY_RESPONSE, NAME } from './Chat.constants';\nimport { L10N } from './Chat.l10n';\nimport * as style from './Chat.module.css';\nimport { Avatar, Input, InputRich, Offline, Message } from './components';\nimport { ServiceLisa } from '../../services';\nimport { ICON } from '../helpers';\n\nlet onlineInterval;\n\nconst Chat = ({ skeleton, name = NAME }) => {\n const { isMobile } = useDevice();\n const { translate } = useLocale();\n const {\n set,\n value: { calendar, currency, hotel, locale, occupation, origin, session, tags, type },\n } = useStore();\n\n const [busy, setBusy] = useState(false);\n const [messages, setMessages] = useState([]);\n const [online, setOnline] = useState(false);\n const [scrollTo, setScrollTo] = useState();\n const [visible, setVisible] = useState(false);\n\n useEffect(() => {\n if (skeleton) return;\n\n (async () => {\n setBusy(true);\n const response = await ServiceLisa.welcome({ locale, session }).catch(handleError);\n if (response) {\n set({ lisa: response, locale: response.locale || locale });\n setMessages([...messages, { auto: true, ...response }]);\n }\n setBusy(false);\n })();\n // eslint-disable-next-line react-hooks/exhaustive-deps\n }, [skeleton]);\n\n useEffect(() => {\n // ! TODO: It's just a demo\n // if (visible && !messages.length) handleInput('Do you have any available offer or discount?');\n if (!visible) return clearInterval(onlineInterval);\n\n const callback = async () => {\n const response = await ServiceLisa.status().catch(() => setOnline(false));\n if (response && !online) setOnline(response);\n };\n\n callback();\n onlineInterval = setInterval(callback, online ? 60000 : 10000);\n\n return () => {\n clearInterval(onlineInterval);\n };\n }, [online, visible]);\n\n useEffect(() => visible && setScrollTo(new Date().getTime()), [busy, messages, visible]);\n\n const storeContext = { calendar, currency, hotel, occupation, origin, tags, type };\n\n const handleInput = (input) => {\n const nextMessages = [...messages, { text: input, timestamp: new Date().getTime() }];\n setMessages(nextMessages);\n\n setTimeout(async () => {\n setBusy(true);\n const response = await ServiceLisa.message({ context: { ...storeContext }, input, session }).catch(handleError);\n setBusy(false);\n\n if (response) {\n set({ lisa: response, locale: response.locale || locale });\n setMessages([...nextMessages, { auto: true, ...response }]);\n }\n }, DELAY_RESPONSE);\n };\n\n const handleAction = ({ context, form, intent } = {}) => {\n setBusy(true);\n\n setTimeout(async () => {\n const response = await ServiceLisa.action({\n context: { ...storeContext, ...context, form },\n intent,\n locale,\n session,\n }).catch(handleError);\n if (response) {\n set({ lisa: response });\n setMessages([...messages, { auto: true, ...response }]);\n }\n\n setBusy(false);\n }, DELAY_RESPONSE);\n };\n\n const handleError = (error) => {\n // eslint-disable-next-line no-console\n console.error('::handleError::', error);\n setOnline(false);\n };\n\n return !skeleton ? (\n <>\n {React.createElement(\n isMobile ? Modal : View,\n isMobile\n ? { className: style.container, visible }\n : { className: styles(style.container, visible && style.visible) },\n <>\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 tiny className={styles(style.bullet, online ? style.online : style.offline)} />\n <Text small lighten>\n {translate(online ? L10N.LABEL_ONLINE : L10N.LABEL_OFFLINE)}\n </Text>\n </View>\n </View>\n\n <View row>\n {/* ! TODO: When store chats */}\n {/* <Button small squared tooltip={translate(L10N.ACTION_MINIMIZE)} transparent onPress={() => {}}>\n <Icon value={ICON.MINIMIZE} />\n </Button> */}\n\n <Button\n small\n squared\n tooltip={translate(L10N.ACTION_CLOSE)}\n transparent\n onPress={() => setVisible(false)}\n >\n <Icon value={ICON.CLOSE} />\n </Button>\n </View>\n </View>\n\n <ScrollView scrollTo={scrollTo} snap={false} className={style.messages}>\n {messages.map((message, index) => (\n <Message\n key={index}\n {...message}\n disabled={busy || index < messages.length - 1}\n onAction={handleAction}\n />\n ))}\n {busy && <Message auto busy />}\n </ScrollView>\n\n {online ? (\n <>\n <Input disabled={busy} onValue={handleInput} />\n <InputRich onValue={handleAction} />\n </>\n ) : (\n <Offline />\n )}\n </>,\n )}\n\n <Tooltip right text={!visible ? translate(L10N.LABEL_GREETINGS, { name }) : undefined}>\n <Pressable\n disabled={busy}\n onPress={() => setVisible(true)}\n className={styles(style.buttonExtend, visible && style.hide)}\n >\n <Avatar disabled={visible} className={style.avatar} />\n </Pressable>\n </Tooltip>\n </>\n ) : null;\n};\n\nChat.displayName = 'Mirai:Core:Chat';\n\nChat.propTypes = {\n name: PropTypes.string,\n skeleton: PropTypes.bool,\n};\n\nexport { Chat };\n"],"mappings":"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"}
@@ -0,0 +1,24 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.L10N = void 0;
7
+ const L10N = exports.L10N = {
8
+ ACTION_CLOSE: {
9
+ id: 'common.action.close'
10
+ },
11
+ LABEL_ASSISTANT: {
12
+ id: 'lisa.label.assistant'
13
+ },
14
+ LABEL_GREETINGS: {
15
+ id: 'lisa.label.greetings'
16
+ },
17
+ LABEL_OFFLINE: {
18
+ id: 'lisa.label.offline'
19
+ },
20
+ LABEL_ONLINE: {
21
+ id: 'lisa.label.online'
22
+ }
23
+ };
24
+ //# sourceMappingURL=Chat.l10n.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Chat.l10n.js","names":["L10N","exports","ACTION_CLOSE","id","LABEL_ASSISTANT","LABEL_GREETINGS","LABEL_OFFLINE","LABEL_ONLINE"],"sources":["../../../src/components/Chat/Chat.l10n.js"],"sourcesContent":["export const L10N = {\n ACTION_CLOSE: { id: 'common.action.close' },\n\n LABEL_ASSISTANT: { id: 'lisa.label.assistant' },\n LABEL_GREETINGS: { id: 'lisa.label.greetings' },\n LABEL_OFFLINE: { id: 'lisa.label.offline' },\n LABEL_ONLINE: { id: 'lisa.label.online' },\n};\n"],"mappings":";;;;;;AAAO,MAAMA,IAAI,GAAAC,OAAA,CAAAD,IAAA,GAAG;EAClBE,YAAY,EAAE;IAAEC,EAAE,EAAE;EAAsB,CAAC;EAE3CC,eAAe,EAAE;IAAED,EAAE,EAAE;EAAuB,CAAC;EAC/CE,eAAe,EAAE;IAAEF,EAAE,EAAE;EAAuB,CAAC;EAC/CG,aAAa,EAAE;IAAEH,EAAE,EAAE;EAAqB,CAAC;EAC3CI,YAAY,EAAE;IAAEJ,EAAE,EAAE;EAAoB;AAC1C,CAAC"}
@@ -0,0 +1,90 @@
1
+ @import url(./Chat.theme.module.css);
2
+
3
+ .container {
4
+ background-color: var(--mirai-chat-base);
5
+ overflow: hidden;
6
+ z-index: var(--mirai-chat-layer);
7
+ }
8
+
9
+ /* -- header ---------------------------------------------------------------- */
10
+ .header {
11
+ backdrop-filter: blur(8px);
12
+ background: var(--mirai-chat-header-background);
13
+ /* box-shadow: 0 var(--mirai-chat-border-size) var(--mirai-chat-border-color); */
14
+ gap: calc(var(--mirai-chat-space) / 2);
15
+ height: var(--mirai-chat-header-height);
16
+ padding: 0 var(--mirai-chat-space);
17
+ position: fixed;
18
+ width: 100%;
19
+ z-index: 0;
20
+ }
21
+
22
+ .header .bullet {
23
+ height: var(--mirai-ui-space-XS);
24
+ width: var(--mirai-ui-space-XS);
25
+ border-radius: 50%;
26
+ margin-right: calc(var(--mirai-ui-space-XS) / 2);
27
+ }
28
+
29
+ .header .bullet.online {
30
+ background-color: var(--mirai-ui-success-border);
31
+ }
32
+
33
+ .header .bullet.offline {
34
+ background-color: var(--mirai-ui-error-border);
35
+ }
36
+
37
+ /* -------------------------------------------------------------------------- */
38
+ .messages {
39
+ flex: 1;
40
+ gap: calc(var(--mirai-chat-space) / 2);
41
+ padding-bottom: calc(var(--mirai-chat-space) * 2);
42
+ padding-top: calc(var(--mirai-chat-header-height) + calc(var(--mirai-chat-space) / 2));
43
+ width: 100%;
44
+ }
45
+
46
+ /* -- button ---------------------------------------------------------------- */
47
+ .buttonExtend {
48
+ bottom: var(--mirai-chat-space);
49
+ padding-left: calc(var(--mirai-chat-space) / 2);
50
+ position: fixed !important;
51
+ right: var(--mirai-chat-space);
52
+ transition: transform var(--mirai-ui-motion-collapse) var(--mirai-ui-motion-easing);
53
+ z-index: var(--mirai-chat-layer);
54
+ }
55
+
56
+ .buttonExtend .avatar {
57
+ box-shadow: var(--mirai-chat-box-shadow);
58
+ }
59
+
60
+ .buttonExtend.hide {
61
+ transform: translateY(150%);
62
+ }
63
+
64
+ /* mobile */
65
+ @media only screen and (max-width: 430px) {
66
+ .container {
67
+ height: 100vh;
68
+ }
69
+ }
70
+
71
+ /* tablet & desktop */
72
+ @media only screen and (min-width: 431px) {
73
+ .container {
74
+ border-radius: var(--mirai-chat-border-radius);
75
+ bottom: var(--mirai-chat-space);
76
+ box-shadow: var(--mirai-chat-box-shadow);
77
+ max-height: var(--mirai-chat-max-height);
78
+ max-width: var(--mirai-chat-width);
79
+ min-height: var(--mirai-chat-height);
80
+ position: fixed;
81
+ right: var(--mirai-chat-space);
82
+ transform: translateY(calc(var(--mirai-chat-max-height) + var(--mirai-chat-space)));
83
+ transition: transform var(--mirai-ui-motion-collapse) var(--mirai-ui-motion-easing);
84
+ width: 100%;
85
+ }
86
+
87
+ .container.visible {
88
+ transform: translateY(0%);
89
+ }
90
+ }
@@ -0,0 +1,49 @@
1
+ :root {
2
+ /* colors */
3
+ --mirai-chat-accent: var(--mirai-ui-accent);
4
+ /* --mirai-chat-accent: #4cd964; */
5
+
6
+ /* commons */
7
+ --mirai-chat-border-color: var(--mirai-ui-content-border);
8
+ --mirai-chat-border-radius: var(--mirai-ui-space-S);
9
+ --mirai-chat-border-size: 1px;
10
+ --mirai-chat-space: var(--mirai-ui-space-M);
11
+
12
+ --mirai-chat-motion-collapse: 200ms;
13
+ --mirai-chat-motion-expand: 300ms;
14
+ --mirai-chat-motion-easing: cubic-bezier(0.1, 0.1, 0.25, 0.9);
15
+
16
+ /* text */
17
+ --mirai-chat-text-accent-color: rgba(255, 255, 255, 0.95);
18
+ --mirai-chat-text-color: #222;
19
+ --mirai-chat-text-color-light: #999;
20
+ --mirai-chat-text-font-size: var(--mirai-ui-font-size-action);
21
+ --mirai-chat-text-font-weight: 500;
22
+ --mirai-chat-text-line-height: var(--mirai-ui-line-height-action);
23
+
24
+ /* <Chat> */
25
+ --mirai-chat-base: var(--mirai-ui-base);
26
+ --mirai-chat-base-opacity: rgba(255, 255, 255, 0.66);
27
+ --mirai-chat-box-shadow: 0 0 var(--mirai-ui-space-S) rgba(0, 0, 0, 0.1);
28
+ --mirai-chat-height: 606px;
29
+ --mirai-chat-layer: var(--mirai-ui-layer-XL);
30
+ --mirai-chat-max-height: 90svh;
31
+ --mirai-chat-width: var(--mirai-ui-breakpoint-S);
32
+
33
+ /* header */
34
+ --mirai-chat-header-height: calc(var(--mirai-ui-space-XL) + var(--mirai-ui-space-M));
35
+ --mirai-chat-header-background: linear-gradient(0deg, var(--mirai-chat-base-opacity) 0%, var(--mirai-chat-base) 100%);
36
+
37
+ /* <Input> */
38
+ --mirai-chat-input-background: var(--mirai-ui-content-background);
39
+ --mirai-chat-input-border-color: var(--mirai-chat-border-color);
40
+
41
+ /* <Message> */
42
+ --mirai-chat-message-background: transparent;
43
+ --mirai-chat-message-offset: calc(var(--mirai-chat-space) / 1.5) var(--mirai-chat-border-radius);
44
+
45
+ /* <Avatar> */
46
+ --mirai-chat-avatar-background: #222;
47
+ --mirai-chat-avatar-color: #fff;
48
+ --mirai-chat-avatar-border-radius: 40%;
49
+ }
@@ -0,0 +1,68 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.Avatar = void 0;
7
+ var _ui = require("@mirai/ui");
8
+ var _propTypes = _interopRequireDefault(require("prop-types"));
9
+ var _react = _interopRequireWildcard(require("react"));
10
+ var style = _interopRequireWildcard(require("./Avatar.module.css"));
11
+ 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); }
12
+ 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; }
13
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
14
+ 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); }
15
+ const Avatar = _ref => {
16
+ let {
17
+ disabled,
18
+ small,
19
+ ...others
20
+ } = _ref;
21
+ const el = (0, _react.useRef)();
22
+ (0, _react.useEffect)(() => {
23
+ const handleMouseMove = _ref2 => {
24
+ let {
25
+ clientX = 0,
26
+ clientY = 0
27
+ } = _ref2;
28
+ const {
29
+ current: eyes
30
+ } = el;
31
+ let X = 0;
32
+ let Y = 0;
33
+ if (eyes && !disabled) {
34
+ const {
35
+ height,
36
+ left,
37
+ top,
38
+ width
39
+ } = eyes.getBoundingClientRect();
40
+ const centerX = left + width / 2;
41
+ const centerY = top + height / 2;
42
+ const angle = Math.atan2(clientY - centerY, clientX - centerX);
43
+ const sensitivity = small ? 2 : 4;
44
+ X = sensitivity * Math.cos(angle);
45
+ Y = sensitivity * Math.sin(angle);
46
+ }
47
+ eyes.style.transform = "translate(".concat(X, "px, ").concat(Y, "px)");
48
+ };
49
+ window.addEventListener('mousemove', handleMouseMove);
50
+ return () => window.removeEventListener('mousemove', handleMouseMove);
51
+ }, [disabled, el, small]);
52
+ return /*#__PURE__*/_react.default.createElement(_ui.View, _extends({}, others, {
53
+ className: (0, _ui.styles)(style.face, small && style.small, others.className)
54
+ }), /*#__PURE__*/_react.default.createElement(_ui.View, {
55
+ ref: el,
56
+ className: style.eyes
57
+ }, /*#__PURE__*/_react.default.createElement(_ui.View, {
58
+ className: [style.eye, style.left]
59
+ }), /*#__PURE__*/_react.default.createElement(_ui.View, {
60
+ className: [style.eye, style.right]
61
+ })));
62
+ };
63
+ exports.Avatar = Avatar;
64
+ Avatar.propTypes = {
65
+ disabled: _propTypes.default.bool,
66
+ small: _propTypes.default.bool
67
+ };
68
+ //# sourceMappingURL=Avatar.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Avatar.js","names":["_ui","require","_propTypes","_interopRequireDefault","_react","_interopRequireWildcard","style","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","prototype","hasOwnProperty","call","i","set","obj","_extends","assign","bind","target","arguments","length","source","key","apply","Avatar","_ref","disabled","small","others","el","useRef","useEffect","handleMouseMove","_ref2","clientX","clientY","current","eyes","X","Y","height","left","top","width","getBoundingClientRect","centerX","centerY","angle","Math","atan2","sensitivity","cos","sin","transform","concat","window","addEventListener","removeEventListener","createElement","View","className","styles","face","ref","eye","right","exports","propTypes","PropTypes","bool"],"sources":["../../../../../src/components/Chat/components/Avatar/Avatar.jsx"],"sourcesContent":["import { styles, View } from '@mirai/ui';\nimport PropTypes from 'prop-types';\nimport React, { useEffect, useRef } from 'react';\n\nimport * as style from './Avatar.module.css';\n\nconst Avatar = ({ disabled, small, ...others }) => {\n const el = useRef();\n\n useEffect(() => {\n const handleMouseMove = ({ clientX = 0, clientY = 0 }) => {\n const { current: eyes } = el;\n let X = 0;\n let Y = 0;\n\n if (eyes && !disabled) {\n const { height, left, top, width } = eyes.getBoundingClientRect();\n const centerX = left + width / 2;\n const centerY = top + height / 2;\n const angle = Math.atan2(clientY - centerY, clientX - centerX);\n const sensitivity = small ? 2 : 4;\n\n X = sensitivity * Math.cos(angle);\n Y = sensitivity * Math.sin(angle);\n }\n\n eyes.style.transform = `translate(${X}px, ${Y}px)`;\n };\n\n window.addEventListener('mousemove', handleMouseMove);\n\n return () => window.removeEventListener('mousemove', handleMouseMove);\n }, [disabled, el, small]);\n\n return (\n <View {...others} className={styles(style.face, small && style.small, others.className)}>\n <View ref={el} className={style.eyes}>\n <View className={[style.eye, style.left]} />\n <View className={[style.eye, style.right]} />\n </View>\n </View>\n );\n};\n\nAvatar.propTypes = {\n disabled: PropTypes.bool,\n small: PropTypes.bool,\n};\n\nexport { Avatar };\n"],"mappings":"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"}
@@ -0,0 +1,81 @@
1
+ .face {
2
+ width: 64px;
3
+ height: 64px;
4
+ background-color: var(--mirai-chat-avatar-background);
5
+ border-radius: var(--mirai-chat-avatar-border-radius);
6
+ position: relative;
7
+ }
8
+
9
+ .face.small {
10
+ min-height: 36px;
11
+ height: 36px;
12
+ min-width: 36px;
13
+ width: 36px;
14
+ }
15
+
16
+ .eyes {
17
+ position: absolute;
18
+ bottom: 27.5%;
19
+ left: 0;
20
+ right: 0;
21
+ height: 17.5%;
22
+ transition: transform 40ms;
23
+ }
24
+
25
+ .eye {
26
+ animation: blink 8s infinite;
27
+ background-color: var(--mirai-chat-avatar-background);
28
+ border-radius: 50%;
29
+ height: 100%;
30
+ position: absolute;
31
+ width: 17.5%;
32
+ }
33
+
34
+ .face:not(.small) .eye {
35
+ box-shadow: 0 0 0 6px var(--mirai-chat-avatar-color);
36
+ }
37
+
38
+ .face.small .eye {
39
+ box-shadow: 0 0 0 3px var(--mirai-chat-avatar-color);
40
+ }
41
+
42
+ .eye.left {
43
+ left: 27.5%;
44
+ }
45
+
46
+ .eye.right {
47
+ right: 27.5%;
48
+ }
49
+
50
+ @keyframes blink {
51
+ 0%,
52
+ 100% {
53
+ transform: scaleY(100%);
54
+ }
55
+ /* double-blink */
56
+ 31% {
57
+ transform: scaleY(100%);
58
+ }
59
+ 32% {
60
+ transform: scaleY(15%);
61
+ }
62
+ 33% {
63
+ transform: scaleY(100%);
64
+ }
65
+ 34% {
66
+ transform: scaleY(15%);
67
+ }
68
+ 35% {
69
+ transform: scaleY(100%);
70
+ }
71
+ /* single-blink */
72
+ 61% {
73
+ transform: scaleY(100%);
74
+ }
75
+ 62% {
76
+ transform: scaleY(15%);
77
+ }
78
+ 63% {
79
+ transform: scaleY(100%);
80
+ }
81
+ }
@@ -0,0 +1,97 @@
1
+ // Jest Snapshot v1, https://goo.gl/fbAQLP
2
+
3
+ exports[`component:<Avatar> inherit:className 1`] = `
4
+ <DocumentFragment>
5
+ <div
6
+ class="view mirai"
7
+ >
8
+ <div
9
+ class="view"
10
+ >
11
+ <div
12
+ class="view"
13
+ />
14
+ <div
15
+ class="view"
16
+ />
17
+ </div>
18
+ </div>
19
+ </DocumentFragment>
20
+ `;
21
+
22
+ exports[`component:<Avatar> prop:disabled 1`] = `
23
+ <DocumentFragment>
24
+ <div
25
+ class="view"
26
+ >
27
+ <div
28
+ class="view"
29
+ >
30
+ <div
31
+ class="view"
32
+ />
33
+ <div
34
+ class="view"
35
+ />
36
+ </div>
37
+ </div>
38
+ </DocumentFragment>
39
+ `;
40
+
41
+ exports[`component:<Avatar> prop:small 1`] = `
42
+ <DocumentFragment>
43
+ <div
44
+ class="view"
45
+ >
46
+ <div
47
+ class="view"
48
+ >
49
+ <div
50
+ class="view"
51
+ />
52
+ <div
53
+ class="view"
54
+ />
55
+ </div>
56
+ </div>
57
+ </DocumentFragment>
58
+ `;
59
+
60
+ exports[`component:<Avatar> renders 1`] = `
61
+ <DocumentFragment>
62
+ <div
63
+ class="view"
64
+ >
65
+ <div
66
+ class="view"
67
+ >
68
+ <div
69
+ class="view"
70
+ />
71
+ <div
72
+ class="view"
73
+ />
74
+ </div>
75
+ </div>
76
+ </DocumentFragment>
77
+ `;
78
+
79
+ exports[`component:<Avatar> testId 1`] = `
80
+ <DocumentFragment>
81
+ <div
82
+ class="view"
83
+ data-testid="mirai"
84
+ >
85
+ <div
86
+ class="view"
87
+ >
88
+ <div
89
+ class="view"
90
+ />
91
+ <div
92
+ class="view"
93
+ />
94
+ </div>
95
+ </div>
96
+ </DocumentFragment>
97
+ `;
@@ -0,0 +1,17 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ var _Avatar = require("./Avatar");
7
+ Object.keys(_Avatar).forEach(function (key) {
8
+ if (key === "default" || key === "__esModule") return;
9
+ if (key in exports && exports[key] === _Avatar[key]) return;
10
+ Object.defineProperty(exports, key, {
11
+ enumerable: true,
12
+ get: function () {
13
+ return _Avatar[key];
14
+ }
15
+ });
16
+ });
17
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","names":["_Avatar","require","Object","keys","forEach","key","exports","defineProperty","enumerable","get"],"sources":["../../../../../src/components/Chat/components/Avatar/index.js"],"sourcesContent":["export * from './Avatar';\n"],"mappings":";;;;;AAAA,IAAAA,OAAA,GAAAC,OAAA;AAAAC,MAAA,CAAAC,IAAA,CAAAH,OAAA,EAAAI,OAAA,WAAAC,GAAA;EAAA,IAAAA,GAAA,kBAAAA,GAAA;EAAA,IAAAA,GAAA,IAAAC,OAAA,IAAAA,OAAA,CAAAD,GAAA,MAAAL,OAAA,CAAAK,GAAA;EAAAH,MAAA,CAAAK,cAAA,CAAAD,OAAA,EAAAD,GAAA;IAAAG,UAAA;IAAAC,GAAA,WAAAA,CAAA;MAAA,OAAAT,OAAA,CAAAK,GAAA;IAAA;EAAA;AAAA"}
@@ -0,0 +1,72 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.Input = void 0;
7
+ var _locale = require("@mirai/locale");
8
+ var _ui = require("@mirai/ui");
9
+ var _propTypes = _interopRequireDefault(require("prop-types"));
10
+ var _react = _interopRequireWildcard(require("react"));
11
+ var _Input = require("./Input.l10n");
12
+ var style = _interopRequireWildcard(require("./Input.module.css"));
13
+ var _helpers = require("../../../helpers");
14
+ 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); }
15
+ 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; }
16
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
17
+ 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); }
18
+ const Input = _ref => {
19
+ let {
20
+ disabled = false,
21
+ onValue = () => {},
22
+ ...others
23
+ } = _ref;
24
+ const {
25
+ translate
26
+ } = (0, _locale.useLocale)();
27
+ const [value, setValue] = (0, _react.useState)();
28
+ const handleChange = value => {
29
+ setValue(value);
30
+ };
31
+ const handleKeyPress = function () {
32
+ let {
33
+ key
34
+ } = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
35
+ if (key === 'Enter') handlePress();
36
+ };
37
+ const handlePress = () => {
38
+ if (isEmpty) return;
39
+ onValue(value);
40
+ setValue();
41
+ };
42
+ const isEmpty = !value || value.trim().length === 0;
43
+ return /*#__PURE__*/_react.default.createElement(_ui.View, _extends({}, others, {
44
+ row: true,
45
+ className: style.container
46
+ }), /*#__PURE__*/_react.default.createElement(_ui.Input, {
47
+ autoResize: true,
48
+ multiLine: true,
49
+ name: "input",
50
+ placeholder: translate(_Input.L10N.LABEL_SEND_MESSAGE),
51
+ value: value,
52
+ onChange: handleChange,
53
+ onKeyPress: handleKeyPress,
54
+ className: style.input
55
+ }), /*#__PURE__*/_react.default.createElement(_ui.Button, {
56
+ disabled: disabled,
57
+ small: true,
58
+ squared: true,
59
+ tooltip: translate(_Input.L10N.ACTION_SEND),
60
+ transparent: true,
61
+ onPress: handlePress
62
+ }, /*#__PURE__*/_react.default.createElement(_ui.Icon, {
63
+ lighten: isEmpty,
64
+ value: _helpers.ICON.SEND
65
+ })));
66
+ };
67
+ exports.Input = Input;
68
+ Input.propTypes = {
69
+ disabled: _propTypes.default.bool,
70
+ onValue: _propTypes.default.func
71
+ };
72
+ //# sourceMappingURL=Input.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Input.js","names":["_locale","require","_ui","_propTypes","_interopRequireDefault","_react","_interopRequireWildcard","_Input","style","_helpers","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","prototype","hasOwnProperty","call","i","set","obj","_extends","assign","bind","target","arguments","length","source","key","apply","Input","_ref","disabled","onValue","others","translate","useLocale","value","setValue","useState","handleChange","handleKeyPress","undefined","handlePress","isEmpty","trim","createElement","View","row","className","container","autoResize","multiLine","name","placeholder","L10N","LABEL_SEND_MESSAGE","onChange","onKeyPress","input","Button","small","squared","tooltip","ACTION_SEND","transparent","onPress","Icon","lighten","ICON","SEND","exports","propTypes","PropTypes","bool","func"],"sources":["../../../../../src/components/Chat/components/Input/Input.jsx"],"sourcesContent":["import { useLocale } from '@mirai/locale';\nimport { Button, Icon, Input as InputBase, View } from '@mirai/ui';\nimport PropTypes from 'prop-types';\nimport React, { useState } from 'react';\n\nimport { L10N } from './Input.l10n';\nimport * as style from './Input.module.css';\nimport { ICON } from '../../../helpers';\n\nconst Input = ({ disabled = false, onValue = () => {}, ...others }) => {\n const { translate } = useLocale();\n\n const [value, setValue] = useState();\n\n const handleChange = (value) => {\n setValue(value);\n };\n\n const handleKeyPress = ({ key } = {}) => {\n if (key === 'Enter') handlePress();\n };\n\n const handlePress = () => {\n if (isEmpty) return;\n\n onValue(value);\n setValue();\n };\n\n const isEmpty = !value || value.trim().length === 0;\n\n return (\n <View {...others} row className={style.container}>\n <InputBase\n autoResize\n multiLine\n name=\"input\"\n placeholder={translate(L10N.LABEL_SEND_MESSAGE)}\n value={value}\n onChange={handleChange}\n onKeyPress={handleKeyPress}\n className={style.input}\n />\n\n <Button disabled={disabled} small squared tooltip={translate(L10N.ACTION_SEND)} transparent onPress={handlePress}>\n <Icon lighten={isEmpty} value={ICON.SEND} />\n </Button>\n </View>\n );\n};\n\nInput.propTypes = {\n disabled: PropTypes.bool,\n onValue: PropTypes.func,\n};\n\nexport { Input };\n"],"mappings":"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"}
@@ -0,0 +1,15 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.L10N = void 0;
7
+ const L10N = exports.L10N = {
8
+ ACTION_SEND: {
9
+ id: 'common.action.send'
10
+ },
11
+ LABEL_SEND_MESSAGE: {
12
+ id: 'lisa.label.send_message'
13
+ }
14
+ };
15
+ //# sourceMappingURL=Input.l10n.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Input.l10n.js","names":["L10N","exports","ACTION_SEND","id","LABEL_SEND_MESSAGE"],"sources":["../../../../../src/components/Chat/components/Input/Input.l10n.js"],"sourcesContent":["export const L10N = {\n ACTION_SEND: { id: 'common.action.send' },\n LABEL_SEND_MESSAGE: { id: 'lisa.label.send_message' },\n};\n"],"mappings":";;;;;;AAAO,MAAMA,IAAI,GAAAC,OAAA,CAAAD,IAAA,GAAG;EAClBE,WAAW,EAAE;IAAEC,EAAE,EAAE;EAAqB,CAAC;EACzCC,kBAAkB,EAAE;IAAED,EAAE,EAAE;EAA0B;AACtD,CAAC"}
@@ -0,0 +1,19 @@
1
+ .container {
2
+ background-color: var(--mirai-chat-input-background);
3
+ border-radius: calc(var(--mirai-chat-border-radius) / 2);
4
+ box-shadow: 0 0 0 var(--mirai-chat-border-size) var(--mirai-chat-input-border-color);
5
+ justify-content: center;
6
+ margin: calc(var(--mirai-chat-space) * -1) var(--mirai-chat-space) var(--mirai-chat-space) var(--mirai-chat-space);
7
+ padding-right: calc(var(--mirai-chat-space) / 2);
8
+ z-index: 0;
9
+ }
10
+
11
+ .input {
12
+ background-color: transparent;
13
+ color: var(--mirai-chat-text-color);
14
+ font-size: var(--mirai-chat-text-font-size);
15
+ font-weight: var(--mirai-chat-text-font-weight);
16
+ height: calc(var(--mirai-chat-text-line-height) + calc(var(--mirai-ui-space-S) * 2));
17
+ line-height: var(--mirai-chat-text-line-height);
18
+ padding: var(--mirai-ui-space-S);
19
+ }