Skip to content

Latest commit

 

History

History
168 lines (124 loc) · 8.04 KB

README.md

File metadata and controls

168 lines (124 loc) · 8.04 KB

Construyendo una styleguide con React (2016-12-21)

Speakers: @vctrfrnndz y @arielger_

Slides: http://slides.com/arielgerstein/construyendo-una-styleguide-con-react

Auth0 Styleguide:

http://styleguide.auth0.com/

https://github.com/auth0/styleguide

Auth0 React Styleguide:

https://auth0-styleguide-pr-102.herokuapp.com

https://github.com/auth0/styleguide/tree/experimental

La charla se va a dividir en tres partes:

  1. ¿Cuáles son las ventajas de construir una styleguide?
  2. ¿Cómo podemos comenzar a crear nuestra styleguide?
  3. ¿Cómo evolucionamos nuestra styleguide en Auth0?

¿Cuáles son las ventajas de construir una styleguide?

Una styleguide es un conjunto de patrones reutilizables que nos permite:

  • Mantener la consistencia y la identidad de nuestra organización.
  • Promover mejores practicas.
  • Simplificar el trabajo de los desarrolladores.

¿Cómo podemos comenzar a crear nuestra propia styleguide?

  • Documentación de fuentes, variables, colores, clases de utilidad y sus distintos usos.
  • Agregar los componentes basicos que se reutilizan en todos las paginas (Header, footer, hero, banners).
  • Asignar mantainers al proyecto (la styleguide debe ser parte del workflow de la organización).
  • Hacerla publica.
  • Aumentar el alcance (agregar brand assets, design language, voice and tone, animations, etc).
  • Incluir la styleguide en todos nuestros proyectos.

Pueden encontrar mas información en: http://styleguides.io/

¿Como evolucionamos nuestra styleguide en Auth0? 📈

Ventajas de usar React para nuestra styleguide:

  • Ecosistema pujante con variedad de componentes, tutoriales, información, etc.

  • Nos permite abstraernos del mark-up de nuestros componentes (HTML/CSS). Nos enfocamos en la API externa del componente mientras que podemos cambiar el HTML/CSS interno.

    Con nuestros componentes HTML/CSS nos vemos obligados a mantener el código indefinidamente:

    Whilst this is an excellent goal, the problem in this case is the distribution of templates. Even if we presume that the rendered markup is absolutely up to date, once they copy that code they are essentially cutting a version which needs to be maintained indefinitely. When they copied the markup for a working component it had an implicit link to a snapshot of the CSS at that point. If you then update the template or refactor the CSS, you need to update all versions of the template scattered around your site.

    A Maintainable Style Guide

  • Flexibilidad: Podemos combinar nuestros componentes de distintas maneras.

Decisiones a la hora de crear una libreria de componentes React: 🤔

  • ¿Cómo manejar los estilos de cada componente? 🖌

  • ¿Cómo dividir nuestra styleguide en secciones? 📦

    Utilizamos una herramienta llamada Lerna que nos permite manejar repositorios con distintos paquetes. Lerna nos permite linkear los proyectos entre si (lerna bootstrap) y manejar el versionado de cada proyecto (independientemente o conjuntamente).

  • Testing ✅

    Actualmente usamos Mocha, Chai y Enzime para testear nuestros componentes.

    import React from 'react';
    import { expect } from 'chai';
    import { shallow } from 'enzyme';
    import Select from './';
    
    const options = [
      'Gernot Linas',
      'Butrus Aziz',
      'Vladimir Gislin',
      'Kassandros Ekwueme',
      'Rashad Ariel'
    ];
    
    describe('<Select />', () => {
      it('it should render a select element', () => {
        const wrapper = shallow(<Select />);
        expect(wrapper.find('select')).to.have.length(1);
      });
      it(`should render ${options.length} options`, () => {
        const wrapper = shallow(<Select options={options} />);
        expect(wrapper.find('select').find('option')).to.have.length(options.length);
      });
    });
    
  • Generamos distintos bundles (ES6 modules, CommonJS, UMD). Si usamos un module bundler como Rollup obtenemos:

    • Tree-shaking: Excluye imports no utilizados. (example)
    • Inlining: Todos los modulos estan en el mismo scope. (Webpack 1 pone cada modulo en un scope distinto)
  • Para el ambiente de desarrollo de los componentes usamos Storybook, que nos permite desarrollar nuestros componentes de manera aislada y mostrar distintos estados de los mismos.

    StoryBook

    import React from 'react';
    import { storiesOf, action } from '@kadira/storybook';
    
    storiesOf('Button', module)
      .add('with text', () => (
        <button onClick={action('clicked')}>Hello Button</button>
      ))
      .add('with some emoji', () => (
        <button onClick={action('clicked')}>😀 😎 👍 💯</button>
      ));
    
  • Usamos React docgen para generar documentacion en base a los componentes. React docgen parsea el archivo de nuestro componente y nos devuelve un JSON con informacion sobre las props, defaultProps, propTypes. Incluso podemos agregar comentarios a modo de descripcion de las propiedades del componente.

    var React = require('react');
    
    /**
    * General component description.
    */
    var Component = React.createClass({
      propTypes: {
        /**
        * Description of prop "foo".
        */
        foo: React.PropTypes.number,
        /**
        * Description of prop "bar".
        */
        bar: React.PropTypes.string
      },
    
      render: function() {
        // ...
      }
    });
    
    module.exports = Component;
    
  • Live playground para probar los componentes:

  • Agregar reglas para los nuevos componentes asi nos aseguramos que nuestra libreria sea consistente. 📝

    • Agregar una configuracion de ESLint para React (https://github.com/yannickcr/eslint-plugin-react)
    • Contiene unicamente stateless componentes lo cual nos permite conectar los componentes con Redux u otras librerias de state-management.
    • Podemos re-exportar componentes de otras librerias desde nuestra styleguide.