Installation
The library is available as NPM package and can be alternatively included via CDN. The installation with a package manager is recommended, this way there is the possibility to use the library either in plugin mode or to import it directly as a component.
Vue compatibility
Please note that for Vue 3 compatibility you have to use most recent 2.x version of the library which is a default version starting with v2.2.0
tag. Vue 2 users have to use 1.x version that is now considered as legacy. The docs for the legacy version can be found in v1-legacy branch.
Package Manager
Use your favorite package manager to install the library from NPM. After the installation you have the choice to initialize the component as a plugin or to import it directly in your components.
npm i vue-ellipse-progress
yarn add vue-ellipse-progress
Initialize as Plugin
Import and initialize the component in your main.js
. By default, after initialization, the component is available as <ve-progress/>
and can be used everywhere. You also are free to define a custom name:
import { createApp } from "vue";
import App from "./App.vue";
import veProgress from "vue-ellipse-progress";
createApp(App).use(veProgress);
// define custom name and use as <vep .../>
// createApp(App).use(veProgress, "vep");
Import component
You also have the option to import the component directly:
<template>
<ve-progress :progress="50" />
</template>
<script setup>
import { VeProgress } from "vue-ellipse-progress";
</script>
CDN
To use the component without a build tool you can customize and get the veprogress.umd.min.js
file from JSDelivr. Just add the following line to your HTML and initialize the component as plugin:
<!DOCTYPE html>
<html lang="en">
<body>
<div id="app"></div>
<script src="https://unpkg.com/vue@next"></script>
<script src="https://cdn.jsdelivr.net/npm/vue-ellipse-progress/dist/veprogress.umd.min.js"></script>
<script>
const { createApp } = Vue;
const App = {
template: `<div> <ve-progress :progress="50"/></div>`,
};
const app = createApp(App);
app.use(veprogress);
app.mount("#app");
</script>
</body>
</html>
SSR
In this section we will look on how to initialize the plugin in Nuxt.js - a popular Vue.js framework for SSR development. We will follow the official Nuxt documentation for Vue plugins initialization to register the plugin on client side.
Nuxt.js 3
In the /plugins
directory create the file veProgress.client.js
with the content:
import veProgress from "vue-ellipse-progress";
export default defineNuxtPlugin((nuxtApp) => {
nuxtApp.vueApp.use(veProgress);
});
Note that Nuxt 3 will automatically scann your /plugins
directory to register plugins. Then you can immediately use the component everywhere:
<template>
<client-only>
<ve-progress :progress="50" />
</client-only>
</template>
Nuxt.js 2
WARNING
Please note that Nuxt.js 2 works with Vue.js 2 and you have to use the compatible 1.x
plugin version
In the /plugins
directory create the file vue-ellipse-progress.js
with the content:
import Vue from 'vue';
import VueEllipseProgress from "vue-ellipse-progress";
Vue.use(VueEllipseProgress);
In your nuxt.config.js
register the plugin:
plugins: [
{
src: '@/plugins/vue-ellipse-progress.js',
mode: 'client'
}
]
Now the component can be used everywhere:
<template>
<client-only>
<vue-ellipse-progress :progress="50" />
</client-only>
</template>
Advanced use cases
In some development environments or tools there is no plugin system. To use the plugin, it must be imported dynamically during hydration only on client side. This is the case for example in static site generator (SSG) like Vitepress that powers this documentation. In such a case, you can import the library in a lifecycle hook and initialize the plugin in your custom wrapper component. Example:
<!-- /MyVeProgressWrapper.vue-->
<template>
<ClientOnly>
<VueEllipseProgress :progress="50" />
</ClientOnly>
</template>
<script setup>
import { shallowRef, onMounted } from "vue";
const VueEllipseProgress = shallowRef(null);
onMounted(async () => {
VueEllipseProgress.value = import("vue-ellipse-progress").then((module) => {
VueEllipseProgress.value = module.VeProgress;
});
})
</script>
TypeScript
Currently, the plugin does not officially support TypeScript. But the transfer to TypeScript with proper typing is planned for v3 release.
If you encounter some TS related errors while trying to use the plugin for example in your fresh Vue 3 app, add the file veProgress.d.ts
in the root of your app:
declare module "vue-ellipse-progress";
Any contributions to improve the TS support are very welcome!