Apelidos
Apelidos permitem que você instale pacotes com nomes personalizados.
Vamos supor que você use lodash em todo o seu projeto. Há um erro no lodash que quebra seu projeto. Você tem uma correção, mas lodash não a mesclará. Normalmente você instalaria lodash diretamente do seu fork (como uma dependência hospedada no git) ou o publicaria com um nome diferente. Se você usar a segunda solução você tem que substituir todos os "require" em seu projeto pelo novo nome de dependência (require('lodash') => require('awesome-dasloh')). Com apelidos, você tem uma terceira opção.
Publicar um novo pacote chamado incrível-lodash e instalá-lo usando lodash como seu apelido:
pnpm add lodash@npm:awesome-lodash
Nenhuma alteração no código é necessária. Todos os "require" de lodash agora serão resolvidos para awesome-lodash.
Às vezes você vai querer usar duas versões diferentes de um pacote em seu projeto. Fácil:
pnpm add lodash1@npm:lodash@1
pnpm add lodash2@npm:lodash@2
Agora você pode exigir a primeira versão do lodash via require('lodash1') e a segunda versão via require('lodash2').
Isso fica ainda mais poderoso quando combinado com ganchos. Talvez você queira substituir lodash por awesome-lodash em todos os pacotes em node_modules. Você pode facilmente alcançar isso com o seguinte .pnpmfile.cjs:
function readPackage(pkg) {
if (pkg.dependencies && pkg.dependencies.lodash) {
pkg.dependencies.lodash = 'npm:awesome-lodash@^1.0.0'
}
return pkg
}
module.exports = {
hooks: {
readPackage
}
}