diff --git a/__tests__/__snapshots__/Storyshots.test.js.snap b/__tests__/__snapshots__/Storyshots.test.js.snap index 6d1aa6a6..9d9a30e3 100644 --- a/__tests__/__snapshots__/Storyshots.test.js.snap +++ b/__tests__/__snapshots__/Storyshots.test.js.snap @@ -61007,6 +61007,1157 @@ exports[`Storyshots RoomItem list roomitem 1`] = ` `; +exports[`Storyshots ServerItem content 1`] = ` +Array [ + + + + + + + + Rocket.Chat + + + https://open.rocket.chat/ + + + +  + + + , + + + + + + + + Super Long Server Name in Rocket.Chat + + + https://superlongservername.tologintoasuperlongservername/ + + + + , + + + + + + + + https://stable.rocket.chat/ + + + https://stable.rocket.chat/ + + + + , +] +`; + +exports[`Storyshots ServerItem themes 1`] = ` +Array [ + + + + + + + + Rocket.Chat + + + https://open.rocket.chat/ + + + +  + + + , + + + + + + + + Rocket.Chat + + + https://open.rocket.chat/ + + + +  + + + , + + + + + + + + Rocket.Chat + + + https://open.rocket.chat/ + + + +  + + + , +] +`; + +exports[`Storyshots ServerItem touchable 1`] = ` +Array [ + + + + + + + + Rocket.Chat + + + https://open.rocket.chat/ + + + + , + + + + + + + + Rocket.Chat + + + https://open.rocket.chat/ + + + + , + + + + + + + + Rocket.Chat + + + https://open.rocket.chat/ + + + + , +] +`; + exports[`Storyshots Thread Messages.Item badge 1`] = ` diff --git a/app/presentation/ServerItem/index.js b/app/presentation/ServerItem/index.js index d71b16e7..ab69020f 100644 --- a/app/presentation/ServerItem/index.js +++ b/app/presentation/ServerItem/index.js @@ -1,23 +1,33 @@ import React from 'react'; import PropTypes from 'prop-types'; -import { View, Text } from 'react-native'; +import { View, Text, Pressable } from 'react-native'; import FastImage from '@rocket.chat/react-native-fast-image'; -import Touch from '../../utils/touch'; import Check from '../../containers/Check'; import styles, { ROW_HEIGHT } from './styles'; import { themes } from '../../constants/colors'; +import { isIOS } from '../../utils/deviceInfo'; +import { withTheme } from '../../theme'; export { ROW_HEIGHT }; +const defaultLogo = require('../../static/images/logo.png'); + const ServerItem = React.memo(({ - server, item, onPress, hasCheck, theme + item, onPress, onLongPress, hasCheck, theme }) => ( - onLongPress?.()} testID={`rooms-list-header-server-${ item.id }`} - theme={theme} + android_ripple={{ + color: themes[theme].bannerBackground + }} + style={({ pressed }) => ({ + backgroundColor: isIOS && pressed + ? themes[theme].bannerBackground + : themes[theme].backgroundColor + })} > {item.iconURL @@ -27,33 +37,33 @@ const ServerItem = React.memo(({ uri: item.iconURL, priority: FastImage.priority.high }} - defaultSource={require('../../static/images/logo.png')} + defaultSource={defaultLogo} style={styles.serverIcon} onError={() => console.log('err_loading_server_icon')} /> ) : ( ) } - {item.name || item.id} - {item.id} + {item.name || item.id} + {item.id} - {item.id === server && hasCheck ? : null} + {hasCheck ? : null} - + )); ServerItem.propTypes = { - onPress: PropTypes.func.isRequired, item: PropTypes.object.isRequired, + onPress: PropTypes.func.isRequired, + onLongPress: PropTypes.func, hasCheck: PropTypes.bool, - server: PropTypes.string, theme: PropTypes.string }; -export default ServerItem; +export default withTheme(ServerItem); diff --git a/app/presentation/ServerItem/styles.js b/app/presentation/ServerItem/styles.js index 34ed0c15..ece4105d 100644 --- a/app/presentation/ServerItem/styles.js +++ b/app/presentation/ServerItem/styles.js @@ -5,10 +5,6 @@ import sharedStyles from '../../views/Styles'; export const ROW_HEIGHT = 56; export default StyleSheet.create({ - serverItem: { - height: ROW_HEIGHT, - justifyContent: 'center' - }, serverItemContainer: { flexDirection: 'row', alignItems: 'center' @@ -16,20 +12,22 @@ export default StyleSheet.create({ serverIcon: { width: 44, height: 44, - marginHorizontal: 15, - borderRadius: 4 + margin: 12, + borderRadius: 4, + resizeMode: 'contain' }, serverTextContainer: { flex: 1, flexDirection: 'column', - justifyContent: 'center' + justifyContent: 'center', + paddingRight: 18 }, serverName: { fontSize: 18, ...sharedStyles.textSemibold }, serverUrl: { - fontSize: 15, + fontSize: 16, ...sharedStyles.textRegular } }); diff --git a/app/views/RoomsListView/ServerDropdown.js b/app/views/RoomsListView/ServerDropdown.js index 66ac731c..95d6603b 100644 --- a/app/views/RoomsListView/ServerDropdown.js +++ b/app/views/RoomsListView/ServerDropdown.js @@ -1,6 +1,6 @@ import React, { Component } from 'react'; import { - View, Text, Animated, Easing, TouchableWithoutFeedback, TouchableOpacity, FlatList, Image, Pressable + View, Text, Animated, Easing, TouchableWithoutFeedback, TouchableOpacity, FlatList } from 'react-native'; import PropTypes from 'prop-types'; import { connect, batch } from 'react-redux'; @@ -14,12 +14,12 @@ import styles from './styles'; import RocketChat from '../../lib/rocketchat'; import I18n from '../../i18n'; import EventEmitter from '../../utils/events'; -import Check from '../../containers/Check'; +import ServerItem from '../../presentation/ServerItem'; import database from '../../lib/database'; import { themes } from '../../constants/colors'; import { withTheme } from '../../theme'; import { KEY_COMMAND, handleCommandSelectServer } from '../../commands'; -import { isTablet, isIOS } from '../../utils/deviceInfo'; +import { isTablet } from '../../utils/deviceInfo'; import { localAuthenticate } from '../../utils/localAuthentication'; import { showConfirmationAlert } from '../../utils/info'; import { logEvent, events } from '../../utils/log'; @@ -202,43 +202,13 @@ class ServerDropdown extends Component { const { server, theme } = this.props; return ( - this.select(item.id)} onLongPress={() => (item.id === server || this.remove(item.id))} - testID={`rooms-list-header-server-${ item.id }`} - android_ripple={{ - color: themes[theme].bannerBackground - }} - style={({ pressed }) => ({ - backgroundColor: isIOS && pressed - ? themes[theme].bannerBackground - : 'transparent' - })} - > - - {item.iconURL - ? ( - console.warn('error loading serverIcon')} - /> - ) - : ( - - ) - } - - {item.name || item.id} - {item.id} - - {item.id === server ? : null} - - + hasCheck={item.id === server} + theme={theme} + /> ); } diff --git a/app/views/SelectServerView.js b/app/views/SelectServerView.js index f956feba..72a6b939 100644 --- a/app/views/SelectServerView.js +++ b/app/views/SelectServerView.js @@ -65,10 +65,9 @@ class SelectServerView extends React.Component { const { server, theme } = this.props; return ( this.select(item.id)} item={item} - hasCheck + hasCheck={item.id === server} theme={theme} /> ); diff --git a/storybook/stories/ServerItem.js b/storybook/stories/ServerItem.js new file mode 100644 index 00000000..d1c53ee0 --- /dev/null +++ b/storybook/stories/ServerItem.js @@ -0,0 +1,73 @@ +/* eslint-disable import/no-extraneous-dependencies, import/no-unresolved, import/extensions, react/prop-types */ +import React from 'react'; +import { storiesOf } from '@storybook/react-native'; + +import ServerItemComponent from '../../app/presentation/ServerItem'; +import { ThemeContext } from '../../app/theme'; + +const stories = storiesOf('ServerItem', module); + +const themes = { + light: 'light', + dark: 'dark', + black: 'black' +}; + +const item = { + name: 'Rocket.Chat', + id: 'https://open.rocket.chat/', + iconURL: 'https://open.rocket.chat/images/logo/android-chrome-512x512.png' +}; + +const ServerItem = props => ( + +); + +stories.add('content', () => ( + <> + + + + +)); + +stories.add('touchable', () => ( + <> + alert('Long Press')} onPress={() => alert('Press')} /> + alert('Press')} /> + alert('Long Press')} /> + +)); + +const ThemeStory = ({ theme }) => ( + + + +); + +stories.add('themes', () => ( + <> + + + + +)); diff --git a/storybook/stories/index.js b/storybook/stories/index.js index 693e921b..8edb159b 100644 --- a/storybook/stories/index.js +++ b/storybook/stories/index.js @@ -6,6 +6,7 @@ import { storiesOf } from '@storybook/react-native'; import RoomItem from './RoomItem'; import './List'; +import './ServerItem'; import Message from './Message'; import UiKitMessage from './UiKitMessage'; import UiKitModal from './UiKitModal';