Tenho uma biblioteca vue.js que supostamente é bem simples, só tenho uma função personalizada para criar um aplicativo Vue como esta:
import AppComp from "./components/App.vue";
export const createMyCustomApp = (props): App<Element> => {
console.log("Creating app with props: ", getNonEmptyProps(props));
return createApp(AppComp , getNonEmptyProps(props));
}
e o App.vue:
<script setup lang="ts">
import {useRouter} from "vue-router";
import {useFetchingError, useIsFetching} from "../app";
import {ComputedRef, defineComponent, onMounted, PropType} from "vue";
import {computed, getCurrentInstance} from "vue";
import Loading from "./Loading.vue";
import Error from "./Error.vue";
defineProps({
loadingComponent: {
type: Object as PropType<ReturnType<typeof defineComponent>>,
default: Loading
},
errorComponent: {
type: Object as PropType<ReturnType<typeof defineComponent>>,
default: Error
}
});
const isFetching: ComputedRef<boolean> = computed(() => useIsFetching());
const fetchingError = computed(() => useFetchingError());
const router = useRouter();
console.log("=".repeat(50));
console.log("router : ", router);
console.log(getCurrentInstance());
console.log("=".repeat(50));
router.afterEach((to, from, failure) => {
// some code
});
router.afterEach(() => /*some code*/);
onMounted(() => {
const newRouter = useRouter();
console.log("After nount" , newRouter);
});
</script>
<template>
<component v-if="isFetching" :is="loadingComponent"/>
<component v-if="fetchingError" :is="errorComponent" :error="fetchingError.message"/>
<router-view v-else></router-view>
</template>
e eu tenho vue
e vue-router
como peerDependencies, este é meu pacote.json
{
"name": "@myusername/redacted",
"version": "0.0.2",
"description": "something....",
"main": "dist/lib.umd.js",
"module": "dist/lib.es.js",
"browser": "dist/lib.cjs.js",
"types": "dist/app.d.ts",
"exports": {
"." : {
"import": "./dist/lib.es.js",
"require": "./dist/lib.cjs.js"
}
},
"files": [
"dist"
],
"publishConfig": {
"registry": "https://npm.pkg.github.com/@myusername"
},
"scripts": {
"dev": "vite",
"build": "vite build"
},
"keywords": [
"client",
"metaframework",
"watchfulraven"
],
"author": "",
"license": "ISC",
"devDependencies": {
"vite": "^6.2.0",
"vite-plugin-dts": "^4.5.0"
},
"peerDependencies": {
"vue": "^3.5.13",
"vue-router": "^4.5.0"
},
"dependencies": {
"@vitejs/plugin-vue": "^5.2.1",
"axios": "^1.8.1"
}
}
e no meu vite.config.ts
:
import {defineConfig} from "vite";
import dts from "vite-plugin-dts";
import vue from "@vitejs/plugin-vue";
export default defineConfig({
build: {
lib: {
entry: "src/app.ts",
name: "lib",
formats: ["es", "cjs", "umd"],
fileName: (format) => `lib.${format}.js`,
},
rollupOptions: {
external: ['vue', 'vue-router'],
output: {
globals: {
vue: 'Vue',
'vue-router': 'VueRouter',
},
},
},
},
plugins: [
vue(),
dts({rollupTypes: true})
]
});
e no meu app.js no meu aplicativo principal eu uso assim:
import {createMyCustomApp} from "@myusername/thepackagename";
import {router} from "@/presentation/routes/router.js";
import {i18n} from "./i18n.ts";
const app = createMyCustomApp({});
app
.use(router)
.use(i18n)
.mount("#app");
mas como eu disse, o roteador console.log retorna indefinido e no meu console diz:
[Vue warn]: injeção "Symbol(router)" não encontrada em <App >
Se eu usar o mesmo componente App.vue, mas localmente, sem o pacote, ele também funciona bem. Passei muito tempo tentando fazê-lo funcionar. Qualquer ajuda seria apreciada.
Composables devem ser usados diretamente no corpo da função de configuração ou
<script setup>
; qualquer outro uso precisa ser confirmado e depende de sua implementação. Aqueles que dependem deprovide
/inject
likeuseRouter
não podem ser usados em outros lugares.Este uso está incorreto:
Este uso está correto:
Isso requer que o plugin do roteador seja instalado, o que é feito aqui com
use(router)
.Além disso, espera-se que isso funcione normalmente em dependências de projeto somente quando
vue
pacotesvue-router
não estiverem duplicados em um pacote. Isso pode depender de vários fatores: indicação correta de transientesvue
evue-router
dependências (peerDependencies
é usado corretamente aqui), gerenciador de pacotes, ferramenta de compilação, a maneira como uma dependência é instalada, etc. Uma combinação deles foi a provável causa do problema.É necessário diagnosticar se os pacotes estão duplicados executando-os
npm list vue
no projeto. A saída deve conter apenas umavue@3...
entrada (no nível superior), o restante deve servue@3... deduped
. O mesmo vale paravue-router
.Uma maneira simples, porém direta, de detectar o problema com duplicação de pacotes é usar no projeto:
Em seguida, faça o mesmo em uma dependência problemática. Caso seja de primeira parte, isso pode ser feito no código-fonte:
Então
vueProject === vueDependency
pode ser verificado em um console. O mesmo vale paravue-router
. Se as dependências não forem duplicadas, ambas as condições serãotrue
.