-
Notifications
You must be signed in to change notification settings - Fork 3k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Simplify Global Create menu #25564
Simplify Global Create menu #25564
Changes from 48 commits
65edf96
d0ef97a
3e61212
31ba218
8e26741
d0362c8
0e46476
725ae24
cb8d751
6bcc194
cd2780a
2e5f42e
b3fa521
70a7032
45d606a
79a02d5
cdcea69
94b8c0d
eb01b1f
a221a57
fe065c1
166a27a
58cd065
3fb9ec0
bad65d4
90afb07
e4348e1
9b3c9af
afb89eb
ad56566
0f1648d
b7907a5
8ad5472
d2a2e50
a2e3350
d63e67c
fb2e415
3826fcb
85519f7
45085a5
df48bd8
8a1cf12
ccd86bd
8ebe2a6
02df4e3
602ba38
22234f4
2cd6be3
058ecfb
cc67090
5b8e6a8
2ee0a42
5788291
5d28fdb
70beac8
0d2d560
7ff6e00
f45b2ca
90b96de
4c478d3
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -8,6 +8,7 @@ import * as StyleUtils from '../styles/StyleUtils'; | |
import optionPropTypes from './optionPropTypes'; | ||
import Icon from './Icon'; | ||
import * as Expensicons from './Icon/Expensicons'; | ||
import Button from './Button'; | ||
import MultipleAvatars from './MultipleAvatars'; | ||
import Hoverable from './Hoverable'; | ||
import DisplayNames from './DisplayNames'; | ||
|
@@ -39,6 +40,14 @@ const propTypes = { | |
/** Whether we should show the selected state */ | ||
showSelectedState: PropTypes.bool, | ||
|
||
/** Whether to show a button pill instead of a tickbox */ | ||
shouldShowSelectedStateAsButton: PropTypes.bool, | ||
|
||
/** Text for button pill */ | ||
selectedStateButtonText: PropTypes.string, | ||
|
||
/** Callback to fire when the multiple selector (tickbox or button) is clicked */ | ||
onSelectedStatePressed: PropTypes.func, | ||
/** Whether we highlight selected option */ | ||
highlightSelected: PropTypes.bool, | ||
|
||
|
@@ -71,6 +80,9 @@ const propTypes = { | |
const defaultProps = { | ||
hoverStyle: styles.sidebarLinkHover, | ||
showSelectedState: false, | ||
shouldShowSelectedStateAsButton: false, | ||
selectedStateButtonText: 'Select', | ||
onSelectedStatePressed: () => {}, | ||
highlightSelected: false, | ||
isSelected: false, | ||
boldStyle: false, | ||
|
@@ -100,6 +112,7 @@ class OptionRow extends Component { | |
this.props.isMultilineSupported !== nextProps.isMultilineSupported || | ||
this.props.isSelected !== nextProps.isSelected || | ||
this.props.shouldHaveOptionSeparator !== nextProps.shouldHaveOptionSeparator || | ||
this.props.selectedStateButtonText !== nextProps.selectedStateButtonText || | ||
this.props.showSelectedState !== nextProps.showSelectedState || | ||
this.props.highlightSelected !== nextProps.highlightSelected || | ||
this.props.showTitleTooltip !== nextProps.showTitleTooltip || | ||
|
@@ -259,7 +272,26 @@ class OptionRow extends Component { | |
/> | ||
</View> | ||
)} | ||
{this.props.showSelectedState && <SelectCircle isChecked={this.props.isSelected} />} | ||
{this.props.showSelectedState && ( | ||
<> | ||
{this.props.shouldShowSelectedStateAsButton && !this.props.isSelected ? ( | ||
<Button | ||
style={[styles.pl2]} | ||
text={this.props.selectedStateButtonText} | ||
onPress={() => this.props.onSelectedStatePressed(this.props.option)} | ||
small | ||
/> | ||
) : ( | ||
<PressableWithFeedback | ||
onPress={() => this.props.onSelectedStatePressed(this.props.option)} | ||
accessibilityRole={CONST.ACCESSIBILITY_ROLE.CHECKBOX} | ||
accessibilityLabel={CONST.ACCESSIBILITY_ROLE.CHECKBOX} | ||
> | ||
<SelectCircle isChecked={this.props.isSelected} /> | ||
</PressableWithFeedback> | ||
Comment on lines
+286
to
+292
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Wrapping with |
||
)} | ||
</> | ||
)} | ||
{this.props.isSelected && this.props.highlightSelected && ( | ||
<View style={styles.defaultCheckmarkWrapper}> | ||
<Icon | ||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -2,7 +2,7 @@ import _ from 'underscore'; | |
import lodashGet from 'lodash/get'; | ||
import React, {Component} from 'react'; | ||
import PropTypes from 'prop-types'; | ||
import {View, InteractionManager} from 'react-native'; | ||
import {View} from 'react-native'; | ||
import Button from '../Button'; | ||
import FixedFooter from '../FixedFooter'; | ||
import OptionsList from '../OptionsList'; | ||
|
@@ -82,14 +82,6 @@ class BaseOptionsSelector extends Component { | |
} | ||
} | ||
|
||
if (this.textInput && this.props.autoFocus && !prevProps.isFocused && this.props.isFocused) { | ||
InteractionManager.runAfterInteractions(() => { | ||
// If we automatically focus on a text input when mounting a component, | ||
// let's automatically focus on it when the component updates as well (eg, when navigating back from a page) | ||
this.textInput.focus(); | ||
}); | ||
} | ||
|
||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. We cannot simply remove this code. This breaks auto focus in android. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. We might consider using There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
Let's follow this pattern Rory suggested
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. That pattern was not followed correctly. |
||
if (_.isEqual(this.props.sections, prevProps.sections)) { | ||
return; | ||
} | ||
|
@@ -359,7 +351,7 @@ class BaseOptionsSelector extends Component { | |
selectTextOnFocus | ||
blurOnSubmit={Boolean(this.state.allOptions.length)} | ||
spellCheck={false} | ||
autoFocus={this.props.autoFocus} | ||
autoFocus={this.props.isFocused && this.props.autoFocus} | ||
shouldDelayFocus={this.props.shouldDelayFocus} | ||
/> | ||
); | ||
|
@@ -372,6 +364,9 @@ class BaseOptionsSelector extends Component { | |
focusedIndex={this.state.focusedIndex} | ||
selectedOptions={this.props.selectedOptions} | ||
canSelectMultipleOptions={this.props.canSelectMultipleOptions} | ||
shouldShowMultipleOptionSelectorAsButton={this.props.shouldShowMultipleOptionSelectorAsButton} | ||
multipleOptionSelectorButtonText={this.props.multipleOptionSelectorButtonText} | ||
onAddToSelection={this.props.onAddToSelection} | ||
hideSectionHeaders={this.props.hideSectionHeaders} | ||
headerMessage={this.props.headerMessage} | ||
boldStyle={this.props.boldStyle} | ||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -53,6 +53,14 @@ const propTypes = { | |
/** Whether we can select multiple options */ | ||
canSelectMultipleOptions: PropTypes.bool, | ||
|
||
/** Whether to show a button pill instead of a standard tickbox */ | ||
shouldShowMultipleOptionSelectorAsButton: PropTypes.bool, | ||
|
||
/** Text for button pill */ | ||
multipleOptionSelectorButtonText: PropTypes.string, | ||
|
||
/** Callback to fire when the multiple selector (tickbox or button) is clicked */ | ||
onAddToSelection: PropTypes.func, | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Same here 😄 There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I was just about pointing this out :D |
||
/** Whether we highlight selected options */ | ||
highlightSelectedOptions: PropTypes.bool, | ||
|
||
|
@@ -125,6 +133,9 @@ const defaultProps = { | |
selectedOptions: [], | ||
headerMessage: '', | ||
canSelectMultipleOptions: false, | ||
shouldShowMultipleOptionSelectorAsButton: false, | ||
multipleOptionSelectorButtonText: '', | ||
onAddToSelection: () => {}, | ||
highlightSelectedOptions: false, | ||
hideSectionHeaders: false, | ||
boldStyle: false, | ||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -38,23 +38,35 @@ const defaultProps = { | |
|
||
const getIcon = (route) => { | ||
switch (route) { | ||
case CONST.TAB.MANUAL: | ||
return Expensicons.Pencil; | ||
case CONST.TAB.SCAN: | ||
return Expensicons.Receipt; | ||
case CONST.TAB.NEW_CHAT: | ||
return Expensicons.User; | ||
case CONST.TAB.NEW_ROOM: | ||
return Expensicons.Hashtag; | ||
case CONST.TAB.DISTANCE: | ||
return Expensicons.Car; | ||
default: | ||
return Expensicons.Pencil; | ||
throw new Error(`Route ${route} has no icon set.`); | ||
} | ||
}; | ||
|
||
const getTitle = (route, translate) => { | ||
switch (route) { | ||
case CONST.TAB.MANUAL: | ||
return translate('tabSelector.manual'); | ||
case CONST.TAB.SCAN: | ||
return translate('tabSelector.scan'); | ||
case CONST.TAB.NEW_CHAT: | ||
return translate('tabSelector.chat'); | ||
case CONST.TAB.NEW_ROOM: | ||
return translate('tabSelector.room'); | ||
case CONST.TAB.DISTANCE: | ||
return translate('common.distance'); | ||
default: | ||
return translate('tabSelector.manual'); | ||
throw new Error(`Route ${route} has no title set.`); | ||
} | ||
}; | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Just an idea, instead of two long {
icon: Expensicons.Pencil;
title: translate('tabSelector.manual');
}
// ...
const {icon, title} = getIconAndTitle(route, translate); There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Makes sense now that it grew significantly |
||
|
||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Missing new line