@hubspot/cli 4.2.1-beta.1 → 4.2.1-beta.3

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.
@@ -1,129 +0,0 @@
1
- const path = require('path');
2
- const chalk = require('chalk');
3
- const { i18n } = require('./lang');
4
- const { logger } = require('@hubspot/cli-lib/logger');
5
- const { handleKeypress } = require('@hubspot/cli-lib/lib/process');
6
- const SpinniesManager = require('./SpinniesManager');
7
- const DevServerManager = require('./DevServerManager');
8
- const { EXIT_CODES } = require('./enums/exitCodes');
9
- const { getProjectDetailUrl } = require('./projects');
10
- const { uiAccountDescription, uiBetaMessage, uiLink, uiLine } = require('./ui');
11
-
12
- const i18nKey = 'cli.lib.LocalDevManagerV2';
13
-
14
- class LocalDevManagerV2 {
15
- constructor(options) {
16
- this.targetAccountId = options.targetAccountId;
17
- this.projectConfig = options.projectConfig;
18
- this.projectDir = options.projectDir;
19
- this.extension = options.extension;
20
- this.debug = options.debug || false;
21
-
22
- this.projectSourceDir = path.join(
23
- this.projectDir,
24
- this.projectConfig.srcDir
25
- );
26
-
27
- if (!this.targetAccountId || !this.projectConfig || !this.projectDir) {
28
- logger.log(i18n(`${i18nKey}.failedToInitialize`));
29
- process.exit(EXIT_CODES.ERROR);
30
- }
31
- }
32
-
33
- async start() {
34
- console.clear();
35
- SpinniesManager.removeAll();
36
- SpinniesManager.init();
37
-
38
- uiBetaMessage(i18n(`${i18nKey}.betaMessage`));
39
- logger.log();
40
- logger.log(
41
- chalk.hex('#FF8F59')(
42
- i18n(`${i18nKey}.running`, {
43
- accountIdentifier: uiAccountDescription(this.targetAccountId),
44
- projectName: this.projectConfig.name,
45
- })
46
- )
47
- );
48
- logger.log(
49
- uiLink(
50
- i18n(`${i18nKey}.viewInHubSpotLink`),
51
- getProjectDetailUrl(this.projectConfig.name, this.targetAccountId)
52
- )
53
- );
54
- logger.log();
55
- logger.log(i18n(`${i18nKey}.quitHelper`));
56
- uiLine();
57
- logger.log();
58
-
59
- await this.devServerStart();
60
-
61
- this.updateKeypressListeners();
62
- }
63
-
64
- async stop() {
65
- SpinniesManager.add('cleanupMessage', {
66
- text: i18n(`${i18nKey}.exitingStart`),
67
- });
68
-
69
- const cleanupSucceeded = await this.devServerCleanup();
70
-
71
- if (!cleanupSucceeded) {
72
- SpinniesManager.fail('cleanupMessage', {
73
- text: i18n(`${i18nKey}.exitingFail`),
74
- });
75
- process.exit(EXIT_CODES.ERROR);
76
- }
77
-
78
- SpinniesManager.succeed('cleanupMessage', {
79
- text: i18n(`${i18nKey}.exitingSucceed`),
80
- });
81
- process.exit(EXIT_CODES.SUCCESS);
82
- }
83
-
84
- updateKeypressListeners() {
85
- handleKeypress(async key => {
86
- if ((key.ctrl && key.name === 'c') || key.name === 'q') {
87
- this.stop();
88
- }
89
- });
90
- }
91
-
92
- async devServerStart() {
93
- try {
94
- DevServerManager.safeLoadServer();
95
- await DevServerManager.start({
96
- accountId: this.targetAccountId,
97
- debug: this.debug,
98
- extension: this.extension,
99
- projectConfig: this.projectConfig,
100
- projectSourceDir: this.projectSourceDir,
101
- });
102
- } catch (e) {
103
- if (this.debug) {
104
- logger.error(e);
105
- }
106
- logger.error(
107
- i18n(`${i18nKey}.devServer.startError`, { message: e.message })
108
- );
109
- process.exit(EXIT_CODES.ERROR);
110
- }
111
- }
112
-
113
- async devServerCleanup() {
114
- try {
115
- await DevServerManager.cleanup();
116
- return true;
117
- } catch (e) {
118
- if (this.debug) {
119
- logger.error(e);
120
- }
121
- logger.error(
122
- i18n(`${i18nKey}.devServer.cleanupError`, { message: e.message })
123
- );
124
- return false;
125
- }
126
- }
127
- }
128
-
129
- module.exports = LocalDevManagerV2;