Skip to content

bitkompagniet/natmus.component-library

Repository files navigation

Nationalmuseet Vue component library

TODO: write introduction.

How to build

The component library can be installed as a module in other vue projects, or it can run in a demo / documentation mode.

Build the demo / documentation app

This will produce a flat html file, js file and assets. Navigate into the source folder from the root directory and run:

npm install
npm run build:demo

This will produce the flat site in source/dist/demo. The contents of this folder can be dropped into a web folder root. Please note that the site produces root-relative URLs (starting with /), so it should not be dropped into a subfolder.

Install as Node module

When included as an NPM module in another Vue project, the exported top level object is a Vue plugin.

import Vue from 'vue';
import nmComponentLibrary from 'nm-component-library';

const options = { ... };

Vue.use(nmComponentLibrary, options);

The plugin can optionally be given an option object of the type INclOptions:

interface INclOptions {
  auth?: IAuth0Options
}

interface IAuth0Options {
  domain: string;
  clientID: string;
  redirectUri: string;
  responseType?: string;
  scope?: string;
}

Note that when the auth object is omitted from the configuration, the authentication sub-plugin will not be initialized, so this.$auth will not exist on components.

The domain and clientID can be found in your admin panel at Auth0.

Run in development mode

In development mode, the demo site can be edited with Hot Module Reloading. It is currently configured to be hot reloaded on the local LAN, but for this to work, you need to configure your LAN IP in source/vue.config.js (set devServer.public to your IP). If you have no need for LAN HMR, you can delete the entire devServer key. If you leave it as is, and the IP does not correspond to your actual IP, HMR will not work.

Navigate into the source folder from root and install dependencies:

npm install

To run the project in development mode with hot module reloading:

npm run serve

The site will be served at: http://localhost:8080/

Directory structure

source
|- dist: build target folder
|  |- demo: the build target of the demo / documentation site
|  |- lib: the build target of the module
|- public: the index and favicon that are baked into the demo site
|- src: main code folder
|  |- assets: styles, fonts, images
|  |  |- fonts: font folder
|  |  |- images: static images
|  |  |- scss: SCSS style sheets overriding Bootstrap styles
|  |  |- base: structure, base font and sizes, utilities
|  |  |- elements: certain component and element overrides
|  |  | app.scss: main SCSS file
|  |- builds: building blocks for configuring the output build
|  |  | customBootstrap.ts: adds Bootstrap and the override SCSS to the build
|  |  | demoWebApp.ts: adds the demo site to the build
|  |  | fontawesome.ts: adds font awesome icons to the build
|  |  | globalComponents.ts: registers all custom components globally with the n-prefix
|  |- components: custom vue components built for this library
|  |- demo: the demo site - everything below is only used in the demo build
|  | main.ts: entry point for the demo web app build
|  | module.ts: entry point for the module build
| README.md: original Vue CLI README
| package.json: Node package file
| tsconfig.json: TypeScript configuration
| tslint.json: tslint configuration
| vue.config.js: vue-cli-service configuration file
| babel.config.js: babel presets

Azure specific changes

Due to Azures handling of fonts, this file needs to be created at the root of the site, ie. the location where index.html is:

web.config:

<configuration>
	<system.webServer>    
	   <staticContent>
		   <remove fileExtension=".otf" />
		   <mimeMap fileExtension=".otf" mimeType="font/otf" />
		</staticContent>
	</system.webServer>
</configuration>

Release Checklist

When releasing a new version, go through this checklist.

  • Decide on next version number:
    • Public API backwards incompatible: MAJOR
    • Public API has new features: MINOR
    • Public API is unchanged (bug fixes): PATCH
  • Run builds:
    • npm run build:demo
    • npm run build:lib
  • Update CHANGELOG.md with the new version.
  • Commit build and changelog. You cannot commit as a part of
  • Run npm version [major|minor|patch].
  • Push to master.