From 06c35dfb9649f00ae634bc64bfd928b0b80c93cf Mon Sep 17 00:00:00 2001 From: Bharat Date: Thu, 1 Apr 2021 02:09:14 +0530 Subject: [PATCH 1/3] Intl hardcoded strings in the frontend codebase --- webapp/src/components/viewMenu.tsx | 34 ++++++++++++++++++++++++----- webapp/src/widgets/propertyMenu.tsx | 18 +++++++++------ 2 files changed, 39 insertions(+), 13 deletions(-) diff --git a/webapp/src/components/viewMenu.tsx b/webapp/src/components/viewMenu.tsx index e70ed7e39..35f961d3c 100644 --- a/webapp/src/components/viewMenu.tsx +++ b/webapp/src/components/viewMenu.tsx @@ -123,7 +123,29 @@ export class ViewMenu extends React.PureComponent { } render(): JSX.Element { - const {boardTree} = this.props + const {boardTree, intl} = this.props + + const duplicateViewText = intl.formatMessage({ + id: 'View.DuplicateView', + defaultMessage: 'Duplicate View', + }) + const deleteViewText = intl.formatMessage({ + id: 'View.DeleteView', + defaultMessage: 'Delete View', + }) + const addViewText = intl.formatMessage({ + id: 'View.AddView', + defaultMessage: 'Add View', + }) + const boardText = intl.formatMessage({ + id: 'View.Board', + defaultMessage: 'Board', + }) + const tableText = intl.formatMessage({ + id: 'View.Table', + defaultMessage: 'Table', + }) + return ( {boardTree.views.map((view) => ( @@ -138,7 +160,7 @@ export class ViewMenu extends React.PureComponent { {!this.props.readonly && } onClick={this.handleDuplicateView} /> @@ -146,7 +168,7 @@ export class ViewMenu extends React.PureComponent { {!this.props.readonly && boardTree.views.length > 1 && } onClick={this.handleDeleteView} /> @@ -154,18 +176,18 @@ export class ViewMenu extends React.PureComponent { {!this.props.readonly && } > } onClick={this.handleAddViewBoard} /> } onClick={this.handleAddViewTable} /> diff --git a/webapp/src/widgets/propertyMenu.tsx b/webapp/src/widgets/propertyMenu.tsx index 227010ca1..2261293cf 100644 --- a/webapp/src/widgets/propertyMenu.tsx +++ b/webapp/src/widgets/propertyMenu.tsx @@ -65,6 +65,10 @@ class PropertyMenu extends React.PureComponent { } public render(): JSX.Element { + const deleteText = this.props.intl.formatMessage({ + id: 'PropertyMenu.delete', + defaultMessage: 'Delete', + }) return ( { this.props.onTypeChanged('text')} /> this.props.onTypeChanged('number')} /> this.props.onTypeChanged('email')} /> this.props.onTypeChanged('select')} /> this.props.onTypeChanged('createdTime')} /> this.props.onTypeChanged('updatedTime')} /> this.props.onDelete(this.props.propertyId)} /> From bede81a921c76385445748dca93976d44143e4f9 Mon Sep 17 00:00:00 2001 From: Bharat Date: Thu, 1 Apr 2021 02:14:02 +0530 Subject: [PATCH 2/3] Merged changes from main and ran extract --- webapp/i18n/en.json | 8 ++++++++ webapp/src/widgets/propertyMenu.tsx | 19 ++++++++++++------- 2 files changed, 20 insertions(+), 7 deletions(-) diff --git a/webapp/i18n/en.json b/webapp/i18n/en.json index 1e8e4d535..112dbd37f 100644 --- a/webapp/i18n/en.json +++ b/webapp/i18n/en.json @@ -39,6 +39,8 @@ "Filter.not-includes": "doesn't include", "FilterComponent.add-filter": "+ Add filter", "FilterComponent.delete": "Delete", + "GalleryCard.delete": "Delete", + "GalleryCard.duplicate": "Duplicate", "KanbanCard.delete": "Delete", "KanbanCard.duplicate": "Duplicate", "KanbanCard.untitled": "Untitled", @@ -52,6 +54,7 @@ "PropertyType.Checkbox": "Checkbox", "PropertyType.CreatedBy": "Created By", "PropertyType.CreatedTime": "Created Time", + "PropertyType.Delete": "Delete", "PropertyType.Email": "Email", "PropertyType.File": "File or Media", "PropertyType.MultiSelect": "Multi Select", @@ -123,9 +126,14 @@ "TableHeaderMenu.sort-ascending": "Sort ascending", "TableHeaderMenu.sort-descending": "Sort descending", "TableRow.open": "Open", + "View.AddView": "Add View", + "View.Board": "Board", + "View.DeleteView": "Delete View", + "View.DuplicateView": "Duplicate View", "View.NewBoardTitle": "Board view", "View.NewGalleryTitle": "Gallery view", "View.NewTableTitle": "Table view", + "View.Table": "Table", "ViewHeader.add-template": "+ New template", "ViewHeader.delete-template": "Delete", "ViewHeader.edit-template": "Edit", diff --git a/webapp/src/widgets/propertyMenu.tsx b/webapp/src/widgets/propertyMenu.tsx index 29ceaebe6..8459ebe45 100644 --- a/webapp/src/widgets/propertyMenu.tsx +++ b/webapp/src/widgets/propertyMenu.tsx @@ -49,6 +49,11 @@ const PropertyMenu = React.memo((props: Props) => { const nameTextbox = useRef(null) const [name, setName] = useState(props.propertyName) + const deleteText = intl.formatMessage({ + id: 'PropertyType.Delete', + defaultMessage: 'Delete', + }) + useEffect(() => { nameTextbox.current?.focus() nameTextbox.current?.setSelectionRange(0, name.length) @@ -85,38 +90,38 @@ const PropertyMenu = React.memo((props: Props) => { props.onTypeChanged('text')} /> props.onTypeChanged('number')} /> props.onTypeChanged('email')} /> props.onTypeChanged('select')} /> props.onTypeChanged('createdTime')} /> props.onTypeChanged('updatedTime')} /> props.onDelete(props.propertyId)} /> From c30534b0c2823dc05b22382ef2c9e6060c7b35cb Mon Sep 17 00:00:00 2001 From: Bharat Date: Thu, 1 Apr 2021 02:25:05 +0530 Subject: [PATCH 3/3] intl dialog.tsx --- webapp/i18n/en.json | 1 + webapp/src/components/dialog.tsx | 17 +++++++++++++---- 2 files changed, 14 insertions(+), 4 deletions(-) diff --git a/webapp/i18n/en.json b/webapp/i18n/en.json index 112dbd37f..6b3e9ea95 100644 --- a/webapp/i18n/en.json +++ b/webapp/i18n/en.json @@ -31,6 +31,7 @@ "ContentBlock.moveDown": "Move down", "ContentBlock.moveUp": "Move up", "ContentBlock.text": "text", + "Dialog.closeDialog": "Close dialog", "EmptyCenterPanel.no-content": "Add or select a board from the sidebar to get started.", "EmptyCenterPanel.workspace": "This is the workspace for:", "Filter.includes": "includes", diff --git a/webapp/src/components/dialog.tsx b/webapp/src/components/dialog.tsx index cf2e85d91..c90508dae 100644 --- a/webapp/src/components/dialog.tsx +++ b/webapp/src/components/dialog.tsx @@ -1,6 +1,7 @@ // Copyright (c) 2015-present Mattermost, Inc. All Rights Reserved. // See LICENSE.txt for license information. import React from 'react' +import {injectIntl, IntlShape} from 'react-intl' import IconButton from '../widgets/buttons/iconButton' import CloseIcon from '../widgets/icons/close' @@ -11,10 +12,11 @@ import './dialog.scss' type Props = { children: React.ReactNode toolsMenu: React.ReactNode - onClose: () => void + onClose: () => void, + intl: IntlShape } -export default class Dialog extends React.PureComponent { +class Dialog extends React.PureComponent { public componentDidMount(): void { document.addEventListener('keydown', this.keydownHandler) } @@ -35,7 +37,12 @@ export default class Dialog extends React.PureComponent { } public render(): JSX.Element { - const {toolsMenu} = this.props + const {toolsMenu, intl} = this.props + + const closeDialogText = intl.formatMessage({ + id: 'Dialog.closeDialog', + defaultMessage: 'Close dialog', + }) return (
{ } - title={'Close dialog'} + title={closeDialogText} className='IconButton--large' />
@@ -77,3 +84,5 @@ export default class Dialog extends React.PureComponent { this.props.onClose() } } + +export default injectIntl(Dialog)