Bundles
The @dnb/eufemia
also supports ready to use UMD
and ESM
bundles.
NB: As these bundles will keep on getting larger once new components arrive, I strongly recommend to only use UMD and ESM bundles as an easy drop-in for simple web pages.
For advanced applications, I recommend a holistic build step, handling all dependencies together, creating mono page bundles with code splitting in place. This ensures that only code which is currently used by the application, is sent to the user.
The reason for that is the first page load (first paint) which is extremely important for good UX, as it has a whole bunch of negative side effects like page flicker and uncontrolled movements as well as load time.
- Tobias Høegh, april 2020
All the code examples are only quick demos, showing how to load the bundles. Keep in mind, there are many ways on how to consume them. The example code is in no way recommended for production usage, as it is highly imperative code and you will make code bases hard to read and maintain.
UMD bundles
Requires React and ReactDOM to be loaded. Supports ES5
.
- dnb-ui-lib.min.js - includes all components and elements and individual Web Component support.
- dnb-ui-components.min.js - includes all components.
- dnb-ui-extensions.min.js - includes all extensions.
- dnb-ui-web-components.min.js - includes all components and enables all custom elements by default.
- dnb-ui-icons.min.js - includes all primary icons in default and medium size.
- dnb-ui-basis.min.js - includes just the core methods like:
isTouchDevice
,defineNavigator
.
Usage of UMD bundles
<body><div id="app"></div><script src="https://unpkg.com/react/umd/react.production.min.js"></script><script src="https://unpkg.com/react-dom/umd/react-dom.production.min.js"></script><script src="https://unpkg.com/@dnb/eufemia/umd/dnb-ui-icons.min.js"></script><script src="https://unpkg.com/@dnb/eufemia/umd/dnb-ui-lib.min.js"></script><script type="application/javascript">const MyButton = React.createElement(window.dnbLib.Button, {text: 'My Button',icon: 'chevron_right',on_click: (params) => {console.log('on_click', params)},})ReactDOM.render(MyButton, document.getElementById('app'))</script></body>
ESM bundles
Requires React and ReactDOM to be loaded as a module resolution (importmap). Supports ES6
(NB: That is the aim, right now it is also compiled down to ES5).
- dnb-ui-lib.min.mjs - includes all components and elements and individual Web Component support.
- dnb-ui-components.min.mjs - includes all components.
- dnb-ui-extensions.min.mjs - includes all extensions.
- dnb-ui-web-components.min.mjs - includes all components and enables all custom elements by default.
- dnb-ui-icons.min.mjs - includes all primary icons in default and medium size.
- dnb-ui-basis.min.mjs - includes just the core methods like:
isTouchDevice
,defineNavigator
.
Usage of ESM bundles
Because importmap
is still not supported by the majority of browsers, we use a shim, which can be simply removed once the browser support is good enough.
<body><div id="app"></div><scriptdefersrc="https://unpkg.com/es-module-shims/dist/es-module-shims.js"></script><script type="importmap-shim">{"imports": {"react": "...","react-dom": "...","../icons/primary_icons.js": "https://unpkg.com/@dnb/eufemia/esm/dnb-ui-icons.min.mjs","../icons/primary_icons_medium.js": "https://unpkg.com/@dnb/eufemia/esm/dnb-ui-icons.min.mjs"}}</script><script type="module-shim">import React from 'react'import ReactDOM from 'react-dom'import { Button } from 'https://unpkg.com/@dnb/eufemia/esm/dnb-ui-lib.min.mjs'const MyButton = React.createElement(Button,{text: 'My Button',icon: 'chevron_right',on_click: (params) => {console.log('on_click', params)}})ReactDOM.render(MyButton, document.getElementById('app'))</script></body>
Note: Because React don't delivers an ESM bundle right now, we have to create our own.
Have a look at this UDM example app as well as the this ESM example app.
Read more about Web Components usage in ESM.