Skip to content

Commit

Permalink
Merge pull request #4 from desko27/feature/spanish-translation
Browse files Browse the repository at this point in the history
Feature/spanish translation
  • Loading branch information
desko27 authored Apr 25, 2020
2 parents edce99a + 12536c7 commit dc63795
Show file tree
Hide file tree
Showing 11 changed files with 128 additions and 22 deletions.
47 changes: 47 additions & 0 deletions README.es.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,47 @@
# Media Portal <img height="34" width="34" src="https://user-images.githubusercontent.com/4168389/80243995-80921700-8668-11ea-90ec-e19eb6c02c75.png"> <img height="30" width="30" src="https://user-images.githubusercontent.com/4168389/80243999-81c34400-8668-11ea-94b5-ad61ef3945b7.png">

> [⬇️ Descargar la aplicación](https://github.com/desko27/mediaportal/releases/latest)
Media Portal es una aplicación para ordenador gratuita y de código abierto, que funciona tanto en sistemas Windows como en Mac.

Si necesitas exponer diferentes imágenes o vídeos durante una videoconferencia y utilizas la función de compartir pantalla, Media Portal te ayuda a preparar una lista de archivos desde la cual mandarás contenido en un solo click.

## Manual de uso

Al ejecutar Media Portal se abren dos ventanas: una es la ventana de gestión de la lista de archivos, la otra es el portal donde veremos el contenido.

![Boot Media Portal](https://user-images.githubusercontent.com/4168389/80231414-9f39e300-8653-11ea-9453-74fbc6f83ac9.png)

A continuación, solo tenemos que seleccionar y arrastrar nuestra lista de archivos de imagen o vídeo hacia la ventana de gestión.

![Dragging Media Files](https://user-images.githubusercontent.com/4168389/80231433-a52fc400-8653-11ea-9d38-6ea11f9d19f3.png)

Entonces, hacemos click en cualquiera de ellos e inmediatamente veremos el contenido en el portal.

Se trate de una imagen...

![Sending Content Image](https://user-images.githubusercontent.com/4168389/80231438-a82ab480-8653-11ea-959f-f2322055848f.png)

... o de vídeo

![Sending Content Video](https://user-images.githubusercontent.com/4168389/80231445-aa8d0e80-8653-11ea-81dd-a4bf6bc1e576.png)


Es así de sencillo, ¡ya puedes empezar a usar Media Portal!

## Preguntas frecuentes

### ¿Puedo usarlo con varias pantallas?
Si tienes dos o más pantallas, puedes mover el portal a cualquiera de ellas, e incluso ampliarlo a pantalla completa haciendo doble click sobre él. Esto te puede venir bien si deseas compartir directamente una de tus pantallas secundarias en tu aplicación de videoconferencias.

### ¿Qué son los checks verdes de la izquierda?
Para llevar control de lo que ya has compartido durante la reunión, Media Portal marcará automáticamente cada archivo al seleccionarlo; de este modo siempre sabrás cuál es el siguiente. También puedes añadir o retirar estas marcas manualmente haciendo click sobre ellas.

### ¿Hay atajos de teclado?
Efectivamente, para los más exigentes, Media Portal ofrece la posibilidad de controlar el envío de contenido mediante atajos de teclado, algo muy conveniente considerando que lo normal es que estemos más pendientes de la aplicación de videoconferencias y que quizá no haya tanto tiempo para ir cambiando entre ventanas.

| Atajo de teclado | Acción |
| --- | --- |
| <kbd>SHIFT</kbd> + <kbd>ALT</kbd> + <kbd>A</kbd> | Envía el contenido siguiente |
| <kbd>SHIFT</kbd> + <kbd>ALT</kbd> + <kbd>0</kbd> | Deja de enviar el contenido actual |
| <kbd>SHIFT</kbd> + <kbd>ALT</kbd> + <kbd>[1-9]</kbd> | Envía el contenido de la posición deseada |
3 changes: 2 additions & 1 deletion package.json
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@
"name": "mediaportal",
"description": "Portal for media",
"author": "desko27",
"version": "2.2.0",
"version": "2.3.0",
"private": true,
"scripts": {
"react-start": "react-scripts start",
Expand Down Expand Up @@ -47,6 +47,7 @@
"react": "^16.8.6",
"react-dom": "^16.8.6",
"react-dropzone": "^10.2.2",
"react-intl": "^4.5.0",
"react-router-dom": "^5.1.2"
},
"devDependencies": {
Expand Down
38 changes: 28 additions & 10 deletions src/App.js
Original file line number Diff line number Diff line change
@@ -1,21 +1,39 @@
import React from 'react'
import { HashRouter as Router, Switch, Route } from 'react-router-dom'
import { IntlProvider } from 'react-intl'

import MainRoute from './routes/MainRoute'
import PortalRoute from './routes/PortalRoute'

import en from './translations/en.json'
import es from './translations/es.json'

const translations = { en, es }
const availableLanguages = Object.keys(translations)

// get language without region code from browser
const [rawBrowserLanguage] = navigator.language.split(/[-_]/)
const originalLang = rawBrowserLanguage && rawBrowserLanguage.toLowerCase()

// take decisions like fallback to english if browser's not available
const DEFAULT_LANGUAGE = 'en'
const browserLanguage = originalLang === 'ca' ? 'es' : originalLang // catalan -> spanish
const language = availableLanguages.includes(browserLanguage) ? browserLanguage : DEFAULT_LANGUAGE

const App = () => {
return (
<Router>
<Switch>
<Route path='/main'>
<MainRoute />
</Route>
<Route path='/portal'>
<PortalRoute />
</Route>
</Switch>
</Router>
<IntlProvider locale={language} messages={translations[language]}>
<Router>
<Switch>
<Route path='/main'>
<MainRoute />
</Route>
<Route path='/portal'>
<PortalRoute />
</Route>
</Switch>
</Router>
</IntlProvider>
)
}

Expand Down
3 changes: 2 additions & 1 deletion src/components/Header/UpdateButton/index.js
Original file line number Diff line number Diff line change
@@ -1,11 +1,12 @@
import React from 'react'
import { FormattedMessage } from 'react-intl'

import styles from './index.module.css'

const UpdateButton = ({ onClick }) => {
return (
<button className={styles.wrapper} onClick={onClick}>
Update!
<FormattedMessage id='header.update' />
</button>
)
}
Expand Down
3 changes: 2 additions & 1 deletion src/components/Header/index.js
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
import React from 'react'
import cx from 'classnames'
import { FormattedMessage } from 'react-intl'

import { ReactComponent as XCircleIcon } from './icons/x-circle.svg'
import { ReactComponent as MenuIcon } from './icons/menu.svg'
Expand Down Expand Up @@ -34,7 +35,7 @@ const Header = ({
</button>
<span className={styles.filesInfo}>
{!!filesNumber && `${Math.round(progressRatio * 100)}% | `}
{filesNumber || '--'} files
{filesNumber || '--'} <FormattedMessage id='header.files' />
</span>
{FLEX_SPACER}
{isUpdateAvailable && <UpdateButton onClick={performUpdate} />}
Expand Down
3 changes: 2 additions & 1 deletion src/components/MediaControls/index.js
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
import React from 'react'
import cx from 'classnames'
import { FormattedMessage } from 'react-intl'

import ElapsedTimeBar from './ElapsedTimeBar'
import { ReactComponent as PlayIcon } from './icons/play.svg'
Expand All @@ -19,7 +20,7 @@ const MediaControls = ({ className, sendAction, video }) => {
if (!video) {
return (
<div className={baseClass}>
No video selected
<FormattedMessage id='media-controls.no-video-selected' />
</div>
)
}
Expand Down
1 change: 1 addition & 0 deletions src/components/Menu/MenuItem/index.module.css
Original file line number Diff line number Diff line change
Expand Up @@ -29,6 +29,7 @@
}

.notificationBall {
flex-shrink: 0;
height: 10px;
width: 10px;
border-radius: 5px;
Expand Down
30 changes: 23 additions & 7 deletions src/components/Menu/index.js
Original file line number Diff line number Diff line change
@@ -1,7 +1,8 @@
import React from 'react'
import cx from 'classnames'

import { FormattedMessage, useIntl } from 'react-intl'
import { version } from '../../../package.json'

import MenuItem from './MenuItem'
import styles from './index.module.css'

Expand All @@ -10,7 +11,10 @@ const openUrl = url => shell.openExternal(url)

const FLEX_SPACER = <div style={{ flexGrow: 1, minHeight: 15 }} />
const LINKS = {
USER_MANUAL: 'https://github.com/desko27/mediaportal/blob/master/README.md',
USER_MANUAL: locale => {
const localizedExtension = locale === 'en' ? '' : `.${locale}`
return `https://github.com/desko27/mediaportal/blob/master/README${localizedExtension}.md`
},
SOURCE_CODE: 'https://github.com/desko27/mediaportal',
REPORT_ISSUE: 'https://github.com/desko27/mediaportal/issues/new',
SEND_COMMENTS: 'mailto:[email protected]'
Expand All @@ -19,20 +23,32 @@ const LINKS = {
const Menu = ({
isOpen,
isUpdateAvailable,
lang,
performUpdate,
setIsOpen
}) => {
const { locale } = useIntl()
return (
<div className={cx(styles.wrapper, isOpen && styles.isOpen)}>
<div className={styles.overlay} onClick={() => setIsOpen(false)} />
<div className={styles.menu}>
{isUpdateAvailable && (
<MenuItem hasNotification onClick={performUpdate}>Download update</MenuItem>
<MenuItem hasNotification onClick={performUpdate}>
<FormattedMessage id='menu.download-update' />
</MenuItem>
)}
<MenuItem onClick={() => openUrl(LINKS.USER_MANUAL)}>See user manual </MenuItem>
<MenuItem onClick={() => openUrl(LINKS.SOURCE_CODE)}>Source code</MenuItem>
<MenuItem onClick={() => openUrl(LINKS.REPORT_ISSUE)}>Report an issue</MenuItem>
<MenuItem onClick={() => openUrl(LINKS.SEND_COMMENTS)}>Send comments</MenuItem>
<MenuItem onClick={() => openUrl(LINKS.USER_MANUAL(locale))}>
<FormattedMessage id='menu.see-user-manual' />
</MenuItem>
<MenuItem onClick={() => openUrl(LINKS.SOURCE_CODE)}>
<FormattedMessage id='menu.source-code' />
</MenuItem>
<MenuItem onClick={() => openUrl(LINKS.REPORT_ISSUE)}>
<FormattedMessage id='menu.report-issue' />
</MenuItem>
<MenuItem onClick={() => openUrl(LINKS.SEND_COMMENTS)}>
<FormattedMessage id='menu.send-comments' />
</MenuItem>
{FLEX_SPACER}
<MenuItem isDisabled>v{version}</MenuItem>
</div>
Expand Down
2 changes: 1 addition & 1 deletion src/components/Menu/index.module.css
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,7 @@
top: var(--h-menu-spacing);
bottom: 0;
right: 0;
width: 200px;
width: 210px;
background-color: var(--c-gray);
box-shadow: calc(-1 * var(--bxsh-width)) 0px 0px 0px rgba(var(--c-black-rgb), 0.15);
transform: translateX(calc(100% + var(--bxsh-width)));
Expand Down
10 changes: 10 additions & 0 deletions src/translations/en.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
{
"header.files": "files",
"header.update": "update!",
"menu.download-update": "Download update",
"menu.see-user-manual": "See user manual",
"menu.source-code": "Source code",
"menu.report-issue": "Report an issue",
"menu.send-comments": "Send comments",
"media-controls.no-video-selected": "No video selected"
}
10 changes: 10 additions & 0 deletions src/translations/es.json
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
{
"header.files": "archivos",
"header.update": "¡novedades!",
"menu.download-update": "Descargar actualización",
"menu.see-user-manual": "Ver instrucciones",
"menu.source-code": "Código fuente",
"menu.report-issue": "Reportar error",
"menu.send-comments": "Enviar comentarios",
"media-controls.no-video-selected": "Sin vídeo seleccionado"
}

0 comments on commit dc63795

Please sign in to comment.