phosphor-vue
Version:
A clean and friendly icon family for Vue, too!
49 lines (42 loc) • 1.45 kB
text/typescript
import _Vue, { PluginFunction } from "vue";
// Import vue components
import * as components from "@/lib/index";
// Define typescript interfaces for autoinstaller
// eslint-disable-next-line @typescript-eslint/no-explicit-any
interface InstallFunction extends PluginFunction<any> {
installed?: boolean;
}
// install function executed by Vue.use()
const install: InstallFunction = function installPhosphorVueTs(
Vue: typeof _Vue
) {
if (install.installed) return;
install.installed = true;
Object.entries(components).forEach(([componentName, component]) => {
Vue.component(componentName, component);
});
};
// Create module definition for Vue.use()
const plugin = {
install
};
// To auto-install on non-es builds, when vue is found
// eslint-disable-next-line no-redeclare
/* global window, global */
if ("false" === process.env.ES_BUILD) {
let GlobalVue = null;
if (typeof window !== "undefined") {
GlobalVue = window.Vue;
} else if (typeof global !== "undefined") {
// eslint-disable-next-line @typescript-eslint/no-explicit-any
GlobalVue = (global as any).Vue;
}
if (GlobalVue) {
(GlobalVue as typeof _Vue).use(plugin);
}
}
// Default export is library as a whole, registered via Vue.use()
export default plugin;
// To allow individual component use, export components
// each can be registered via Vue.component()
export * from "@/lib/index";