1
0
mirror of https://github.com/mattermost/focalboard.git synced 2025-01-11 18:13:52 +02:00

Add i18n and migrate other menu in the FilterComponent

This commit is contained in:
Jesús Espino 2020-10-25 11:10:59 +01:00
parent c5e0c735db
commit 1e4172d699
5 changed files with 71 additions and 36 deletions

View File

@ -11,6 +11,12 @@
"BoardComponent.no-property-title": "Items with an empty {property} property will go here. This column cannot be removed.",
"BoardComponent.show": "Show",
"Comment.delete": "Delete",
"FilterComponent.add-filter": "+ Add Filter",
"FilterComponent.delete": "Delete",
"FilterComponent.includes": "includes",
"FilterComponent.is-empty": "is empty",
"FilterComponent.is-not-empty": "is not empty",
"FilterComponent.not-includes": "doesn't include",
"Sidebar.add-board": "+ Add Board",
"Sidebar.delete-board": "Delete Board",
"Sidebar.export-archive": "Export Archive",

View File

@ -11,6 +11,12 @@
"BoardComponent.no-property-title": "Elementos sin la propiedad {property} irán aquí. Esta columna no se puede eliminar.",
"BoardComponent.show": "Mostrar",
"Comment.delete": "Borrar",
"FilterComponent.add-filter": "+ Añadir filtro",
"FilterComponent.delete": "Borrar",
"FilterComponent.includes": "incluye",
"FilterComponent.is-empty": "está vacío",
"FilterComponent.is-not-empty": "no está vacío",
"FilterComponent.not-includes": "no incluye",
"Sidebar.add-board": "+ Añadir Panel",
"Sidebar.delete-board": "Borrar Panel",
"Sidebar.export-archive": "Exportar Archivo",

View File

@ -1,6 +1,7 @@
// Copyright (c) 2015-present Mattermost, Inc. All Rights Reserved.
// See LICENSE.txt for license information.
import React from 'react'
import {FormattedMessage, IntlShape, injectIntl} from 'react-intl'
import {IPropertyTemplate} from '../blocks/board'
@ -17,6 +18,7 @@ import Menu from '../widgets/menu'
type Props = {
boardTree: BoardTree
onClose: () => void
intl: IntlShape
}
class FilterComponent extends React.Component<Props> {
@ -47,8 +49,25 @@ class FilterComponent extends React.Component<Props> {
this.props.onClose()
}
render(): JSX.Element {
private conditionClicked = (optionId: string, filter: FilterClause): void => {
const {boardTree} = this.props
const {activeView: view} = boardTree
const filterIndex = view.filter.filters.indexOf(filter)
Utils.assert(filterIndex >= 0, "Can't find filter")
const filterGroup = new FilterGroup(view.filter)
const newFilter = filterGroup.filters[filterIndex] as FilterClause
Utils.assert(newFilter, `No filter at index ${filterIndex}`)
if (newFilter.condition !== optionId) {
newFilter.condition = optionId as FilterCondition
mutator.changeViewFilter(view, filterGroup)
}
}
render(): JSX.Element {
const {boardTree, intl} = this.props
const {board, activeView} = boardTree
// TODO: Handle FilterGroups (compound filter statements)
@ -92,10 +111,31 @@ class FilterComponent extends React.Component<Props> {
/>))}
</Menu>
</MenuWrapper>
<div
className='octo-button'
onClick={(e) => this.conditionClicked(e, filter)}
>{FilterClause.filterConditionDisplayString(filter.condition)}</div>
<MenuWrapper>
<div className='octo-button'>{FilterClause.filterConditionDisplayString(filter.condition)}</div>
<Menu>
<Menu.Text
id='includes'
name={intl.formatMessage({id: 'FilterComponent.includes', defaultMessage: 'includes'})}
onClick={(id) => this.conditionClicked(id, filter)}
/>
<Menu.Text
id='notIncludes'
name={intl.formatMessage({id: 'FilterComponent.not-includes', defaultMessage: 'doesn\'t include'})}
onClick={(id) => this.conditionClicked(id, filter)}
/>
<Menu.Text
id='isEmpty'
name={intl.formatMessage({id: 'FilterComponent.is-empty', defaultMessage: 'is empty'})}
onClick={(id) => this.conditionClicked(id, filter)}
/>
<Menu.Text
id='isNotEmpty'
name={intl.formatMessage({id: 'FilterComponent.is-not-empty', defaultMessage: 'is not empty'})}
onClick={(id) => this.conditionClicked(id, filter)}
/>
</Menu>
</MenuWrapper>
{
this.filterValue(filter, template)
}
@ -103,7 +143,12 @@ class FilterComponent extends React.Component<Props> {
<div
className='octo-button'
onClick={() => this.deleteClicked(filter)}
>Delete</div>
>
<FormattedMessage
id='FilterComponent.delete'
defaultMessage='Delete'
/>
</div>
</div>)
})}
@ -112,7 +157,12 @@ class FilterComponent extends React.Component<Props> {
<div
className='octo-button'
onClick={() => this.addFilterClicked()}
>+ Add Filter</div>
>
<FormattedMessage
id='FilterComponent.add-filter'
defaultMessage='+ Add Filter'
/>
</div>
</div>
)
}
@ -142,31 +192,6 @@ class FilterComponent extends React.Component<Props> {
return undefined
}
private conditionClicked(e: React.MouseEvent, filter: FilterClause) {
const {boardTree} = this.props
const {activeView: view} = boardTree
const filterIndex = view.filter.filters.indexOf(filter)
Utils.assert(filterIndex >= 0, "Can't find filter")
OldMenu.shared.options = [
{id: 'includes', name: 'includes'},
{id: 'notIncludes', name: "doesn't include"},
{id: 'isEmpty', name: 'is empty'},
{id: 'isNotEmpty', name: 'is not empty'},
]
OldMenu.shared.onMenuClicked = (optionId: string, type?: string) => {
const filterGroup = new FilterGroup(view.filter)
const newFilter = filterGroup.filters[filterIndex] as FilterClause
Utils.assert(newFilter, `No filter at index ${filterIndex}`)
if (newFilter.condition !== optionId) {
newFilter.condition = optionId as FilterCondition
mutator.changeViewFilter(view, filterGroup)
}
}
OldMenu.shared.showAtElement(e.target as HTMLElement)
}
private valuesClicked(e: React.MouseEvent, filter: FilterClause) {
const {boardTree} = this.props
const {board, activeView: view} = boardTree
@ -228,4 +253,4 @@ class FilterComponent extends React.Component<Props> {
}
}
export {FilterComponent}
export default injectIntl(FilterComponent)

View File

@ -18,7 +18,7 @@ import Menu from '../widgets/menu'
import MenuWrapper from '../widgets/menuWrapper'
import {Editable} from './editable'
import {FilterComponent} from './filterComponent'
import FilterComponent from './filterComponent'
type Props = {
boardTree?: BoardTree

View File

@ -1,11 +1,9 @@
// Copyright (c) 2015-present Mattermost, Inc. All Rights Reserved.
// See LICENSE.txt for license information.
import React from 'react'
import ReactDOM from 'react-dom'
import {BoardView} from '../blocks/boardView'
import {MutableBoardTree} from '../viewModel/boardTree'
import {FilterComponent} from '../components/filterComponent'
import {WorkspaceComponent} from '../components/workspaceComponent'
import {FlashMessage} from '../flashMessage'
import mutator from '../mutator'