Add Portuguese translation (incomplete)

This commit is contained in:
Deluan 2020-04-13 19:51:03 -04:00 committed by Deluan Quintão
parent 2dfe01963a
commit 289ba68824
10 changed files with 208 additions and 25 deletions

5
ui/package-lock.json generated
View File

@ -13127,6 +13127,11 @@
"resolved": "https://registry.npmjs.org/ra-language-english/-/ra-language-english-3.2.0.tgz",
"integrity": "sha512-/XmwYWoQoB4MBkkzBCbg/ykCuRGjHQOHLk2ik6n1aM10AWHxiiJNyRw2aoLzH7Vc5rcp4BBJQCuhT+DgfYIJ2Q=="
},
"ra-language-portuguese": {
"version": "1.6.0",
"resolved": "https://registry.npmjs.org/ra-language-portuguese/-/ra-language-portuguese-1.6.0.tgz",
"integrity": "sha512-9PAxgrisjmDOTRefjCe2y2ruYQw/iqXnXgUt09vOYUcjY4J0ctabJ4+joGI0jV/x9icF9c7Pui2USc5QDRTktQ=="
},
"ra-ui-materialui": {
"version": "3.3.3",
"resolved": "https://registry.npmjs.org/ra-ui-materialui/-/ra-ui-materialui-3.3.3.tgz",

View File

@ -12,6 +12,7 @@
"md5-hex": "^3.0.1",
"prop-types": "^15.7.2",
"ra-data-json-server": "^3.3.3",
"ra-language-portuguese": "^1.6.0",
"react": "^16.13.1",
"react-admin": "^3.3.3",
"react-dom": "^16.13.1",

View File

@ -8,7 +8,8 @@ import {
NumberInput,
ReferenceInput,
SearchInput,
Pagination
Pagination,
useTranslate
} from 'react-admin'
import { Title } from '../common'
import { withWidth } from '@material-ui/core'
@ -17,21 +18,25 @@ import AlbumListView from './AlbumListView'
import AlbumGridView from './AlbumGridView'
import { ALBUM_MODE_LIST } from './albumState'
const AlbumFilter = (props) => (
<Filter {...props}>
<SearchInput source="name" alwaysOn />
<ReferenceInput
source="artist_id"
reference="artist"
sort={{ field: 'name', order: 'ASC' }}
filterToQuery={(searchText) => ({ name: [searchText] })}
>
<AutocompleteInput emptyText="-- None --" />
</ReferenceInput>
<NullableBooleanInput source="compilation" />
<NumberInput source="year" />
</Filter>
)
const AlbumFilter = (props) => {
const translate = useTranslate()
return (
<Filter {...props}>
<SearchInput source="name" alwaysOn />
<ReferenceInput
label={translate('resources.album.fields.artist')}
source="artist_id"
reference="artist"
sort={{ field: 'name', order: 'ASC' }}
filterToQuery={(searchText) => ({ name: [searchText] })}
>
<AutocompleteInput emptyText="-- None --" />
</ReferenceInput>
<NullableBooleanInput source="compilation" />
<NumberInput source="year" />
</Filter>
)
}
const getPerPage = (width) => {
if (width === 'xs') return 12

View File

@ -27,12 +27,30 @@ const Player = () => {
glassBg: false,
showThemeSwitch: false,
showMediaSession: true,
panelTitle: translate('player.panelTitle'),
defaultPosition: {
top: 300,
left: 120
},
locale: {
playListsText: translate('player.playListsText'),
openText: translate('player.openText'),
closeText: translate('player.closeText'),
notContentText: translate('player.notContentText'),
clickToPlayText: translate('player.clickToPlayText'),
clickToPauseText: translate('player.clickToPauseText'),
nextTrackText: translate('player.nextTrackText'),
previousTrackText: translate('player.previousTrackText'),
reloadText: translate('player.reloadText'),
volumeText: translate('player.volumeText'),
toggleLyricText: translate('player.toggleLyricText'),
toggleMiniModeText: translate('player.toggleMiniModeText'),
destroyText: translate('player.destroyText'),
downloadText: translate('player.downloadText'),
removeAudioListsText: translate('player.removeAudioListsText'),
controllerTitle: translate('player.controllerTitle'),
clickToDeleteText: (name) =>
translate('player.clickToDeleteText', { name }),
emptyLyricText: translate('player.emptyLyricText'),
playModeText: {
order: translate('player.playModeText.order'),
orderLoop: translate('player.playModeText.orderLoop'),

View File

@ -2,6 +2,7 @@ import deepmerge from 'deepmerge'
import englishMessages from 'ra-language-english'
export default deepmerge(englishMessages, {
languageName: 'English',
resources: {
song: {
name: 'Song |||| Songs',
@ -45,12 +46,34 @@ export default deepmerge(englishMessages, {
menu: {
library: 'Library',
settings: 'Settings',
personal: 'Personal',
version: 'Version %{version}',
theme: 'Theme'
theme: 'Theme',
personal: {
name: 'Personal',
options: {
theme: 'Theme'
}
}
},
player: {
panelTitle: 'Play Queue',
playListsText: 'Play Queue',
openText: 'Open',
closeText: 'Close',
notContentText: 'No music',
clickToPlayText: 'Click to play',
clickToPauseText: 'Click to pause',
nextTrackText: 'Next track',
previousTrackText: 'Previous track',
reloadText: 'Reload',
volumeText: 'Volume',
toggleLyricText: 'Toggle lyric',
toggleMiniModeText: 'Minimize',
destroyText: 'Destroy',
downloadText: 'Download',
removeAudioListsText: 'Delete audio lists',
controllerTitle: '',
clickToDeleteText: `Click to delete %{name}`,
emptyLyricText: 'No lyric',
playModeText: {
order: 'In order',
orderLoop: 'Repeat',

View File

@ -1,3 +1,13 @@
import en from './en'
import pt from './pt'
export default { en }
// When adding a new translation, import it above and add it to the list bellow
const allLanguages = { en, pt }
// "Hack" to make "albumSongs" resource use the same translations as "song"
Object.keys(allLanguages).forEach(
(k) => (allLanguages[k].resources.albumSong = allLanguages[k].resources.song)
)
export default allLanguages

112
ui/src/i18n/pt.js Normal file
View File

@ -0,0 +1,112 @@
import deepmerge from 'deepmerge'
import en from './en'
import portugueseMessages from 'ra-language-portuguese'
export default deepmerge.all([
en,
portugueseMessages,
{
languageName: 'Português',
resources: {
song: {
name: 'Música |||| Músicas',
fields: {
title: 'Título',
artist: 'Artista',
album: 'Álbum',
path: 'Caminho',
genre: 'Gênero',
compilation: 'Coletânea',
duration: 'Duração',
year: 'Ano',
trackNumber: '#'
},
bulk: {
addToQueue: 'Play Later'
}
},
album: {
name: 'Álbum |||| Álbuns',
fields: {
name: 'Nome',
artist: 'Artista',
songCount: 'Songs',
genre: 'Gênero',
playCount: 'Plays',
compilation: 'Coletânea',
duration: 'Duração',
year: 'Ano'
},
actions: {
playAll: 'Play',
playNext: 'Play Next',
addToQueue: 'Play Later',
shuffle: 'Shuffle'
}
},
artist: {
name: 'Artista |||| Artistas',
fields: {
name: 'Nome'
}
},
user: {
name: 'Usuário |||| Usuários',
fields: {
name: 'Nome'
}
},
transcoding: {
name: 'Conversão |||| Conversões',
fields: {
name: 'Nome'
}
},
player: {
name: 'Tocador |||| Tocadores',
fields: {
name: 'Nome'
}
}
},
ra: {
auth: {
welcome1: 'Thanks for installing Navidrome!',
welcome2: 'To start, create an admin user',
confirmPassword: 'Confirm Password',
buttonCreateAdmin: 'Create Admin'
},
validation: {
invalidChars: 'Please only use letter and numbers',
passwordDoesNotMatch: 'Password does not match'
}
},
menu: {
library: 'Biblioteca',
settings: 'Configurações',
version: 'Versão %{version}',
personal: {
name: 'Pessoal',
options: {
theme: 'Tema'
}
}
},
player: {
playListsText: 'Fila de Execução',
openText: 'Abrir',
closeText: 'Fechar',
clickToPlayText: 'Clique para tocar',
clickToPauseText: 'Clique para pausar',
nextTrackText: 'Próxima faixa',
previousTrackText: 'Faixa anterior',
clickToDeleteText: `Clique para remover %{name}`,
playModeText: {
order: 'Em ordem',
orderLoop: 'Repetir tudo',
singleLoop: 'Repetir',
shufflePlay: 'Aleatório'
}
}
}
])

View File

@ -16,7 +16,7 @@ const PersonalMenu = forwardRef(({ onClick, sidebarIsOpen, dense }, ref) => {
<MenuItemLink
ref={ref}
to="/personal"
primaryText={translate('menu.personal')}
primaryText={translate('menu.personal.name')}
leftIcon={<TuneIcon />}
onClick={onClick}
className={classes.menuItem}

View File

@ -21,10 +21,11 @@ const Personal = () => {
return (
<Card className={classes.root}>
<Title title={'Navidrome - ' + translate('menu.personal')} />
<Title title={'Navidrome - ' + translate('menu.personal.name')} />
<SimpleForm toolbar={null}>
<SelectInput
source="theme"
label={translate('menu.personal.options.theme')}
defaultValue={currentTheme}
choices={themeChoices}
onChange={(event) => {

View File

@ -6,7 +6,8 @@ import {
List,
NumberField,
SearchInput,
TextField
TextField,
useTranslate
} from 'react-admin'
import { useMediaQuery } from '@material-ui/core'
import {
@ -30,6 +31,7 @@ const SongFilter = (props) => (
)
const SongList = (props) => {
const translate = useTranslate()
const dispatch = useDispatch()
const isXsmall = useMediaQuery((theme) => theme.breakpoints.down('xs'))
const isDesktop = useMediaQuery((theme) => theme.breakpoints.up('md'))
@ -63,7 +65,13 @@ const SongList = (props) => {
rowClick={(id, basePath, record) => dispatch(setTrack(record))}
>
<TextField source="title" />
{isDesktop && <AlbumLinkField source="albumId" sortBy="album" />}
{isDesktop && (
<AlbumLinkField
source="albumId"
label={translate('resources.song.fields.album')}
sortBy="album"
/>
)}
<TextField source="artist" />
{isDesktop && <NumberField source="trackNumber" />}
{isDesktop && <NumberField source="playCount" />}