Espen Henriksen

Front-end team lead

Oslo Market Solutions

 

espen_dev

esphen

OMS' Component Library

Why

Reusability

  • OMS have many different customers
  • Each have their own distinctive style
  • The same data is always present on many customers' sites
  • Solution: Build a component library!
  • Our components cannot be opinionated in design
  • White label

Ease of use

  • If it is easy to reuse, people will reuse
  • People get time to do other stuff
  • Less debugging, works out of the box
  • Fix it once, fix it everywhere
  • Easy and consistent upgrade path

Hide complexity

  • OMS has a proprietary API for fetching market data
  • Defined in a "spec"
  • API is sometimes complex
  • Data fetching is encapsulated inside each component
  • Configure data fetching using props instead of building a spec

Accessibility

  • Everyone is temporarily able-bodied
  • If you live long enough, you'll become disabled
  • WCAG
  • Fix accessibility one place
  • More rigorous review
  • Less to audit
  • Stricter linting

Show & tell

A component

🤮

😍 😍 😍 😍 😍 😍

i18n

i18n

  • Internationalization
  • Can't (practically) avoid text inside components
  • We want to support any and all languages
  • The library can't assume to know what languages will be available
  • Up to the consumer of the component to define correct translations

i18n-webpack-plugin

  • GitHub under webpack-contrib
  • Replaces compile time
  • No language keys, natual language as key
  • Define translations in json
  • Abandoned?
  • Maybe context next time

Build

Build

  • Babel for ESM and CommonJS output
  • Rollup for UMD output
  • Each pushed branch deploys a new version of the styleguidist documentation site
  • Pre-commit hooks with tests, prettier, eslint and stylelint

Why not atomic design?

Code drift

  • Story time
  • Everyone used to write their own components
  • Each slightly different
  • Copied from one project to the next
  • Components drifted and became different over time
  • Solved by centralizing the code

Self contained

  • Standard components with standard behavior
  • Exactly the same content across many websites
  • Everyone's problem domain is unique
  • Our solution is not the right one for everyone

Thanks for listening!

Questions?

OMS' Component Library

By Eline H

OMS' Component Library

  • 31