@plusscommunities/pluss-core-app 6.1.7-beta.0 → 7.0.0-beta.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/module/components/Attachment.js +1 -1
- package/dist/module/components/Attachment.js.map +1 -1
- package/dist/module/components/AudienceSelectorPage.js +1 -1
- package/dist/module/components/AudienceSelectorPage.js.map +1 -1
- package/dist/module/components/CommentReply.js +1 -1
- package/dist/module/components/CommentReply.js.map +1 -1
- package/dist/module/components/CommentSection.js +1 -1
- package/dist/module/components/CommentSection.js.map +1 -1
- package/dist/module/components/DropDownItem.js +1 -1
- package/dist/module/components/DropDownItem.js.map +1 -1
- package/dist/module/components/FormCardSectionOptionLauncher.js +1 -1
- package/dist/module/components/FormCardSectionOptionLauncher.js.map +1 -1
- package/dist/module/components/GenericInput.js +1 -1
- package/dist/module/components/GenericInput.js.map +1 -1
- package/dist/module/components/GenericInputSection.js +1 -1
- package/dist/module/components/GenericInputSection.js.map +1 -1
- package/dist/module/components/Header.js +1 -1
- package/dist/module/components/Header.js.map +1 -1
- package/dist/module/components/ImagePopup.js +1 -1
- package/dist/module/components/ImagePopup.js.map +1 -1
- package/dist/module/components/ImageUploader.js +1 -1
- package/dist/module/components/ImageUploader.js.map +1 -1
- package/dist/module/components/PDFPopup.js +1 -1
- package/dist/module/components/PDFPopup.js.map +1 -1
- package/dist/module/components/PlussChat.js +1 -1
- package/dist/module/components/PlussChat.js.map +1 -1
- package/dist/module/components/PositionedImage.js +1 -1
- package/dist/module/components/PositionedImage.js.map +1 -1
- package/dist/module/components/SharingTools.js +1 -1
- package/dist/module/components/SharingTools.js.map +1 -1
- package/dist/module/components/expo-image-picker-multiple/ImageTile.js +1 -1
- package/dist/module/components/expo-image-picker-multiple/ImageTile.js.map +1 -1
- package/package.json +4 -3
- package/src/components/Attachment.js +1 -1
- package/src/components/AudienceSelectorPage.js +1 -1
- package/src/components/CommentReply.js +1 -1
- package/src/components/CommentSection.js +5 -6
- package/src/components/DropDownItem.js +1 -1
- package/src/components/FormCardSectionOptionLauncher.js +1 -1
- package/src/components/GenericInput.js +1 -1
- package/src/components/GenericInputSection.js +1 -1
- package/src/components/Header.js +1 -1
- package/src/components/ImagePopup.js +1 -1
- package/src/components/ImageUploader.js +1 -1
- package/src/components/PDFPopup.js +1 -1
- package/src/components/PlussChat.js +1 -1
- package/src/components/PositionedImage.js +1 -1
- package/src/components/SharingTools.js +1 -1
- package/src/components/expo-image-picker-multiple/ImageTile.js +1 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["React","Component","View","Image","ImageBackground","TouchableOpacity","Text","KeyboardAvoidingView","Platform","ScrollView","GiftedChat","Bubble","MessageText","Send","InputToolbar","Composer","connect","_","moment","Icon","getBottomSpace","Spinner","ProfilePic","PlussChatTime","PDFPopup","Attachment","PlussChatMessage","TextStyle","TEXT_DARK","LINEGREY","TEXT_DARKEST","getMainBrandingColourFromState","getLightBrandingColourFromState","BG_GREY","TEXT_BLUEGREY","getEnabledTabsFromState","get1400","getThumb300","imageExists","isVideo","getImageSource","getFileName","Config","Services","ImageUploader","ImageUploadProgress","ImagePopup","VideoPopup","IMAGE_SIZE_SMALL","IMAGE_SIZE_LARGE","IMAGES_PER_ROW","IMAGE_MARGIN","IMAGE_PREVIEW_AREA_HEIGHT","IMAGE_PREVIEW_SIZE","PlussChat","constructor","props","_defineProperty","event","navigation","navigate","attachment","Type","place","imagesToUpload","isEmpty","state","upload","hasImagesAttached","every","i","uploading","thumbNailExists","checkThumb","setInterval","Promise","all","map","image","resolve","newImage","push","url","allowRetry","thumbNailUrl","thumbnailsExist","clearInterval","setState","a","selectedPDF","keyboardOpen","uploadUri","imageUri","uploadProgress","progress","img","uri","percentage","replace","waitForThumbnails","images","selected","imagePopupSource","imagePopupIndex","indexOf","imagePopupOpen","message","replyingTo","filter","showFullscreenVideo","length","currentVideoUrl","isSingleTab","tabCount","MIN_COMPOSER_HEIGHT","select","ios","android","currentUser","_id","user","uid","name","displayName","avatar","isUndefined","profilePic","env","tinyChatDefault","messages","UNSAFE_componentWillMount","updateMessages","UNSAFE_componentWillReceiveProps","nextProps","newState","onSend","showUploadMenu","imageUploader","closeGallery","sendMessages","hasImagesReady","text","renderBubble","bubbleProps","wrapperStyle","currentMessage","paddingTop","paddingBottom","minWidth","attachments","paddingHorizontal","createElement","_extends","renderMessageImage","isCustomViewBottom","left","backgroundColor","borderRadius","right","colourBrandingLight","containerToNextStyle","borderBottomLeftRadius","borderBottomRightRadius","containerToPreviousStyle","borderTopLeftRadius","borderTopRightRadius","renderMessage","key","RowId","colourBrandingMain","onPressReply","onReply","renderMessageText","messageTextProps","textStyle","fontFamily","fontSize","color","marginTop","marginBottom","marginLeft","marginRight","linkStyle","renderTime","renderDay","dayProps","renderCustomView","position","containerWidth","style","styles","imagesContainer","width","paddingVertical","thumb","onPress","toggleFullscreenVideo","bind","messageImageSmall","messageImageLarge","source","imagePlayContainer","type","iconStyle","imageControlIcon","onPressImage","onOpenAttachment","title","onPressEvent","eventContainer","eventImage","eventImageMargin","Thumbnail","eventInfo","numberOfLines","eventTitle","eventInfoAlign","Title","eventDate","utc","StartTime","local","format","onPressAttachment","renderSend","top","alwaysShowSend","containerStyle","sendContainer","height","send","renderAccessory","hasAttachment","horizontal","uploadImagesContainer","uploader","progressTextStyle","isVideoUrl","accessoryImageContainer","accessoryImage","imageStyle","accessoryImageBorder","previewItemRemoveButton","onRemoveImage","hitSlop","bottom","previewItemRemoveContainer","previewItemRemoveIcon","renderInputToolbar","inputContainer","renderComposer","accessoryStyle","accessory","renderFooter","renderLoading","justifyContent","alignContent","size","renderAvatar","Diameter","_this$state$replyingT","_this$state$replyingT2","composerContainer","replyingRemoveButton","replyingRemoveContainer","replyingRemoveIcon","composerInputWrapper","input","OS","composerHeight","placeholder","textInputStyle","inputText","textInputProps","onFocus","onFocusInput","onBlur","onBlurInput","renderChat","noTab","iosBottomOffset","minInputToolbarHeight","keyboardShouldPersistTaps","renderAvatarOnTop","bottomOffset","renderImageUploader","ref","onUploadStarted","onUploadProgress","onUploadSuccess","onUploadFailed","onLibrarySelected","quality","allowsEditing","fileName","popupTitle","userId","multiple","allowVideo","renderImagePopup","visible","index","onClose","renderVideoPlayerPopup","renderPDF","onCloseAttachment","pdfCount","render","noAndroidAvoid","behavior","chatContainer","flex","paddingLeft","paddingRight","flexDirection","resizeMode","minHeight","textAlign","alignSelf","margin","alignItems","borderBottomWidth","borderBottomColor","borderWidth","borderColor","borderTopWidth","borderTopColor","settingDropDownOpen","flexWrap","overflow","textShadowColor","textShadowOffset","mapStateToProps"],"sources":["PlussChat.js"],"sourcesContent":["import React, { Component } from 'react';\nimport { View, Image, ImageBackground, TouchableOpacity, Text, KeyboardAvoidingView, Platform, ScrollView } from 'react-native';\nimport { GiftedChat, Bubble, MessageText, Send, InputToolbar, Composer } from 'react-native-gifted-chat';\nimport { connect } from 'react-redux';\nimport _ from 'lodash';\nimport moment from 'moment';\nimport { Icon } from 'react-native-elements';\nimport { getBottomSpace } from 'react-native-iphone-x-helper';\nimport { Spinner } from './Spinner';\nimport { ProfilePic } from './ProfilePic';\nimport PlussChatTime from './PlussChatTime';\nimport { PDFPopup } from './PDFPopup';\nimport { Attachment } from './Attachment';\nimport PlussChatMessage from './PlussChatMessage';\nimport { TextStyle } from './TextStyle';\nimport {\n TEXT_DARK,\n LINEGREY,\n TEXT_DARKEST,\n getMainBrandingColourFromState,\n getLightBrandingColourFromState,\n BG_GREY,\n TEXT_BLUEGREY,\n} from '../colours';\nimport { getEnabledTabsFromState, get1400, getThumb300, imageExists, isVideo, getImageSource, getFileName } from '../helper';\nimport Config, { Services } from '../config';\nimport ImageUploader from './ImageUploader';\nimport ImageUploadProgress from './ImageUploadProgress';\nimport { ImagePopup } from './ImagePopup';\nimport { VideoPopup } from './VideoPopup';\n\nconst IMAGE_SIZE_SMALL = 55;\nconst IMAGE_SIZE_LARGE = 110;\nconst IMAGES_PER_ROW = 4;\nconst IMAGE_MARGIN = 2;\nconst IMAGE_PREVIEW_AREA_HEIGHT = 105;\nconst IMAGE_PREVIEW_SIZE = IMAGE_PREVIEW_AREA_HEIGHT - 25;\n\nclass PlussChat extends Component {\n constructor(props) {\n super(props);\n const isSingleTab = this.props.tabCount === 1 && getBottomSpace() > 0;\n this.MIN_COMPOSER_HEIGHT = Platform.select({\n ios: isSingleTab ? 42 : 33,\n android: 41,\n });\n\n this.state = {\n currentUser: {\n _id: this.props.user.uid,\n name: this.props.user.displayName,\n avatar:\n !_.isUndefined(this.props.user.profilePic) && !_.isEmpty(this.props.user.profilePic)\n ? this.props.user.profilePic\n : Config.env.tinyChatDefault,\n },\n\n messages: [],\n imagePopupSource: [],\n imagePopupIndex: 0,\n imagePopupOpen: false,\n imagesToUpload: [],\n showFullscreenVideo: false,\n currentVideoUrl: '',\n };\n this.checkThumb = null;\n }\n\n UNSAFE_componentWillMount() {\n this.updateMessages(this.props);\n }\n\n UNSAFE_componentWillReceiveProps(nextProps) {\n this.updateMessages(nextProps);\n }\n\n updateMessages(props) {\n const newState = {};\n if (!_.isUndefined(props.messages)) {\n newState.messages = props.messages;\n }\n this.setState(newState);\n }\n\n /***\n *\n * Messaging functionality\n */\n onSend(messages = []) {\n // if (this.chatKey) {\n // this.sendMessage(messages[0]);\n // }\n }\n\n onPressEvent = event => {\n Services.navigation.navigate('eventDetail', { event });\n };\n onPressAttachment = attachment => {\n switch (attachment.Type) {\n case 'Event':\n Services.navigation.navigate('eventDetail', { event: attachment });\n break;\n case 'Place':\n Services.navigation.navigate('placeDetail', { place: attachment });\n break;\n default:\n return;\n }\n };\n\n hasImagesAttached = (imagesToUpload = null) => {\n return !_.isEmpty(imagesToUpload || this.state.imagesToUpload);\n };\n\n hasImagesReady = (imagesToUpload = null) => {\n const upload = imagesToUpload || this.state.imagesToUpload;\n return this.hasImagesAttached(upload) && upload.every(i => !i.uploading && i.thumbNailExists);\n };\n\n waitForThumbnails = () => {\n if (this.checkThumb) return;\n\n this.checkThumb = setInterval(async () => {\n const imagesToUpload = [];\n await Promise.all(\n this.state.imagesToUpload.map(image => {\n return new Promise(async resolve => {\n const newImage = { ...image };\n imagesToUpload.push(newImage);\n if (newImage.url && !newImage.thumbNailExists) {\n newImage.uploading = false;\n newImage.allowRetry = false;\n newImage.thumbNailExists = await imageExists(newImage.thumbNailUrl);\n resolve(newImage.thumbNailExists);\n }\n resolve(true);\n });\n }),\n );\n const thumbnailsExist = imagesToUpload.every(image => !image.url || image.thumbNailExists);\n if (thumbnailsExist) {\n clearInterval(this.checkThumb);\n this.checkThumb = null;\n this.setState({ imagesToUpload });\n }\n }, 2000);\n };\n\n onOpenAttachment = a => {\n this.setState({\n selectedPDF: a,\n });\n };\n\n onCloseAttachment = () => {\n this.setState({\n selectedPDF: null,\n });\n };\n\n showUploadMenu() {\n this.imageUploader.showUploadMenu();\n }\n\n onFocusInput = () => {\n this.setState({\n keyboardOpen: true,\n });\n if (this.props.keyboardOpen) {\n this.props.keyboardOpen();\n }\n };\n\n onBlurInput = () => {\n this.setState({\n keyboardOpen: false,\n });\n };\n\n onUploadStarted = (uploadUri, imageUri) => {\n const imagesToUpload = [\n ...this.state.imagesToUpload,\n {\n uploading: true,\n uploadProgress: '0%',\n uploadUri,\n imageUri,\n allowRetry: true,\n },\n ];\n this.setState({ imagesToUpload });\n };\n\n onUploadProgress = progress => {\n const imagesToUpload = [...this.state.imagesToUpload];\n imagesToUpload.map(img => {\n if (img.uploadUri === progress.uri) {\n img.uploadProgress = progress.percentage;\n img.uploading = true;\n img.allowRetry = true;\n }\n });\n this.setState({ imagesToUpload });\n };\n\n onUploadSuccess = async (uri, uploadUri) => {\n const imagesToUpload = [...this.state.imagesToUpload];\n imagesToUpload.map(img => {\n if (img.uploadUri === uploadUri && img.uploading) {\n img.url = uri.replace('/general/', '/general1400/');\n img.thumbNailExists = false;\n img.thumbNailUrl = getThumb300(img.url);\n img.allowRetry = true;\n }\n });\n this.setState({ imagesToUpload }, () => this.waitForThumbnails());\n };\n\n onUploadFailed = uploadUri => {\n const imagesToUpload = [...this.state.imagesToUpload];\n imagesToUpload.map(img => {\n if (img.uploadUri === uploadUri) {\n img.uploading = true; // Requried for retry\n img.uploadProgress = '';\n img.allowRetry = true;\n }\n });\n this.setState({ imagesToUpload });\n };\n\n onLibrarySelected = uri => {\n const imagesToUpload = [\n ...this.state.imagesToUpload,\n {\n uploading: false,\n allowRetry: false,\n url: get1400(uri),\n thumbNailExists: true,\n thumbNailUrl: getThumb300(uri),\n },\n ];\n this.setState({ imagesToUpload });\n };\n\n onPressImage = (images, selected) => {\n this.setState({\n imagePopupSource: images,\n imagePopupIndex: images.indexOf(selected),\n imagePopupOpen: true,\n });\n };\n\n onReply = message => {\n this.setState({\n replyingTo: message,\n });\n };\n\n closeGallery() {\n this.setState({\n imagePopupSource: [],\n imagePopupIndex: 0,\n imagePopupOpen: false,\n });\n }\n\n onRemoveImage = url => {\n const imagesToUpload = this.state.imagesToUpload.filter(image => image.url !== url);\n this.setState({ imagesToUpload });\n };\n\n toggleFullscreenVideo = url => {\n if (typeof url !== 'string') url = '';\n this.setState({ showFullscreenVideo: url.length > 0, currentVideoUrl: url });\n };\n\n sendMessages(messages) {\n if (this.hasImagesAttached()) {\n // Don't allow send if attached images aren't ready\n if (!this.hasImagesReady()) return;\n messages[0].image = this.state.imagesToUpload.map(image => image.url);\n }\n if (_.isEmpty(messages[0].text)) {\n messages[0].text = '';\n }\n if (!messages[0].text && !messages[0].image) return;\n\n if (this.state.replyingTo) {\n messages[0].replyingTo = this.state.replyingTo;\n }\n\n this.props.onSend(messages);\n this.setState({ imagesToUpload: [], replyingTo: null });\n }\n\n /**\n *\n * Render Functions\n */\n renderBubble(bubbleProps) {\n const wrapperStyle = {};\n if (!_.isEmpty(bubbleProps.currentMessage.text) && !_.isEmpty(bubbleProps.currentMessage.image)) {\n wrapperStyle.paddingTop = 8;\n wrapperStyle.paddingBottom = 16;\n wrapperStyle.minWidth = 142; // 110 image width + 16 padding either side\n }\n if (!_.isEmpty(bubbleProps.currentMessage.attachments)) {\n wrapperStyle.paddingTop = 8;\n wrapperStyle.paddingBottom = 16;\n wrapperStyle.paddingHorizontal = 16;\n }\n return (\n <Bubble\n {...bubbleProps}\n renderMessageImage={() => null}\n isCustomViewBottom={true}\n wrapperStyle={{\n left: {\n backgroundColor: LINEGREY,\n borderRadius: 25,\n ...wrapperStyle,\n },\n right: {\n backgroundColor: this.props.colourBrandingLight,\n borderRadius: 25,\n ...wrapperStyle,\n },\n }}\n containerToNextStyle={{\n left: {\n borderBottomLeftRadius: 5,\n },\n right: {\n borderBottomRightRadius: 5,\n },\n }}\n containerToPreviousStyle={{\n left: {\n borderTopLeftRadius: 5,\n },\n right: {\n borderTopRightRadius: 5,\n },\n }}\n />\n );\n }\n renderMessage(props) {\n return (\n <PlussChatMessage\n key={props.RowId}\n colourBrandingMain={this.props.colourBrandingMain}\n onPressReply={() => {\n this.onReply(props.currentMessage);\n }}\n {...props}\n />\n );\n }\n renderMessageText(messageTextProps) {\n return (\n <MessageText\n {...messageTextProps}\n textStyle={{\n left: {\n fontFamily: 'sf-regular',\n fontSize: 16,\n color: TEXT_DARKEST,\n marginTop: 10,\n marginBottom: 10,\n marginLeft: 15,\n marginRight: 15,\n },\n right: {\n fontFamily: 'sf-regular',\n fontSize: 16,\n color: this.props.colourBrandingMain,\n marginTop: 10,\n marginBottom: 10,\n marginLeft: 15,\n marginRight: 15,\n },\n }}\n linkStyle={{\n left: {\n color: TEXT_DARKEST,\n },\n right: {\n color: this.props.colourBrandingMain,\n },\n }}\n />\n );\n }\n renderTime() {\n return null;\n }\n renderDay(dayProps) {\n return (\n <PlussChatTime\n {...dayProps}\n textStyle={{\n fontFamily: 'sf-semibold',\n color: TEXT_DARK,\n fontSize: 12,\n }}\n />\n );\n }\n renderCustomView({ currentMessage, position }) {\n if (currentMessage.image) {\n const images = typeof currentMessage.image === 'string' ? [currentMessage.image] : currentMessage.image;\n const containerWidth = (() => {\n if (images.length === 0) return 0;\n if (images.length === 1) return IMAGE_SIZE_LARGE;\n if (images.length <= IMAGES_PER_ROW) return (IMAGE_SIZE_SMALL + IMAGE_MARGIN) * images.length;\n return (IMAGE_SIZE_SMALL + IMAGE_MARGIN) * IMAGES_PER_ROW;\n })();\n return (\n <View style={[styles.imagesContainer, { width: containerWidth, paddingVertical: currentMessage.text ? 0 : 20 }]}>\n {images.map(img => {\n const thumb = getThumb300(img);\n if (isVideo(img)) {\n return (\n <TouchableOpacity key={thumb} onPress={this.toggleFullscreenVideo.bind(this, img)}>\n <ImageBackground style={images.length > 1 ? styles.messageImageSmall : styles.messageImageLarge} source={{ uri: thumb }}>\n <View style={styles.imagePlayContainer}>\n <Icon name=\"play\" type=\"font-awesome\" iconStyle={styles.imageControlIcon} />\n </View>\n </ImageBackground>\n </TouchableOpacity>\n );\n }\n return (\n <TouchableOpacity key={thumb} onPress={() => this.onPressImage(images, img)}>\n <Image source={{ uri: thumb }} style={images.length > 1 ? styles.messageImageSmall : styles.messageImageLarge} />\n </TouchableOpacity>\n );\n })}\n </View>\n );\n }\n if (!_.isEmpty(currentMessage.attachments)) {\n return (\n <View>\n {currentMessage.attachments.map((url, i) => {\n return (\n <Attachment\n onPress={() => {\n this.onOpenAttachment(url);\n }}\n key={i}\n title={getFileName(url)}\n />\n );\n })}\n </View>\n );\n }\n if (currentMessage.event) {\n return (\n <TouchableOpacity onPress={this.onPressEvent.bind(this, currentMessage.event)}>\n <View style={styles.eventContainer[position]}>\n <Image style={[styles.eventImage, styles.eventImageMargin[position]]} source={{ uri: currentMessage.event.Thumbnail }} />\n <View style={styles.eventInfo}>\n <Text\n numberOfLines={3}\n style={[styles.eventTitle, styles.eventInfoAlign[position], { color: this.props.colourBrandingMain }]}\n >\n {currentMessage.event.Title}\n </Text>\n <Text style={[styles.eventDate, styles.eventInfoAlign[position], { color: this.props.colourBrandingMain }]}>\n {moment\n .utc(currentMessage.event.StartTime)\n .local()\n .format('ddd D MMM')}\n </Text>\n </View>\n </View>\n </TouchableOpacity>\n );\n }\n if (currentMessage.attachment) {\n return (\n <TouchableOpacity onPress={this.onPressAttachment.bind(this, currentMessage.attachment)}>\n <View style={styles.eventContainer[position]}>\n <Image style={[styles.eventImage, styles.eventImageMargin[position]]} source={{ uri: currentMessage.attachment.Thumbnail }} />\n <View style={styles.eventInfo}>\n <Text\n numberOfLines={3}\n style={[styles.eventTitle, styles.eventInfoAlign[position], { color: this.props.colourBrandingMain }]}\n >\n {currentMessage.attachment.Title}\n </Text>\n {currentMessage.attachment.StartTime && (\n <Text style={[styles.eventDate, styles.eventInfoAlign[position], { color: this.props.colourBrandingMain }]}>\n {moment\n .utc(currentMessage.attachment.StartTime)\n .local()\n .format('ddd D MMM')}\n </Text>\n )}\n </View>\n </View>\n </TouchableOpacity>\n );\n }\n return null;\n }\n\n renderSend(props) {\n return (\n <View style={[{ position: 'absolute', top: 0, right: 0 }, !!this.state.replyingTo && { marginTop: 38 }]}>\n {(!_.isEmpty(props.text) || this.hasImagesReady(props.imagesToUpload)) && (\n <Send\n {...props}\n alwaysShowSend={true}\n containerStyle={[\n styles.sendContainer,\n {\n width: this.MIN_COMPOSER_HEIGHT,\n height: this.MIN_COMPOSER_HEIGHT,\n },\n ]}\n >\n <Icon name={'paper-plane'} type=\"font-awesome\" iconStyle={[styles.send, { width: this.MIN_COMPOSER_HEIGHT }]} />\n </Send>\n )}\n <TouchableOpacity\n onPress={this.showUploadMenu.bind(this)}\n style={[\n styles.sendContainer,\n {\n right: _.isEmpty(props.text) && !this.hasImagesReady(props.imagesToUpload) ? 0 : 8 + this.MIN_COMPOSER_HEIGHT,\n width: this.MIN_COMPOSER_HEIGHT,\n height: this.MIN_COMPOSER_HEIGHT,\n },\n ]}\n >\n <Icon name={'picture-o'} type=\"font-awesome\" iconStyle={[styles.send, { width: this.MIN_COMPOSER_HEIGHT }]} />\n </TouchableOpacity>\n </View>\n );\n }\n\n renderAccessory(props) {\n const hasAttachment = this.hasImagesAttached(props.imagesToUpload);\n if (!hasAttachment) {\n return null;\n }\n return (\n <ScrollView horizontal style={styles.uploadImagesContainer}>\n {props.imagesToUpload.map(image => {\n if (image.uploading) {\n return (\n <ImageUploadProgress\n key={image.uploadUri}\n uploader={this.imageUploader}\n image={image}\n color={this.props.colourBrandingMain}\n style={{ width: IMAGE_PREVIEW_SIZE, marginRight: 10 }}\n progressTextStyle={{ fontSize: 10 }}\n />\n );\n }\n const isVideoUrl = isVideo(image.url);\n return (\n <View key={image.url} style={styles.accessoryImageContainer}>\n <ImageBackground\n style={styles.accessoryImage}\n imageStyle={styles.accessoryImageBorder}\n source={getImageSource(image.thumbNailExists ? image.thumbNailUrl : image.url)}\n >\n {isVideoUrl && (\n <View style={styles.imagePlayContainer}>\n <TouchableOpacity onPress={this.toggleFullscreenVideo.bind(this, image.url)}>\n <Icon name=\"play\" type=\"font-awesome\" iconStyle={styles.imageControlIcon} />\n </TouchableOpacity>\n </View>\n )}\n </ImageBackground>\n <TouchableOpacity\n style={styles.previewItemRemoveButton}\n onPress={() => this.onRemoveImage(image.url)}\n hitSlop={{ top: 8, right: 8, bottom: 8, left: 8 }}\n >\n <View style={[styles.previewItemRemoveContainer, { backgroundColor: this.props.colourBrandingMain }]}>\n <Icon name=\"times\" type=\"font-awesome\" iconStyle={styles.previewItemRemoveIcon} />\n </View>\n </TouchableOpacity>\n </View>\n );\n })}\n </ScrollView>\n );\n }\n\n renderInputToolbar(props) {\n const hasAttachment = this.hasImagesAttached(props.imagesToUpload);\n return (\n <InputToolbar\n {...props}\n containerStyle={styles.inputContainer}\n renderComposer={this.renderComposer.bind(this)}\n renderAccessory={hasAttachment ? this.renderAccessory.bind(this) : null}\n accessoryStyle={hasAttachment && styles.accessory}\n />\n );\n }\n renderFooter() {\n // if (this.state.keyboardOpen) {\n // return null;\n // }\n // fixes an issue where there's no gap between bottom message and reply container\n return <View style={{ height: 10 }} />;\n }\n renderLoading() {\n return (\n <View style={{ marginTop: 15, justifyContent: 'center', alignContent: 'center' }}>\n <Spinner size={'small'} color={this.props.colourBrandingMain} />\n </View>\n );\n }\n renderAvatar(props) {\n return (\n <View style={{ marginRight: 2 }}>\n <ProfilePic ProfilePic={props.currentMessage.user.avatar} Diameter={28} />\n </View>\n );\n }\n renderComposer(props) {\n return (\n <View style={styles.composerContainer}>\n {this.state.replyingTo && (\n <View style={styles.replyingTo}>\n <TextStyle type=\"body\">\n Replying to {_.isEmpty(this.state.replyingTo?.user?.name) ? 'message' : this.state.replyingTo?.user?.name}\n </TextStyle>\n <TouchableOpacity\n style={styles.replyingRemoveButton}\n onPress={() => this.onReply(null)}\n hitSlop={{ top: 8, right: 8, bottom: 8, left: 8 }}\n >\n <View style={[styles.replyingRemoveContainer, { backgroundColor: this.props.colourBrandingMain }]}>\n <Icon name=\"times\" type=\"font-awesome\" iconStyle={styles.replyingRemoveIcon} />\n </View>\n </TouchableOpacity>\n </View>\n )}\n <View style={styles.composerInputWrapper}>\n <View\n style={[\n styles.input,\n {\n //height: props.composerHeight + 10,\n //borderRadius: (this.MIN_COMPOSER_HEIGHT + 10) / 2,\n marginRight:\n _.isEmpty(props.text) && !this.hasImagesReady(props.imagesToUpload)\n ? 8 + this.MIN_COMPOSER_HEIGHT\n : 2 * (this.MIN_COMPOSER_HEIGHT + 8),\n justifyContent: 'center',\n },\n Platform.OS === 'ios' && {\n height: props.composerHeight + 10,\n },\n ]}\n >\n <Composer\n {...props}\n //composerHeight={props.composerHeight}\n placeholder=\"Type a message...\"\n textInputStyle={styles.inputText}\n textInputProps={{\n onFocus: this.onFocusInput.bind(this),\n onBlur: this.onBlurInput.bind(this),\n }}\n />\n </View>\n </View>\n </View>\n );\n }\n\n /***\n * Main Render\n */\n renderChat() {\n const { tabCount, noTab } = this.props;\n const iosBottomOffset = (tabCount === 1 || noTab ? -10 : 52) + getBottomSpace();\n const minInputToolbarHeight =\n this.MIN_COMPOSER_HEIGHT + 16 + (this.state.replyingTo ? 30 : 0) + (this.hasImagesAttached() ? IMAGE_PREVIEW_AREA_HEIGHT : 0);\n\n return (\n <GiftedChat\n alwaysShowSend={false}\n keyboardShouldPersistTaps={'never'}\n renderAvatarOnTop\n minInputToolbarHeight={minInputToolbarHeight}\n bottomOffset={Platform.OS === 'android' ? 0 : iosBottomOffset}\n onSend={this.sendMessages.bind(this)}\n messages={this.state.messages}\n user={this.state.currentUser}\n renderBubble={this.renderBubble.bind(this)}\n renderMessage={this.renderMessage.bind(this)}\n renderMessageText={this.renderMessageText.bind(this)}\n renderTime={this.renderTime.bind(this)}\n renderDay={this.renderDay.bind(this)}\n renderCustomView={this.renderCustomView.bind(this)}\n renderSend={this.renderSend.bind(this)}\n renderInputToolbar={this.renderInputToolbar.bind(this)}\n renderFooter={this.renderFooter.bind(this)}\n renderLoading={this.renderLoading.bind(this)}\n renderAvatar={this.renderAvatar.bind(this)}\n imagesToUpload={this.state.imagesToUpload}\n />\n );\n }\n\n renderImageUploader() {\n return (\n <ImageUploader\n ref={ref => (this.imageUploader = ref)}\n onUploadStarted={this.onUploadStarted}\n onUploadProgress={this.onUploadProgress}\n onUploadSuccess={this.onUploadSuccess}\n onUploadFailed={this.onUploadFailed}\n onLibrarySelected={this.onLibrarySelected}\n quality={0.8}\n allowsEditing={false}\n fileName={'imageInput'}\n popupTitle={'Add Image'}\n userId={this.props.user.uid}\n multiple\n allowVideo\n />\n );\n }\n\n renderImagePopup() {\n const { imagePopupOpen, imagePopupSource, imagePopupIndex } = this.state;\n return (\n <ImagePopup\n visible={imagePopupOpen}\n images={imagePopupSource}\n index={imagePopupIndex}\n onClose={this.closeGallery.bind(this)}\n ref=\"imagePopup\"\n />\n );\n }\n\n renderVideoPlayerPopup() {\n const { showFullscreenVideo, currentVideoUrl } = this.state;\n if (!currentVideoUrl) return;\n\n return <VideoPopup uri={currentVideoUrl} visible={showFullscreenVideo} onClose={this.toggleFullscreenVideo} />;\n }\n\n renderPDF() {\n if (_.isEmpty(this.state.selectedPDF)) {\n return null;\n }\n return (\n <PDFPopup source={this.state.selectedPDF} onClose={this.onCloseAttachment} title={getFileName(this.state.selectedPDF)} pdfCount={1} />\n );\n }\n\n render() {\n if (Platform.OS === 'android' && !this.props.noAndroidAvoid) {\n return (\n <KeyboardAvoidingView behavior={Platform.OS === 'ios' && 'padding'} style={styles.chatContainer}>\n {this.renderChat()}\n {this.renderImageUploader()}\n {this.renderImagePopup()}\n {this.renderVideoPlayerPopup()}\n {this.renderPDF()}\n </KeyboardAvoidingView>\n );\n }\n return (\n <View style={styles.chatContainer}>\n {this.renderChat()}\n {this.renderImageUploader()}\n {this.renderImagePopup()}\n {this.renderVideoPlayerPopup()}\n {this.renderPDF()}\n </View>\n );\n }\n}\n\nconst styles = {\n chatContainer: {\n flex: 1,\n justifyContent: 'center',\n },\n eventContainer: {\n left: {\n paddingTop: 5,\n paddingLeft: 15,\n paddingRight: 15,\n paddingBottom: 5,\n flexDirection: 'row',\n },\n right: {\n paddingTop: 5,\n paddingLeft: 15,\n paddingRight: 15,\n paddingBottom: 5,\n flexDirection: 'row-reverse',\n },\n },\n eventImage: {\n width: 80,\n height: 80,\n resizeMode: 'cover',\n borderRadius: 2,\n },\n eventImageMargin: {\n right: {\n marginLeft: 15,\n },\n left: {\n marginRight: 15,\n },\n },\n eventInfo: {\n minHeight: 80,\n width: 150,\n },\n eventTitle: {\n fontSize: 12,\n fontFamily: 'sf-bold',\n backgroundColor: 'rgba(255,255,255,0)',\n },\n eventInfoAlign: {\n left: {\n textAlign: 'left',\n },\n right: {\n textAlign: 'right',\n },\n },\n messageImageLarge: {\n width: IMAGE_SIZE_LARGE,\n height: IMAGE_SIZE_LARGE,\n borderRadius: 2,\n alignSelf: 'center',\n },\n messageImageSmall: {\n width: IMAGE_SIZE_SMALL,\n height: IMAGE_SIZE_SMALL,\n borderRadius: 2,\n alignSelf: 'center',\n marginRight: IMAGE_MARGIN,\n marginBottom: IMAGE_MARGIN,\n },\n eventDate: {\n fontSize: 12,\n fontFamily: 'sf-regular',\n backgroundColor: 'rgba(255,255,255,0)',\n },\n inputContainer: {\n backgroundColor: '#fff',\n paddingVertical: 8,\n paddingHorizontal: 8,\n },\n inputText: {\n color: TEXT_DARKEST,\n fontSize: 14,\n fontFamily: 'sf-medium',\n },\n input: {\n margin: 0,\n backgroundColor: BG_GREY,\n borderRadius: 5,\n flex: 1,\n },\n composerContainer: {\n flex: 1,\n },\n composerInputWrapper: {\n flex: 1,\n flexDirection: 'row',\n },\n replyingTo: {\n minHeight: 30,\n flexDirection: 'row',\n alignItems: 'center',\n borderBottomWidth: 1,\n borderBottomColor: LINEGREY,\n marginBottom: 8,\n },\n replyingRemoveButton: {\n marginLeft: 10,\n },\n replyingRemoveContainer: {\n justifyContent: 'center',\n alignItems: 'center',\n borderRadius: 10,\n width: 20,\n height: 20,\n borderWidth: 2,\n borderColor: '#fff',\n },\n replyingRemoveIcon: {\n fontSize: 10,\n color: '#fff',\n marginBottom: 1,\n },\n sendContainer: {\n position: 'absolute',\n top: 0,\n right: 0,\n height: 30,\n width: 30,\n alignItems: 'center',\n justifyContent: 'center',\n backgroundColor: '#fff',\n },\n send: {\n fontSize: 15,\n color: TEXT_BLUEGREY,\n fontSize: 24,\n textAlign: 'center',\n },\n accessory: {\n height: IMAGE_PREVIEW_AREA_HEIGHT,\n borderTopWidth: 1,\n borderTopColor: LINEGREY,\n paddingTop: 8,\n marginTop: 8,\n },\n accessoryImageContainer: {\n paddingRight: 8,\n paddingTop: 8,\n marginRight: 5,\n },\n accessoryImage: {\n width: IMAGE_PREVIEW_SIZE,\n height: IMAGE_PREVIEW_SIZE,\n },\n accessoryImageBorder: {\n borderRadius: 2,\n },\n settingDropDownOpen: {\n height: 'auto',\n },\n imagesContainer: {\n marginLeft: 10,\n marginRight: 10,\n flexDirection: 'row',\n flexWrap: 'wrap',\n },\n uploadImagesContainer: {\n flexDirection: 'row',\n overflow: 'visible',\n },\n previewItemRemoveButton: {\n position: 'absolute',\n top: 0,\n right: 0,\n },\n previewItemRemoveContainer: {\n justifyContent: 'center',\n alignItems: 'center',\n borderRadius: 10,\n width: 20,\n height: 20,\n borderWidth: 2,\n borderColor: '#fff',\n },\n previewItemRemoveIcon: {\n fontSize: 10,\n color: '#fff',\n marginBottom: 1,\n },\n imagePlayContainer: {\n position: 'absolute',\n top: 0,\n left: 0,\n right: 0,\n bottom: 0,\n alignItems: 'center',\n justifyContent: 'center',\n },\n imageControlIcon: {\n color: '#fff',\n fontSize: 20,\n textShadowColor: 'rgba(0,0,0,0.3)',\n textShadowOffset: { width: 2, height: 2 },\n },\n};\n\nconst mapStateToProps = state => {\n return {\n user: state.user,\n colourBrandingMain: getMainBrandingColourFromState(state),\n colourBrandingLight: getLightBrandingColourFromState(state),\n tabCount: getEnabledTabsFromState(state).length,\n };\n};\n\nexport default connect(mapStateToProps, {})(PlussChat);\n"],"mappings":"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","ignoreList":[]}
|
|
1
|
+
{"version":3,"names":["React","Component","View","Image","ImageBackground","TouchableOpacity","Text","KeyboardAvoidingView","Platform","ScrollView","GiftedChat","Bubble","MessageText","Send","InputToolbar","Composer","connect","_","moment","Icon","getBottomSpace","Spinner","ProfilePic","PlussChatTime","PDFPopup","Attachment","PlussChatMessage","TextStyle","TEXT_DARK","LINEGREY","TEXT_DARKEST","getMainBrandingColourFromState","getLightBrandingColourFromState","BG_GREY","TEXT_BLUEGREY","getEnabledTabsFromState","get1400","getThumb300","imageExists","isVideo","getImageSource","getFileName","Config","Services","ImageUploader","ImageUploadProgress","ImagePopup","VideoPopup","IMAGE_SIZE_SMALL","IMAGE_SIZE_LARGE","IMAGES_PER_ROW","IMAGE_MARGIN","IMAGE_PREVIEW_AREA_HEIGHT","IMAGE_PREVIEW_SIZE","PlussChat","constructor","props","_defineProperty","event","navigation","navigate","attachment","Type","place","imagesToUpload","isEmpty","state","upload","hasImagesAttached","every","i","uploading","thumbNailExists","checkThumb","setInterval","Promise","all","map","image","resolve","newImage","push","url","allowRetry","thumbNailUrl","thumbnailsExist","clearInterval","setState","a","selectedPDF","keyboardOpen","uploadUri","imageUri","uploadProgress","progress","img","uri","percentage","replace","waitForThumbnails","images","selected","imagePopupSource","imagePopupIndex","indexOf","imagePopupOpen","message","replyingTo","filter","showFullscreenVideo","length","currentVideoUrl","isSingleTab","tabCount","MIN_COMPOSER_HEIGHT","select","ios","android","currentUser","_id","user","uid","name","displayName","avatar","isUndefined","profilePic","env","tinyChatDefault","messages","UNSAFE_componentWillMount","updateMessages","UNSAFE_componentWillReceiveProps","nextProps","newState","onSend","showUploadMenu","imageUploader","closeGallery","sendMessages","hasImagesReady","text","renderBubble","bubbleProps","wrapperStyle","currentMessage","paddingTop","paddingBottom","minWidth","attachments","paddingHorizontal","createElement","_extends","renderMessageImage","isCustomViewBottom","left","backgroundColor","borderRadius","right","colourBrandingLight","containerToNextStyle","borderBottomLeftRadius","borderBottomRightRadius","containerToPreviousStyle","borderTopLeftRadius","borderTopRightRadius","renderMessage","key","RowId","colourBrandingMain","onPressReply","onReply","renderMessageText","messageTextProps","textStyle","fontFamily","fontSize","color","marginTop","marginBottom","marginLeft","marginRight","linkStyle","renderTime","renderDay","dayProps","renderCustomView","position","containerWidth","style","styles","imagesContainer","width","paddingVertical","thumb","onPress","toggleFullscreenVideo","bind","messageImageSmall","messageImageLarge","source","imagePlayContainer","type","iconStyle","imageControlIcon","onPressImage","onOpenAttachment","title","onPressEvent","eventContainer","eventImage","eventImageMargin","Thumbnail","eventInfo","numberOfLines","eventTitle","eventInfoAlign","Title","eventDate","utc","StartTime","local","format","onPressAttachment","renderSend","top","alwaysShowSend","containerStyle","sendContainer","height","send","renderAccessory","hasAttachment","horizontal","uploadImagesContainer","uploader","progressTextStyle","isVideoUrl","accessoryImageContainer","accessoryImage","imageStyle","accessoryImageBorder","previewItemRemoveButton","onRemoveImage","hitSlop","bottom","previewItemRemoveContainer","previewItemRemoveIcon","renderInputToolbar","inputContainer","renderComposer","accessoryStyle","accessory","renderFooter","renderLoading","justifyContent","alignContent","size","renderAvatar","Diameter","_this$state$replyingT","_this$state$replyingT2","composerContainer","replyingRemoveButton","replyingRemoveContainer","replyingRemoveIcon","composerInputWrapper","input","OS","composerHeight","placeholder","textInputStyle","inputText","textInputProps","onFocus","onFocusInput","onBlur","onBlurInput","renderChat","noTab","iosBottomOffset","minInputToolbarHeight","keyboardShouldPersistTaps","renderAvatarOnTop","bottomOffset","renderImageUploader","ref","onUploadStarted","onUploadProgress","onUploadSuccess","onUploadFailed","onLibrarySelected","quality","allowsEditing","fileName","popupTitle","userId","multiple","allowVideo","renderImagePopup","visible","index","onClose","renderVideoPlayerPopup","renderPDF","onCloseAttachment","pdfCount","render","noAndroidAvoid","behavior","chatContainer","flex","paddingLeft","paddingRight","flexDirection","resizeMode","minHeight","textAlign","alignSelf","margin","alignItems","borderBottomWidth","borderBottomColor","borderWidth","borderColor","borderTopWidth","borderTopColor","settingDropDownOpen","flexWrap","overflow","textShadowColor","textShadowOffset","mapStateToProps"],"sources":["PlussChat.js"],"sourcesContent":["import React, { Component } from 'react';\nimport { View, Image, ImageBackground, TouchableOpacity, Text, KeyboardAvoidingView, Platform, ScrollView } from 'react-native';\nimport { GiftedChat, Bubble, MessageText, Send, InputToolbar, Composer } from 'react-native-gifted-chat';\nimport { connect } from 'react-redux';\nimport _ from 'lodash';\nimport moment from 'moment';\nimport { Icon } from '@rneui/themed';\nimport { getBottomSpace } from 'react-native-iphone-x-helper';\nimport { Spinner } from './Spinner';\nimport { ProfilePic } from './ProfilePic';\nimport PlussChatTime from './PlussChatTime';\nimport { PDFPopup } from './PDFPopup';\nimport { Attachment } from './Attachment';\nimport PlussChatMessage from './PlussChatMessage';\nimport { TextStyle } from './TextStyle';\nimport {\n TEXT_DARK,\n LINEGREY,\n TEXT_DARKEST,\n getMainBrandingColourFromState,\n getLightBrandingColourFromState,\n BG_GREY,\n TEXT_BLUEGREY,\n} from '../colours';\nimport { getEnabledTabsFromState, get1400, getThumb300, imageExists, isVideo, getImageSource, getFileName } from '../helper';\nimport Config, { Services } from '../config';\nimport ImageUploader from './ImageUploader';\nimport ImageUploadProgress from './ImageUploadProgress';\nimport { ImagePopup } from './ImagePopup';\nimport { VideoPopup } from './VideoPopup';\n\nconst IMAGE_SIZE_SMALL = 55;\nconst IMAGE_SIZE_LARGE = 110;\nconst IMAGES_PER_ROW = 4;\nconst IMAGE_MARGIN = 2;\nconst IMAGE_PREVIEW_AREA_HEIGHT = 105;\nconst IMAGE_PREVIEW_SIZE = IMAGE_PREVIEW_AREA_HEIGHT - 25;\n\nclass PlussChat extends Component {\n constructor(props) {\n super(props);\n const isSingleTab = this.props.tabCount === 1 && getBottomSpace() > 0;\n this.MIN_COMPOSER_HEIGHT = Platform.select({\n ios: isSingleTab ? 42 : 33,\n android: 41,\n });\n\n this.state = {\n currentUser: {\n _id: this.props.user.uid,\n name: this.props.user.displayName,\n avatar:\n !_.isUndefined(this.props.user.profilePic) && !_.isEmpty(this.props.user.profilePic)\n ? this.props.user.profilePic\n : Config.env.tinyChatDefault,\n },\n\n messages: [],\n imagePopupSource: [],\n imagePopupIndex: 0,\n imagePopupOpen: false,\n imagesToUpload: [],\n showFullscreenVideo: false,\n currentVideoUrl: '',\n };\n this.checkThumb = null;\n }\n\n UNSAFE_componentWillMount() {\n this.updateMessages(this.props);\n }\n\n UNSAFE_componentWillReceiveProps(nextProps) {\n this.updateMessages(nextProps);\n }\n\n updateMessages(props) {\n const newState = {};\n if (!_.isUndefined(props.messages)) {\n newState.messages = props.messages;\n }\n this.setState(newState);\n }\n\n /***\n *\n * Messaging functionality\n */\n onSend(messages = []) {\n // if (this.chatKey) {\n // this.sendMessage(messages[0]);\n // }\n }\n\n onPressEvent = event => {\n Services.navigation.navigate('eventDetail', { event });\n };\n onPressAttachment = attachment => {\n switch (attachment.Type) {\n case 'Event':\n Services.navigation.navigate('eventDetail', { event: attachment });\n break;\n case 'Place':\n Services.navigation.navigate('placeDetail', { place: attachment });\n break;\n default:\n return;\n }\n };\n\n hasImagesAttached = (imagesToUpload = null) => {\n return !_.isEmpty(imagesToUpload || this.state.imagesToUpload);\n };\n\n hasImagesReady = (imagesToUpload = null) => {\n const upload = imagesToUpload || this.state.imagesToUpload;\n return this.hasImagesAttached(upload) && upload.every(i => !i.uploading && i.thumbNailExists);\n };\n\n waitForThumbnails = () => {\n if (this.checkThumb) return;\n\n this.checkThumb = setInterval(async () => {\n const imagesToUpload = [];\n await Promise.all(\n this.state.imagesToUpload.map(image => {\n return new Promise(async resolve => {\n const newImage = { ...image };\n imagesToUpload.push(newImage);\n if (newImage.url && !newImage.thumbNailExists) {\n newImage.uploading = false;\n newImage.allowRetry = false;\n newImage.thumbNailExists = await imageExists(newImage.thumbNailUrl);\n resolve(newImage.thumbNailExists);\n }\n resolve(true);\n });\n }),\n );\n const thumbnailsExist = imagesToUpload.every(image => !image.url || image.thumbNailExists);\n if (thumbnailsExist) {\n clearInterval(this.checkThumb);\n this.checkThumb = null;\n this.setState({ imagesToUpload });\n }\n }, 2000);\n };\n\n onOpenAttachment = a => {\n this.setState({\n selectedPDF: a,\n });\n };\n\n onCloseAttachment = () => {\n this.setState({\n selectedPDF: null,\n });\n };\n\n showUploadMenu() {\n this.imageUploader.showUploadMenu();\n }\n\n onFocusInput = () => {\n this.setState({\n keyboardOpen: true,\n });\n if (this.props.keyboardOpen) {\n this.props.keyboardOpen();\n }\n };\n\n onBlurInput = () => {\n this.setState({\n keyboardOpen: false,\n });\n };\n\n onUploadStarted = (uploadUri, imageUri) => {\n const imagesToUpload = [\n ...this.state.imagesToUpload,\n {\n uploading: true,\n uploadProgress: '0%',\n uploadUri,\n imageUri,\n allowRetry: true,\n },\n ];\n this.setState({ imagesToUpload });\n };\n\n onUploadProgress = progress => {\n const imagesToUpload = [...this.state.imagesToUpload];\n imagesToUpload.map(img => {\n if (img.uploadUri === progress.uri) {\n img.uploadProgress = progress.percentage;\n img.uploading = true;\n img.allowRetry = true;\n }\n });\n this.setState({ imagesToUpload });\n };\n\n onUploadSuccess = async (uri, uploadUri) => {\n const imagesToUpload = [...this.state.imagesToUpload];\n imagesToUpload.map(img => {\n if (img.uploadUri === uploadUri && img.uploading) {\n img.url = uri.replace('/general/', '/general1400/');\n img.thumbNailExists = false;\n img.thumbNailUrl = getThumb300(img.url);\n img.allowRetry = true;\n }\n });\n this.setState({ imagesToUpload }, () => this.waitForThumbnails());\n };\n\n onUploadFailed = uploadUri => {\n const imagesToUpload = [...this.state.imagesToUpload];\n imagesToUpload.map(img => {\n if (img.uploadUri === uploadUri) {\n img.uploading = true; // Requried for retry\n img.uploadProgress = '';\n img.allowRetry = true;\n }\n });\n this.setState({ imagesToUpload });\n };\n\n onLibrarySelected = uri => {\n const imagesToUpload = [\n ...this.state.imagesToUpload,\n {\n uploading: false,\n allowRetry: false,\n url: get1400(uri),\n thumbNailExists: true,\n thumbNailUrl: getThumb300(uri),\n },\n ];\n this.setState({ imagesToUpload });\n };\n\n onPressImage = (images, selected) => {\n this.setState({\n imagePopupSource: images,\n imagePopupIndex: images.indexOf(selected),\n imagePopupOpen: true,\n });\n };\n\n onReply = message => {\n this.setState({\n replyingTo: message,\n });\n };\n\n closeGallery() {\n this.setState({\n imagePopupSource: [],\n imagePopupIndex: 0,\n imagePopupOpen: false,\n });\n }\n\n onRemoveImage = url => {\n const imagesToUpload = this.state.imagesToUpload.filter(image => image.url !== url);\n this.setState({ imagesToUpload });\n };\n\n toggleFullscreenVideo = url => {\n if (typeof url !== 'string') url = '';\n this.setState({ showFullscreenVideo: url.length > 0, currentVideoUrl: url });\n };\n\n sendMessages(messages) {\n if (this.hasImagesAttached()) {\n // Don't allow send if attached images aren't ready\n if (!this.hasImagesReady()) return;\n messages[0].image = this.state.imagesToUpload.map(image => image.url);\n }\n if (_.isEmpty(messages[0].text)) {\n messages[0].text = '';\n }\n if (!messages[0].text && !messages[0].image) return;\n\n if (this.state.replyingTo) {\n messages[0].replyingTo = this.state.replyingTo;\n }\n\n this.props.onSend(messages);\n this.setState({ imagesToUpload: [], replyingTo: null });\n }\n\n /**\n *\n * Render Functions\n */\n renderBubble(bubbleProps) {\n const wrapperStyle = {};\n if (!_.isEmpty(bubbleProps.currentMessage.text) && !_.isEmpty(bubbleProps.currentMessage.image)) {\n wrapperStyle.paddingTop = 8;\n wrapperStyle.paddingBottom = 16;\n wrapperStyle.minWidth = 142; // 110 image width + 16 padding either side\n }\n if (!_.isEmpty(bubbleProps.currentMessage.attachments)) {\n wrapperStyle.paddingTop = 8;\n wrapperStyle.paddingBottom = 16;\n wrapperStyle.paddingHorizontal = 16;\n }\n return (\n <Bubble\n {...bubbleProps}\n renderMessageImage={() => null}\n isCustomViewBottom={true}\n wrapperStyle={{\n left: {\n backgroundColor: LINEGREY,\n borderRadius: 25,\n ...wrapperStyle,\n },\n right: {\n backgroundColor: this.props.colourBrandingLight,\n borderRadius: 25,\n ...wrapperStyle,\n },\n }}\n containerToNextStyle={{\n left: {\n borderBottomLeftRadius: 5,\n },\n right: {\n borderBottomRightRadius: 5,\n },\n }}\n containerToPreviousStyle={{\n left: {\n borderTopLeftRadius: 5,\n },\n right: {\n borderTopRightRadius: 5,\n },\n }}\n />\n );\n }\n renderMessage(props) {\n return (\n <PlussChatMessage\n key={props.RowId}\n colourBrandingMain={this.props.colourBrandingMain}\n onPressReply={() => {\n this.onReply(props.currentMessage);\n }}\n {...props}\n />\n );\n }\n renderMessageText(messageTextProps) {\n return (\n <MessageText\n {...messageTextProps}\n textStyle={{\n left: {\n fontFamily: 'sf-regular',\n fontSize: 16,\n color: TEXT_DARKEST,\n marginTop: 10,\n marginBottom: 10,\n marginLeft: 15,\n marginRight: 15,\n },\n right: {\n fontFamily: 'sf-regular',\n fontSize: 16,\n color: this.props.colourBrandingMain,\n marginTop: 10,\n marginBottom: 10,\n marginLeft: 15,\n marginRight: 15,\n },\n }}\n linkStyle={{\n left: {\n color: TEXT_DARKEST,\n },\n right: {\n color: this.props.colourBrandingMain,\n },\n }}\n />\n );\n }\n renderTime() {\n return null;\n }\n renderDay(dayProps) {\n return (\n <PlussChatTime\n {...dayProps}\n textStyle={{\n fontFamily: 'sf-semibold',\n color: TEXT_DARK,\n fontSize: 12,\n }}\n />\n );\n }\n renderCustomView({ currentMessage, position }) {\n if (currentMessage.image) {\n const images = typeof currentMessage.image === 'string' ? [currentMessage.image] : currentMessage.image;\n const containerWidth = (() => {\n if (images.length === 0) return 0;\n if (images.length === 1) return IMAGE_SIZE_LARGE;\n if (images.length <= IMAGES_PER_ROW) return (IMAGE_SIZE_SMALL + IMAGE_MARGIN) * images.length;\n return (IMAGE_SIZE_SMALL + IMAGE_MARGIN) * IMAGES_PER_ROW;\n })();\n return (\n <View style={[styles.imagesContainer, { width: containerWidth, paddingVertical: currentMessage.text ? 0 : 20 }]}>\n {images.map(img => {\n const thumb = getThumb300(img);\n if (isVideo(img)) {\n return (\n <TouchableOpacity key={thumb} onPress={this.toggleFullscreenVideo.bind(this, img)}>\n <ImageBackground style={images.length > 1 ? styles.messageImageSmall : styles.messageImageLarge} source={{ uri: thumb }}>\n <View style={styles.imagePlayContainer}>\n <Icon name=\"play\" type=\"font-awesome\" iconStyle={styles.imageControlIcon} />\n </View>\n </ImageBackground>\n </TouchableOpacity>\n );\n }\n return (\n <TouchableOpacity key={thumb} onPress={() => this.onPressImage(images, img)}>\n <Image source={{ uri: thumb }} style={images.length > 1 ? styles.messageImageSmall : styles.messageImageLarge} />\n </TouchableOpacity>\n );\n })}\n </View>\n );\n }\n if (!_.isEmpty(currentMessage.attachments)) {\n return (\n <View>\n {currentMessage.attachments.map((url, i) => {\n return (\n <Attachment\n onPress={() => {\n this.onOpenAttachment(url);\n }}\n key={i}\n title={getFileName(url)}\n />\n );\n })}\n </View>\n );\n }\n if (currentMessage.event) {\n return (\n <TouchableOpacity onPress={this.onPressEvent.bind(this, currentMessage.event)}>\n <View style={styles.eventContainer[position]}>\n <Image style={[styles.eventImage, styles.eventImageMargin[position]]} source={{ uri: currentMessage.event.Thumbnail }} />\n <View style={styles.eventInfo}>\n <Text\n numberOfLines={3}\n style={[styles.eventTitle, styles.eventInfoAlign[position], { color: this.props.colourBrandingMain }]}\n >\n {currentMessage.event.Title}\n </Text>\n <Text style={[styles.eventDate, styles.eventInfoAlign[position], { color: this.props.colourBrandingMain }]}>\n {moment\n .utc(currentMessage.event.StartTime)\n .local()\n .format('ddd D MMM')}\n </Text>\n </View>\n </View>\n </TouchableOpacity>\n );\n }\n if (currentMessage.attachment) {\n return (\n <TouchableOpacity onPress={this.onPressAttachment.bind(this, currentMessage.attachment)}>\n <View style={styles.eventContainer[position]}>\n <Image style={[styles.eventImage, styles.eventImageMargin[position]]} source={{ uri: currentMessage.attachment.Thumbnail }} />\n <View style={styles.eventInfo}>\n <Text\n numberOfLines={3}\n style={[styles.eventTitle, styles.eventInfoAlign[position], { color: this.props.colourBrandingMain }]}\n >\n {currentMessage.attachment.Title}\n </Text>\n {currentMessage.attachment.StartTime && (\n <Text style={[styles.eventDate, styles.eventInfoAlign[position], { color: this.props.colourBrandingMain }]}>\n {moment\n .utc(currentMessage.attachment.StartTime)\n .local()\n .format('ddd D MMM')}\n </Text>\n )}\n </View>\n </View>\n </TouchableOpacity>\n );\n }\n return null;\n }\n\n renderSend(props) {\n return (\n <View style={[{ position: 'absolute', top: 0, right: 0 }, !!this.state.replyingTo && { marginTop: 38 }]}>\n {(!_.isEmpty(props.text) || this.hasImagesReady(props.imagesToUpload)) && (\n <Send\n {...props}\n alwaysShowSend={true}\n containerStyle={[\n styles.sendContainer,\n {\n width: this.MIN_COMPOSER_HEIGHT,\n height: this.MIN_COMPOSER_HEIGHT,\n },\n ]}\n >\n <Icon name={'paper-plane'} type=\"font-awesome\" iconStyle={[styles.send, { width: this.MIN_COMPOSER_HEIGHT }]} />\n </Send>\n )}\n <TouchableOpacity\n onPress={this.showUploadMenu.bind(this)}\n style={[\n styles.sendContainer,\n {\n right: _.isEmpty(props.text) && !this.hasImagesReady(props.imagesToUpload) ? 0 : 8 + this.MIN_COMPOSER_HEIGHT,\n width: this.MIN_COMPOSER_HEIGHT,\n height: this.MIN_COMPOSER_HEIGHT,\n },\n ]}\n >\n <Icon name={'picture-o'} type=\"font-awesome\" iconStyle={[styles.send, { width: this.MIN_COMPOSER_HEIGHT }]} />\n </TouchableOpacity>\n </View>\n );\n }\n\n renderAccessory(props) {\n const hasAttachment = this.hasImagesAttached(props.imagesToUpload);\n if (!hasAttachment) {\n return null;\n }\n return (\n <ScrollView horizontal style={styles.uploadImagesContainer}>\n {props.imagesToUpload.map(image => {\n if (image.uploading) {\n return (\n <ImageUploadProgress\n key={image.uploadUri}\n uploader={this.imageUploader}\n image={image}\n color={this.props.colourBrandingMain}\n style={{ width: IMAGE_PREVIEW_SIZE, marginRight: 10 }}\n progressTextStyle={{ fontSize: 10 }}\n />\n );\n }\n const isVideoUrl = isVideo(image.url);\n return (\n <View key={image.url} style={styles.accessoryImageContainer}>\n <ImageBackground\n style={styles.accessoryImage}\n imageStyle={styles.accessoryImageBorder}\n source={getImageSource(image.thumbNailExists ? image.thumbNailUrl : image.url)}\n >\n {isVideoUrl && (\n <View style={styles.imagePlayContainer}>\n <TouchableOpacity onPress={this.toggleFullscreenVideo.bind(this, image.url)}>\n <Icon name=\"play\" type=\"font-awesome\" iconStyle={styles.imageControlIcon} />\n </TouchableOpacity>\n </View>\n )}\n </ImageBackground>\n <TouchableOpacity\n style={styles.previewItemRemoveButton}\n onPress={() => this.onRemoveImage(image.url)}\n hitSlop={{ top: 8, right: 8, bottom: 8, left: 8 }}\n >\n <View style={[styles.previewItemRemoveContainer, { backgroundColor: this.props.colourBrandingMain }]}>\n <Icon name=\"times\" type=\"font-awesome\" iconStyle={styles.previewItemRemoveIcon} />\n </View>\n </TouchableOpacity>\n </View>\n );\n })}\n </ScrollView>\n );\n }\n\n renderInputToolbar(props) {\n const hasAttachment = this.hasImagesAttached(props.imagesToUpload);\n return (\n <InputToolbar\n {...props}\n containerStyle={styles.inputContainer}\n renderComposer={this.renderComposer.bind(this)}\n renderAccessory={hasAttachment ? this.renderAccessory.bind(this) : null}\n accessoryStyle={hasAttachment && styles.accessory}\n />\n );\n }\n renderFooter() {\n // if (this.state.keyboardOpen) {\n // return null;\n // }\n // fixes an issue where there's no gap between bottom message and reply container\n return <View style={{ height: 10 }} />;\n }\n renderLoading() {\n return (\n <View style={{ marginTop: 15, justifyContent: 'center', alignContent: 'center' }}>\n <Spinner size={'small'} color={this.props.colourBrandingMain} />\n </View>\n );\n }\n renderAvatar(props) {\n return (\n <View style={{ marginRight: 2 }}>\n <ProfilePic ProfilePic={props.currentMessage.user.avatar} Diameter={28} />\n </View>\n );\n }\n renderComposer(props) {\n return (\n <View style={styles.composerContainer}>\n {this.state.replyingTo && (\n <View style={styles.replyingTo}>\n <TextStyle type=\"body\">\n Replying to {_.isEmpty(this.state.replyingTo?.user?.name) ? 'message' : this.state.replyingTo?.user?.name}\n </TextStyle>\n <TouchableOpacity\n style={styles.replyingRemoveButton}\n onPress={() => this.onReply(null)}\n hitSlop={{ top: 8, right: 8, bottom: 8, left: 8 }}\n >\n <View style={[styles.replyingRemoveContainer, { backgroundColor: this.props.colourBrandingMain }]}>\n <Icon name=\"times\" type=\"font-awesome\" iconStyle={styles.replyingRemoveIcon} />\n </View>\n </TouchableOpacity>\n </View>\n )}\n <View style={styles.composerInputWrapper}>\n <View\n style={[\n styles.input,\n {\n //height: props.composerHeight + 10,\n //borderRadius: (this.MIN_COMPOSER_HEIGHT + 10) / 2,\n marginRight:\n _.isEmpty(props.text) && !this.hasImagesReady(props.imagesToUpload)\n ? 8 + this.MIN_COMPOSER_HEIGHT\n : 2 * (this.MIN_COMPOSER_HEIGHT + 8),\n justifyContent: 'center',\n },\n Platform.OS === 'ios' && {\n height: props.composerHeight + 10,\n },\n ]}\n >\n <Composer\n {...props}\n //composerHeight={props.composerHeight}\n placeholder=\"Type a message...\"\n textInputStyle={styles.inputText}\n textInputProps={{\n onFocus: this.onFocusInput.bind(this),\n onBlur: this.onBlurInput.bind(this),\n }}\n />\n </View>\n </View>\n </View>\n );\n }\n\n /***\n * Main Render\n */\n renderChat() {\n const { tabCount, noTab } = this.props;\n const iosBottomOffset = (tabCount === 1 || noTab ? -10 : 52) + getBottomSpace();\n const minInputToolbarHeight =\n this.MIN_COMPOSER_HEIGHT + 16 + (this.state.replyingTo ? 30 : 0) + (this.hasImagesAttached() ? IMAGE_PREVIEW_AREA_HEIGHT : 0);\n\n return (\n <GiftedChat\n alwaysShowSend={false}\n keyboardShouldPersistTaps={'never'}\n renderAvatarOnTop\n minInputToolbarHeight={minInputToolbarHeight}\n bottomOffset={Platform.OS === 'android' ? 0 : iosBottomOffset}\n onSend={this.sendMessages.bind(this)}\n messages={this.state.messages}\n user={this.state.currentUser}\n renderBubble={this.renderBubble.bind(this)}\n renderMessage={this.renderMessage.bind(this)}\n renderMessageText={this.renderMessageText.bind(this)}\n renderTime={this.renderTime.bind(this)}\n renderDay={this.renderDay.bind(this)}\n renderCustomView={this.renderCustomView.bind(this)}\n renderSend={this.renderSend.bind(this)}\n renderInputToolbar={this.renderInputToolbar.bind(this)}\n renderFooter={this.renderFooter.bind(this)}\n renderLoading={this.renderLoading.bind(this)}\n renderAvatar={this.renderAvatar.bind(this)}\n imagesToUpload={this.state.imagesToUpload}\n />\n );\n }\n\n renderImageUploader() {\n return (\n <ImageUploader\n ref={ref => (this.imageUploader = ref)}\n onUploadStarted={this.onUploadStarted}\n onUploadProgress={this.onUploadProgress}\n onUploadSuccess={this.onUploadSuccess}\n onUploadFailed={this.onUploadFailed}\n onLibrarySelected={this.onLibrarySelected}\n quality={0.8}\n allowsEditing={false}\n fileName={'imageInput'}\n popupTitle={'Add Image'}\n userId={this.props.user.uid}\n multiple\n allowVideo\n />\n );\n }\n\n renderImagePopup() {\n const { imagePopupOpen, imagePopupSource, imagePopupIndex } = this.state;\n return (\n <ImagePopup\n visible={imagePopupOpen}\n images={imagePopupSource}\n index={imagePopupIndex}\n onClose={this.closeGallery.bind(this)}\n ref=\"imagePopup\"\n />\n );\n }\n\n renderVideoPlayerPopup() {\n const { showFullscreenVideo, currentVideoUrl } = this.state;\n if (!currentVideoUrl) return;\n\n return <VideoPopup uri={currentVideoUrl} visible={showFullscreenVideo} onClose={this.toggleFullscreenVideo} />;\n }\n\n renderPDF() {\n if (_.isEmpty(this.state.selectedPDF)) {\n return null;\n }\n return (\n <PDFPopup source={this.state.selectedPDF} onClose={this.onCloseAttachment} title={getFileName(this.state.selectedPDF)} pdfCount={1} />\n );\n }\n\n render() {\n if (Platform.OS === 'android' && !this.props.noAndroidAvoid) {\n return (\n <KeyboardAvoidingView behavior={Platform.OS === 'ios' && 'padding'} style={styles.chatContainer}>\n {this.renderChat()}\n {this.renderImageUploader()}\n {this.renderImagePopup()}\n {this.renderVideoPlayerPopup()}\n {this.renderPDF()}\n </KeyboardAvoidingView>\n );\n }\n return (\n <View style={styles.chatContainer}>\n {this.renderChat()}\n {this.renderImageUploader()}\n {this.renderImagePopup()}\n {this.renderVideoPlayerPopup()}\n {this.renderPDF()}\n </View>\n );\n }\n}\n\nconst styles = {\n chatContainer: {\n flex: 1,\n justifyContent: 'center',\n },\n eventContainer: {\n left: {\n paddingTop: 5,\n paddingLeft: 15,\n paddingRight: 15,\n paddingBottom: 5,\n flexDirection: 'row',\n },\n right: {\n paddingTop: 5,\n paddingLeft: 15,\n paddingRight: 15,\n paddingBottom: 5,\n flexDirection: 'row-reverse',\n },\n },\n eventImage: {\n width: 80,\n height: 80,\n resizeMode: 'cover',\n borderRadius: 2,\n },\n eventImageMargin: {\n right: {\n marginLeft: 15,\n },\n left: {\n marginRight: 15,\n },\n },\n eventInfo: {\n minHeight: 80,\n width: 150,\n },\n eventTitle: {\n fontSize: 12,\n fontFamily: 'sf-bold',\n backgroundColor: 'rgba(255,255,255,0)',\n },\n eventInfoAlign: {\n left: {\n textAlign: 'left',\n },\n right: {\n textAlign: 'right',\n },\n },\n messageImageLarge: {\n width: IMAGE_SIZE_LARGE,\n height: IMAGE_SIZE_LARGE,\n borderRadius: 2,\n alignSelf: 'center',\n },\n messageImageSmall: {\n width: IMAGE_SIZE_SMALL,\n height: IMAGE_SIZE_SMALL,\n borderRadius: 2,\n alignSelf: 'center',\n marginRight: IMAGE_MARGIN,\n marginBottom: IMAGE_MARGIN,\n },\n eventDate: {\n fontSize: 12,\n fontFamily: 'sf-regular',\n backgroundColor: 'rgba(255,255,255,0)',\n },\n inputContainer: {\n backgroundColor: '#fff',\n paddingVertical: 8,\n paddingHorizontal: 8,\n },\n inputText: {\n color: TEXT_DARKEST,\n fontSize: 14,\n fontFamily: 'sf-medium',\n },\n input: {\n margin: 0,\n backgroundColor: BG_GREY,\n borderRadius: 5,\n flex: 1,\n },\n composerContainer: {\n flex: 1,\n },\n composerInputWrapper: {\n flex: 1,\n flexDirection: 'row',\n },\n replyingTo: {\n minHeight: 30,\n flexDirection: 'row',\n alignItems: 'center',\n borderBottomWidth: 1,\n borderBottomColor: LINEGREY,\n marginBottom: 8,\n },\n replyingRemoveButton: {\n marginLeft: 10,\n },\n replyingRemoveContainer: {\n justifyContent: 'center',\n alignItems: 'center',\n borderRadius: 10,\n width: 20,\n height: 20,\n borderWidth: 2,\n borderColor: '#fff',\n },\n replyingRemoveIcon: {\n fontSize: 10,\n color: '#fff',\n marginBottom: 1,\n },\n sendContainer: {\n position: 'absolute',\n top: 0,\n right: 0,\n height: 30,\n width: 30,\n alignItems: 'center',\n justifyContent: 'center',\n backgroundColor: '#fff',\n },\n send: {\n fontSize: 15,\n color: TEXT_BLUEGREY,\n fontSize: 24,\n textAlign: 'center',\n },\n accessory: {\n height: IMAGE_PREVIEW_AREA_HEIGHT,\n borderTopWidth: 1,\n borderTopColor: LINEGREY,\n paddingTop: 8,\n marginTop: 8,\n },\n accessoryImageContainer: {\n paddingRight: 8,\n paddingTop: 8,\n marginRight: 5,\n },\n accessoryImage: {\n width: IMAGE_PREVIEW_SIZE,\n height: IMAGE_PREVIEW_SIZE,\n },\n accessoryImageBorder: {\n borderRadius: 2,\n },\n settingDropDownOpen: {\n height: 'auto',\n },\n imagesContainer: {\n marginLeft: 10,\n marginRight: 10,\n flexDirection: 'row',\n flexWrap: 'wrap',\n },\n uploadImagesContainer: {\n flexDirection: 'row',\n overflow: 'visible',\n },\n previewItemRemoveButton: {\n position: 'absolute',\n top: 0,\n right: 0,\n },\n previewItemRemoveContainer: {\n justifyContent: 'center',\n alignItems: 'center',\n borderRadius: 10,\n width: 20,\n height: 20,\n borderWidth: 2,\n borderColor: '#fff',\n },\n previewItemRemoveIcon: {\n fontSize: 10,\n color: '#fff',\n marginBottom: 1,\n },\n imagePlayContainer: {\n position: 'absolute',\n top: 0,\n left: 0,\n right: 0,\n bottom: 0,\n alignItems: 'center',\n justifyContent: 'center',\n },\n imageControlIcon: {\n color: '#fff',\n fontSize: 20,\n textShadowColor: 'rgba(0,0,0,0.3)',\n textShadowOffset: { width: 2, height: 2 },\n },\n};\n\nconst mapStateToProps = state => {\n return {\n user: state.user,\n colourBrandingMain: getMainBrandingColourFromState(state),\n colourBrandingLight: getLightBrandingColourFromState(state),\n tabCount: getEnabledTabsFromState(state).length,\n };\n};\n\nexport default connect(mapStateToProps, {})(PlussChat);\n"],"mappings":";;;;AAAA,OAAOA,KAAK,IAAIC,SAAS,QAAQ,OAAO;AACxC,SAASC,IAAI,EAAEC,KAAK,EAAEC,eAAe,EAAEC,gBAAgB,EAAEC,IAAI,EAAEC,oBAAoB,EAAEC,QAAQ,EAAEC,UAAU,QAAQ,cAAc;AAC/H,SAASC,UAAU,EAAEC,MAAM,EAAEC,WAAW,EAAEC,IAAI,EAAEC,YAAY,EAAEC,QAAQ,QAAQ,0BAA0B;AACxG,SAASC,OAAO,QAAQ,aAAa;AACrC,OAAOC,CAAC,MAAM,QAAQ;AACtB,OAAOC,MAAM,MAAM,QAAQ;AAC3B,SAASC,IAAI,QAAQ,eAAe;AACpC,SAASC,cAAc,QAAQ,8BAA8B;AAC7D,SAASC,OAAO,QAAQ,WAAW;AACnC,SAASC,UAAU,QAAQ,cAAc;AACzC,OAAOC,aAAa,MAAM,iBAAiB;AAC3C,SAASC,QAAQ,QAAQ,YAAY;AACrC,SAASC,UAAU,QAAQ,cAAc;AACzC,OAAOC,gBAAgB,MAAM,oBAAoB;AACjD,SAASC,SAAS,QAAQ,aAAa;AACvC,SACEC,SAAS,EACTC,QAAQ,EACRC,YAAY,EACZC,8BAA8B,EAC9BC,+BAA+B,EAC/BC,OAAO,EACPC,aAAa,QACR,YAAY;AACnB,SAASC,uBAAuB,EAAEC,OAAO,EAAEC,WAAW,EAAEC,WAAW,EAAEC,OAAO,EAAEC,cAAc,EAAEC,WAAW,QAAQ,WAAW;AAC5H,OAAOC,MAAM,IAAIC,QAAQ,QAAQ,WAAW;AAC5C,OAAOC,aAAa,MAAM,iBAAiB;AAC3C,OAAOC,mBAAmB,MAAM,uBAAuB;AACvD,SAASC,UAAU,QAAQ,cAAc;AACzC,SAASC,UAAU,QAAQ,cAAc;AAEzC,MAAMC,gBAAgB,GAAG,EAAE;AAC3B,MAAMC,gBAAgB,GAAG,GAAG;AAC5B,MAAMC,cAAc,GAAG,CAAC;AACxB,MAAMC,YAAY,GAAG,CAAC;AACtB,MAAMC,yBAAyB,GAAG,GAAG;AACrC,MAAMC,kBAAkB,GAAGD,yBAAyB,GAAG,EAAE;AAEzD,MAAME,SAAS,SAASrD,SAAS,CAAC;EAChCsD,WAAWA,CAACC,KAAK,EAAE;IACjB,KAAK,CAACA,KAAK,CAAC;IAACC,eAAA,uBAsDAC,KAAK,IAAI;MACtBf,QAAQ,CAACgB,UAAU,CAACC,QAAQ,CAAC,aAAa,EAAE;QAAEF;MAAM,CAAC,CAAC;IACxD,CAAC;IAAAD,eAAA,4BACmBI,UAAU,IAAI;MAChC,QAAQA,UAAU,CAACC,IAAI;QACrB,KAAK,OAAO;UACVnB,QAAQ,CAACgB,UAAU,CAACC,QAAQ,CAAC,aAAa,EAAE;YAAEF,KAAK,EAAEG;UAAW,CAAC,CAAC;UAClE;QACF,KAAK,OAAO;UACVlB,QAAQ,CAACgB,UAAU,CAACC,QAAQ,CAAC,aAAa,EAAE;YAAEG,KAAK,EAAEF;UAAW,CAAC,CAAC;UAClE;QACF;UACE;MACJ;IACF,CAAC;IAAAJ,eAAA,4BAEmB,CAACO,cAAc,GAAG,IAAI,KAAK;MAC7C,OAAO,CAAC/C,CAAC,CAACgD,OAAO,CAACD,cAAc,IAAI,IAAI,CAACE,KAAK,CAACF,cAAc,CAAC;IAChE,CAAC;IAAAP,eAAA,yBAEgB,CAACO,cAAc,GAAG,IAAI,KAAK;MAC1C,MAAMG,MAAM,GAAGH,cAAc,IAAI,IAAI,CAACE,KAAK,CAACF,cAAc;MAC1D,OAAO,IAAI,CAACI,iBAAiB,CAACD,MAAM,CAAC,IAAIA,MAAM,CAACE,KAAK,CAACC,CAAC,IAAI,CAACA,CAAC,CAACC,SAAS,IAAID,CAAC,CAACE,eAAe,CAAC;IAC/F,CAAC;IAAAf,eAAA,4BAEmB,MAAM;MACxB,IAAI,IAAI,CAACgB,UAAU,EAAE;MAErB,IAAI,CAACA,UAAU,GAAGC,WAAW,CAAC,YAAY;QACxC,MAAMV,cAAc,GAAG,EAAE;QACzB,MAAMW,OAAO,CAACC,GAAG,CACf,IAAI,CAACV,KAAK,CAACF,cAAc,CAACa,GAAG,CAACC,KAAK,IAAI;UACrC,OAAO,IAAIH,OAAO,CAAC,MAAMI,OAAO,IAAI;YAClC,MAAMC,QAAQ,GAAG;cAAE,GAAGF;YAAM,CAAC;YAC7Bd,cAAc,CAACiB,IAAI,CAACD,QAAQ,CAAC;YAC7B,IAAIA,QAAQ,CAACE,GAAG,IAAI,CAACF,QAAQ,CAACR,eAAe,EAAE;cAC7CQ,QAAQ,CAACT,SAAS,GAAG,KAAK;cAC1BS,QAAQ,CAACG,UAAU,GAAG,KAAK;cAC3BH,QAAQ,CAACR,eAAe,GAAG,MAAMlC,WAAW,CAAC0C,QAAQ,CAACI,YAAY,CAAC;cACnEL,OAAO,CAACC,QAAQ,CAACR,eAAe,CAAC;YACnC;YACAO,OAAO,CAAC,IAAI,CAAC;UACf,CAAC,CAAC;QACJ,CAAC,CACH,CAAC;QACD,MAAMM,eAAe,GAAGrB,cAAc,CAACK,KAAK,CAACS,KAAK,IAAI,CAACA,KAAK,CAACI,GAAG,IAAIJ,KAAK,CAACN,eAAe,CAAC;QAC1F,IAAIa,eAAe,EAAE;UACnBC,aAAa,CAAC,IAAI,CAACb,UAAU,CAAC;UAC9B,IAAI,CAACA,UAAU,GAAG,IAAI;UACtB,IAAI,CAACc,QAAQ,CAAC;YAAEvB;UAAe,CAAC,CAAC;QACnC;MACF,CAAC,EAAE,IAAI,CAAC;IACV,CAAC;IAAAP,eAAA,2BAEkB+B,CAAC,IAAI;MACtB,IAAI,CAACD,QAAQ,CAAC;QACZE,WAAW,EAAED;MACf,CAAC,CAAC;IACJ,CAAC;IAAA/B,eAAA,4BAEmB,MAAM;MACxB,IAAI,CAAC8B,QAAQ,CAAC;QACZE,WAAW,EAAE;MACf,CAAC,CAAC;IACJ,CAAC;IAAAhC,eAAA,uBAMc,MAAM;MACnB,IAAI,CAAC8B,QAAQ,CAAC;QACZG,YAAY,EAAE;MAChB,CAAC,CAAC;MACF,IAAI,IAAI,CAAClC,KAAK,CAACkC,YAAY,EAAE;QAC3B,IAAI,CAAClC,KAAK,CAACkC,YAAY,CAAC,CAAC;MAC3B;IACF,CAAC;IAAAjC,eAAA,sBAEa,MAAM;MAClB,IAAI,CAAC8B,QAAQ,CAAC;QACZG,YAAY,EAAE;MAChB,CAAC,CAAC;IACJ,CAAC;IAAAjC,eAAA,0BAEiB,CAACkC,SAAS,EAAEC,QAAQ,KAAK;MACzC,MAAM5B,cAAc,GAAG,CACrB,GAAG,IAAI,CAACE,KAAK,CAACF,cAAc,EAC5B;QACEO,SAAS,EAAE,IAAI;QACfsB,cAAc,EAAE,IAAI;QACpBF,SAAS;QACTC,QAAQ;QACRT,UAAU,EAAE;MACd,CAAC,CACF;MACD,IAAI,CAACI,QAAQ,CAAC;QAAEvB;MAAe,CAAC,CAAC;IACnC,CAAC;IAAAP,eAAA,2BAEkBqC,QAAQ,IAAI;MAC7B,MAAM9B,cAAc,GAAG,CAAC,GAAG,IAAI,CAACE,KAAK,CAACF,cAAc,CAAC;MACrDA,cAAc,CAACa,GAAG,CAACkB,GAAG,IAAI;QACxB,IAAIA,GAAG,CAACJ,SAAS,KAAKG,QAAQ,CAACE,GAAG,EAAE;UAClCD,GAAG,CAACF,cAAc,GAAGC,QAAQ,CAACG,UAAU;UACxCF,GAAG,CAACxB,SAAS,GAAG,IAAI;UACpBwB,GAAG,CAACZ,UAAU,GAAG,IAAI;QACvB;MACF,CAAC,CAAC;MACF,IAAI,CAACI,QAAQ,CAAC;QAAEvB;MAAe,CAAC,CAAC;IACnC,CAAC;IAAAP,eAAA,0BAEiB,OAAOuC,GAAG,EAAEL,SAAS,KAAK;MAC1C,MAAM3B,cAAc,GAAG,CAAC,GAAG,IAAI,CAACE,KAAK,CAACF,cAAc,CAAC;MACrDA,cAAc,CAACa,GAAG,CAACkB,GAAG,IAAI;QACxB,IAAIA,GAAG,CAACJ,SAAS,KAAKA,SAAS,IAAII,GAAG,CAACxB,SAAS,EAAE;UAChDwB,GAAG,CAACb,GAAG,GAAGc,GAAG,CAACE,OAAO,CAAC,WAAW,EAAE,eAAe,CAAC;UACnDH,GAAG,CAACvB,eAAe,GAAG,KAAK;UAC3BuB,GAAG,CAACX,YAAY,GAAG/C,WAAW,CAAC0D,GAAG,CAACb,GAAG,CAAC;UACvCa,GAAG,CAACZ,UAAU,GAAG,IAAI;QACvB;MACF,CAAC,CAAC;MACF,IAAI,CAACI,QAAQ,CAAC;QAAEvB;MAAe,CAAC,EAAE,MAAM,IAAI,CAACmC,iBAAiB,CAAC,CAAC,CAAC;IACnE,CAAC;IAAA1C,eAAA,yBAEgBkC,SAAS,IAAI;MAC5B,MAAM3B,cAAc,GAAG,CAAC,GAAG,IAAI,CAACE,KAAK,CAACF,cAAc,CAAC;MACrDA,cAAc,CAACa,GAAG,CAACkB,GAAG,IAAI;QACxB,IAAIA,GAAG,CAACJ,SAAS,KAAKA,SAAS,EAAE;UAC/BI,GAAG,CAACxB,SAAS,GAAG,IAAI,CAAC,CAAC;UACtBwB,GAAG,CAACF,cAAc,GAAG,EAAE;UACvBE,GAAG,CAACZ,UAAU,GAAG,IAAI;QACvB;MACF,CAAC,CAAC;MACF,IAAI,CAACI,QAAQ,CAAC;QAAEvB;MAAe,CAAC,CAAC;IACnC,CAAC;IAAAP,eAAA,4BAEmBuC,GAAG,IAAI;MACzB,MAAMhC,cAAc,GAAG,CACrB,GAAG,IAAI,CAACE,KAAK,CAACF,cAAc,EAC5B;QACEO,SAAS,EAAE,KAAK;QAChBY,UAAU,EAAE,KAAK;QACjBD,GAAG,EAAE9C,OAAO,CAAC4D,GAAG,CAAC;QACjBxB,eAAe,EAAE,IAAI;QACrBY,YAAY,EAAE/C,WAAW,CAAC2D,GAAG;MAC/B,CAAC,CACF;MACD,IAAI,CAACT,QAAQ,CAAC;QAAEvB;MAAe,CAAC,CAAC;IACnC,CAAC;IAAAP,eAAA,uBAEc,CAAC2C,MAAM,EAAEC,QAAQ,KAAK;MACnC,IAAI,CAACd,QAAQ,CAAC;QACZe,gBAAgB,EAAEF,MAAM;QACxBG,eAAe,EAAEH,MAAM,CAACI,OAAO,CAACH,QAAQ,CAAC;QACzCI,cAAc,EAAE;MAClB,CAAC,CAAC;IACJ,CAAC;IAAAhD,eAAA,kBAESiD,OAAO,IAAI;MACnB,IAAI,CAACnB,QAAQ,CAAC;QACZoB,UAAU,EAAED;MACd,CAAC,CAAC;IACJ,CAAC;IAAAjD,eAAA,wBAUeyB,GAAG,IAAI;MACrB,MAAMlB,cAAc,GAAG,IAAI,CAACE,KAAK,CAACF,cAAc,CAAC4C,MAAM,CAAC9B,KAAK,IAAIA,KAAK,CAACI,GAAG,KAAKA,GAAG,CAAC;MACnF,IAAI,CAACK,QAAQ,CAAC;QAAEvB;MAAe,CAAC,CAAC;IACnC,CAAC;IAAAP,eAAA,gCAEuByB,GAAG,IAAI;MAC7B,IAAI,OAAOA,GAAG,KAAK,QAAQ,EAAEA,GAAG,GAAG,EAAE;MACrC,IAAI,CAACK,QAAQ,CAAC;QAAEsB,mBAAmB,EAAE3B,GAAG,CAAC4B,MAAM,GAAG,CAAC;QAAEC,eAAe,EAAE7B;MAAI,CAAC,CAAC;IAC9E,CAAC;IAzOC,MAAM8B,WAAW,GAAG,IAAI,CAACxD,KAAK,CAACyD,QAAQ,KAAK,CAAC,IAAI7F,cAAc,CAAC,CAAC,GAAG,CAAC;IACrE,IAAI,CAAC8F,mBAAmB,GAAG1G,QAAQ,CAAC2G,MAAM,CAAC;MACzCC,GAAG,EAAEJ,WAAW,GAAG,EAAE,GAAG,EAAE;MAC1BK,OAAO,EAAE;IACX,CAAC,CAAC;IAEF,IAAI,CAACnD,KAAK,GAAG;MACXoD,WAAW,EAAE;QACXC,GAAG,EAAE,IAAI,CAAC/D,KAAK,CAACgE,IAAI,CAACC,GAAG;QACxBC,IAAI,EAAE,IAAI,CAAClE,KAAK,CAACgE,IAAI,CAACG,WAAW;QACjCC,MAAM,EACJ,CAAC3G,CAAC,CAAC4G,WAAW,CAAC,IAAI,CAACrE,KAAK,CAACgE,IAAI,CAACM,UAAU,CAAC,IAAI,CAAC7G,CAAC,CAACgD,OAAO,CAAC,IAAI,CAACT,KAAK,CAACgE,IAAI,CAACM,UAAU,CAAC,GAChF,IAAI,CAACtE,KAAK,CAACgE,IAAI,CAACM,UAAU,GAC1BpF,MAAM,CAACqF,GAAG,CAACC;MACnB,CAAC;MAEDC,QAAQ,EAAE,EAAE;MACZ3B,gBAAgB,EAAE,EAAE;MACpBC,eAAe,EAAE,CAAC;MAClBE,cAAc,EAAE,KAAK;MACrBzC,cAAc,EAAE,EAAE;MAClB6C,mBAAmB,EAAE,KAAK;MAC1BE,eAAe,EAAE;IACnB,CAAC;IACD,IAAI,CAACtC,UAAU,GAAG,IAAI;EACxB;EAEAyD,yBAAyBA,CAAA,EAAG;IAC1B,IAAI,CAACC,cAAc,CAAC,IAAI,CAAC3E,KAAK,CAAC;EACjC;EAEA4E,gCAAgCA,CAACC,SAAS,EAAE;IAC1C,IAAI,CAACF,cAAc,CAACE,SAAS,CAAC;EAChC;EAEAF,cAAcA,CAAC3E,KAAK,EAAE;IACpB,MAAM8E,QAAQ,GAAG,CAAC,CAAC;IACnB,IAAI,CAACrH,CAAC,CAAC4G,WAAW,CAACrE,KAAK,CAACyE,QAAQ,CAAC,EAAE;MAClCK,QAAQ,CAACL,QAAQ,GAAGzE,KAAK,CAACyE,QAAQ;IACpC;IACA,IAAI,CAAC1C,QAAQ,CAAC+C,QAAQ,CAAC;EACzB;;EAEA;AACF;AACA;AACA;EACEC,MAAMA,CAACN,QAAQ,GAAG,EAAE,EAAE;IACpB;IACA;IACA;EAAA;EAqEFO,cAAcA,CAAA,EAAG;IACf,IAAI,CAACC,aAAa,CAACD,cAAc,CAAC,CAAC;EACrC;EAgGAE,YAAYA,CAAA,EAAG;IACb,IAAI,CAACnD,QAAQ,CAAC;MACZe,gBAAgB,EAAE,EAAE;MACpBC,eAAe,EAAE,CAAC;MAClBE,cAAc,EAAE;IAClB,CAAC,CAAC;EACJ;EAYAkC,YAAYA,CAACV,QAAQ,EAAE;IACrB,IAAI,IAAI,CAAC7D,iBAAiB,CAAC,CAAC,EAAE;MAC5B;MACA,IAAI,CAAC,IAAI,CAACwE,cAAc,CAAC,CAAC,EAAE;MAC5BX,QAAQ,CAAC,CAAC,CAAC,CAACnD,KAAK,GAAG,IAAI,CAACZ,KAAK,CAACF,cAAc,CAACa,GAAG,CAACC,KAAK,IAAIA,KAAK,CAACI,GAAG,CAAC;IACvE;IACA,IAAIjE,CAAC,CAACgD,OAAO,CAACgE,QAAQ,CAAC,CAAC,CAAC,CAACY,IAAI,CAAC,EAAE;MAC/BZ,QAAQ,CAAC,CAAC,CAAC,CAACY,IAAI,GAAG,EAAE;IACvB;IACA,IAAI,CAACZ,QAAQ,CAAC,CAAC,CAAC,CAACY,IAAI,IAAI,CAACZ,QAAQ,CAAC,CAAC,CAAC,CAACnD,KAAK,EAAE;IAE7C,IAAI,IAAI,CAACZ,KAAK,CAACyC,UAAU,EAAE;MACzBsB,QAAQ,CAAC,CAAC,CAAC,CAACtB,UAAU,GAAG,IAAI,CAACzC,KAAK,CAACyC,UAAU;IAChD;IAEA,IAAI,CAACnD,KAAK,CAAC+E,MAAM,CAACN,QAAQ,CAAC;IAC3B,IAAI,CAAC1C,QAAQ,CAAC;MAAEvB,cAAc,EAAE,EAAE;MAAE2C,UAAU,EAAE;IAAK,CAAC,CAAC;EACzD;;EAEA;AACF;AACA;AACA;EACEmC,YAAYA,CAACC,WAAW,EAAE;IACxB,MAAMC,YAAY,GAAG,CAAC,CAAC;IACvB,IAAI,CAAC/H,CAAC,CAACgD,OAAO,CAAC8E,WAAW,CAACE,cAAc,CAACJ,IAAI,CAAC,IAAI,CAAC5H,CAAC,CAACgD,OAAO,CAAC8E,WAAW,CAACE,cAAc,CAACnE,KAAK,CAAC,EAAE;MAC/FkE,YAAY,CAACE,UAAU,GAAG,CAAC;MAC3BF,YAAY,CAACG,aAAa,GAAG,EAAE;MAC/BH,YAAY,CAACI,QAAQ,GAAG,GAAG,CAAC,CAAC;IAC/B;IACA,IAAI,CAACnI,CAAC,CAACgD,OAAO,CAAC8E,WAAW,CAACE,cAAc,CAACI,WAAW,CAAC,EAAE;MACtDL,YAAY,CAACE,UAAU,GAAG,CAAC;MAC3BF,YAAY,CAACG,aAAa,GAAG,EAAE;MAC/BH,YAAY,CAACM,iBAAiB,GAAG,EAAE;IACrC;IACA,oBACEtJ,KAAA,CAAAuJ,aAAA,CAAC5I,MAAM,EAAA6I,QAAA,KACDT,WAAW;MACfU,kBAAkB,EAAEA,CAAA,KAAM,IAAK;MAC/BC,kBAAkB,EAAE,IAAK;MACzBV,YAAY,EAAE;QACZW,IAAI,EAAE;UACJC,eAAe,EAAE/H,QAAQ;UACzBgI,YAAY,EAAE,EAAE;UAChB,GAAGb;QACL,CAAC;QACDc,KAAK,EAAE;UACLF,eAAe,EAAE,IAAI,CAACpG,KAAK,CAACuG,mBAAmB;UAC/CF,YAAY,EAAE,EAAE;UAChB,GAAGb;QACL;MACF,CAAE;MACFgB,oBAAoB,EAAE;QACpBL,IAAI,EAAE;UACJM,sBAAsB,EAAE;QAC1B,CAAC;QACDH,KAAK,EAAE;UACLI,uBAAuB,EAAE;QAC3B;MACF,CAAE;MACFC,wBAAwB,EAAE;QACxBR,IAAI,EAAE;UACJS,mBAAmB,EAAE;QACvB,CAAC;QACDN,KAAK,EAAE;UACLO,oBAAoB,EAAE;QACxB;MACF;IAAE,EACH,CAAC;EAEN;EACAC,aAAaA,CAAC9G,KAAK,EAAE;IACnB,oBACExD,KAAA,CAAAuJ,aAAA,CAAC7H,gBAAgB,EAAA8H,QAAA;MACfe,GAAG,EAAE/G,KAAK,CAACgH,KAAM;MACjBC,kBAAkB,EAAE,IAAI,CAACjH,KAAK,CAACiH,kBAAmB;MAClDC,YAAY,EAAEA,CAAA,KAAM;QAClB,IAAI,CAACC,OAAO,CAACnH,KAAK,CAACyF,cAAc,CAAC;MACpC;IAAE,GACEzF,KAAK,CACV,CAAC;EAEN;EACAoH,iBAAiBA,CAACC,gBAAgB,EAAE;IAClC,oBACE7K,KAAA,CAAAuJ,aAAA,CAAC3I,WAAW,EAAA4I,QAAA,KACNqB,gBAAgB;MACpBC,SAAS,EAAE;QACTnB,IAAI,EAAE;UACJoB,UAAU,EAAE,YAAY;UACxBC,QAAQ,EAAE,EAAE;UACZC,KAAK,EAAEnJ,YAAY;UACnBoJ,SAAS,EAAE,EAAE;UACbC,YAAY,EAAE,EAAE;UAChBC,UAAU,EAAE,EAAE;UACdC,WAAW,EAAE;QACf,CAAC;QACDvB,KAAK,EAAE;UACLiB,UAAU,EAAE,YAAY;UACxBC,QAAQ,EAAE,EAAE;UACZC,KAAK,EAAE,IAAI,CAACzH,KAAK,CAACiH,kBAAkB;UACpCS,SAAS,EAAE,EAAE;UACbC,YAAY,EAAE,EAAE;UAChBC,UAAU,EAAE,EAAE;UACdC,WAAW,EAAE;QACf;MACF,CAAE;MACFC,SAAS,EAAE;QACT3B,IAAI,EAAE;UACJsB,KAAK,EAAEnJ;QACT,CAAC;QACDgI,KAAK,EAAE;UACLmB,KAAK,EAAE,IAAI,CAACzH,KAAK,CAACiH;QACpB;MACF;IAAE,EACH,CAAC;EAEN;EACAc,UAAUA,CAAA,EAAG;IACX,OAAO,IAAI;EACb;EACAC,SAASA,CAACC,QAAQ,EAAE;IAClB,oBACEzL,KAAA,CAAAuJ,aAAA,CAAChI,aAAa,EAAAiI,QAAA,KACRiC,QAAQ;MACZX,SAAS,EAAE;QACTC,UAAU,EAAE,aAAa;QACzBE,KAAK,EAAErJ,SAAS;QAChBoJ,QAAQ,EAAE;MACZ;IAAE,EACH,CAAC;EAEN;EACAU,gBAAgBA,CAAC;IAAEzC,cAAc;IAAE0C;EAAS,CAAC,EAAE;IAC7C,IAAI1C,cAAc,CAACnE,KAAK,EAAE;MACxB,MAAMsB,MAAM,GAAG,OAAO6C,cAAc,CAACnE,KAAK,KAAK,QAAQ,GAAG,CAACmE,cAAc,CAACnE,KAAK,CAAC,GAAGmE,cAAc,CAACnE,KAAK;MACvG,MAAM8G,cAAc,GAAG,CAAC,MAAM;QAC5B,IAAIxF,MAAM,CAACU,MAAM,KAAK,CAAC,EAAE,OAAO,CAAC;QACjC,IAAIV,MAAM,CAACU,MAAM,KAAK,CAAC,EAAE,OAAO7D,gBAAgB;QAChD,IAAImD,MAAM,CAACU,MAAM,IAAI5D,cAAc,EAAE,OAAO,CAACF,gBAAgB,GAAGG,YAAY,IAAIiD,MAAM,CAACU,MAAM;QAC7F,OAAO,CAAC9D,gBAAgB,GAAGG,YAAY,IAAID,cAAc;MAC3D,CAAC,EAAE,CAAC;MACJ,oBACElD,KAAA,CAAAuJ,aAAA,CAACrJ,IAAI;QAAC2L,KAAK,EAAE,CAACC,MAAM,CAACC,eAAe,EAAE;UAAEC,KAAK,EAAEJ,cAAc;UAAEK,eAAe,EAAEhD,cAAc,CAACJ,IAAI,GAAG,CAAC,GAAG;QAAG,CAAC;MAAE,GAC7GzC,MAAM,CAACvB,GAAG,CAACkB,GAAG,IAAI;QACjB,MAAMmG,KAAK,GAAG7J,WAAW,CAAC0D,GAAG,CAAC;QAC9B,IAAIxD,OAAO,CAACwD,GAAG,CAAC,EAAE;UAChB,oBACE/F,KAAA,CAAAuJ,aAAA,CAAClJ,gBAAgB;YAACkK,GAAG,EAAE2B,KAAM;YAACC,OAAO,EAAE,IAAI,CAACC,qBAAqB,CAACC,IAAI,CAAC,IAAI,EAAEtG,GAAG;UAAE,gBAChF/F,KAAA,CAAAuJ,aAAA,CAACnJ,eAAe;YAACyL,KAAK,EAAEzF,MAAM,CAACU,MAAM,GAAG,CAAC,GAAGgF,MAAM,CAACQ,iBAAiB,GAAGR,MAAM,CAACS,iBAAkB;YAACC,MAAM,EAAE;cAAExG,GAAG,EAAEkG;YAAM;UAAE,gBACtHlM,KAAA,CAAAuJ,aAAA,CAACrJ,IAAI;YAAC2L,KAAK,EAAEC,MAAM,CAACW;UAAmB,gBACrCzM,KAAA,CAAAuJ,aAAA,CAACpI,IAAI;YAACuG,IAAI,EAAC,MAAM;YAACgF,IAAI,EAAC,cAAc;YAACC,SAAS,EAAEb,MAAM,CAACc;UAAiB,CAAE,CACvE,CACS,CACD,CAAC;QAEvB;QACA,oBACE5M,KAAA,CAAAuJ,aAAA,CAAClJ,gBAAgB;UAACkK,GAAG,EAAE2B,KAAM;UAACC,OAAO,EAAEA,CAAA,KAAM,IAAI,CAACU,YAAY,CAACzG,MAAM,EAAEL,GAAG;QAAE,gBAC1E/F,KAAA,CAAAuJ,aAAA,CAACpJ,KAAK;UAACqM,MAAM,EAAE;YAAExG,GAAG,EAAEkG;UAAM,CAAE;UAACL,KAAK,EAAEzF,MAAM,CAACU,MAAM,GAAG,CAAC,GAAGgF,MAAM,CAACQ,iBAAiB,GAAGR,MAAM,CAACS;QAAkB,CAAE,CAChG,CAAC;MAEvB,CAAC,CACG,CAAC;IAEX;IACA,IAAI,CAACtL,CAAC,CAACgD,OAAO,CAACgF,cAAc,CAACI,WAAW,CAAC,EAAE;MAC1C,oBACErJ,KAAA,CAAAuJ,aAAA,CAACrJ,IAAI,QACF+I,cAAc,CAACI,WAAW,CAACxE,GAAG,CAAC,CAACK,GAAG,EAAEZ,CAAC,KAAK;QAC1C,oBACEtE,KAAA,CAAAuJ,aAAA,CAAC9H,UAAU;UACT0K,OAAO,EAAEA,CAAA,KAAM;YACb,IAAI,CAACW,gBAAgB,CAAC5H,GAAG,CAAC;UAC5B,CAAE;UACFqF,GAAG,EAAEjG,CAAE;UACPyI,KAAK,EAAEtK,WAAW,CAACyC,GAAG;QAAE,CACzB,CAAC;MAEN,CAAC,CACG,CAAC;IAEX;IACA,IAAI+D,cAAc,CAACvF,KAAK,EAAE;MACxB,oBACE1D,KAAA,CAAAuJ,aAAA,CAAClJ,gBAAgB;QAAC8L,OAAO,EAAE,IAAI,CAACa,YAAY,CAACX,IAAI,CAAC,IAAI,EAAEpD,cAAc,CAACvF,KAAK;MAAE,gBAC5E1D,KAAA,CAAAuJ,aAAA,CAACrJ,IAAI;QAAC2L,KAAK,EAAEC,MAAM,CAACmB,cAAc,CAACtB,QAAQ;MAAE,gBAC3C3L,KAAA,CAAAuJ,aAAA,CAACpJ,KAAK;QAAC0L,KAAK,EAAE,CAACC,MAAM,CAACoB,UAAU,EAAEpB,MAAM,CAACqB,gBAAgB,CAACxB,QAAQ,CAAC,CAAE;QAACa,MAAM,EAAE;UAAExG,GAAG,EAAEiD,cAAc,CAACvF,KAAK,CAAC0J;QAAU;MAAE,CAAE,CAAC,eACzHpN,KAAA,CAAAuJ,aAAA,CAACrJ,IAAI;QAAC2L,KAAK,EAAEC,MAAM,CAACuB;MAAU,gBAC5BrN,KAAA,CAAAuJ,aAAA,CAACjJ,IAAI;QACHgN,aAAa,EAAE,CAAE;QACjBzB,KAAK,EAAE,CAACC,MAAM,CAACyB,UAAU,EAAEzB,MAAM,CAAC0B,cAAc,CAAC7B,QAAQ,CAAC,EAAE;UAAEV,KAAK,EAAE,IAAI,CAACzH,KAAK,CAACiH;QAAmB,CAAC;MAAE,GAErGxB,cAAc,CAACvF,KAAK,CAAC+J,KAClB,CAAC,eACPzN,KAAA,CAAAuJ,aAAA,CAACjJ,IAAI;QAACuL,KAAK,EAAE,CAACC,MAAM,CAAC4B,SAAS,EAAE5B,MAAM,CAAC0B,cAAc,CAAC7B,QAAQ,CAAC,EAAE;UAAEV,KAAK,EAAE,IAAI,CAACzH,KAAK,CAACiH;QAAmB,CAAC;MAAE,GACxGvJ,MAAM,CACJyM,GAAG,CAAC1E,cAAc,CAACvF,KAAK,CAACkK,SAAS,CAAC,CACnCC,KAAK,CAAC,CAAC,CACPC,MAAM,CAAC,WAAW,CACjB,CACF,CACF,CACU,CAAC;IAEvB;IACA,IAAI7E,cAAc,CAACpF,UAAU,EAAE;MAC7B,oBACE7D,KAAA,CAAAuJ,aAAA,CAAClJ,gBAAgB;QAAC8L,OAAO,EAAE,IAAI,CAAC4B,iBAAiB,CAAC1B,IAAI,CAAC,IAAI,EAAEpD,cAAc,CAACpF,UAAU;MAAE,gBACtF7D,KAAA,CAAAuJ,aAAA,CAACrJ,IAAI;QAAC2L,KAAK,EAAEC,MAAM,CAACmB,cAAc,CAACtB,QAAQ;MAAE,gBAC3C3L,KAAA,CAAAuJ,aAAA,CAACpJ,KAAK;QAAC0L,KAAK,EAAE,CAACC,MAAM,CAACoB,UAAU,EAAEpB,MAAM,CAACqB,gBAAgB,CAACxB,QAAQ,CAAC,CAAE;QAACa,MAAM,EAAE;UAAExG,GAAG,EAAEiD,cAAc,CAACpF,UAAU,CAACuJ;QAAU;MAAE,CAAE,CAAC,eAC9HpN,KAAA,CAAAuJ,aAAA,CAACrJ,IAAI;QAAC2L,KAAK,EAAEC,MAAM,CAACuB;MAAU,gBAC5BrN,KAAA,CAAAuJ,aAAA,CAACjJ,IAAI;QACHgN,aAAa,EAAE,CAAE;QACjBzB,KAAK,EAAE,CAACC,MAAM,CAACyB,UAAU,EAAEzB,MAAM,CAAC0B,cAAc,CAAC7B,QAAQ,CAAC,EAAE;UAAEV,KAAK,EAAE,IAAI,CAACzH,KAAK,CAACiH;QAAmB,CAAC;MAAE,GAErGxB,cAAc,CAACpF,UAAU,CAAC4J,KACvB,CAAC,EACNxE,cAAc,CAACpF,UAAU,CAAC+J,SAAS,iBAClC5N,KAAA,CAAAuJ,aAAA,CAACjJ,IAAI;QAACuL,KAAK,EAAE,CAACC,MAAM,CAAC4B,SAAS,EAAE5B,MAAM,CAAC0B,cAAc,CAAC7B,QAAQ,CAAC,EAAE;UAAEV,KAAK,EAAE,IAAI,CAACzH,KAAK,CAACiH;QAAmB,CAAC;MAAE,GACxGvJ,MAAM,CACJyM,GAAG,CAAC1E,cAAc,CAACpF,UAAU,CAAC+J,SAAS,CAAC,CACxCC,KAAK,CAAC,CAAC,CACPC,MAAM,CAAC,WAAW,CACjB,CAEJ,CACF,CACU,CAAC;IAEvB;IACA,OAAO,IAAI;EACb;EAEAE,UAAUA,CAACxK,KAAK,EAAE;IAChB,oBACExD,KAAA,CAAAuJ,aAAA,CAACrJ,IAAI;MAAC2L,KAAK,EAAE,CAAC;QAAEF,QAAQ,EAAE,UAAU;QAAEsC,GAAG,EAAE,CAAC;QAAEnE,KAAK,EAAE;MAAE,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC5F,KAAK,CAACyC,UAAU,IAAI;QAAEuE,SAAS,EAAE;MAAG,CAAC;IAAE,GACrG,CAAC,CAACjK,CAAC,CAACgD,OAAO,CAACT,KAAK,CAACqF,IAAI,CAAC,IAAI,IAAI,CAACD,cAAc,CAACpF,KAAK,CAACQ,cAAc,CAAC,kBACnEhE,KAAA,CAAAuJ,aAAA,CAAC1I,IAAI,EAAA2I,QAAA,KACChG,KAAK;MACT0K,cAAc,EAAE,IAAK;MACrBC,cAAc,EAAE,CACdrC,MAAM,CAACsC,aAAa,EACpB;QACEpC,KAAK,EAAE,IAAI,CAAC9E,mBAAmB;QAC/BmH,MAAM,EAAE,IAAI,CAACnH;MACf,CAAC;IACD,iBAEFlH,KAAA,CAAAuJ,aAAA,CAACpI,IAAI;MAACuG,IAAI,EAAE,aAAc;MAACgF,IAAI,EAAC,cAAc;MAACC,SAAS,EAAE,CAACb,MAAM,CAACwC,IAAI,EAAE;QAAEtC,KAAK,EAAE,IAAI,CAAC9E;MAAoB,CAAC;IAAE,CAAE,CAC3G,CACP,eACDlH,KAAA,CAAAuJ,aAAA,CAAClJ,gBAAgB;MACf8L,OAAO,EAAE,IAAI,CAAC3D,cAAc,CAAC6D,IAAI,CAAC,IAAI,CAAE;MACxCR,KAAK,EAAE,CACLC,MAAM,CAACsC,aAAa,EACpB;QACEtE,KAAK,EAAE7I,CAAC,CAACgD,OAAO,CAACT,KAAK,CAACqF,IAAI,CAAC,IAAI,CAAC,IAAI,CAACD,cAAc,CAACpF,KAAK,CAACQ,cAAc,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,IAAI,CAACkD,mBAAmB;QAC7G8E,KAAK,EAAE,IAAI,CAAC9E,mBAAmB;QAC/BmH,MAAM,EAAE,IAAI,CAACnH;MACf,CAAC;IACD,gBAEFlH,KAAA,CAAAuJ,aAAA,CAACpI,IAAI;MAACuG,IAAI,EAAE,WAAY;MAACgF,IAAI,EAAC,cAAc;MAACC,SAAS,EAAE,CAACb,MAAM,CAACwC,IAAI,EAAE;QAAEtC,KAAK,EAAE,IAAI,CAAC9E;MAAoB,CAAC;IAAE,CAAE,CAC7F,CACd,CAAC;EAEX;EAEAqH,eAAeA,CAAC/K,KAAK,EAAE;IACrB,MAAMgL,aAAa,GAAG,IAAI,CAACpK,iBAAiB,CAACZ,KAAK,CAACQ,cAAc,CAAC;IAClE,IAAI,CAACwK,aAAa,EAAE;MAClB,OAAO,IAAI;IACb;IACA,oBACExO,KAAA,CAAAuJ,aAAA,CAAC9I,UAAU;MAACgO,UAAU;MAAC5C,KAAK,EAAEC,MAAM,CAAC4C;IAAsB,GACxDlL,KAAK,CAACQ,cAAc,CAACa,GAAG,CAACC,KAAK,IAAI;MACjC,IAAIA,KAAK,CAACP,SAAS,EAAE;QACnB,oBACEvE,KAAA,CAAAuJ,aAAA,CAAC1G,mBAAmB;UAClB0H,GAAG,EAAEzF,KAAK,CAACa,SAAU;UACrBgJ,QAAQ,EAAE,IAAI,CAAClG,aAAc;UAC7B3D,KAAK,EAAEA,KAAM;UACbmG,KAAK,EAAE,IAAI,CAACzH,KAAK,CAACiH,kBAAmB;UACrCoB,KAAK,EAAE;YAAEG,KAAK,EAAE3I,kBAAkB;YAAEgI,WAAW,EAAE;UAAG,CAAE;UACtDuD,iBAAiB,EAAE;YAAE5D,QAAQ,EAAE;UAAG;QAAE,CACrC,CAAC;MAEN;MACA,MAAM6D,UAAU,GAAGtM,OAAO,CAACuC,KAAK,CAACI,GAAG,CAAC;MACrC,oBACElF,KAAA,CAAAuJ,aAAA,CAACrJ,IAAI;QAACqK,GAAG,EAAEzF,KAAK,CAACI,GAAI;QAAC2G,KAAK,EAAEC,MAAM,CAACgD;MAAwB,gBAC1D9O,KAAA,CAAAuJ,aAAA,CAACnJ,eAAe;QACdyL,KAAK,EAAEC,MAAM,CAACiD,cAAe;QAC7BC,UAAU,EAAElD,MAAM,CAACmD,oBAAqB;QACxCzC,MAAM,EAAEhK,cAAc,CAACsC,KAAK,CAACN,eAAe,GAAGM,KAAK,CAACM,YAAY,GAAGN,KAAK,CAACI,GAAG;MAAE,GAE9E2J,UAAU,iBACT7O,KAAA,CAAAuJ,aAAA,CAACrJ,IAAI;QAAC2L,KAAK,EAAEC,MAAM,CAACW;MAAmB,gBACrCzM,KAAA,CAAAuJ,aAAA,CAAClJ,gBAAgB;QAAC8L,OAAO,EAAE,IAAI,CAACC,qBAAqB,CAACC,IAAI,CAAC,IAAI,EAAEvH,KAAK,CAACI,GAAG;MAAE,gBAC1ElF,KAAA,CAAAuJ,aAAA,CAACpI,IAAI;QAACuG,IAAI,EAAC,MAAM;QAACgF,IAAI,EAAC,cAAc;QAACC,SAAS,EAAEb,MAAM,CAACc;MAAiB,CAAE,CAC3D,CACd,CAEO,CAAC,eAClB5M,KAAA,CAAAuJ,aAAA,CAAClJ,gBAAgB;QACfwL,KAAK,EAAEC,MAAM,CAACoD,uBAAwB;QACtC/C,OAAO,EAAEA,CAAA,KAAM,IAAI,CAACgD,aAAa,CAACrK,KAAK,CAACI,GAAG,CAAE;QAC7CkK,OAAO,EAAE;UAAEnB,GAAG,EAAE,CAAC;UAAEnE,KAAK,EAAE,CAAC;UAAEuF,MAAM,EAAE,CAAC;UAAE1F,IAAI,EAAE;QAAE;MAAE,gBAElD3J,KAAA,CAAAuJ,aAAA,CAACrJ,IAAI;QAAC2L,KAAK,EAAE,CAACC,MAAM,CAACwD,0BAA0B,EAAE;UAAE1F,eAAe,EAAE,IAAI,CAACpG,KAAK,CAACiH;QAAmB,CAAC;MAAE,gBACnGzK,KAAA,CAAAuJ,aAAA,CAACpI,IAAI;QAACuG,IAAI,EAAC,OAAO;QAACgF,IAAI,EAAC,cAAc;QAACC,SAAS,EAAEb,MAAM,CAACyD;MAAsB,CAAE,CAC7E,CACU,CACd,CAAC;IAEX,CAAC,CACS,CAAC;EAEjB;EAEAC,kBAAkBA,CAAChM,KAAK,EAAE;IACxB,MAAMgL,aAAa,GAAG,IAAI,CAACpK,iBAAiB,CAACZ,KAAK,CAACQ,cAAc,CAAC;IAClE,oBACEhE,KAAA,CAAAuJ,aAAA,CAACzI,YAAY,EAAA0I,QAAA,KACPhG,KAAK;MACT2K,cAAc,EAAErC,MAAM,CAAC2D,cAAe;MACtCC,cAAc,EAAE,IAAI,CAACA,cAAc,CAACrD,IAAI,CAAC,IAAI,CAAE;MAC/CkC,eAAe,EAAEC,aAAa,GAAG,IAAI,CAACD,eAAe,CAAClC,IAAI,CAAC,IAAI,CAAC,GAAG,IAAK;MACxEsD,cAAc,EAAEnB,aAAa,IAAI1C,MAAM,CAAC8D;IAAU,EACnD,CAAC;EAEN;EACAC,YAAYA,CAAA,EAAG;IACb;IACA;IACA;IACA;IACA,oBAAO7P,KAAA,CAAAuJ,aAAA,CAACrJ,IAAI;MAAC2L,KAAK,EAAE;QAAEwC,MAAM,EAAE;MAAG;IAAE,CAAE,CAAC;EACxC;EACAyB,aAAaA,CAAA,EAAG;IACd,oBACE9P,KAAA,CAAAuJ,aAAA,CAACrJ,IAAI;MAAC2L,KAAK,EAAE;QAAEX,SAAS,EAAE,EAAE;QAAE6E,cAAc,EAAE,QAAQ;QAAEC,YAAY,EAAE;MAAS;IAAE,gBAC/EhQ,KAAA,CAAAuJ,aAAA,CAAClI,OAAO;MAAC4O,IAAI,EAAE,OAAQ;MAAChF,KAAK,EAAE,IAAI,CAACzH,KAAK,CAACiH;IAAmB,CAAE,CAC3D,CAAC;EAEX;EACAyF,YAAYA,CAAC1M,KAAK,EAAE;IAClB,oBACExD,KAAA,CAAAuJ,aAAA,CAACrJ,IAAI;MAAC2L,KAAK,EAAE;QAAER,WAAW,EAAE;MAAE;IAAE,gBAC9BrL,KAAA,CAAAuJ,aAAA,CAACjI,UAAU;MAACA,UAAU,EAAEkC,KAAK,CAACyF,cAAc,CAACzB,IAAI,CAACI,MAAO;MAACuI,QAAQ,EAAE;IAAG,CAAE,CACrE,CAAC;EAEX;EACAT,cAAcA,CAAClM,KAAK,EAAE;IAAA,IAAA4M,qBAAA,EAAAC,sBAAA;IACpB,oBACErQ,KAAA,CAAAuJ,aAAA,CAACrJ,IAAI;MAAC2L,KAAK,EAAEC,MAAM,CAACwE;IAAkB,GACnC,IAAI,CAACpM,KAAK,CAACyC,UAAU,iBACpB3G,KAAA,CAAAuJ,aAAA,CAACrJ,IAAI;MAAC2L,KAAK,EAAEC,MAAM,CAACnF;IAAW,gBAC7B3G,KAAA,CAAAuJ,aAAA,CAAC5H,SAAS;MAAC+K,IAAI,EAAC;IAAM,GAAC,cACT,EAACzL,CAAC,CAACgD,OAAO,EAAAmM,qBAAA,GAAC,IAAI,CAAClM,KAAK,CAACyC,UAAU,cAAAyJ,qBAAA,gBAAAA,qBAAA,GAArBA,qBAAA,CAAuB5I,IAAI,cAAA4I,qBAAA,uBAA3BA,qBAAA,CAA6B1I,IAAI,CAAC,GAAG,SAAS,IAAA2I,sBAAA,GAAG,IAAI,CAACnM,KAAK,CAACyC,UAAU,cAAA0J,sBAAA,gBAAAA,sBAAA,GAArBA,sBAAA,CAAuB7I,IAAI,cAAA6I,sBAAA,uBAA3BA,sBAAA,CAA6B3I,IAC5F,CAAC,eACZ1H,KAAA,CAAAuJ,aAAA,CAAClJ,gBAAgB;MACfwL,KAAK,EAAEC,MAAM,CAACyE,oBAAqB;MACnCpE,OAAO,EAAEA,CAAA,KAAM,IAAI,CAACxB,OAAO,CAAC,IAAI,CAAE;MAClCyE,OAAO,EAAE;QAAEnB,GAAG,EAAE,CAAC;QAAEnE,KAAK,EAAE,CAAC;QAAEuF,MAAM,EAAE,CAAC;QAAE1F,IAAI,EAAE;MAAE;IAAE,gBAElD3J,KAAA,CAAAuJ,aAAA,CAACrJ,IAAI;MAAC2L,KAAK,EAAE,CAACC,MAAM,CAAC0E,uBAAuB,EAAE;QAAE5G,eAAe,EAAE,IAAI,CAACpG,KAAK,CAACiH;MAAmB,CAAC;IAAE,gBAChGzK,KAAA,CAAAuJ,aAAA,CAACpI,IAAI;MAACuG,IAAI,EAAC,OAAO;MAACgF,IAAI,EAAC,cAAc;MAACC,SAAS,EAAEb,MAAM,CAAC2E;IAAmB,CAAE,CAC1E,CACU,CACd,CACP,eACDzQ,KAAA,CAAAuJ,aAAA,CAACrJ,IAAI;MAAC2L,KAAK,EAAEC,MAAM,CAAC4E;IAAqB,gBACvC1Q,KAAA,CAAAuJ,aAAA,CAACrJ,IAAI;MACH2L,KAAK,EAAE,CACLC,MAAM,CAAC6E,KAAK,EACZ;QACE;QACA;QACAtF,WAAW,EACTpK,CAAC,CAACgD,OAAO,CAACT,KAAK,CAACqF,IAAI,CAAC,IAAI,CAAC,IAAI,CAACD,cAAc,CAACpF,KAAK,CAACQ,cAAc,CAAC,GAC/D,CAAC,GAAG,IAAI,CAACkD,mBAAmB,GAC5B,CAAC,IAAI,IAAI,CAACA,mBAAmB,GAAG,CAAC,CAAC;QACxC6I,cAAc,EAAE;MAClB,CAAC,EACDvP,QAAQ,CAACoQ,EAAE,KAAK,KAAK,IAAI;QACvBvC,MAAM,EAAE7K,KAAK,CAACqN,cAAc,GAAG;MACjC,CAAC;IACD,gBAEF7Q,KAAA,CAAAuJ,aAAA,CAACxI,QAAQ,EAAAyI,QAAA,KACHhG,KAAK;MACT;MACAsN,WAAW,EAAC,mBAAmB;MAC/BC,cAAc,EAAEjF,MAAM,CAACkF,SAAU;MACjCC,cAAc,EAAE;QACdC,OAAO,EAAE,IAAI,CAACC,YAAY,CAAC9E,IAAI,CAAC,IAAI,CAAC;QACrC+E,MAAM,EAAE,IAAI,CAACC,WAAW,CAAChF,IAAI,CAAC,IAAI;MACpC;IAAE,EACH,CACG,CACF,CACF,CAAC;EAEX;;EAEA;AACF;AACA;EACEiF,UAAUA,CAAA,EAAG;IACX,MAAM;MAAErK,QAAQ;MAAEsK;IAAM,CAAC,GAAG,IAAI,CAAC/N,KAAK;IACtC,MAAMgO,eAAe,GAAG,CAACvK,QAAQ,KAAK,CAAC,IAAIsK,KAAK,GAAG,CAAC,EAAE,GAAG,EAAE,IAAInQ,cAAc,CAAC,CAAC;IAC/E,MAAMqQ,qBAAqB,GACzB,IAAI,CAACvK,mBAAmB,GAAG,EAAE,IAAI,IAAI,CAAChD,KAAK,CAACyC,UAAU,GAAG,EAAE,GAAG,CAAC,CAAC,IAAI,IAAI,CAACvC,iBAAiB,CAAC,CAAC,GAAGhB,yBAAyB,GAAG,CAAC,CAAC;IAE/H,oBACEpD,KAAA,CAAAuJ,aAAA,CAAC7I,UAAU;MACTwN,cAAc,EAAE,KAAM;MACtBwD,yBAAyB,EAAE,OAAQ;MACnCC,iBAAiB;MACjBF,qBAAqB,EAAEA,qBAAsB;MAC7CG,YAAY,EAAEpR,QAAQ,CAACoQ,EAAE,KAAK,SAAS,GAAG,CAAC,GAAGY,eAAgB;MAC9DjJ,MAAM,EAAE,IAAI,CAACI,YAAY,CAAC0D,IAAI,CAAC,IAAI,CAAE;MACrCpE,QAAQ,EAAE,IAAI,CAAC/D,KAAK,CAAC+D,QAAS;MAC9BT,IAAI,EAAE,IAAI,CAACtD,KAAK,CAACoD,WAAY;MAC7BwB,YAAY,EAAE,IAAI,CAACA,YAAY,CAACuD,IAAI,CAAC,IAAI,CAAE;MAC3C/B,aAAa,EAAE,IAAI,CAACA,aAAa,CAAC+B,IAAI,CAAC,IAAI,CAAE;MAC7CzB,iBAAiB,EAAE,IAAI,CAACA,iBAAiB,CAACyB,IAAI,CAAC,IAAI,CAAE;MACrDd,UAAU,EAAE,IAAI,CAACA,UAAU,CAACc,IAAI,CAAC,IAAI,CAAE;MACvCb,SAAS,EAAE,IAAI,CAACA,SAAS,CAACa,IAAI,CAAC,IAAI,CAAE;MACrCX,gBAAgB,EAAE,IAAI,CAACA,gBAAgB,CAACW,IAAI,CAAC,IAAI,CAAE;MACnD2B,UAAU,EAAE,IAAI,CAACA,UAAU,CAAC3B,IAAI,CAAC,IAAI,CAAE;MACvCmD,kBAAkB,EAAE,IAAI,CAACA,kBAAkB,CAACnD,IAAI,CAAC,IAAI,CAAE;MACvDwD,YAAY,EAAE,IAAI,CAACA,YAAY,CAACxD,IAAI,CAAC,IAAI,CAAE;MAC3CyD,aAAa,EAAE,IAAI,CAACA,aAAa,CAACzD,IAAI,CAAC,IAAI,CAAE;MAC7C6D,YAAY,EAAE,IAAI,CAACA,YAAY,CAAC7D,IAAI,CAAC,IAAI,CAAE;MAC3CrI,cAAc,EAAE,IAAI,CAACE,KAAK,CAACF;IAAe,CAC3C,CAAC;EAEN;EAEA6N,mBAAmBA,CAAA,EAAG;IACpB,oBACE7R,KAAA,CAAAuJ,aAAA,CAAC3G,aAAa;MACZkP,GAAG,EAAEA,GAAG,IAAK,IAAI,CAACrJ,aAAa,GAAGqJ,GAAK;MACvCC,eAAe,EAAE,IAAI,CAACA,eAAgB;MACtCC,gBAAgB,EAAE,IAAI,CAACA,gBAAiB;MACxCC,eAAe,EAAE,IAAI,CAACA,eAAgB;MACtCC,cAAc,EAAE,IAAI,CAACA,cAAe;MACpCC,iBAAiB,EAAE,IAAI,CAACA,iBAAkB;MAC1CC,OAAO,EAAE,GAAI;MACbC,aAAa,EAAE,KAAM;MACrBC,QAAQ,EAAE,YAAa;MACvBC,UAAU,EAAE,WAAY;MACxBC,MAAM,EAAE,IAAI,CAAChP,KAAK,CAACgE,IAAI,CAACC,GAAI;MAC5BgL,QAAQ;MACRC,UAAU;IAAA,CACX,CAAC;EAEN;EAEAC,gBAAgBA,CAAA,EAAG;IACjB,MAAM;MAAElM,cAAc;MAAEH,gBAAgB;MAAEC;IAAgB,CAAC,GAAG,IAAI,CAACrC,KAAK;IACxE,oBACElE,KAAA,CAAAuJ,aAAA,CAACzG,UAAU;MACT8P,OAAO,EAAEnM,cAAe;MACxBL,MAAM,EAAEE,gBAAiB;MACzBuM,KAAK,EAAEtM,eAAgB;MACvBuM,OAAO,EAAE,IAAI,CAACpK,YAAY,CAAC2D,IAAI,CAAC,IAAI,CAAE;MACtCyF,GAAG,EAAC;IAAY,CACjB,CAAC;EAEN;EAEAiB,sBAAsBA,CAAA,EAAG;IACvB,MAAM;MAAElM,mBAAmB;MAAEE;IAAgB,CAAC,GAAG,IAAI,CAAC7C,KAAK;IAC3D,IAAI,CAAC6C,eAAe,EAAE;IAEtB,oBAAO/G,KAAA,CAAAuJ,aAAA,CAACxG,UAAU;MAACiD,GAAG,EAAEe,eAAgB;MAAC6L,OAAO,EAAE/L,mBAAoB;MAACiM,OAAO,EAAE,IAAI,CAAC1G;IAAsB,CAAE,CAAC;EAChH;EAEA4G,SAASA,CAAA,EAAG;IACV,IAAI/R,CAAC,CAACgD,OAAO,CAAC,IAAI,CAACC,KAAK,CAACuB,WAAW,CAAC,EAAE;MACrC,OAAO,IAAI;IACb;IACA,oBACEzF,KAAA,CAAAuJ,aAAA,CAAC/H,QAAQ;MAACgL,MAAM,EAAE,IAAI,CAACtI,KAAK,CAACuB,WAAY;MAACqN,OAAO,EAAE,IAAI,CAACG,iBAAkB;MAAClG,KAAK,EAAEtK,WAAW,CAAC,IAAI,CAACyB,KAAK,CAACuB,WAAW,CAAE;MAACyN,QAAQ,EAAE;IAAE,CAAE,CAAC;EAE1I;EAEAC,MAAMA,CAAA,EAAG;IACP,IAAI3S,QAAQ,CAACoQ,EAAE,KAAK,SAAS,IAAI,CAAC,IAAI,CAACpN,KAAK,CAAC4P,cAAc,EAAE;MAC3D,oBACEpT,KAAA,CAAAuJ,aAAA,CAAChJ,oBAAoB;QAAC8S,QAAQ,EAAE7S,QAAQ,CAACoQ,EAAE,KAAK,KAAK,IAAI,SAAU;QAAC/E,KAAK,EAAEC,MAAM,CAACwH;MAAc,GAC7F,IAAI,CAAChC,UAAU,CAAC,CAAC,EACjB,IAAI,CAACO,mBAAmB,CAAC,CAAC,EAC1B,IAAI,CAACc,gBAAgB,CAAC,CAAC,EACvB,IAAI,CAACI,sBAAsB,CAAC,CAAC,EAC7B,IAAI,CAACC,SAAS,CAAC,CACI,CAAC;IAE3B;IACA,oBACEhT,KAAA,CAAAuJ,aAAA,CAACrJ,IAAI;MAAC2L,KAAK,EAAEC,MAAM,CAACwH;IAAc,GAC/B,IAAI,CAAChC,UAAU,CAAC,CAAC,EACjB,IAAI,CAACO,mBAAmB,CAAC,CAAC,EAC1B,IAAI,CAACc,gBAAgB,CAAC,CAAC,EACvB,IAAI,CAACI,sBAAsB,CAAC,CAAC,EAC7B,IAAI,CAACC,SAAS,CAAC,CACZ,CAAC;EAEX;AACF;AAEA,MAAMlH,MAAM,GAAG;EACbwH,aAAa,EAAE;IACbC,IAAI,EAAE,CAAC;IACPxD,cAAc,EAAE;EAClB,CAAC;EACD9C,cAAc,EAAE;IACdtD,IAAI,EAAE;MACJT,UAAU,EAAE,CAAC;MACbsK,WAAW,EAAE,EAAE;MACfC,YAAY,EAAE,EAAE;MAChBtK,aAAa,EAAE,CAAC;MAChBuK,aAAa,EAAE;IACjB,CAAC;IACD5J,KAAK,EAAE;MACLZ,UAAU,EAAE,CAAC;MACbsK,WAAW,EAAE,EAAE;MACfC,YAAY,EAAE,EAAE;MAChBtK,aAAa,EAAE,CAAC;MAChBuK,aAAa,EAAE;IACjB;EACF,CAAC;EACDxG,UAAU,EAAE;IACVlB,KAAK,EAAE,EAAE;IACTqC,MAAM,EAAE,EAAE;IACVsF,UAAU,EAAE,OAAO;IACnB9J,YAAY,EAAE;EAChB,CAAC;EACDsD,gBAAgB,EAAE;IAChBrD,KAAK,EAAE;MACLsB,UAAU,EAAE;IACd,CAAC;IACDzB,IAAI,EAAE;MACJ0B,WAAW,EAAE;IACf;EACF,CAAC;EACDgC,SAAS,EAAE;IACTuG,SAAS,EAAE,EAAE;IACb5H,KAAK,EAAE;EACT,CAAC;EACDuB,UAAU,EAAE;IACVvC,QAAQ,EAAE,EAAE;IACZD,UAAU,EAAE,SAAS;IACrBnB,eAAe,EAAE;EACnB,CAAC;EACD4D,cAAc,EAAE;IACd7D,IAAI,EAAE;MACJkK,SAAS,EAAE;IACb,CAAC;IACD/J,KAAK,EAAE;MACL+J,SAAS,EAAE;IACb;EACF,CAAC;EACDtH,iBAAiB,EAAE;IACjBP,KAAK,EAAE/I,gBAAgB;IACvBoL,MAAM,EAAEpL,gBAAgB;IACxB4G,YAAY,EAAE,CAAC;IACfiK,SAAS,EAAE;EACb,CAAC;EACDxH,iBAAiB,EAAE;IACjBN,KAAK,EAAEhJ,gBAAgB;IACvBqL,MAAM,EAAErL,gBAAgB;IACxB6G,YAAY,EAAE,CAAC;IACfiK,SAAS,EAAE,QAAQ;IACnBzI,WAAW,EAAElI,YAAY;IACzBgI,YAAY,EAAEhI;EAChB,CAAC;EACDuK,SAAS,EAAE;IACT1C,QAAQ,EAAE,EAAE;IACZD,UAAU,EAAE,YAAY;IACxBnB,eAAe,EAAE;EACnB,CAAC;EACD6F,cAAc,EAAE;IACd7F,eAAe,EAAE,MAAM;IACvBqC,eAAe,EAAE,CAAC;IAClB3C,iBAAiB,EAAE;EACrB,CAAC;EACD0H,SAAS,EAAE;IACT/F,KAAK,EAAEnJ,YAAY;IACnBkJ,QAAQ,EAAE,EAAE;IACZD,UAAU,EAAE;EACd,CAAC;EACD4F,KAAK,EAAE;IACLoD,MAAM,EAAE,CAAC;IACTnK,eAAe,EAAE3H,OAAO;IACxB4H,YAAY,EAAE,CAAC;IACf0J,IAAI,EAAE;EACR,CAAC;EACDjD,iBAAiB,EAAE;IACjBiD,IAAI,EAAE;EACR,CAAC;EACD7C,oBAAoB,EAAE;IACpB6C,IAAI,EAAE,CAAC;IACPG,aAAa,EAAE;EACjB,CAAC;EACD/M,UAAU,EAAE;IACViN,SAAS,EAAE,EAAE;IACbF,aAAa,EAAE,KAAK;IACpBM,UAAU,EAAE,QAAQ;IACpBC,iBAAiB,EAAE,CAAC;IACpBC,iBAAiB,EAAErS,QAAQ;IAC3BsJ,YAAY,EAAE;EAChB,CAAC;EACDoF,oBAAoB,EAAE;IACpBnF,UAAU,EAAE;EACd,CAAC;EACDoF,uBAAuB,EAAE;IACvBT,cAAc,EAAE,QAAQ;IACxBiE,UAAU,EAAE,QAAQ;IACpBnK,YAAY,EAAE,EAAE;IAChBmC,KAAK,EAAE,EAAE;IACTqC,MAAM,EAAE,EAAE;IACV8F,WAAW,EAAE,CAAC;IACdC,WAAW,EAAE;EACf,CAAC;EACD3D,kBAAkB,EAAE;IAClBzF,QAAQ,EAAE,EAAE;IACZC,KAAK,EAAE,MAAM;IACbE,YAAY,EAAE;EAChB,CAAC;EACDiD,aAAa,EAAE;IACbzC,QAAQ,EAAE,UAAU;IACpBsC,GAAG,EAAE,CAAC;IACNnE,KAAK,EAAE,CAAC;IACRuE,MAAM,EAAE,EAAE;IACVrC,KAAK,EAAE,EAAE;IACTgI,UAAU,EAAE,QAAQ;IACpBjE,cAAc,EAAE,QAAQ;IACxBnG,eAAe,EAAE;EACnB,CAAC;EACD0E,IAAI,EAAE;IACJtD,QAAQ,EAAE,EAAE;IACZC,KAAK,EAAE/I,aAAa;IACpB8I,QAAQ,EAAE,EAAE;IACZ6I,SAAS,EAAE;EACb,CAAC;EACDjE,SAAS,EAAE;IACTvB,MAAM,EAAEjL,yBAAyB;IACjCiR,cAAc,EAAE,CAAC;IACjBC,cAAc,EAAEzS,QAAQ;IACxBqH,UAAU,EAAE,CAAC;IACbgC,SAAS,EAAE;EACb,CAAC;EACD4D,uBAAuB,EAAE;IACvB2E,YAAY,EAAE,CAAC;IACfvK,UAAU,EAAE,CAAC;IACbmC,WAAW,EAAE;EACf,CAAC;EACD0D,cAAc,EAAE;IACd/C,KAAK,EAAE3I,kBAAkB;IACzBgL,MAAM,EAAEhL;EACV,CAAC;EACD4L,oBAAoB,EAAE;IACpBpF,YAAY,EAAE;EAChB,CAAC;EACD0K,mBAAmB,EAAE;IACnBlG,MAAM,EAAE;EACV,CAAC;EACDtC,eAAe,EAAE;IACfX,UAAU,EAAE,EAAE;IACdC,WAAW,EAAE,EAAE;IACfqI,aAAa,EAAE,KAAK;IACpBc,QAAQ,EAAE;EACZ,CAAC;EACD9F,qBAAqB,EAAE;IACrBgF,aAAa,EAAE,KAAK;IACpBe,QAAQ,EAAE;EACZ,CAAC;EACDvF,uBAAuB,EAAE;IACvBvD,QAAQ,EAAE,UAAU;IACpBsC,GAAG,EAAE,CAAC;IACNnE,KAAK,EAAE;EACT,CAAC;EACDwF,0BAA0B,EAAE;IAC1BS,cAAc,EAAE,QAAQ;IACxBiE,UAAU,EAAE,QAAQ;IACpBnK,YAAY,EAAE,EAAE;IAChBmC,KAAK,EAAE,EAAE;IACTqC,MAAM,EAAE,EAAE;IACV8F,WAAW,EAAE,CAAC;IACdC,WAAW,EAAE;EACf,CAAC;EACD7E,qBAAqB,EAAE;IACrBvE,QAAQ,EAAE,EAAE;IACZC,KAAK,EAAE,MAAM;IACbE,YAAY,EAAE;EAChB,CAAC;EACDsB,kBAAkB,EAAE;IAClBd,QAAQ,EAAE,UAAU;IACpBsC,GAAG,EAAE,CAAC;IACNtE,IAAI,EAAE,CAAC;IACPG,KAAK,EAAE,CAAC;IACRuF,MAAM,EAAE,CAAC;IACT2E,UAAU,EAAE,QAAQ;IACpBjE,cAAc,EAAE;EAClB,CAAC;EACDnD,gBAAgB,EAAE;IAChB3B,KAAK,EAAE,MAAM;IACbD,QAAQ,EAAE,EAAE;IACZ0J,eAAe,EAAE,iBAAiB;IAClCC,gBAAgB,EAAE;MAAE3I,KAAK,EAAE,CAAC;MAAEqC,MAAM,EAAE;IAAE;EAC1C;AACF,CAAC;AAED,MAAMuG,eAAe,GAAG1Q,KAAK,IAAI;EAC/B,OAAO;IACLsD,IAAI,EAAEtD,KAAK,CAACsD,IAAI;IAChBiD,kBAAkB,EAAE1I,8BAA8B,CAACmC,KAAK,CAAC;IACzD6F,mBAAmB,EAAE/H,+BAA+B,CAACkC,KAAK,CAAC;IAC3D+C,QAAQ,EAAE9E,uBAAuB,CAAC+B,KAAK,CAAC,CAAC4C;EAC3C,CAAC;AACH,CAAC;AAED,eAAe9F,OAAO,CAAC4T,eAAe,EAAE,CAAC,CAAC,CAAC,CAACtR,SAAS,CAAC","ignoreList":[]}
|
|
@@ -4,7 +4,7 @@ function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol"
|
|
|
4
4
|
function _toPrimitive(t, r) { if ("object" != typeof t || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != typeof i) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
|
|
5
5
|
import React, { Component } from 'react';
|
|
6
6
|
import { View, Animated, PanResponder, Image, StyleSheet } from 'react-native';
|
|
7
|
-
import { Icon } from '
|
|
7
|
+
import { Icon } from '@rneui/themed';
|
|
8
8
|
import { BOXGREY, TEXT_LIGHT } from '../colours';
|
|
9
9
|
class PositionedImage extends Component {
|
|
10
10
|
constructor(props) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["React","Component","View","Animated","PanResponder","Image","StyleSheet","Icon","BOXGREY","TEXT_LIGHT","PositionedImage","constructor","props","_defineProperty","getSize","source","uri","imageWidth","imageHeight","newWidth","width","newHeight","height","setState","isVertical","showGuide","onPositionEnd","onDimensionAvailable","offset","state","actual","x","y","imagePosition","setValue","setTimeout","timing","animatedOpacity","toValue","duration","useNativeDriver","start","lastPos","ValueXY","addListener","value","imagePanResponder","create","onStartShouldSetPanResponder","startPos","onPositionStart","panning","onPanResponderMove","event","gesture","newPos","dy","dx","onPanResponderTerminationRequest","onPanResponderRelease","endPos","endY","limitY","endX","limitX","spring","onPanResponderTerminate","Value","componentDidMount","calculateDimensions","componentDidUpdate","prevProps","renderGrid","createElement","style","styles","gridContainer","gridHorizontal","gridVertical","renderGuide","guideContainer","opacity","guideIconContainer","flexDirection","name","type","iconStyle","guideIcon","guideIconDisabled","render","container","_extends","getLayout","panHandlers","overflow","backgroundColor","position","top","right","bottom","left","alignItems","justifyContent","color","fontSize","margin","borderBottomWidth","borderBottomColor","borderLeftWidth","borderLeftColor"],"sources":["PositionedImage.js"],"sourcesContent":["import React, { Component } from 'react';\nimport { View, Animated, PanResponder, Image, StyleSheet } from 'react-native';\nimport { Icon } from 'react-native-elements';\nimport { BOXGREY, TEXT_LIGHT } from '../colours';\n\nclass PositionedImage extends Component {\n constructor(props) {\n super(props);\n\n this.lastPos = { x: 0, y: 0 };\n this.imagePosition = new Animated.ValueXY(this.lastPos);\n this.imagePosition.addListener(value => {\n this.lastPos = value;\n });\n const imagePanResponder = PanResponder.create({\n onStartShouldSetPanResponder: () => {\n this.startPos = this.lastPos;\n if (this.props.onPositionEnd) {\n if (this.props.onPositionStart) this.props.onPositionStart();\n this.setState({ panning: true });\n return true;\n }\n return false;\n },\n onPanResponderMove: (event, gesture) => {\n const newPos = this.state.isVertical ? { x: 0, y: this.startPos.y + gesture.dy } : { x: this.startPos.x + gesture.dx, y: 0 };\n this.imagePosition.setValue(newPos);\n },\n onPanResponderTerminationRequest: (event, gesture) => true,\n onPanResponderRelease: (event, gesture) => {\n let endPos = { x: 0, y: 0 };\n if (this.state.isVertical) {\n const endY = this.startPos.y + gesture.dy;\n const limitY = this.props.height - this.state.imageHeight;\n if (endY > 0) {\n // console.log('top reached', endY);\n endPos = { x: 0, y: 0 };\n } else if (endY < limitY) {\n // console.log('bottom reached', endY, limitY);\n endPos = { x: 0, y: limitY };\n } else {\n endPos = { x: 0, y: endY };\n }\n } else {\n const endX = this.startPos.x + gesture.dx;\n const limitX = this.props.width - this.state.imageWidth;\n if (endX > 0) {\n // console.log('left reached', endX);\n endPos = { x: 0, y: 0 };\n } else if (endX < limitX) {\n // console.log('right reached', endX, limitX);\n endPos = { x: limitX, y: 0 };\n } else {\n endPos = { x: endX, y: 0 };\n }\n }\n Animated.spring(this.imagePosition, { toValue: endPos, useNativeDriver: false }).start();\n\n if (this.props.onPositionEnd)\n this.props.onPositionEnd({\n x: endPos.x / this.state.imageWidth,\n y: endPos.y / this.state.imageHeight,\n });\n\n this.setState({ panning: false });\n },\n onPanResponderTerminate: (event, gesture) => {\n this.setState({ panning: false });\n },\n });\n\n this.state = {\n imageWidth: 0,\n imageHeight: 0,\n imagePanResponder,\n isVertical: true,\n showGuide: false,\n animatedOpacity: new Animated.Value(1),\n panning: false,\n };\n }\n\n componentDidMount() {\n this.calculateDimensions();\n }\n\n componentDidUpdate(prevProps) {\n if (prevProps.source.uri !== this.props.source.uri) {\n // console.log('componentDidUpdate', prevProps.source.uri, this.props.source.uri);\n this.calculateDimensions();\n }\n }\n\n calculateDimensions = () => {\n Image.getSize(this.props.source.uri, (imageWidth, imageHeight) => {\n // Default vertical positioning\n const newWidth = this.props.width;\n const newHeight = imageHeight * (this.props.width / imageWidth);\n\n if (newHeight < this.props.height) {\n // If vertical positioning isn't possible, enable horizontal positioning\n this.setState(\n {\n imageWidth: imageWidth * (this.props.height / imageHeight),\n imageHeight: this.props.height,\n isVertical: false,\n showGuide: this.props.onPositionEnd ? true : false,\n },\n this.onDimensionAvailable,\n );\n } else {\n this.setState(\n {\n imageWidth: newWidth,\n imageHeight: newHeight,\n isVertical: true,\n showGuide: this.props.onPositionEnd ? true : false,\n },\n this.onDimensionAvailable,\n );\n }\n });\n };\n\n onDimensionAvailable = () => {\n const { offset } = this.props;\n const { imageWidth, imageHeight, isVertical } = this.state;\n\n if (offset) {\n // Apply percentage offset\n const actual = {\n x: offset.x * imageWidth,\n y: offset.y * imageHeight,\n };\n this.imagePosition.setValue(actual);\n } else {\n // Centered by default\n this.imagePosition.setValue({\n x: isVertical ? 0 : -0.5 * imageWidth + 0.5 * this.props.width,\n y: isVertical ? -0.5 * imageHeight + 0.5 * this.props.height : 0,\n });\n }\n\n if (this.props.onPositionEnd) {\n setTimeout(() => {\n Animated.timing(this.state.animatedOpacity, {\n toValue: 0,\n duration: 900,\n useNativeDriver: false,\n }).start(() => {\n this.setState({ showGuide: false });\n });\n }, 1000);\n }\n };\n\n renderGrid() {\n if (!this.state.panning) return null;\n return (\n <View style={styles.gridContainer}>\n <View style={styles.gridHorizontal} />\n <View style={styles.gridVertical} />\n </View>\n );\n }\n\n renderGuide() {\n if (!this.state.showGuide) return null;\n const { animatedOpacity, isVertical } = this.state;\n return (\n <Animated.View style={[styles.guideContainer, { opacity: animatedOpacity }]}>\n <View style={[styles.guideIconContainer, { flexDirection: 'column' }]}>\n <Icon name=\"arrow-up\" type=\"font-awesome\" iconStyle={[styles.guideIcon, !isVertical && styles.guideIconDisabled]} />\n <Icon name=\"arrow-down\" type=\"font-awesome\" iconStyle={[styles.guideIcon, !isVertical && styles.guideIconDisabled]} />\n </View>\n <View style={[styles.guideIconContainer, { flexDirection: 'row' }]}>\n <Icon name=\"arrow-left\" type=\"font-awesome\" iconStyle={[styles.guideIcon, isVertical && styles.guideIconDisabled]} />\n <Icon name=\"arrow-right\" type=\"font-awesome\" iconStyle={[styles.guideIcon, isVertical && styles.guideIconDisabled]} />\n </View>\n </Animated.View>\n );\n }\n\n render() {\n const { imageWidth, imageHeight, imagePanResponder } = this.state;\n\n return (\n <View style={[styles.container, { width: this.props.width, height: this.props.height }, this.props.style]}>\n <Animated.Image\n source={this.props.source}\n style={[{ width: imageWidth, height: imageHeight }, this.imagePosition.getLayout()]}\n {...imagePanResponder.panHandlers}\n />\n {this.renderGrid()}\n {this.renderGuide()}\n </View>\n );\n }\n}\n\nconst styles = StyleSheet.create({\n container: {\n overflow: 'hidden',\n backgroundColor: BOXGREY,\n },\n guideContainer: {\n position: 'absolute',\n top: 0,\n right: 0,\n bottom: 0,\n left: 0,\n alignItems: 'center',\n justifyContent: 'center',\n backgroundColor: '#0006',\n },\n guideIconContainer: {\n position: 'absolute',\n top: 0,\n right: 0,\n bottom: 0,\n left: 0,\n alignItems: 'center',\n justifyContent: 'center',\n },\n guideIcon: {\n color: '#fff',\n fontSize: 50,\n margin: 15,\n },\n guideIconDisabled: {\n color: TEXT_LIGHT,\n },\n gridContainer: {\n position: 'absolute',\n top: 0,\n right: 0,\n bottom: 0,\n left: 0,\n },\n gridHorizontal: {\n position: 'absolute',\n top: 0,\n right: 0,\n left: 0,\n height: '50%',\n borderBottomWidth: 1,\n borderBottomColor: BOXGREY,\n },\n gridVertical: {\n position: 'absolute',\n top: 0,\n right: 0,\n bottom: 0,\n width: '50%',\n borderLeftWidth: 1,\n borderLeftColor: BOXGREY,\n },\n});\n\nexport default PositionedImage;\n"],"mappings":"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","ignoreList":[]}
|
|
1
|
+
{"version":3,"names":["React","Component","View","Animated","PanResponder","Image","StyleSheet","Icon","BOXGREY","TEXT_LIGHT","PositionedImage","constructor","props","_defineProperty","getSize","source","uri","imageWidth","imageHeight","newWidth","width","newHeight","height","setState","isVertical","showGuide","onPositionEnd","onDimensionAvailable","offset","state","actual","x","y","imagePosition","setValue","setTimeout","timing","animatedOpacity","toValue","duration","useNativeDriver","start","lastPos","ValueXY","addListener","value","imagePanResponder","create","onStartShouldSetPanResponder","startPos","onPositionStart","panning","onPanResponderMove","event","gesture","newPos","dy","dx","onPanResponderTerminationRequest","onPanResponderRelease","endPos","endY","limitY","endX","limitX","spring","onPanResponderTerminate","Value","componentDidMount","calculateDimensions","componentDidUpdate","prevProps","renderGrid","createElement","style","styles","gridContainer","gridHorizontal","gridVertical","renderGuide","guideContainer","opacity","guideIconContainer","flexDirection","name","type","iconStyle","guideIcon","guideIconDisabled","render","container","_extends","getLayout","panHandlers","overflow","backgroundColor","position","top","right","bottom","left","alignItems","justifyContent","color","fontSize","margin","borderBottomWidth","borderBottomColor","borderLeftWidth","borderLeftColor"],"sources":["PositionedImage.js"],"sourcesContent":["import React, { Component } from 'react';\nimport { View, Animated, PanResponder, Image, StyleSheet } from 'react-native';\nimport { Icon } from '@rneui/themed';\nimport { BOXGREY, TEXT_LIGHT } from '../colours';\n\nclass PositionedImage extends Component {\n constructor(props) {\n super(props);\n\n this.lastPos = { x: 0, y: 0 };\n this.imagePosition = new Animated.ValueXY(this.lastPos);\n this.imagePosition.addListener(value => {\n this.lastPos = value;\n });\n const imagePanResponder = PanResponder.create({\n onStartShouldSetPanResponder: () => {\n this.startPos = this.lastPos;\n if (this.props.onPositionEnd) {\n if (this.props.onPositionStart) this.props.onPositionStart();\n this.setState({ panning: true });\n return true;\n }\n return false;\n },\n onPanResponderMove: (event, gesture) => {\n const newPos = this.state.isVertical ? { x: 0, y: this.startPos.y + gesture.dy } : { x: this.startPos.x + gesture.dx, y: 0 };\n this.imagePosition.setValue(newPos);\n },\n onPanResponderTerminationRequest: (event, gesture) => true,\n onPanResponderRelease: (event, gesture) => {\n let endPos = { x: 0, y: 0 };\n if (this.state.isVertical) {\n const endY = this.startPos.y + gesture.dy;\n const limitY = this.props.height - this.state.imageHeight;\n if (endY > 0) {\n // console.log('top reached', endY);\n endPos = { x: 0, y: 0 };\n } else if (endY < limitY) {\n // console.log('bottom reached', endY, limitY);\n endPos = { x: 0, y: limitY };\n } else {\n endPos = { x: 0, y: endY };\n }\n } else {\n const endX = this.startPos.x + gesture.dx;\n const limitX = this.props.width - this.state.imageWidth;\n if (endX > 0) {\n // console.log('left reached', endX);\n endPos = { x: 0, y: 0 };\n } else if (endX < limitX) {\n // console.log('right reached', endX, limitX);\n endPos = { x: limitX, y: 0 };\n } else {\n endPos = { x: endX, y: 0 };\n }\n }\n Animated.spring(this.imagePosition, { toValue: endPos, useNativeDriver: false }).start();\n\n if (this.props.onPositionEnd)\n this.props.onPositionEnd({\n x: endPos.x / this.state.imageWidth,\n y: endPos.y / this.state.imageHeight,\n });\n\n this.setState({ panning: false });\n },\n onPanResponderTerminate: (event, gesture) => {\n this.setState({ panning: false });\n },\n });\n\n this.state = {\n imageWidth: 0,\n imageHeight: 0,\n imagePanResponder,\n isVertical: true,\n showGuide: false,\n animatedOpacity: new Animated.Value(1),\n panning: false,\n };\n }\n\n componentDidMount() {\n this.calculateDimensions();\n }\n\n componentDidUpdate(prevProps) {\n if (prevProps.source.uri !== this.props.source.uri) {\n // console.log('componentDidUpdate', prevProps.source.uri, this.props.source.uri);\n this.calculateDimensions();\n }\n }\n\n calculateDimensions = () => {\n Image.getSize(this.props.source.uri, (imageWidth, imageHeight) => {\n // Default vertical positioning\n const newWidth = this.props.width;\n const newHeight = imageHeight * (this.props.width / imageWidth);\n\n if (newHeight < this.props.height) {\n // If vertical positioning isn't possible, enable horizontal positioning\n this.setState(\n {\n imageWidth: imageWidth * (this.props.height / imageHeight),\n imageHeight: this.props.height,\n isVertical: false,\n showGuide: this.props.onPositionEnd ? true : false,\n },\n this.onDimensionAvailable,\n );\n } else {\n this.setState(\n {\n imageWidth: newWidth,\n imageHeight: newHeight,\n isVertical: true,\n showGuide: this.props.onPositionEnd ? true : false,\n },\n this.onDimensionAvailable,\n );\n }\n });\n };\n\n onDimensionAvailable = () => {\n const { offset } = this.props;\n const { imageWidth, imageHeight, isVertical } = this.state;\n\n if (offset) {\n // Apply percentage offset\n const actual = {\n x: offset.x * imageWidth,\n y: offset.y * imageHeight,\n };\n this.imagePosition.setValue(actual);\n } else {\n // Centered by default\n this.imagePosition.setValue({\n x: isVertical ? 0 : -0.5 * imageWidth + 0.5 * this.props.width,\n y: isVertical ? -0.5 * imageHeight + 0.5 * this.props.height : 0,\n });\n }\n\n if (this.props.onPositionEnd) {\n setTimeout(() => {\n Animated.timing(this.state.animatedOpacity, {\n toValue: 0,\n duration: 900,\n useNativeDriver: false,\n }).start(() => {\n this.setState({ showGuide: false });\n });\n }, 1000);\n }\n };\n\n renderGrid() {\n if (!this.state.panning) return null;\n return (\n <View style={styles.gridContainer}>\n <View style={styles.gridHorizontal} />\n <View style={styles.gridVertical} />\n </View>\n );\n }\n\n renderGuide() {\n if (!this.state.showGuide) return null;\n const { animatedOpacity, isVertical } = this.state;\n return (\n <Animated.View style={[styles.guideContainer, { opacity: animatedOpacity }]}>\n <View style={[styles.guideIconContainer, { flexDirection: 'column' }]}>\n <Icon name=\"arrow-up\" type=\"font-awesome\" iconStyle={[styles.guideIcon, !isVertical && styles.guideIconDisabled]} />\n <Icon name=\"arrow-down\" type=\"font-awesome\" iconStyle={[styles.guideIcon, !isVertical && styles.guideIconDisabled]} />\n </View>\n <View style={[styles.guideIconContainer, { flexDirection: 'row' }]}>\n <Icon name=\"arrow-left\" type=\"font-awesome\" iconStyle={[styles.guideIcon, isVertical && styles.guideIconDisabled]} />\n <Icon name=\"arrow-right\" type=\"font-awesome\" iconStyle={[styles.guideIcon, isVertical && styles.guideIconDisabled]} />\n </View>\n </Animated.View>\n );\n }\n\n render() {\n const { imageWidth, imageHeight, imagePanResponder } = this.state;\n\n return (\n <View style={[styles.container, { width: this.props.width, height: this.props.height }, this.props.style]}>\n <Animated.Image\n source={this.props.source}\n style={[{ width: imageWidth, height: imageHeight }, this.imagePosition.getLayout()]}\n {...imagePanResponder.panHandlers}\n />\n {this.renderGrid()}\n {this.renderGuide()}\n </View>\n );\n }\n}\n\nconst styles = StyleSheet.create({\n container: {\n overflow: 'hidden',\n backgroundColor: BOXGREY,\n },\n guideContainer: {\n position: 'absolute',\n top: 0,\n right: 0,\n bottom: 0,\n left: 0,\n alignItems: 'center',\n justifyContent: 'center',\n backgroundColor: '#0006',\n },\n guideIconContainer: {\n position: 'absolute',\n top: 0,\n right: 0,\n bottom: 0,\n left: 0,\n alignItems: 'center',\n justifyContent: 'center',\n },\n guideIcon: {\n color: '#fff',\n fontSize: 50,\n margin: 15,\n },\n guideIconDisabled: {\n color: TEXT_LIGHT,\n },\n gridContainer: {\n position: 'absolute',\n top: 0,\n right: 0,\n bottom: 0,\n left: 0,\n },\n gridHorizontal: {\n position: 'absolute',\n top: 0,\n right: 0,\n left: 0,\n height: '50%',\n borderBottomWidth: 1,\n borderBottomColor: BOXGREY,\n },\n gridVertical: {\n position: 'absolute',\n top: 0,\n right: 0,\n bottom: 0,\n width: '50%',\n borderLeftWidth: 1,\n borderLeftColor: BOXGREY,\n },\n});\n\nexport default PositionedImage;\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -4,7 +4,7 @@ function _toPrimitive(t, r) { if ("object" != typeof t || !t) return t; var e =
|
|
|
4
4
|
import React, { Component } from 'react';
|
|
5
5
|
import _ from 'lodash';
|
|
6
6
|
import { TouchableOpacity, StyleSheet, View, Text } from 'react-native';
|
|
7
|
-
import { Icon } from '
|
|
7
|
+
import { Icon } from '@rneui/themed';
|
|
8
8
|
import * as FileSystem from 'expo-file-system';
|
|
9
9
|
import * as Sharing from 'expo-sharing';
|
|
10
10
|
import * as MediaLibrary from 'expo-media-library';
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["React","Component","_","TouchableOpacity","StyleSheet","View","Text","Icon","FileSystem","Sharing","MediaLibrary","StatusBarHeight","isVideo","getMimeType","MiddlePopup","Config","SharingTools","constructor","props","_defineProperty","remoteUrl","uri","parts","split","splice","mediaId","extension","downloadPath","cacheDirectory","localUrl","downloadAsync","setState","message","downloadMedia","saveToLibraryAsync","setTimeout","isAvailableAsync","video","mimeType","fileDetails","shareOptions","dialogTitle","UTI","shareAsync","state","renderTools","createElement","style","styles","toolsContainer","env","allowMediaDownload","onPress","onSave","activeOpacity","name","type","iconStyle","toolIcon","toolIconContainer","allowMediaSharing","onShare","renderMessage","visible","isEmpty","messageContainer","messageText","render","container","create","position","flexDirection","justifyContent","left","zIndex","top","width","height","fontSize","padding","textAlign","color","backgroundColor","borderRadius","paddingVertical","paddingHorizontal","fontFamily"],"sources":["SharingTools.js"],"sourcesContent":["import React, { Component } from 'react';\nimport _ from 'lodash';\nimport { TouchableOpacity, StyleSheet, View, Text } from 'react-native';\nimport { Icon } from '
|
|
1
|
+
{"version":3,"names":["React","Component","_","TouchableOpacity","StyleSheet","View","Text","Icon","FileSystem","Sharing","MediaLibrary","StatusBarHeight","isVideo","getMimeType","MiddlePopup","Config","SharingTools","constructor","props","_defineProperty","remoteUrl","uri","parts","split","splice","mediaId","extension","downloadPath","cacheDirectory","localUrl","downloadAsync","setState","message","downloadMedia","saveToLibraryAsync","setTimeout","isAvailableAsync","video","mimeType","fileDetails","shareOptions","dialogTitle","UTI","shareAsync","state","renderTools","createElement","style","styles","toolsContainer","env","allowMediaDownload","onPress","onSave","activeOpacity","name","type","iconStyle","toolIcon","toolIconContainer","allowMediaSharing","onShare","renderMessage","visible","isEmpty","messageContainer","messageText","render","container","create","position","flexDirection","justifyContent","left","zIndex","top","width","height","fontSize","padding","textAlign","color","backgroundColor","borderRadius","paddingVertical","paddingHorizontal","fontFamily"],"sources":["SharingTools.js"],"sourcesContent":["import React, { Component } from 'react';\nimport _ from 'lodash';\nimport { TouchableOpacity, StyleSheet, View, Text } from 'react-native';\nimport { Icon } from '@rneui/themed';\nimport * as FileSystem from 'expo-file-system';\nimport * as Sharing from 'expo-sharing';\nimport * as MediaLibrary from 'expo-media-library';\nimport { StatusBarHeight, isVideo, getMimeType } from '../helper';\nimport { MiddlePopup } from './MiddlePopup';\nimport Config from '../config';\n\nclass SharingTools extends Component {\n constructor(props) {\n super(props);\n\n this.state = {\n message: '',\n };\n }\n\n downloadMedia = async () => {\n const remoteUrl = this.props.uri;\n const parts = remoteUrl.split('/').splice(-2);\n const mediaId = parts[0];\n const extension = parts[1].split('.').splice(-1)[0];\n\n const downloadPath = `${FileSystem.cacheDirectory}${mediaId}.${extension}`;\n const { uri: localUrl } = await FileSystem.downloadAsync(remoteUrl, downloadPath);\n return { localUrl, extension };\n };\n\n onSave = () => {\n this.setState({ message: 'Saving...' }, async () => {\n const { localUrl } = await this.downloadMedia();\n await MediaLibrary.saveToLibraryAsync(localUrl);\n\n this.setState({ message: 'Saved' }, () => {\n setTimeout(() => {\n this.setState({ message: '' });\n }, 2000);\n });\n });\n };\n\n onShare = async () => {\n if (!(await Sharing.isAvailableAsync())) return;\n\n this.setState({ message: 'Preparing...' }, async () => {\n const { localUrl, extension } = await this.downloadMedia();\n // console.log('sharing...', localUrl);\n\n const video = isVideo(localUrl);\n const mimeType = getMimeType(localUrl);\n const fileDetails = {\n extension: `.${extension}`,\n shareOptions: {\n mimeType,\n dialogTitle: video ? 'Share video' : 'Share photo',\n UTI: mimeType,\n },\n };\n\n await Sharing.shareAsync(localUrl, fileDetails.shareOptions);\n this.setState({ message: '' });\n });\n };\n\n renderTools() {\n return (\n <View style={styles.toolsContainer}>\n {Config.env.allowMediaDownload && (\n <TouchableOpacity onPress={this.onSave} activeOpacity={0.6}>\n <Icon name=\"download\" type=\"font-awesome\" iconStyle={styles.toolIcon} style={styles.toolIconContainer} />\n </TouchableOpacity>\n )}\n {Config.env.allowMediaSharing && (\n <TouchableOpacity onPress={this.onShare} activeOpacity={0.6}>\n <Icon name=\"share-square-o\" type=\"font-awesome\" iconStyle={styles.toolIcon} style={styles.toolIconContainer} />\n </TouchableOpacity>\n )}\n </View>\n );\n }\n\n renderMessage() {\n return (\n <MiddlePopup visible={!_.isEmpty(this.state.message)}>\n <View style={styles.messageContainer}>\n <Text style={styles.messageText}>{this.state.message}</Text>\n </View>\n </MiddlePopup>\n );\n }\n\n render() {\n return (\n <View style={styles.container}>\n {this.renderTools()}\n {this.renderMessage()}\n </View>\n );\n }\n}\n\nconst styles = StyleSheet.create({\n container: {\n position: 'absolute',\n },\n toolsContainer: {\n position: 'absolute',\n flexDirection: 'row',\n justifyContent: 'space-between',\n left: 0,\n zIndex: 3,\n top: StatusBarHeight(0),\n },\n toolIconContainer: {\n width: 55,\n height: 55,\n },\n toolIcon: {\n fontSize: 25,\n padding: 15,\n width: 55,\n textAlign: 'center',\n color: '#fff',\n zIndex: 3,\n },\n messageContainer: {\n backgroundColor: '#000',\n borderRadius: 10,\n paddingVertical: 10,\n paddingHorizontal: 30,\n },\n messageText: {\n fontFamily: 'sf-bold',\n fontSize: 24,\n color: '#fff',\n },\n});\n\nexport { SharingTools };\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import React from 'react';
|
|
2
2
|
import { Dimensions, ImageBackground, TouchableHighlight, View, Text, StyleSheet } from 'react-native';
|
|
3
3
|
import * as MediaLibrary from 'expo-media-library';
|
|
4
|
-
import { Icon } from '
|
|
4
|
+
import { Icon } from '@rneui/themed';
|
|
5
5
|
import moment from 'moment';
|
|
6
6
|
import { getThumb300 } from '../../helper';
|
|
7
7
|
const screenWidth = Dimensions.get('window').width;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["React","Dimensions","ImageBackground","TouchableHighlight","View","Text","StyleSheet","MediaLibrary","Icon","moment","getThumb300","screenWidth","get","width","ImageTile","PureComponent","renderVideoOverlay","item","props","mediaType","MediaType","video","durationText","duration","asMilliseconds","utc","format","createElement","style","styles","defaultVideoOverlay","name","type","iconStyle","videoIcon","videoIconContainer","videoDurationText","renderSelectedOverlay","selected","selectedItemNumber","renderSelectedComponent","defaultSelectedOverlay","opacity","render","index","selectImage","height","isRemote","actualWidth","actualHeight","uri","underlayColor","onPress","imageContainer","imageBackground","source","create","flex","alignItems","justifyContent","backgroundColor","position","left","bottom","right","flexDirection","paddingRight","paddingBottom","fontSize","color","textAlign","fontFamily"],"sources":["ImageTile.js"],"sourcesContent":["import React from 'react';\nimport { Dimensions, ImageBackground, TouchableHighlight, View, Text, StyleSheet } from 'react-native';\nimport * as MediaLibrary from 'expo-media-library';\nimport { Icon } from '
|
|
1
|
+
{"version":3,"names":["React","Dimensions","ImageBackground","TouchableHighlight","View","Text","StyleSheet","MediaLibrary","Icon","moment","getThumb300","screenWidth","get","width","ImageTile","PureComponent","renderVideoOverlay","item","props","mediaType","MediaType","video","durationText","duration","asMilliseconds","utc","format","createElement","style","styles","defaultVideoOverlay","name","type","iconStyle","videoIcon","videoIconContainer","videoDurationText","renderSelectedOverlay","selected","selectedItemNumber","renderSelectedComponent","defaultSelectedOverlay","opacity","render","index","selectImage","height","isRemote","actualWidth","actualHeight","uri","underlayColor","onPress","imageContainer","imageBackground","source","create","flex","alignItems","justifyContent","backgroundColor","position","left","bottom","right","flexDirection","paddingRight","paddingBottom","fontSize","color","textAlign","fontFamily"],"sources":["ImageTile.js"],"sourcesContent":["import React from 'react';\nimport { Dimensions, ImageBackground, TouchableHighlight, View, Text, StyleSheet } from 'react-native';\nimport * as MediaLibrary from 'expo-media-library';\nimport { Icon } from '@rneui/themed';\nimport moment from 'moment';\nimport { getThumb300 } from '../../helper';\n\nconst screenWidth = Dimensions.get('window').width;\n\nclass ImageTile extends React.PureComponent {\n renderVideoOverlay() {\n const { item } = this.props;\n if (item.mediaType !== MediaLibrary.MediaType.video) return null;\n\n let durationText = '';\n if (item.duration) {\n const duration = moment.duration(item.duration, 'seconds').asMilliseconds();\n durationText = moment.utc(duration).format('HH:mm:ss');\n }\n return (\n <View style={styles.defaultVideoOverlay}>\n <Icon name=\"video-camera\" type=\"font-awesome\" iconStyle={styles.videoIcon} style={styles.videoIconContainer} />\n <Text style={styles.videoDurationText}>{durationText}</Text>\n </View>\n );\n }\n\n renderSelectedOverlay() {\n const { selected, selectedItemNumber, renderSelectedComponent } = this.props;\n if (!selected) return null;\n if (renderSelectedComponent) return renderSelectedComponent(selectedItemNumber);\n return <View style={[styles.defaultSelectedOverlay, { opacity: selected ? 0.5 : 1 }]} />;\n }\n\n render() {\n const { item, index, selectImage, width, height, style, isRemote } = this.props;\n if (!item) return null;\n\n const actualWidth = width || screenWidth / 4;\n const actualHeight = height || screenWidth / 4;\n const uri = isRemote ? getThumb300(item.uri) : item.uri;\n\n return (\n <TouchableHighlight underlayColor=\"transparent\" onPress={() => selectImage(item, index)}>\n <View style={[{ width: actualWidth, height: actualHeight }, style]}>\n <View style={styles.imageContainer}>\n <ImageBackground style={styles.imageBackground} source={{ uri }}>\n {this.renderVideoOverlay()}\n {this.renderSelectedOverlay()}\n </ImageBackground>\n </View>\n </View>\n </TouchableHighlight>\n );\n }\n}\n\nconst styles = StyleSheet.create({\n imageContainer: {\n flex: 1,\n alignItems: 'center',\n justifyContent: 'center',\n },\n imageBackground: {\n width: '100%',\n height: '100%',\n },\n defaultSelectedOverlay: {\n flex: 1,\n backgroundColor: '#000',\n },\n defaultVideoOverlay: {\n position: 'absolute',\n left: 3,\n bottom: 3,\n right: 3,\n flexDirection: 'row',\n justifyContent: 'space-between',\n alignItems: 'center',\n },\n videoIconContainer: {\n flex: 1,\n paddingRight: 8,\n paddingBottom: 1,\n },\n videoIcon: {\n fontSize: 12,\n color: '#fff',\n textAlign: 'right',\n },\n videoDurationText: {\n fontFamily: 'sf-semibold',\n fontSize: 12,\n color: '#fff',\n },\n});\n\nexport default ImageTile;\n"],"mappings":"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","ignoreList":[]}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@plusscommunities/pluss-core-app",
|
|
3
|
-
"version": "
|
|
3
|
+
"version": "7.0.0-beta.0",
|
|
4
4
|
"description": "Core extension package for Pluss Communities platform",
|
|
5
5
|
"main": "dist/module/index.js",
|
|
6
6
|
"module": "dist/module/index.js",
|
|
@@ -47,7 +47,8 @@
|
|
|
47
47
|
"react-native": "0.73.6",
|
|
48
48
|
"react-native-auto-height-image": "3.1.3",
|
|
49
49
|
"react-native-calendars": "^1.1309.1",
|
|
50
|
-
"
|
|
50
|
+
"@rneui/base": "^4.0.0-rc.8",
|
|
51
|
+
"@rneui/themed": "^4.0.0-rc.8",
|
|
51
52
|
"react-native-gifted-chat": "^0.16.3",
|
|
52
53
|
"react-native-image-zoom-viewer": "^3.0.1",
|
|
53
54
|
"react-native-iphone-x-helper": "^1.3.1",
|
|
@@ -66,4 +67,4 @@
|
|
|
66
67
|
"module"
|
|
67
68
|
]
|
|
68
69
|
}
|
|
69
|
-
}
|
|
70
|
+
}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import React, { PureComponent } from 'react';
|
|
2
2
|
import { TouchableOpacity, View, Text } from 'react-native';
|
|
3
3
|
import { connect } from 'react-redux';
|
|
4
|
-
import { Icon } from '
|
|
4
|
+
import { Icon } from '@rneui/themed';
|
|
5
5
|
import { getLightBrandingColourFromState, getMainBrandingColourFromState } from '../colours';
|
|
6
6
|
|
|
7
7
|
class Attachment extends PureComponent {
|
|
@@ -2,7 +2,7 @@ import React, { Component } from 'react';
|
|
|
2
2
|
import { connect } from 'react-redux';
|
|
3
3
|
import _ from 'lodash';
|
|
4
4
|
import { TouchableOpacity, View, ScrollView, Text, StyleSheet } from 'react-native';
|
|
5
|
-
import { Icon } from '
|
|
5
|
+
import { Icon } from '@rneui/themed';
|
|
6
6
|
import { Services } from '../config';
|
|
7
7
|
import { FormCard } from './FormCard';
|
|
8
8
|
import { FormCardSection } from './FormCardSection';
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import React, { Component } from 'react';
|
|
2
2
|
import { connect } from 'react-redux';
|
|
3
3
|
import { Keyboard, TextInput, View, ImageBackground, TouchableOpacity, Dimensions } from 'react-native';
|
|
4
|
-
import { Icon } from '
|
|
4
|
+
import { Icon } from '@rneui/themed';
|
|
5
5
|
import { getBottomSpace } from 'react-native-iphone-x-helper';
|
|
6
6
|
import _ from 'lodash';
|
|
7
7
|
import { getApiError } from '../session';
|