@hubspot/cli 7.8.12-experimental.0 → 7.8.12-experimental.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (244) hide show
  1. package/bin/cli.js +31 -25
  2. package/commands/__tests__/auth.test.js +5 -0
  3. package/commands/__tests__/doctor.test.js +16 -16
  4. package/commands/account/clean.js +18 -27
  5. package/commands/account/createOverride.js +13 -31
  6. package/commands/account/info.js +20 -31
  7. package/commands/account/list.js +16 -22
  8. package/commands/account/remove.js +12 -20
  9. package/commands/account/removeOverride.js +11 -21
  10. package/commands/account/rename.js +6 -9
  11. package/commands/account/use.js +12 -26
  12. package/commands/account.js +2 -2
  13. package/commands/app/__tests__/migrate.test.js +5 -5
  14. package/commands/app/migrate.js +13 -18
  15. package/commands/app.js +1 -6
  16. package/commands/auth.d.ts +1 -0
  17. package/commands/auth.js +16 -7
  18. package/commands/cms/convertFields.js +7 -9
  19. package/commands/cms/getReactModule.js +9 -14
  20. package/commands/cms/lighthouseScore.js +33 -36
  21. package/commands/cms.js +2 -2
  22. package/commands/completion.js +3 -3
  23. package/commands/config/set.d.ts +1 -1
  24. package/commands/config/set.js +64 -36
  25. package/commands/config.js +2 -2
  26. package/commands/create.js +2 -2
  27. package/commands/customObject/create.js +10 -12
  28. package/commands/customObject/schema/create.js +9 -11
  29. package/commands/customObject/schema/delete.js +16 -16
  30. package/commands/customObject/schema/fetch-all.js +12 -11
  31. package/commands/customObject/schema/fetch.js +15 -15
  32. package/commands/customObject/schema/list.js +4 -4
  33. package/commands/customObject/schema/update.js +13 -13
  34. package/commands/customObject/schema.js +2 -2
  35. package/commands/customObject.js +6 -7
  36. package/commands/doctor.js +8 -11
  37. package/commands/feedback.js +6 -11
  38. package/commands/fetch.js +8 -8
  39. package/commands/filemanager/fetch.js +7 -7
  40. package/commands/filemanager/upload.js +15 -34
  41. package/commands/filemanager.js +2 -2
  42. package/commands/function/deploy.js +11 -29
  43. package/commands/function/list.js +8 -8
  44. package/commands/function/server.js +9 -11
  45. package/commands/function.d.ts +1 -1
  46. package/commands/function.js +2 -2
  47. package/commands/getStarted.js +2 -2
  48. package/commands/hubdb/clear.js +7 -15
  49. package/commands/hubdb/create.js +9 -15
  50. package/commands/hubdb/delete.js +8 -15
  51. package/commands/hubdb/fetch.js +6 -9
  52. package/commands/hubdb.d.ts +1 -1
  53. package/commands/hubdb.js +2 -2
  54. package/commands/init.js +2 -3
  55. package/commands/lint.js +16 -16
  56. package/commands/list.js +8 -14
  57. package/commands/logs.js +14 -20
  58. package/commands/mv.js +6 -17
  59. package/commands/open.js +5 -5
  60. package/commands/project/__tests__/add.test.js +4 -2
  61. package/commands/project/__tests__/deploy.test.js +3 -4
  62. package/commands/project/__tests__/installDeps.test.js +8 -8
  63. package/commands/project/__tests__/logs.test.js +1 -1
  64. package/commands/project/__tests__/migrate.test.js +5 -5
  65. package/commands/project/__tests__/migrateApp.test.js +2 -5
  66. package/commands/project/__tests__/validate.test.js +98 -0
  67. package/commands/project/add.js +3 -3
  68. package/commands/project/cloneApp.js +14 -19
  69. package/commands/project/create.js +0 -1
  70. package/commands/project/deploy.js +3 -3
  71. package/commands/project/dev/deprecatedFlow.js +7 -16
  72. package/commands/project/dev/index.js +14 -12
  73. package/commands/project/dev/unifiedFlow.js +3 -1
  74. package/commands/project/download.js +10 -13
  75. package/commands/project/installDeps.js +8 -8
  76. package/commands/project/listBuilds.js +11 -20
  77. package/commands/project/logs.js +21 -24
  78. package/commands/project/migrateApp.js +9 -15
  79. package/commands/project/open.js +6 -13
  80. package/commands/project/upload.d.ts +2 -2
  81. package/commands/project/upload.js +17 -26
  82. package/commands/project/validate.js +6 -6
  83. package/commands/project/watch.js +13 -22
  84. package/commands/project.js +2 -2
  85. package/commands/sandbox/__tests__/create.test.js +5 -5
  86. package/commands/sandbox/create.js +22 -32
  87. package/commands/sandbox/delete.js +38 -63
  88. package/commands/sandbox.js +2 -2
  89. package/commands/secret/addSecret.js +7 -17
  90. package/commands/secret/deleteSecret.js +10 -20
  91. package/commands/secret/listSecret.js +8 -10
  92. package/commands/secret/updateSecret.js +9 -17
  93. package/commands/secret.js +2 -2
  94. package/commands/testAccount/__tests__/delete.test.js +2 -4
  95. package/commands/testAccount/create.js +0 -3
  96. package/commands/testAccount/delete.d.ts +4 -3
  97. package/commands/testAccount/delete.js +155 -14
  98. package/commands/theme/preview.js +1 -4
  99. package/lang/en.d.ts +310 -124
  100. package/lang/en.js +351 -169
  101. package/lang/en.lyaml +2 -2
  102. package/lib/__tests__/buildAccount.test.js +2 -1
  103. package/lib/__tests__/commonOpts.test.js +1 -1
  104. package/lib/__tests__/dependencyManagement.test.js +1 -1
  105. package/lib/__tests__/developerTestAccounts.test.js +3 -3
  106. package/lib/__tests__/npm.test.js +1 -1
  107. package/lib/__tests__/oauth.test.js +4 -4
  108. package/lib/__tests__/process.test.js +10 -5
  109. package/lib/__tests__/sandboxSync.test.js +8 -8
  110. package/lib/__tests__/sandboxes.test.js +8 -8
  111. package/lib/__tests__/serverlessLogs.test.js +1 -1
  112. package/lib/__tests__/usageTracking.test.js +5 -5
  113. package/lib/__tests__/validation.test.js +2 -1
  114. package/lib/__tests__/yargsUtils.test.js +83 -9
  115. package/lib/app/__tests__/migrate.test.js +5 -5
  116. package/lib/app/__tests__/migrate_legacy.test.js +1 -1
  117. package/lib/app/migrate.js +1 -1
  118. package/lib/app/migrate_legacy.js +20 -24
  119. package/lib/buildAccount.js +25 -57
  120. package/lib/commonOpts.d.ts +1 -1
  121. package/lib/commonOpts.js +25 -22
  122. package/lib/configOptions.js +7 -0
  123. package/lib/constants.d.ts +6 -1
  124. package/lib/constants.js +10 -1
  125. package/lib/dependencyManagement.js +9 -27
  126. package/lib/developerTestAccounts.js +9 -23
  127. package/lib/doctor/Diagnosis.js +11 -23
  128. package/lib/doctor/DiagnosticInfoBuilder.js +12 -11
  129. package/lib/doctor/Doctor.js +42 -90
  130. package/lib/doctor/__tests__/Doctor.test.js +4 -4
  131. package/lib/errorHandlers/index.js +12 -20
  132. package/lib/errorHandlers/suppressError.js +11 -18
  133. package/lib/lang.js +6 -5
  134. package/lib/links.js +4 -4
  135. package/lib/middleware/__test__/commandTargetingUtils.test.js +99 -0
  136. package/lib/middleware/__test__/configMiddleware.test.js +11 -11
  137. package/lib/middleware/__test__/yargsChecksMiddleware.test.js +6 -8
  138. package/lib/middleware/commandTargetingUtils.d.ts +8 -0
  139. package/lib/middleware/commandTargetingUtils.js +78 -0
  140. package/lib/middleware/configMiddleware.d.ts +1 -1
  141. package/lib/middleware/configMiddleware.js +21 -81
  142. package/lib/middleware/gitMiddleware.js +5 -1
  143. package/lib/middleware/notificationsMiddleware.js +5 -11
  144. package/lib/middleware/yargsChecksMiddleware.js +6 -9
  145. package/lib/npm.js +2 -2
  146. package/lib/oauth.js +5 -5
  147. package/lib/process.js +5 -4
  148. package/lib/projectProfiles.d.ts +1 -1
  149. package/lib/projectProfiles.js +2 -10
  150. package/lib/projects/__tests__/AppDevModeInterface.test.js +14 -34
  151. package/lib/projects/__tests__/LocalDevWebsocketServer.test.js +70 -39
  152. package/lib/projects/__tests__/localDevProjectHelpers.test.js +2 -0
  153. package/lib/projects/__tests__/platformVersion.test.js +8 -8
  154. package/lib/projects/__tests__/projects.test.js +12 -12
  155. package/lib/projects/__tests__/structure.test.js +3 -3
  156. package/lib/projects/__tests__/upload.test.d.ts +1 -0
  157. package/lib/projects/__tests__/upload.test.js +82 -0
  158. package/lib/projects/add/__tests__/legacyAddComponent.test.js +6 -6
  159. package/lib/projects/add/__tests__/v3AddComponent.test.js +4 -4
  160. package/lib/projects/create/__tests__/legacy.test.js +5 -5
  161. package/lib/projects/create/__tests__/v3.test.js +1 -1
  162. package/lib/projects/create/index.js +2 -2
  163. package/lib/projects/create/legacy.js +2 -2
  164. package/lib/projects/create/v3.js +2 -2
  165. package/lib/projects/localDev/AppDevModeInterface.d.ts +2 -0
  166. package/lib/projects/localDev/AppDevModeInterface.js +22 -20
  167. package/lib/projects/localDev/LocalDevLogger.js +10 -11
  168. package/lib/projects/localDev/LocalDevManager.js +4 -5
  169. package/lib/projects/localDev/LocalDevWebsocketServer.d.ts +0 -1
  170. package/lib/projects/localDev/LocalDevWebsocketServer.js +7 -10
  171. package/lib/projects/localDev/helpers/project.d.ts +1 -0
  172. package/lib/projects/localDev/helpers/project.js +37 -0
  173. package/lib/projects/platformVersion.d.ts +1 -1
  174. package/lib/projects/platformVersion.js +1 -1
  175. package/lib/projects/structure.d.ts +2 -2
  176. package/lib/projects/structure.js +6 -6
  177. package/lib/projects/upload.d.ts +2 -3
  178. package/lib/projects/upload.js +17 -9
  179. package/lib/prompts/__tests__/downloadProjectPrompt.test.js +1 -0
  180. package/lib/prompts/accountNamePrompt.js +14 -19
  181. package/lib/prompts/accountsPrompt.js +2 -2
  182. package/lib/prompts/cmsFieldPrompt.js +2 -2
  183. package/lib/prompts/createApiSamplePrompt.js +5 -5
  184. package/lib/prompts/createDeveloperTestAccountConfigPrompt.js +10 -1
  185. package/lib/prompts/createFunctionPrompt.js +14 -14
  186. package/lib/prompts/createModulePrompt.js +9 -9
  187. package/lib/prompts/createTemplatePrompt.js +2 -2
  188. package/lib/prompts/downloadProjectPrompt.js +5 -8
  189. package/lib/prompts/personalAccessKeyPrompt.js +3 -3
  190. package/lib/prompts/previewPrompt.js +6 -6
  191. package/lib/prompts/projectAddPrompt.js +6 -0
  192. package/lib/prompts/projectDevTargetAccountPrompt.js +20 -32
  193. package/lib/prompts/projectNamePrompt.js +4 -8
  194. package/lib/prompts/projectsLogsPrompt.js +2 -4
  195. package/lib/prompts/promptUtils.js +27 -9
  196. package/lib/prompts/sandboxesPrompt.js +7 -7
  197. package/lib/prompts/secretPrompt.js +3 -3
  198. package/lib/prompts/selectAppPrompt.js +3 -3
  199. package/lib/prompts/selectHubDBTablePrompt.js +9 -13
  200. package/lib/prompts/selectPublicAppForMigrationPrompt.js +15 -19
  201. package/lib/prompts/setAsDefaultAccountPrompt.js +4 -8
  202. package/lib/prompts/uploadPrompt.js +5 -5
  203. package/lib/sandboxSync.js +24 -41
  204. package/lib/sandboxes.js +19 -47
  205. package/lib/schema.js +3 -3
  206. package/lib/serverlessLogs.js +11 -13
  207. package/lib/theme/__tests__/migrate.test.js +3 -3
  208. package/lib/theme/migrate.js +2 -2
  209. package/lib/ui/SpinniesManager.d.ts +2 -0
  210. package/lib/ui/SpinniesManager.js +7 -0
  211. package/lib/ui/boxen.js +1 -2
  212. package/lib/ui/git.js +13 -10
  213. package/lib/ui/index.d.ts +4 -0
  214. package/lib/ui/index.js +47 -38
  215. package/lib/ui/serverlessFunctionLogs.js +9 -7
  216. package/lib/ui/uiMessages.d.ts +68 -0
  217. package/lib/ui/uiMessages.js +71 -0
  218. package/lib/usageTracking.js +7 -7
  219. package/lib/validation.js +20 -23
  220. package/lib/yargsUtils.d.ts +1 -1
  221. package/lib/yargsUtils.js +12 -5
  222. package/mcp-server/tools/cms/HsCreateModuleTool.d.ts +2 -2
  223. package/mcp-server/tools/index.js +4 -0
  224. package/mcp-server/tools/project/GetApiUsagePatternsByAppIdTool.d.ts +23 -0
  225. package/mcp-server/tools/project/GetApiUsagePatternsByAppIdTool.js +68 -0
  226. package/mcp-server/tools/project/GetApplicationInfoTool.d.ts +11 -0
  227. package/mcp-server/tools/project/GetApplicationInfoTool.js +49 -0
  228. package/mcp-server/tools/project/GetConfigValuesTool.js +2 -2
  229. package/mcp-server/tools/project/GuidedWalkthroughTool.d.ts +2 -2
  230. package/mcp-server/tools/project/__tests__/GetApiUsagePatternsByAppIdTool.test.d.ts +1 -0
  231. package/mcp-server/tools/project/__tests__/GetApiUsagePatternsByAppIdTool.test.js +169 -0
  232. package/mcp-server/tools/project/__tests__/GetApplicationInfoTool.test.d.ts +1 -0
  233. package/mcp-server/tools/project/__tests__/GetApplicationInfoTool.test.js +115 -0
  234. package/mcp-server/utils/toolUsageTracking.js +2 -2
  235. package/package.json +6 -6
  236. package/types/Yargs.d.ts +1 -1
  237. package/commands/app/__tests__/install.test.js +0 -47
  238. package/commands/app/install.d.ts +0 -8
  239. package/commands/app/install.js +0 -122
  240. package/lib/middleware/__test__/utils.test.js +0 -51
  241. package/lib/middleware/utils.d.ts +0 -8
  242. package/lib/middleware/utils.js +0 -14
  243. /package/commands/{app/__tests__/install.test.d.ts → project/__tests__/validate.test.d.ts} +0 -0
  244. /package/lib/middleware/__test__/{utils.test.d.ts → commandTargetingUtils.test.d.ts} +0 -0
@@ -97,7 +97,6 @@ async function handler(args) {
97
97
  'projectInstallDepsCommand',
98
98
  'projectHelpCommand',
99
99
  'feedbackCommand',
100
- 'sampleProjects',
101
100
  ]);
102
101
  process.exit(EXIT_CODES.SUCCESS);
103
102
  }
@@ -1,7 +1,7 @@
1
1
  import { fetchProject } from '@hubspot/local-dev-lib/api/projects';
2
2
  import { getAccountConfig } from '@hubspot/local-dev-lib/config';
3
3
  import { isHubSpotHttpError } from '@hubspot/local-dev-lib/errors/index';
4
- import { useV3Api } from '../../lib/projects/platformVersion.js';
4
+ import { isV2Project } from '../../lib/projects/platformVersion.js';
5
5
  import { trackCommandUsage } from '../../lib/usageTracking.js';
6
6
  import { logError, ApiErrorContext } from '../../lib/errorHandlers/index.js';
7
7
  import { getProjectConfig } from '../../lib/projects/config.js';
@@ -24,7 +24,7 @@ async function handler(args) {
24
24
  let targetAccountId;
25
25
  const jsonOutput = {};
26
26
  const { projectConfig, projectDir } = await getProjectConfig();
27
- if (useV3Api(projectConfig?.platformVersion)) {
27
+ if (isV2Project(projectConfig?.platformVersion)) {
28
28
  if (args.profile) {
29
29
  logProfileHeader(args.profile);
30
30
  const profile = loadProfile(projectConfig, projectDir, args.profile);
@@ -87,7 +87,7 @@ async function handler(args) {
87
87
  uiLogger.error(commands.project.deploy.errors.noBuildId);
88
88
  return process.exit(EXIT_CODES.ERROR);
89
89
  }
90
- const deployResult = await handleProjectDeploy(targetAccountId, projectName, buildIdToDeploy, useV3Api(projectConfig?.platformVersion), forceOption);
90
+ const deployResult = await handleProjectDeploy(targetAccountId, projectName, buildIdToDeploy, isV2Project(projectConfig?.platformVersion), forceOption);
91
91
  if (!deployResult) {
92
92
  return process.exit(EXIT_CODES.ERROR);
93
93
  }
@@ -1,11 +1,10 @@
1
- import { logger } from '@hubspot/local-dev-lib/logger';
2
1
  import { getAccountConfig, getConfigAccounts, getEnv, } from '@hubspot/local-dev-lib/config';
3
2
  import { getValidEnv } from '@hubspot/local-dev-lib/environment';
4
3
  import { findProjectComponents, getProjectComponentTypes, } from '../../../lib/projects/structure.js';
5
4
  import { ComponentTypes } from '../../../types/Projects.js';
6
- import { i18n } from '../../../lib/lang.js';
5
+ import { commands } from '../../../lang/en.js';
6
+ import { uiLogger } from '../../../lib/ui/logger.js';
7
7
  import { EXIT_CODES } from '../../../lib/enums/exitCodes.js';
8
- import { uiCommandReference } from '../../../lib/ui/index.js';
9
8
  import SpinniesManager from '../../../lib/ui/SpinniesManager.js';
10
9
  import LocalDevManager from '../../../lib/projects/localDev/LocalDevManager.js';
11
10
  import { confirmDefaultAccountIsTarget, suggestRecommendedNestedAccount, checkIfAccountFlagIsSupported, checkIfDefaultAccountIsSupported, createSandboxForLocalDev, createDeveloperTestAccountForLocalDev, useExistingDevTestAccount, checkIfParentAccountIsAuthed, hasSandboxes, } from '../../../lib/projects/localDev/helpers/account.js';
@@ -23,28 +22,20 @@ export async function deprecatedProjectDevFlow({ args, accountId, projectConfig,
23
22
  const hasPublicApps = !!componentTypes[ComponentTypes.PublicApp];
24
23
  const accountConfig = getAccountConfig(accountId);
25
24
  if (!accountConfig) {
26
- logger.error(i18n('commands.project.subcommands.dev.errors.noAccount', {
27
- accountId: accountId,
28
- authCommand: uiCommandReference('hs auth'),
29
- }));
25
+ uiLogger.error(commands.project.dev.errors.noAccount(accountId));
30
26
  process.exit(EXIT_CODES.ERROR);
31
27
  }
32
28
  if (runnableComponents.length === 0) {
33
- logger.error(i18n(`commands.project.subcommands.dev.errors.noRunnableComponents`, {
34
- projectDir,
35
- command: uiCommandReference('hs project add'),
36
- }));
29
+ uiLogger.error(commands.project.dev.errors.noRunnableComponents);
37
30
  process.exit(EXIT_CODES.SUCCESS);
38
31
  }
39
32
  else if (hasPrivateApps && hasPublicApps) {
40
- logger.error(i18n(`commands.project.subcommands.dev.errors.invalidProjectComponents`));
33
+ uiLogger.error(commands.project.dev.errors.invalidProjectComponents);
41
34
  process.exit(EXIT_CODES.SUCCESS);
42
35
  }
43
36
  const accounts = getConfigAccounts();
44
37
  if (!accounts) {
45
- logger.error(i18n(`commands.project.subcommands.dev.errors.noAccountsInConfig`, {
46
- authCommand: uiCommandReference('hs auth'),
47
- }));
38
+ uiLogger.error(commands.project.dev.errors.noAccountsInConfig);
48
39
  process.exit(EXIT_CODES.ERROR);
49
40
  }
50
41
  let bypassRecommendedAccountPrompt = false;
@@ -110,7 +101,7 @@ export async function deprecatedProjectDevFlow({ args, accountId, projectConfig,
110
101
  targetProjectAccountId = derivedAccountId;
111
102
  }
112
103
  if (!targetProjectAccountId || !targetTestingAccountId) {
113
- logger.error(i18n(`commands.project.subcommands.dev.errors.noAccount`));
104
+ uiLogger.error(commands.project.dev.errors.noAccount(accountId));
114
105
  process.exit(EXIT_CODES.ERROR);
115
106
  }
116
107
  // eslint-disable-next-line prefer-const
@@ -5,12 +5,11 @@ import { EXIT_CODES } from '../../../lib/enums/exitCodes.js';
5
5
  import { uiLine } from '../../../lib/ui/index.js';
6
6
  import { deprecatedProjectDevFlow } from './deprecatedFlow.js';
7
7
  import { unifiedProjectDevFlow } from './unifiedFlow.js';
8
- import { useV3Api } from '../../../lib/projects/platformVersion.js';
8
+ import { isV2Project } from '../../../lib/projects/platformVersion.js';
9
9
  import { makeYargsBuilder } from '../../../lib/yargsUtils.js';
10
10
  import { loadProfile, exitIfUsingProfiles, } from '../../../lib/projectProfiles.js';
11
11
  import { commands } from '../../../lang/en.js';
12
12
  import { uiLogger } from '../../../lib/ui/logger.js';
13
- import { logger } from '@hubspot/local-dev-lib/logger';
14
13
  const command = 'dev';
15
14
  const describe = commands.project.dev.describe;
16
15
  function validateAccountFlags(testingAccount, projectAccount, userProvidedAccount, useV3) {
@@ -28,14 +27,14 @@ async function handler(args) {
28
27
  const { derivedAccountId, userProvidedAccount, testingAccount, projectAccount, } = args;
29
28
  const { projectConfig, projectDir } = await getProjectConfig();
30
29
  validateProjectConfig(projectConfig, projectDir);
31
- const useV3 = useV3Api(projectConfig.platformVersion);
30
+ const useV2Projects = isV2Project(projectConfig.platformVersion);
32
31
  if (!projectDir) {
33
32
  uiLogger.error(commands.project.dev.errors.noProjectConfig);
34
33
  process.exit(EXIT_CODES.ERROR);
35
34
  }
36
- validateAccountFlags(testingAccount, projectAccount, userProvidedAccount, useV3);
37
- logger.log(commands.project.dev.logs.header);
38
- if (useV3) {
35
+ validateAccountFlags(testingAccount, projectAccount, userProvidedAccount, useV2Projects);
36
+ uiLogger.log(commands.project.dev.logs.header);
37
+ if (useV2Projects) {
39
38
  uiLogger.log(commands.project.dev.logs.learnMoreMessageV3);
40
39
  }
41
40
  else {
@@ -55,7 +54,7 @@ async function handler(args) {
55
54
  else if (userProvidedAccount && derivedAccountId) {
56
55
  targetProjectAccountId = derivedAccountId;
57
56
  }
58
- if (!targetProjectAccountId && useV3Api(projectConfig.platformVersion)) {
57
+ if (!targetProjectAccountId && isV2Project(projectConfig.platformVersion)) {
59
58
  if (args.profile) {
60
59
  profile = loadProfile(projectConfig, projectDir, args.profile);
61
60
  if (!profile) {
@@ -74,13 +73,13 @@ async function handler(args) {
74
73
  if (!targetProjectAccountId) {
75
74
  // The user is not using profile or account flags, so we can use the derived accountId
76
75
  targetProjectAccountId = derivedAccountId;
77
- if (useV3) {
76
+ if (useV2Projects) {
78
77
  uiLogger.log('');
79
78
  uiLogger.log(commands.project.dev.logs.defaultProjectAccountExplanation(targetProjectAccountId));
80
79
  }
81
80
  }
82
81
  trackCommandUsage('project-dev', {}, targetProjectAccountId);
83
- if (useV3Api(projectConfig.platformVersion)) {
82
+ if (isV2Project(projectConfig.platformVersion)) {
84
83
  const targetTestingAccountId = (testingAccount && getAccountId(testingAccount)) || undefined;
85
84
  await unifiedProjectDevFlow({
86
85
  args,
@@ -110,15 +109,19 @@ function projectDevBuilder(yargs) {
110
109
  yargs.options('testing-account', {
111
110
  type: 'string',
112
111
  description: commands.project.dev.options.testingAccount,
113
- hidden: true,
114
112
  implies: ['project-account'],
115
113
  });
116
114
  yargs.options('project-account', {
117
115
  type: 'string',
118
116
  description: commands.project.dev.options.projectAccount,
119
- hidden: true,
120
117
  implies: ['testingAccount'],
121
118
  });
119
+ yargs.option('account', {
120
+ alias: 'a',
121
+ describe: '',
122
+ type: 'string',
123
+ description: commands.project.dev.options.account,
124
+ });
122
125
  yargs.example([['$0 project dev', commands.project.dev.examples.default]]);
123
126
  yargs.conflicts('profile', 'account');
124
127
  yargs.conflicts('profile', 'testing-account');
@@ -127,7 +130,6 @@ function projectDevBuilder(yargs) {
127
130
  }
128
131
  export const builder = makeYargsBuilder(projectDevBuilder, command, describe, {
129
132
  useGlobalOptions: true,
130
- useAccountOptions: true,
131
133
  useConfigOptions: true,
132
134
  useEnvironmentOptions: true,
133
135
  });
@@ -8,7 +8,7 @@ import { getValidEnv } from '@hubspot/local-dev-lib/environment';
8
8
  import { logError } from '../../../lib/errorHandlers/index.js';
9
9
  import { EXIT_CODES } from '../../../lib/enums/exitCodes.js';
10
10
  import { ensureProjectExists } from '../../../lib/projects/ensureProjectExists.js';
11
- import { createInitialBuildForNewProject, createNewProjectForLocalDev, compareLocalProjectToDeployed, } from '../../../lib/projects/localDev/helpers/project.js';
11
+ import { createInitialBuildForNewProject, createNewProjectForLocalDev, compareLocalProjectToDeployed, checkAndInstallDependencies, } from '../../../lib/projects/localDev/helpers/project.js';
12
12
  import { useExistingDevTestAccount, createDeveloperTestAccountForLocalDev, selectAccountTypePrompt, createSandboxForLocalDev, } from '../../../lib/projects/localDev/helpers/account.js';
13
13
  import { selectDeveloperTestTargetAccountPrompt, selectSandboxTargetAccountPrompt, } from '../../../lib/prompts/projectDevTargetAccountPrompt.js';
14
14
  import SpinniesManager from '../../../lib/ui/SpinniesManager.js';
@@ -118,6 +118,8 @@ export async function unifiedProjectDevFlow({ args, targetProjectAccountId, prov
118
118
  project = await createNewProjectForLocalDev(projectConfig, targetProjectAccountId, false, false);
119
119
  await createInitialBuildForNewProject(projectConfig, projectDir, targetProjectAccountId, true, args.profile);
120
120
  }
121
+ // Check for missing/outdated dependencies
122
+ await checkAndInstallDependencies();
121
123
  // End setup, start local dev process
122
124
  const localDevProcess = new LocalDevProcess({
123
125
  initialProjectNodes: projectNodes,
@@ -1,21 +1,21 @@
1
1
  import path from 'path';
2
2
  import { getCwd, sanitizeFileName } from '@hubspot/local-dev-lib/path';
3
- import { logger } from '@hubspot/local-dev-lib/logger';
4
3
  import { extractZipArchive } from '@hubspot/local-dev-lib/archive';
5
4
  import { downloadProject, fetchProjectBuilds, } from '@hubspot/local-dev-lib/api/projects';
6
5
  import { logError, ApiErrorContext } from '../../lib/errorHandlers/index.js';
7
6
  import { getProjectConfig } from '../../lib/projects/config.js';
8
7
  import { downloadProjectPrompt } from '../../lib/prompts/downloadProjectPrompt.js';
9
- import { i18n } from '../../lib/lang.js';
8
+ import { commands } from '../../lang/en.js';
9
+ import { uiLogger } from '../../lib/ui/logger.js';
10
10
  import { trackCommandUsage } from '../../lib/usageTracking.js';
11
11
  import { EXIT_CODES } from '../../lib/enums/exitCodes.js';
12
12
  import { makeYargsBuilder } from '../../lib/yargsUtils.js';
13
13
  const command = 'download';
14
- const describe = i18n(`commands.project.subcommands.download.describe`);
14
+ const describe = commands.project.download.describe;
15
15
  async function handler(args) {
16
16
  const { projectConfig } = await getProjectConfig();
17
17
  if (projectConfig) {
18
- logger.error(i18n(`commands.project.subcommands.download.warnings.cannotDownloadWithinProject`));
18
+ uiLogger.error(commands.project.download.warnings.cannotDownloadWithinProject);
19
19
  process.exit(EXIT_CODES.ERROR);
20
20
  }
21
21
  const { dest, build, derivedAccountId } = args;
@@ -32,16 +32,13 @@ async function handler(args) {
32
32
  }
33
33
  }
34
34
  if (!buildNumberToDownload) {
35
- logger.error(i18n(`commands.project.subcommands.download.errors.noBuildIdToDownload`));
35
+ uiLogger.error(commands.project.download.errors.noBuildIdToDownload);
36
36
  process.exit(EXIT_CODES.ERROR);
37
37
  }
38
38
  const absoluteDestPath = dest ? path.resolve(getCwd(), dest) : getCwd();
39
39
  const { data: zippedProject } = await downloadProject(derivedAccountId, projectName, buildNumberToDownload);
40
40
  await extractZipArchive(zippedProject, sanitizeFileName(projectName), path.resolve(absoluteDestPath), { includesRootDir: false });
41
- logger.log(i18n(`commands.project.subcommands.download.logs.downloadSucceeded`, {
42
- buildId: buildNumberToDownload,
43
- projectName,
44
- }));
41
+ uiLogger.log(commands.project.download.logs.downloadSucceeded(buildNumberToDownload, projectName));
45
42
  process.exit(EXIT_CODES.SUCCESS);
46
43
  }
47
44
  catch (e) {
@@ -55,15 +52,15 @@ async function handler(args) {
55
52
  function projectDownloadBuilder(yargs) {
56
53
  yargs.options({
57
54
  project: {
58
- describe: i18n(`commands.project.subcommands.download.options.project.describe`),
55
+ describe: commands.project.download.options.project.describe,
59
56
  type: 'string',
60
57
  },
61
58
  dest: {
62
- describe: i18n(`commands.project.subcommands.download.options.dest.describe`),
59
+ describe: commands.project.download.options.dest.describe,
63
60
  type: 'string',
64
61
  },
65
62
  build: {
66
- describe: i18n(`commands.project.subcommands.download.options.build.describe`),
63
+ describe: commands.project.download.options.build.describe,
67
64
  alias: ['build-id'],
68
65
  type: 'number',
69
66
  },
@@ -71,7 +68,7 @@ function projectDownloadBuilder(yargs) {
71
68
  yargs.example([
72
69
  [
73
70
  '$0 project download --project=myProject --dest=myProjectFolder',
74
- i18n(`commands.project.subcommands.download.examples.default`),
71
+ commands.project.download.examples.default,
75
72
  ],
76
73
  ]);
77
74
  return yargs;
@@ -1,22 +1,22 @@
1
- import { logger } from '@hubspot/local-dev-lib/logger';
2
1
  import { installPackages, getProjectPackageJsonLocations, } from '../../lib/dependencyManagement.js';
3
2
  import { EXIT_CODES } from '../../lib/enums/exitCodes.js';
4
3
  import { getProjectConfig } from '../../lib/projects/config.js';
5
4
  import { promptUser } from '../../lib/prompts/promptUtils.js';
6
5
  import path from 'path';
7
- import { i18n } from '../../lib/lang.js';
6
+ import { commands } from '../../lang/en.js';
7
+ import { uiLogger } from '../../lib/ui/logger.js';
8
8
  import { trackCommandUsage } from '../../lib/usageTracking.js';
9
9
  import { logError } from '../../lib/errorHandlers/index.js';
10
10
  import { makeYargsBuilder } from '../../lib/yargsUtils.js';
11
11
  const command = 'install-deps [packages..]';
12
- const describe = i18n(`commands.project.subcommands.installDeps.help.describe`);
12
+ const describe = commands.project.installDeps.help.describe;
13
13
  async function handler(args) {
14
14
  const { derivedAccountId, packages } = args;
15
15
  try {
16
16
  trackCommandUsage('project-install-deps', undefined, derivedAccountId);
17
17
  const projectConfig = await getProjectConfig();
18
18
  if (!projectConfig || !projectConfig.projectDir) {
19
- logger.error(i18n(`commands.project.subcommands.installDeps.noProjectConfig`));
19
+ uiLogger.error(commands.project.installDeps.noProjectConfig);
20
20
  return process.exit(EXIT_CODES.ERROR);
21
21
  }
22
22
  const { projectDir } = projectConfig;
@@ -27,14 +27,14 @@ async function handler(args) {
27
27
  name: 'selectedInstallLocations',
28
28
  type: 'checkbox',
29
29
  when: () => packages && packages.length > 0,
30
- message: i18n(`commands.project.subcommands.installDeps.installLocationPrompt`),
30
+ message: commands.project.installDeps.installLocationPrompt,
31
31
  choices: installLocations.map(dir => ({
32
32
  name: path.relative(projectDir, dir),
33
33
  value: dir,
34
34
  })),
35
35
  validate: (choices) => {
36
36
  if (choices === undefined || choices.length === 0) {
37
- return i18n(`commands.project.subcommands.installDeps.installLocationPromptRequired`);
37
+ return commands.project.installDeps.installLocationPromptRequired;
38
38
  }
39
39
  return true;
40
40
  },
@@ -58,11 +58,11 @@ function projectInstallDepsBuilder(yargs) {
58
58
  yargs.example([
59
59
  [
60
60
  '$0 project install-deps',
61
- i18n(`commands.project.subcommands.installDeps.help.installAppDepsExample`),
61
+ commands.project.installDeps.help.installAppDepsExample,
62
62
  ],
63
63
  [
64
64
  '$0 project install-deps dependency1 dependency2',
65
- i18n(`commands.project.subcommands.installDeps.help.addDepToSubComponentExample`),
65
+ commands.project.installDeps.help.addDepToSubComponentExample,
66
66
  ],
67
67
  ]);
68
68
  return yargs;
@@ -1,5 +1,4 @@
1
1
  import { isHubSpotHttpError } from '@hubspot/local-dev-lib/errors/index';
2
- import { logger } from '@hubspot/local-dev-lib/logger';
3
2
  import { fetchProject, fetchProjectBuilds, } from '@hubspot/local-dev-lib/api/projects';
4
3
  import { getTableContents, getTableHeader } from '../../lib/ui/table.js';
5
4
  import { uiLink } from '../../lib/ui/index.js';
@@ -8,27 +7,24 @@ import { getProjectDetailUrl } from '../../lib/projects/urls.js';
8
7
  import moment from 'moment';
9
8
  import { promptUser } from '../../lib/prompts/promptUtils.js';
10
9
  import { trackCommandUsage } from '../../lib/usageTracking.js';
11
- import { i18n } from '../../lib/lang.js';
10
+ import { uiLogger } from '../../lib/ui/logger.js';
12
11
  import { logError, ApiErrorContext } from '../../lib/errorHandlers/index.js';
13
12
  import { EXIT_CODES } from '../../lib/enums/exitCodes.js';
14
13
  import { makeYargsBuilder } from '../../lib/yargsUtils.js';
15
14
  import { commands } from '../../lang/en.js';
16
15
  const command = 'list-builds';
17
- const describe = i18n(`commands.project.subcommands.listBuilds.describe`);
16
+ const describe = commands.project.listBuilds.describe;
18
17
  async function fetchAndDisplayBuilds(accountId, project, options) {
19
18
  const { data: { results, paging }, } = await fetchProjectBuilds(accountId, project.name, options);
20
19
  const currentDeploy = project.deployedBuildId;
21
20
  if (options && options.after) {
22
- logger.log(i18n(`commands.project.subcommands.listBuilds.logs.showingNextBuilds`, {
23
- count: results.length,
24
- projectName: project.name,
25
- }));
21
+ uiLogger.log(commands.project.listBuilds.showingNextBuilds(results.length, project.name));
26
22
  }
27
23
  else {
28
- logger.log(commands.project.listBuilds.showingRecentBuilds(results.length, project.name, uiLink(commands.project.listBuilds.viewAllBuildsLink, getProjectDetailUrl(project.name, accountId))));
24
+ uiLogger.log(commands.project.listBuilds.showingRecentBuilds(results.length, project.name, uiLink(commands.project.listBuilds.viewAllBuildsLink, getProjectDetailUrl(project.name, accountId))));
29
25
  }
30
26
  if (results.length === 0) {
31
- logger.log(i18n(`commands.project.subcommands.listBuilds.errors.noBuilds`));
27
+ uiLogger.log(commands.project.listBuilds.errors.noBuilds);
32
28
  }
33
29
  else {
34
30
  const builds = results.map(build => {
@@ -49,7 +45,7 @@ async function fetchAndDisplayBuilds(accountId, project, options) {
49
45
  ];
50
46
  });
51
47
  builds.unshift(getTableHeader(['Build ID', 'Status', 'Completed', 'Duration', 'Details']));
52
- logger.log(getTableContents(builds, {
48
+ uiLogger.log(getTableContents(builds, {
53
49
  columnDefault: {
54
50
  paddingLeft: 3,
55
51
  },
@@ -58,7 +54,7 @@ async function fetchAndDisplayBuilds(accountId, project, options) {
58
54
  if (paging && paging.next) {
59
55
  await promptUser({
60
56
  name: 'more',
61
- message: i18n(`commands.project.subcommands.listBuilds.continueOrExitPrompt`),
57
+ message: commands.project.listBuilds.continueOrExitPrompt,
62
58
  });
63
59
  await fetchAndDisplayBuilds(accountId, project, {
64
60
  limit: options.limit,
@@ -81,9 +77,7 @@ async function handler(args) {
81
77
  }
82
78
  catch (e) {
83
79
  if (isHubSpotHttpError(e) && e.status === 404) {
84
- logger.error(i18n(`commands.project.subcommands.listBuilds.errors.projectNotFound`, {
85
- projectName,
86
- }));
80
+ uiLogger.error(commands.project.listBuilds.errors.projectNotFound(projectName));
87
81
  }
88
82
  else {
89
83
  logError(e, new ApiErrorContext({
@@ -97,19 +91,16 @@ async function handler(args) {
97
91
  function projectListBuildsBuilder(yargs) {
98
92
  yargs.options({
99
93
  project: {
100
- describe: i18n(`commands.project.subcommands.listBuilds.options.project.describe`),
94
+ describe: commands.project.listBuilds.options.project.describe,
101
95
  type: 'string',
102
96
  },
103
97
  limit: {
104
- describe: i18n(`commands.project.subcommands.listBuilds.options.limit.describe`),
98
+ describe: commands.project.listBuilds.options.limit.describe,
105
99
  type: 'string',
106
100
  },
107
101
  });
108
102
  yargs.example([
109
- [
110
- '$0 project list-builds',
111
- i18n(`commands.project.subcommands.listBuilds.examples.default`),
112
- ],
103
+ ['$0 project list-builds', commands.project.listBuilds.examples.default],
113
104
  ]);
114
105
  return yargs;
115
106
  }
@@ -1,13 +1,13 @@
1
1
  import { getEnv } from '@hubspot/local-dev-lib/config';
2
2
  import { getHubSpotWebsiteOrigin } from '@hubspot/local-dev-lib/urls';
3
3
  import { ENVIRONMENTS } from '@hubspot/local-dev-lib/constants/environments';
4
- import { logger } from '@hubspot/local-dev-lib/logger';
5
4
  import { trackCommandUsage } from '../../lib/usageTracking.js';
6
5
  import { getTableContents, getTableHeader } from '../../lib/ui/table.js';
7
6
  import { logError } from '../../lib/errorHandlers/index.js';
8
- import { uiLine, uiLink } from '../../lib/ui/index.js';
7
+ import { uiLine } from '../../lib/ui/index.js';
9
8
  import { projectLogsPrompt } from '../../lib/prompts/projectsLogsPrompt.js';
10
- import { i18n } from '../../lib/lang.js';
9
+ import { commands } from '../../lang/en.js';
10
+ import { uiLogger } from '../../lib/ui/logger.js';
11
11
  import { EXIT_CODES } from '../../lib/enums/exitCodes.js';
12
12
  import { ProjectLogsManager } from '../../lib/projects/ProjectLogsManager.js';
13
13
  import { makeYargsBuilder } from '../../lib/yargsUtils.js';
@@ -16,34 +16,34 @@ function getPrivateAppsUrl(accountId) {
16
16
  return `${baseUrl}/private-apps/${accountId}`;
17
17
  }
18
18
  function logTable(tableHeader, logsInfo) {
19
- logger.log(i18n(`commands.project.subcommands.logs.logs.showingLogs`));
20
- logger.log(getTableContents([tableHeader, logsInfo], { border: { bodyLeft: ' ' } }));
19
+ uiLogger.log(commands.project.logs.logs.showingLogs);
20
+ uiLogger.log(getTableContents([tableHeader, logsInfo], { border: { bodyLeft: ' ' } }));
21
21
  }
22
22
  function logPreamble() {
23
23
  if (ProjectLogsManager.isPublicFunction) {
24
24
  logTable(getTableHeader([
25
- i18n(`commands.project.subcommands.logs.table.accountHeader`),
26
- i18n(`commands.project.subcommands.logs.table.functionHeader`),
27
- i18n(`commands.project.subcommands.logs.table.endpointHeader`),
25
+ commands.project.logs.table.accountHeader,
26
+ commands.project.logs.table.functionHeader,
27
+ commands.project.logs.table.endpointHeader,
28
28
  ]), [
29
29
  ProjectLogsManager.accountId,
30
30
  ProjectLogsManager.functionName,
31
31
  ProjectLogsManager.endpointName,
32
32
  ]);
33
- logger.log(uiLink(i18n(`commands.project.subcommands.logs.logs.hubspotLogsDirectLink`), `${getPrivateAppsUrl(ProjectLogsManager.accountId)}/${ProjectLogsManager.appId}/logs/serverlessGatewayExecution?path=${ProjectLogsManager.endpointName}`));
33
+ uiLogger.log(commands.project.logs.logs.hubspotLogsDirectLink(`${getPrivateAppsUrl(ProjectLogsManager.accountId)}/${ProjectLogsManager.appId}/logs/serverlessGatewayExecution?path=${ProjectLogsManager.endpointName}`));
34
34
  }
35
35
  else {
36
36
  logTable(getTableHeader([
37
- i18n(`commands.project.subcommands.logs.table.accountHeader`),
38
- i18n(`commands.project.subcommands.logs.table.functionHeader`),
37
+ commands.project.logs.table.accountHeader,
38
+ commands.project.logs.table.functionHeader,
39
39
  ]), [ProjectLogsManager.accountId, ProjectLogsManager.functionName]);
40
- logger.log(uiLink(i18n(`commands.project.subcommands.logs.logs.hubspotLogsDirectLink`), `${getPrivateAppsUrl(ProjectLogsManager.accountId)}/${ProjectLogsManager.appId}/logs/crm?serverlessFunction=${ProjectLogsManager.functionName}`));
40
+ uiLogger.log(commands.project.logs.logs.hubspotLogsDirectLink(`${getPrivateAppsUrl(ProjectLogsManager.accountId)}/${ProjectLogsManager.appId}/logs/crm?serverlessFunction=${ProjectLogsManager.functionName}`));
41
41
  }
42
- logger.log();
42
+ uiLogger.log('');
43
43
  uiLine();
44
44
  }
45
45
  const command = 'logs';
46
- const describe = i18n(`commands.project.subcommands.logs.describe`);
46
+ const describe = commands.project.logs.describe;
47
47
  async function handler(args) {
48
48
  const { derivedAccountId } = args;
49
49
  trackCommandUsage('project-logs', undefined, derivedAccountId);
@@ -70,38 +70,35 @@ function projectLogsBuilder(yargs) {
70
70
  yargs.options({
71
71
  function: {
72
72
  alias: 'function',
73
- describe: i18n(`commands.project.subcommands.logs.options.function.describe`),
73
+ describe: commands.project.logs.options.function.describe,
74
74
  requiresArg: true,
75
75
  type: 'string',
76
76
  },
77
77
  latest: {
78
78
  alias: 'l',
79
- describe: i18n(`commands.project.subcommands.logs.options.latest.describe`),
79
+ describe: commands.project.logs.options.latest.describe,
80
80
  type: 'boolean',
81
81
  },
82
82
  compact: {
83
- describe: i18n(`commands.project.subcommands.logs.options.compact.describe`),
83
+ describe: commands.project.logs.options.compact.describe,
84
84
  type: 'boolean',
85
85
  },
86
86
  tail: {
87
87
  alias: ['t', 'follow'],
88
- describe: i18n(`commands.project.subcommands.logs.options.tail.describe`),
88
+ describe: commands.project.logs.options.tail.describe,
89
89
  type: 'boolean',
90
90
  },
91
91
  limit: {
92
- describe: i18n(`commands.project.subcommands.logs.options.limit.describe`),
92
+ describe: commands.project.logs.options.limit.describe,
93
93
  type: 'number',
94
94
  },
95
95
  });
96
96
  yargs.conflicts('tail', 'limit');
97
97
  yargs.example([
98
- [
99
- '$0 project logs',
100
- i18n(`commands.project.subcommands.logs.examples.default`),
101
- ],
98
+ ['$0 project logs', commands.project.logs.examples.default],
102
99
  [
103
100
  '$0 project logs --function=my-function',
104
- i18n(`commands.project.subcommands.logs.examples.withOptions`),
101
+ commands.project.logs.examples.withOptions,
105
102
  ],
106
103
  ]);
107
104
  return yargs;
@@ -1,34 +1,31 @@
1
- import { logger } from '@hubspot/local-dev-lib/logger';
2
- import { i18n } from '../../lib/lang.js';
3
- import { uiCommandReference, uiDeprecatedTag } from '../../lib/ui/index.js';
1
+ import { uiLogger } from '../../lib/ui/logger.js';
2
+ import { commands } from '../../lang/en.js';
3
+ import { uiDeprecatedTag } from '../../lib/ui/index.js';
4
4
  import { handlerGenerator } from '../app/migrate.js';
5
5
  import { makeYargsBuilder } from '../../lib/yargsUtils.js';
6
6
  import { PLATFORM_VERSIONS } from '@hubspot/local-dev-lib/constants/projects';
7
7
  const { v2023_2, v2025_2 } = PLATFORM_VERSIONS;
8
8
  const command = 'migrate-app';
9
9
  // TODO: Leave this as deprecated and remove in the next major release
10
- const describe = uiDeprecatedTag(i18n(`commands.project.subcommands.migrateApp.describe`), false);
10
+ const describe = uiDeprecatedTag(commands.project.migrateApp.describe, false);
11
11
  const deprecated = true;
12
12
  async function handler(args) {
13
- logger.warn(i18n(`commands.project.subcommands.migrateApp.deprecationWarning`, {
14
- oldCommand: uiCommandReference('hs project migrate-app'),
15
- newCommand: uiCommandReference(`hs app migrate --platform-version=${args.platformVersion}`),
16
- }));
13
+ uiLogger.warn(commands.project.migrateApp.deprecationWarning(args.platformVersion));
17
14
  const localHandler = handlerGenerator('migrate-app');
18
15
  await localHandler(args);
19
16
  }
20
17
  function projectMigrateAppBuilder(yargs) {
21
18
  yargs.options({
22
19
  name: {
23
- describe: i18n(`commands.project.subcommands.migrateApp.options.name.describe`),
20
+ describe: commands.project.migrateApp.options.name.describe,
24
21
  type: 'string',
25
22
  },
26
23
  dest: {
27
- describe: i18n(`commands.project.subcommands.migrateApp.options.dest.describe`),
24
+ describe: commands.project.migrateApp.options.dest.describe,
28
25
  type: 'string',
29
26
  },
30
27
  'app-id': {
31
- describe: i18n(`commands.project.subcommands.migrateApp.options.appId.describe`),
28
+ describe: commands.project.migrateApp.options.appId.describe,
32
29
  type: 'number',
33
30
  },
34
31
  'platform-version': {
@@ -38,10 +35,7 @@ function projectMigrateAppBuilder(yargs) {
38
35
  },
39
36
  });
40
37
  yargs.example([
41
- [
42
- `$0 project migrate-app`,
43
- i18n(`commands.project.subcommands.migrateApp.examples.default`),
44
- ],
38
+ [`$0 project migrate-app`, commands.project.migrateApp.examples.default],
45
39
  ]);
46
40
  return yargs;
47
41
  }
@@ -1,7 +1,7 @@
1
1
  import open from 'open';
2
2
  import { trackCommandUsage } from '../../lib/usageTracking.js';
3
- import { i18n } from '../../lib/lang.js';
4
- import { logger } from '@hubspot/local-dev-lib/logger';
3
+ import { commands } from '../../lang/en.js';
4
+ import { uiLogger } from '../../lib/ui/logger.js';
5
5
  import { getProjectConfig } from '../../lib/projects/config.js';
6
6
  import { ensureProjectExists } from '../../lib/projects/ensureProjectExists.js';
7
7
  import { getProjectDetailUrl } from '../../lib/projects/urls.js';
@@ -9,7 +9,7 @@ import { projectNamePrompt } from '../../lib/prompts/projectNamePrompt.js';
9
9
  import { EXIT_CODES } from '../../lib/enums/exitCodes.js';
10
10
  import { makeYargsBuilder } from '../../lib/yargsUtils.js';
11
11
  const command = 'open';
12
- const describe = i18n(`commands.project.subcommands.open.describe`);
12
+ const describe = commands.project.open.describe;
13
13
  async function handler(args) {
14
14
  const { project, derivedAccountId } = args;
15
15
  trackCommandUsage('project-open', undefined, derivedAccountId);
@@ -32,24 +32,17 @@ async function handler(args) {
32
32
  }
33
33
  const url = getProjectDetailUrl(projectName, derivedAccountId);
34
34
  open(url, { url: true });
35
- logger.success(i18n(`commands.project.subcommands.open.success`, {
36
- projectName: projectName,
37
- }));
35
+ uiLogger.success(commands.project.open.success(projectName));
38
36
  process.exit(EXIT_CODES.SUCCESS);
39
37
  }
40
38
  function projectOpenBuilder(yargs) {
41
39
  yargs.options({
42
40
  project: {
43
- describe: i18n(`commands.project.subcommands.open.options.project.describe`),
41
+ describe: commands.project.open.options.project.describe,
44
42
  type: 'string',
45
43
  },
46
44
  });
47
- yargs.example([
48
- [
49
- '$0 project open',
50
- i18n(`commands.project.subcommands.open.examples.default`),
51
- ],
52
- ]);
45
+ yargs.example([['$0 project open', commands.project.open.examples.default]]);
53
46
  return yargs;
54
47
  }
55
48
  const builder = makeYargsBuilder(projectOpenBuilder, command, describe, {
@@ -1,5 +1,5 @@
1
- import { CommonArgs, EnvironmentArgs, JSONOutputArgs, YargsCommandModule } from '../../types/Yargs.js';
2
- type ProjectUploadArgs = CommonArgs & JSONOutputArgs & EnvironmentArgs & {
1
+ import { CommonArgs, JSONOutputArgs, YargsCommandModule } from '../../types/Yargs.js';
2
+ type ProjectUploadArgs = CommonArgs & JSONOutputArgs & {
3
3
  forceCreate: boolean;
4
4
  message: string;
5
5
  m: string;