Getting started

To install this library first you have to add it to your dependencies:

yarn add @geoblink/design-system
npm i -P @geoblink/design-system

After that, you must install it in your Vue instance:


 



 



import Vue from 'vue'
import GeoblinkDesignSystem from '@geoblink/design-system'

// ...

Vue.use(GeoblinkDesignSystem)

// ...

Finally you have to import the styles. You can import the built CSS styles or the raw SCSS file (which include the design tokens as variables):

@import '~@geoblink/design-system/dist/system.css';
@import '~@geoblink/design-system/dist/system.utils.scss';

Depending on your bundler settings you can import it in your JavaScript bundle, too:

import '@geoblink/design-system/dist/system.css'
import '@geoblink/design-system/dist/system.utils.scss'

Finally you'll be able use any component from the Design System like they are used in the demos:

Using icons

We use icons from FontAwesome library in some components but we want neither to force a specific version of the package nor to use it at all! So we make this an opt-in behaviour.

To enable icons you have to install @fortawesome/vue-fontawesome package and register font-awesome-icon globally:

yarn add @fortawesome/fontawesome-svg-core
yarn add @fortawesome/vue-fontawesome
yarn add @fortawesome/free-solid-svg-icons
npm i --save @fortawesome/fontawesome-svg-core
npm i --save @fortawesome/vue-fontawesome
npm i --save @fortawesome/free-solid-svg-icons

Afterwards in your main JavaScript entrypoint:

import Vue from 'vue'
import { library } from '@fortawesome/fontawesome-svg-core'
import { faUserSecret } from '@fortawesome/free-solid-svg-icons' // Or any icon you want to use
import { FontAwesomeIcon } from '@fortawesome/vue-fontawesome'

library.add(faUserSecret) // Or any icon you want to use

Vue.component('font-awesome-icon', FontAwesomeIcon)

// ...

Using free icons

By default we use icons from FontAwesome Pro. Even though we encourage you to consider upgrading to pro, it's possible to use Geoblink Design System without using any paid resource.

To do so, you have to run mockFontAwesomeProIcons once in your main JavaScript entrypoint:



 




 



import Vue from 'vue'
import { library } from '@fortawesome/fontawesome-svg-core'
import { mockFontAwesomeProIcons } from '@geoblink/design-system'
import { FontAwesomeIcon } from '@fortawesome/vue-fontawesome'

Vue.component('font-awesome-icon', FontAwesomeIcon)

mockFontAwesomeProIcons(library)

// ...

Advanced import

It's possible to import only part of the library.

You can import components on a individual basis by importing them directly:






 









<template>
  <geo-primary-button>My button!</geo-primary-button>
</template>

<script>
import GeoPrimaryButton from '@geoblink/design-system/dist/components/GeoPrimaryButton'

export default {
  name: 'My component',
  components: {
    GeoPrimaryButton
  }
}
</script>

Styles can be imported individually, too:


 


<style>
import '~@geoblink/design-system/dist/styles/geo-primary-button'
</style>

And you can also import them in your component's JavaScript code:







 









<template>
  <geo-primary-button>My button!</geo-primary-button>
</template>

<script>
import GeoPrimaryButton from '@geoblink/design-system/dist/components/GeoPrimaryButton'
import '@geoblink/design-system/dist/styles/geo-primary-button'

export default {
  name: 'My component',
  components: {
    GeoPrimaryButton
  }
}
</script>