From 48d7821ea2d55492653c9695de3c56dc90fc7bb9 Mon Sep 17 00:00:00 2001 From: btea <2356281422@qq.com> Date: Wed, 30 Aug 2023 13:58:17 +0800 Subject: [PATCH] feat(element-plus): support nightly option (#685) --- src/core/resolvers/element-plus.ts | 24 +++++++++++++++--------- 1 file changed, 15 insertions(+), 9 deletions(-) diff --git a/src/core/resolvers/element-plus.ts b/src/core/resolvers/element-plus.ts index d8425d63..5adfb503 100644 --- a/src/core/resolvers/element-plus.ts +++ b/src/core/resolvers/element-plus.ts @@ -38,6 +38,11 @@ export interface ElementPlusResolverOptions { * a list of component names that have no styles, so resolving their styles file should be prevented */ noStylesComponents?: string[] + + /** + * nightly version + */ + nightly?: boolean } type ElementPlusResolverOptionsResolved = Required> & @@ -73,9 +78,9 @@ function getSideEffectsLegacy( } function getSideEffects(dirName: string, options: ElementPlusResolverOptionsResolved): SideEffectsInfo | undefined { - const { importStyle, ssr } = options - const themeFolder = 'element-plus/theme-chalk' - const esComponentsFolder = 'element-plus/es/components' + const { importStyle, ssr, nightly } = options + const themeFolder = nightly ? '@element-plus/nightly/theme-chalk' : 'element-plus/theme-chalk' + const esComponentsFolder = nightly ? '@element-plus/nightly/es/components' : 'element-plus/es/components' if (importStyle === 'sass') { return ssr @@ -104,13 +109,13 @@ function resolveComponent(name: string, options: ElementPlusResolverOptionsResol } const partialName = kebabCase(name.slice(2))// ElTableColumn -> table-column - const { version, ssr } = options + const { version, ssr, nightly } = options // >=1.1.0-beta.1 - if (compare(version, '1.1.0-beta.1', '>=')) { + if (compare(version, '1.1.0-beta.1', '>=') || nightly) { return { name, - from: `element-plus/${ssr ? 'lib' : 'es'}`, + from: `${nightly ? '@element-plus/nightly' : 'element-plus'}/${ssr ? 'lib' : 'es'}`, sideEffects: getSideEffects(partialName, options), } } @@ -144,13 +149,13 @@ function resolveDirective(name: string, options: ElementPlusResolverOptionsResol if (!directive) return - const { version, ssr } = options + const { version, ssr, nightly } = options // >=1.1.0-beta.1 - if (compare(version, '1.1.0-beta.1', '>=')) { + if (compare(version, '1.1.0-beta.1', '>=') || nightly) { return { name: directive.importName, - from: `element-plus/${ssr ? 'lib' : 'es'}`, + from: `${nightly ? '@element-plus/nightly' : 'element-plus'}/${ssr ? 'lib' : 'es'}`, sideEffects: getSideEffects(directive.styleName, options), } } @@ -183,6 +188,7 @@ export function ElementPlusResolver( directives: true, exclude: undefined, noStylesComponents: options.noStylesComponents || [], + nightly: false, ...options, } return optionsResolved