Saltar al contenido

🎉 Material UI v5 is out now! Check out the announcement blog post

Derecha-a-izquierda

Idiomas de derecha a izquierda como árabe, persa o hebreo son compatibles. Para cambiar la dirección de los componentes de Material-UI debe seguir los siguientes pasos.

Pasos

1. HTML

Asegúrese de que el atributo dir está establecido en el body, de lo contrario los componentes nativos no funcionarán:

<body dir="rtl">

2. Tema

Establece la dirección en su tema personalizado:

const theme = createTheme({
  direction: 'rtl',
});

3. jss-rtl

Necesitas este plugin JSS para voltear los estilos: jss-rtl.

npm install jss-rtl

Después de haber instalado el plugin en su proyecto, los componentes de Material-UI todavía requieren que se cargue por la instancia jss, como se describe a continuación. Internamente, withStyles está utilizando este plugin JSS cuando dirección: 'rtl' está establecido en el tema. Dirígete al plugin README para aprender más sobre él.

Una vez que haya creado una nueva instancia JSS con el plugin, necesitará ponerla a disposición de todos los componentes del árbol de componentes. The StylesProvider component enables this:

import { create } from 'jss';
import rtl from 'jss-rtl';
import { StylesProvider, jssPreset } from '@material-ui/core/styles';

// Configura JSS
const jss = create({ plugins: [. .jsssPreset(). lugins, rtl()] });

function RTL(props) {
  return (
    <StylesProvider jss={jss}>
      {props.children}
    </StylesProvider>
  );
}

Demo

Utilice el botón de cambiar de dirección en la esquina superior derecha para voltear toda la documentación

<ThemeProvider theme={theme}>
  <div dir="rtl">
    <TextField placeholder="Name" />
    <input type="text" placeholder="Name" />
  </div>
</ThemeProvider>

Opting out of rtl transformation

If you want to prevent a specific rule-set from being affected by the rtl transformation you can add flip: false at the beginning.

Use the direction toggle button on the top right corner to see the effect.

Affected
Unaffected
<div className={classes.affected}>Affected</div>
<div className={classes.unaffected}>Unaffected</div>