diff --git a/packages/uni-cli-shared/src/messages/en.ts b/packages/uni-cli-shared/src/messages/en.ts index 4448dae74062ea071057ed72a909b5c113d2692e..53feb358188c6bbfb3adfb7d89163c1896a36186 100644 --- a/packages/uni-cli-shared/src/messages/en.ts +++ b/packages/uni-cli-shared/src/messages/en.ts @@ -34,4 +34,17 @@ export default { 'When running on Windows to iOS mobile phone, the modification of the uts plugin code needs to be submitted to the cloud to package the custom playground to take effect.', 'uts.ios.standard.tips': 'When the standard playground runs to an IOS phone, the uts plugin is temporarily not supported. If you need to call the uts plugin, please use a custom playground', + 'prompt.run.message': 'Run method: open {devtools}, import {outputDir} run.', + 'prompt.run.devtools.app': 'HBuilderX', + 'prompt.run.devtools.mp-alipay': 'Alipay Mini Program Devtools', + 'prompt.run.devtools.mp-baidu': 'Baidu Mini Program Devtools', + 'prompt.run.devtools.mp--kuaishou': 'Kuaishou Mini Program Devtools', + 'prompt.run.devtools.mp-lark': 'Lark Mini Program Devtools', + 'prompt.run.devtools.mp-qq': 'QQ Mini Program Devtools', + 'prompt.run.devtools.mp-toutiao': 'ByteDance Mini Program Devtools', + 'prompt.run.devtools.mp-weixin': 'Weixin Mini Program Devtools', + 'prompt.run.devtools.quickapp-webview': + 'Quick App Alliance Devtools | Huawei Quick App Devtools', + 'prompt.run.devtools.quickapp-webview-huawei': 'Huawei Quick App Devtools', + 'prompt.run.devtools.quickapp-webview-union': 'Quick App Alliance Devtools', } as const diff --git a/packages/uni-cli-shared/src/messages/zh_CN.ts b/packages/uni-cli-shared/src/messages/zh_CN.ts index c43e86db8af46f30b531ca3b81753352307a02d3..44254bbb7320b484a728b5592814ae73327bf540 100644 --- a/packages/uni-cli-shared/src/messages/zh_CN.ts +++ b/packages/uni-cli-shared/src/messages/zh_CN.ts @@ -34,4 +34,17 @@ export default { 'iOS手机在windows上使用标准基座真机运行无法使用uts插件,如需使用uts插件请提交云端打包自定义基座', 'uts.ios.standard.tips': 'iOS手机在标准基座真机运行暂不支持uts插件,如需调用uts插件请使用自定义基座', + 'prompt.run.message': '运行方式:打开 {devtools}, 导入 {outputDir} 运行。', + 'prompt.run.devtools.app': 'HBuilderX', + 'prompt.run.devtools.mp-alipay': '支付宝小程序开发者工具', + 'prompt.run.devtools.mp-baidu': '百度开发者工具', + 'prompt.run.devtools.mp--kuaishou': '快手开发者工具', + 'prompt.run.devtools.mp-lark': '飞书开发者工具', + 'prompt.run.devtools.mp-qq': 'QQ小程序开发者工具', + 'prompt.run.devtools.mp-toutiao': '字节跳动开发者工具', + 'prompt.run.devtools.mp-weixin': '微信开发者工具', + 'prompt.run.devtools.quickapp-webview': + '快应用联盟开发者工具 | 华为快应用开发者工具', + 'prompt.run.devtools.quickapp-webview-huawei': '华为快应用开发者工具', + 'prompt.run.devtools.quickapp-webview-union': '快应用联盟开发者工具', } as const diff --git a/packages/vite-plugin-uni/src/cli/action.ts b/packages/vite-plugin-uni/src/cli/action.ts index c3637e35b3f387c8de367f129178835f36472866..c7041ea65829a59fc6d169ef2bdabfbc00c17eb9 100644 --- a/packages/vite-plugin-uni/src/cli/action.ts +++ b/packages/vite-plugin-uni/src/cli/action.ts @@ -10,7 +10,12 @@ import { import { CliOptions } from '.' import { build, buildSSR } from './build' import { createServer, createSSRServer } from './server' -import { initEnv, printStartupDuration } from './utils' +import { + type PLATFORM, + initEnv, + printStartupDuration, + showRunPrompt, +} from './utils' import { initEasycom } from '../utils/easycom' export async function runDev(options: CliOptions & ServerOptions) { @@ -53,6 +58,7 @@ export async function runDev(options: CliOptions & ServerOptions) { } isFirstEnd = false output('log', M['dev.watching.end']) + showRunPrompt(options.platform as PLATFORM) printStartupDuration(createLogger(options.logLevel), false) if (process.env.UNI_UTS_ERRORS) { console.error(process.env.UNI_UTS_ERRORS) @@ -116,6 +122,9 @@ export async function runBuild(options: CliOptions & BuildOptions) { ? buildSSR(options) : build(options)) console.log(M['build.done']) + if (options.platform !== 'h5') { + showRunPrompt(options.platform as PLATFORM) + } } catch (e: any) { console.error(`Build failed with errors.`) process.exit(1) diff --git a/packages/vite-plugin-uni/src/cli/utils.ts b/packages/vite-plugin-uni/src/cli/utils.ts index 23abda2e365ca0518305e084de9b9dee55177e8b..e28b7bce286be57a2cd757f098c457abb8de9461 100644 --- a/packages/vite-plugin-uni/src/cli/utils.ts +++ b/packages/vite-plugin-uni/src/cli/utils.ts @@ -11,6 +11,7 @@ import { initModulePaths, parseScripts, getPlatformDir, + output, } from '@dcloudio/uni-cli-shared' import { CliOptions } from '.' @@ -30,6 +31,19 @@ export const PLATFORMS = [ 'quickapp-webview-union', ] +export type PLATFORM = + | 'app' + | 'mp-alipay' + | 'mp-baidu' + | 'mp-kuaishou' + | 'mp-lark' + | 'mp-qq' + | 'mp-toutiao' + | 'mp-weixin' + | 'quickapp-webview' + | 'quickapp-webview-huawei' + | 'quickapp-webview-union' + function resolveConfigFile() { const viteConfigJs = path.resolve(process.env.UNI_INPUT_DIR, 'vite.config.js') const viteConfigTs = path.resolve(process.env.UNI_INPUT_DIR, 'vite.config.ts') @@ -301,3 +315,30 @@ function initCustomScripts(options: CliOptions) { process.env.UNI_CUSTOM_DEFINE = JSON.stringify(custom.define) process.env.UNI_CUSTOM_CONTEXT = JSON.stringify(custom.context) } + +export function showRunPrompt(platform: PLATFORM) { + if (!isInHBuilderX()) { + const devtools = getPlatformDevtools(getOriginalPlatform(platform)) + const outputDir = path.relative( + process.env.UNI_CLI_CONTEXT, + process.env.UNI_OUTPUT_DIR + ) + output( + 'log', + `${M['prompt.run.message'] + .replace('{devtools}', M[devtools]) + .replace('{outputDir}', colors.cyan(outputDir))}` + ) + } +} + +function getOriginalPlatform(platform: PLATFORM) { + if (platform.startsWith('quickapp-webview') && process.env.UNI_SUB_PLATFORM) { + return process.env.UNI_SUB_PLATFORM + } + return platform +} + +function getPlatformDevtools(platform: PLATFORM) { + return `prompt.run.devtools.${platform}` as keyof typeof M +}