@utrecht/web-component-library-vue
TypeScript icon, indicating that this package has built-in type declarations

1.0.3-alpha.28 • Public • Published

Web Components in Vue.js

The @utrecht/web-component-library-stencil package contains the actual implementation of every web component, while the @utrecht/web-component-library-vue only contains wrapper Vue.js 3 components to help validate all the templates, and some supporting code to support Vue.js form bindings. The implementation of each component will be loaded separately and on-demand, so including the entire component library will not slow down your application.

Install both packages to use Vue.js components in your project:

npm install --save-dev --save-exact \
  @utrecht/web-component-library-vue \
  @utrecht/web-component-library-stencil

For example, in your App.vue:

<template>
  <utrecht-heading-1>Login</utrecht-heading-1>
  <form action="/login" method="post">
    <utrecht-form-field-textbox v-model="username" autocomplete="username">Username</utrecht-form-field-textbox>
    <utrecht-form-field-textbox v-model="password" autocomplete="current-password" type="password"
      >Password</utrecht-form-field-textbox
    >
    <div>
      <utrecht-button type="submit">Login</utrecht-button>
    </div>
  </form>
</template>

<script>
  import { UtrechtButton, UtrechtFormFieldTextbox, UtrechtHeading1 } from "@utrecht/web-component-library-vue";

  export default {
    components: {
      "utrecht-button": UtrechtButton,
      "utrecht-form-field-textbox": UtrechtFormFieldTextbox,
      "utrecht-heading-1": UtrechtHeading1,
    },
    data() {
      return {
        username: "",
        password: "",
      };
    },
  };
</script>

Since the implementation of the web components needs to be loaded in the browser, include the following effect to import web component library from @utrecht/web-component-library-stencil, for example in your main.js:

import "@utrecht/design-tokens/dist/index.css";
import { defineCustomElements } from "@utrecht/web-component-library-stencil/loader";

createApp(App).use(router).mount("#app");

defineCustomElements();

Readme

Keywords

Package Sidebar

Install

npm i @utrecht/web-component-library-vue

Weekly Downloads

51

Version

1.0.3-alpha.28

License

EUPL-1.2

Unpacked Size

3.03 MB

Total Files

257

Last publish

Collaborators

  • littlebobbytabl.es
  • yolijn
  • nl-design-system-ci