From 9716fbabb9353bbcb656cb58dc6a78c82523841c Mon Sep 17 00:00:00 2001 From: Vit Horacek <36083550+mountiny@users.noreply.github.com> Date: Thu, 5 Oct 2023 23:47:35 +0100 Subject: [PATCH] Merge pull request #28955 from Expensify/vit-revert27836 [CP Staging] Revert "Merge pull request #27836 from Expensify/dangrous-roomwelcomemessages" (cherry picked from commit d420b0ae3db00caeeac090bbcfa44c907a1ad7a5) --- .../ValuePicker/ValueSelectorModal.js | 84 --------------- src/components/ValuePicker/index.js | 102 ------------------ src/languages/en.ts | 1 - src/languages/es.ts | 1 - src/libs/ReportUtils.js | 4 +- src/libs/actions/Report.js | 7 +- src/pages/workspace/WorkspaceNewRoomPage.js | 54 ++++------ 7 files changed, 22 insertions(+), 231 deletions(-) delete mode 100644 src/components/ValuePicker/ValueSelectorModal.js delete mode 100644 src/components/ValuePicker/index.js diff --git a/src/components/ValuePicker/ValueSelectorModal.js b/src/components/ValuePicker/ValueSelectorModal.js deleted file mode 100644 index 23aac4839d2a..000000000000 --- a/src/components/ValuePicker/ValueSelectorModal.js +++ /dev/null @@ -1,84 +0,0 @@ -import React, {useState, useEffect} from 'react'; -import PropTypes from 'prop-types'; -import _ from 'lodash'; -import CONST from '../../CONST'; -import HeaderWithBackButton from '../HeaderWithBackButton'; -import SelectionList from '../SelectionList'; -import Modal from '../Modal'; -import ScreenWrapper from '../ScreenWrapper'; -import styles from '../../styles/styles'; - -const propTypes = { - /** Whether the modal is visible */ - isVisible: PropTypes.bool.isRequired, - - /** Current value selected */ - currentValue: PropTypes.string, - - /** Items to pick from */ - items: PropTypes.arrayOf(PropTypes.shape({value: PropTypes.string, label: PropTypes.string})), - - /** The selected item */ - selectedItem: PropTypes.shape({value: PropTypes.string, label: PropTypes.string}), - - /** Label for values */ - label: PropTypes.string, - - /** Function to call when the user selects a item */ - onItemSelected: PropTypes.func, - - /** Function to call when the user closes the modal */ - onClose: PropTypes.func, -}; - -const defaultProps = { - currentValue: '', - items: [], - selectedItem: {}, - label: '', - onClose: () => {}, - onItemSelected: () => {}, -}; - -function ValueSelectorModal({currentValue, items, selectedItem, label, isVisible, onClose, onItemSelected}) { - const [sectionsData, setSectionsData] = useState([]); - - useEffect(() => { - const itemsData = _.map(items, (item) => ({value: item.value, keyForList: item.value, text: item.label, isSelected: item === selectedItem})); - setSectionsData(itemsData); - }, [items, selectedItem]); - - return ( - - - - - - - ); -} - -ValueSelectorModal.propTypes = propTypes; -ValueSelectorModal.defaultProps = defaultProps; -ValueSelectorModal.displayName = 'ValueSelectorModal'; - -export default ValueSelectorModal; diff --git a/src/components/ValuePicker/index.js b/src/components/ValuePicker/index.js deleted file mode 100644 index 161fbbfadb8b..000000000000 --- a/src/components/ValuePicker/index.js +++ /dev/null @@ -1,102 +0,0 @@ -import React, {useState} from 'react'; -import {View} from 'react-native'; -import PropTypes from 'prop-types'; -import _ from 'lodash'; -import styles from '../../styles/styles'; -import MenuItemWithTopDescription from '../MenuItemWithTopDescription'; -import ValueSelectorModal from './ValueSelectorModal'; -import FormHelpMessage from '../FormHelpMessage'; -import refPropTypes from '../refPropTypes'; - -const propTypes = { - /** Form Error description */ - errorText: PropTypes.string, - - /** Item to display */ - value: PropTypes.string, - - /** A placeholder value to display */ - placeholder: PropTypes.string, - - /** Items to pick from */ - items: PropTypes.arrayOf(PropTypes.shape({value: PropTypes.string, label: PropTypes.string})), - - /** Label of picker */ - label: PropTypes.string, - - /** Callback to call when the input changes */ - onInputChange: PropTypes.func, - - /** A ref to forward to MenuItemWithTopDescription */ - forwardedRef: refPropTypes, -}; - -const defaultProps = { - value: undefined, - label: undefined, - placeholder: '', - items: {}, - forwardedRef: undefined, - errorText: '', - onInputChange: () => {}, -}; - -function ValuePicker({value, label, items, placeholder, errorText, onInputChange, forwardedRef}) { - const [isPickerVisible, setIsPickerVisible] = useState(false); - - const showPickerModal = () => { - setIsPickerVisible(true); - }; - - const hidePickerModal = () => { - setIsPickerVisible(false); - }; - - const updateInput = (item) => { - if (item.value !== value) { - onInputChange(item.value); - } - hidePickerModal(); - }; - - const descStyle = value.length === 0 ? styles.textNormal : null; - const selectedItem = _.find(items, {value}); - const selectedLabel = selectedItem ? selectedItem.label : ''; - - return ( - - - - - - - - ); -} - -ValuePicker.propTypes = propTypes; -ValuePicker.defaultProps = defaultProps; -ValuePicker.displayName = 'ValuePicker'; - -export default React.forwardRef((props, ref) => ( - -)); diff --git a/src/languages/en.ts b/src/languages/en.ts index 389faa4a696b..7bf0812b7646 100755 --- a/src/languages/en.ts +++ b/src/languages/en.ts @@ -877,7 +877,6 @@ export default { }, welcomeMessagePage: { welcomeMessage: 'Welcome message', - welcomeMessageOptional: 'Welcome message (optional)', explainerText: 'Set a custom welcome message that will be sent to users when they join this room.', }, languagePage: { diff --git a/src/languages/es.ts b/src/languages/es.ts index 50ca3e5b23bc..24f8069daf94 100644 --- a/src/languages/es.ts +++ b/src/languages/es.ts @@ -874,7 +874,6 @@ export default { }, welcomeMessagePage: { welcomeMessage: 'Mensaje de bienvenida', - welcomeMessageOptional: 'Mensaje de bienvenida (opcional)', explainerText: 'Configura un mensaje de bienvenida privado y personalizado que se enviará cuando los usuarios se unan a esta sala de chat.', }, languagePage: { diff --git a/src/libs/ReportUtils.js b/src/libs/ReportUtils.js index f95b9c6aaca8..f377914884cd 100644 --- a/src/libs/ReportUtils.js +++ b/src/libs/ReportUtils.js @@ -2522,7 +2522,6 @@ function buildOptimisticTaskReportAction(taskReportID, actionName, message = '') * @param {String} notificationPreference * @param {String} parentReportActionID * @param {String} parentReportID - * @param {String} welcomeMessage * @returns {Object} */ function buildOptimisticChatReport( @@ -2538,7 +2537,6 @@ function buildOptimisticChatReport( notificationPreference = CONST.REPORT.NOTIFICATION_PREFERENCE.ALWAYS, parentReportActionID = '', parentReportID = '', - welcomeMessage = '', ) { const currentTime = DateUtils.getDBTime(); return { @@ -2565,7 +2563,7 @@ function buildOptimisticChatReport( stateNum: 0, statusNum: 0, visibility, - welcomeMessage, + welcomeMessage: '', writeCapability, }; } diff --git a/src/libs/actions/Report.js b/src/libs/actions/Report.js index 199240e35266..00ec54d01474 100644 --- a/src/libs/actions/Report.js +++ b/src/libs/actions/Report.js @@ -1410,9 +1410,8 @@ function navigateToConciergeChat() { * @param {String} visibility * @param {Array} policyMembersAccountIDs * @param {String} writeCapability - * @param {String} welcomeMessage */ -function addPolicyReport(policyID, reportName, visibility, policyMembersAccountIDs, writeCapability = CONST.REPORT.WRITE_CAPABILITIES.ALL, welcomeMessage = '') { +function addPolicyReport(policyID, reportName, visibility, policyMembersAccountIDs, writeCapability = CONST.REPORT.WRITE_CAPABILITIES.ALL) { // The participants include the current user (admin), and for restricted rooms, the policy members. Participants must not be empty. const members = visibility === CONST.REPORT.VISIBILITY.RESTRICTED ? policyMembersAccountIDs : []; const participants = _.unique([currentUserAccountID, ...members]); @@ -1429,9 +1428,6 @@ function addPolicyReport(policyID, reportName, visibility, policyMembersAccountI // The room might contain all policy members so notifying always should be opt-in only. CONST.REPORT.NOTIFICATION_PREFERENCE.DAILY, - '', - '', - welcomeMessage, ); const createdReportAction = ReportUtils.buildOptimisticCreatedReportAction(CONST.POLICY.OWNER_EMAIL_FAKE); @@ -1496,7 +1492,6 @@ function addPolicyReport(policyID, reportName, visibility, policyMembersAccountI reportID: policyReport.reportID, createdReportActionID: createdReportAction.reportActionID, writeCapability, - welcomeMessage, }, {optimisticData, successData, failureData}, ); diff --git a/src/pages/workspace/WorkspaceNewRoomPage.js b/src/pages/workspace/WorkspaceNewRoomPage.js index e142c3be2cb8..19dc0756d90a 100644 --- a/src/pages/workspace/WorkspaceNewRoomPage.js +++ b/src/pages/workspace/WorkspaceNewRoomPage.js @@ -1,4 +1,8 @@ +<<<<<<< HEAD import React, {useState, useEffect, useCallback, useMemo} from 'react'; +======= +import React, {useState, useCallback, useMemo, useRef} from 'react'; +>>>>>>> d420b0a (Merge pull request #28955 from Expensify/vit-revert27836) import {View} from 'react-native'; import _ from 'underscore'; import {withOnyx} from 'react-native-onyx'; @@ -9,12 +13,12 @@ import * as App from '../../libs/actions/App'; import useLocalize from '../../hooks/useLocalize'; import styles from '../../styles/styles'; import RoomNameInput from '../../components/RoomNameInput'; +import Picker from '../../components/Picker'; import KeyboardAvoidingView from '../../components/KeyboardAvoidingView'; import ScreenWrapper from '../../components/ScreenWrapper'; import ONYXKEYS from '../../ONYXKEYS'; import CONST from '../../CONST'; import Text from '../../components/Text'; -import TextInput from '../../components/TextInput'; import Permissions from '../../libs/Permissions'; import * as ErrorUtils from '../../libs/ErrorUtils'; import * as ValidationUtils from '../../libs/ValidationUtils'; @@ -25,7 +29,11 @@ import policyMemberPropType from '../policyMemberPropType'; import FullPageNotFoundView from '../../components/BlockingViews/FullPageNotFoundView'; import compose from '../../libs/compose'; import variables from '../../styles/variables'; +<<<<<<< HEAD import ValuePicker from '../../components/ValuePicker'; +======= +import useDelayedInputFocus from '../../hooks/useDelayedInputFocus'; +>>>>>>> d420b0a (Merge pull request #28955 from Expensify/vit-revert27836) const propTypes = { /** All reports shared with the user */ @@ -73,7 +81,6 @@ function WorkspaceNewRoomPage(props) { const {translate} = useLocalize(); const [visibility, setVisibility] = useState(CONST.REPORT.VISIBILITY.RESTRICTED); const [policyID, setPolicyID] = useState(null); - const [writeCapability, setWriteCapability] = useState(CONST.REPORT.WRITE_CAPABILITIES.ALL); const visibilityDescription = useMemo(() => translate(`newRoomPage.${visibility}Description`), [translate, visibility]); const isPolicyAdmin = useMemo(() => { if (!policyID) { @@ -88,17 +95,9 @@ function WorkspaceNewRoomPage(props) { */ const submit = (values) => { const policyMembers = _.map(_.keys(props.allPolicyMembers[`${ONYXKEYS.COLLECTION.POLICY_MEMBERS}${values.policyID}`]), (accountID) => Number(accountID)); - Report.addPolicyReport(policyID, values.roomName, visibility, policyMembers, writeCapability, values.welcomeMessage); + Report.addPolicyReport(values.policyID, values.roomName, values.visibility, policyMembers, values.writeCapability); }; - useEffect(() => { - if (isPolicyAdmin) { - return; - } - - setWriteCapability(CONST.REPORT.WRITE_CAPABILITIES.ALL); - }, [policyID, isPolicyAdmin]); - /** * @param {Object} values - form input values passed by the Form component * @returns {Boolean} @@ -179,6 +178,7 @@ function WorkspaceNewRoomPage(props) {
- - - - - + {isPolicyAdmin && ( - - + )} - - + {visibilityDescription}