@varlet/release 0.0.1 → 0.0.3-alpha.1700238601515

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.
package/LICENCE ADDED
@@ -0,0 +1,21 @@
1
+ The MIT License (MIT)
2
+
3
+ Copyright (c) 2022 varlet
4
+
5
+ Permission is hereby granted, free of charge, to any person obtaining a copy
6
+ of this software and associated documentation files (the "Software"), to deal
7
+ in the Software without restriction, including without limitation the rights
8
+ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9
+ copies of the Software, and to permit persons to whom the Software is
10
+ furnished to do so, subject to the following conditions:
11
+
12
+ The above copyright notice and this permission notice shall be included in all
13
+ copies or substantial portions of the Software.
14
+
15
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18
+ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21
+ SOFTWARE.
package/README.md ADDED
@@ -0,0 +1,116 @@
1
+ <h1 align="center">Varlet Release</h1>
2
+
3
+ <p align="center">
4
+ <span>English</span> |
5
+ <a href="https://github.com/varletjs/release/blob/main/README.zh-CN.md">中文</a>
6
+ </p>
7
+ <p align="center">
8
+ <a href="https://www.npmjs.com/package/@varlet/release" target="_blank" rel="noopener noreferrer"><img src="https://badgen.net/npm/v/@varlet/release" alt="NPM Version" /></a>
9
+ <a href="https://github.com/varletjs/release/blob/main/LICENCE" target="_blank" rel="noopener noreferrer"><img src="https://badgen.net/github/license/varletjs/release" alt="License" /></a>
10
+ </p>
11
+
12
+ ## Intro
13
+
14
+ `Varlet Release` is a tool to release all packages and generate changelogs.
15
+
16
+ ## Installation
17
+
18
+ ### npm
19
+
20
+ ```shell
21
+ npm i @varlet/release -D
22
+ ```
23
+
24
+ ### yarn
25
+
26
+ ```shell
27
+ yarn add @varlet/release -D
28
+ ```
29
+
30
+ ### pnpm
31
+
32
+ ```shell
33
+ pnpm add @varlet/release -D
34
+ ```
35
+
36
+ ## Usage
37
+
38
+ ### Using Command
39
+
40
+ ```shell
41
+ # Release all packages and generate changelogs
42
+ npx vr release
43
+
44
+ # Specify remote name
45
+ npx vr release -r <remote>
46
+ # or
47
+ npx vr release --remote <remote>
48
+
49
+ # Just generate changelogs
50
+ npx vr changelog
51
+
52
+ # Specify changelog filename
53
+ npx vr changelog -f <filename>
54
+ # or
55
+ npx vr changelog --file <filename>
56
+
57
+ ```
58
+
59
+ ### Configuration
60
+
61
+ #### release
62
+
63
+ | Params | Instructions |
64
+ | -------------------- | ------------------- |
65
+ | -r --remote <remote> | Specify remote name |
66
+
67
+ #### changelog
68
+
69
+ | Params | Instructions |
70
+ | --------------------------------- | -------------------------- |
71
+ | -f --file <filename> | Specify changelog filename |
72
+ | -rc --releaseCount <releaseCount> | Release count |
73
+
74
+ ### Custom Handle
75
+
76
+ #### Example
77
+
78
+ ```js
79
+ import { release, changelog } from '@varlet/release'
80
+
81
+ // Do what you want to do...
82
+ release()
83
+ ```
84
+
85
+ You can pass in a task that will be called before the publish after the package version is changed.
86
+
87
+ ```js
88
+ import { release, changelog } from '@varlet/release'
89
+
90
+ async function task() {
91
+ await doSomething1()
92
+ await doSomething2()
93
+ }
94
+
95
+ release({ task })
96
+ ```
97
+
98
+ #### Types
99
+
100
+ ```ts
101
+ interface ReleaseCommandOptions {
102
+ remote?: string
103
+ task?(): Promise<void>
104
+ }
105
+ function release(options: ReleaseCommandOptions): Promise<void>
106
+
107
+ interface ChangelogCommandOptions {
108
+ file?: string
109
+ releaseCount?: number
110
+ }
111
+ function changelog({ releaseCount, file }?: ChangelogCommandOptions): Promise<void>
112
+ ```
113
+
114
+ ## License
115
+
116
+ [MIT](https://github.com/varletjs/release/blob/main/LICENCE)
@@ -0,0 +1,116 @@
1
+ <h1 align="center">Varlet Release</h1>
2
+
3
+ <p align="center">
4
+ <span>中文</span> |
5
+ <a href="https://github.com/varletjs/release/blob/main/README.md">English</a>
6
+ </p>
7
+ <p align="center">
8
+ <a href="https://www.npmjs.com/package/@varlet/release" target="_blank" rel="noopener noreferrer"><img src="https://badgen.net/npm/v/@varlet/release" alt="NPM Version" /></a>
9
+ <a href="https://github.com/valetjs/release/blob/master/LICENSE" target="_blank" rel="noopener noreferrer"><img src="https://badgen.net/github/license/varletjs/release" alt="License" /></a>
10
+ </p>
11
+
12
+ ## 介绍
13
+
14
+ `Varlet Release` 是一个用于发布所有包并生成变更日志的工具。
15
+
16
+ ## 安装
17
+
18
+ ### npm
19
+
20
+ ```shell
21
+ npm i @varlet/release -D
22
+ ```
23
+
24
+ ### yarn
25
+
26
+ ```shell
27
+ yarn add @varlet/release -D
28
+ ```
29
+
30
+ ### pnpm
31
+
32
+ ```shell
33
+ pnpm add @varlet/release -D
34
+ ```
35
+
36
+ ## 使用
37
+
38
+ ### 使用命令
39
+
40
+ ```shell
41
+ # 发布所有包并生成变更日志
42
+ npx vr release
43
+
44
+ # 指定远程仓库名称
45
+ npx vr release -r <remote>
46
+ # or
47
+ npx vr release --remote <remote>
48
+
49
+ # 仅生成变更日志
50
+ npx vr changelog
51
+
52
+ # 指定变更日志文件名
53
+ npx vr changelog -f <filename>
54
+ # or
55
+ npx vr changelog --file <filename>
56
+
57
+ ```
58
+
59
+ ### 配置
60
+
61
+ #### release
62
+
63
+ | 参数 | 说明 |
64
+ | -------------------- | ---------------- |
65
+ | -r --remote <remote> | 指定远程仓库名称 |
66
+
67
+ #### changelog
68
+
69
+ | 参数 | 说明 |
70
+ | --------------------------------- | ------------------ |
71
+ | -f --file <filename> | 指定变更日志文件名 |
72
+ | -rc --releaseCount <releaseCount> | 发布数量 |
73
+
74
+ ### 自定义处理
75
+
76
+ #### 示例
77
+
78
+ ```js
79
+ import { release, changelog } from '@varlet/release'
80
+
81
+ // Do what you want to do...
82
+ release()
83
+ ```
84
+
85
+ 你可以传入一个 `task`,在包版本更改后,在发布之前会调用 `task`。
86
+
87
+ ```js
88
+ import { release, changelog } from '@varlet/release'
89
+
90
+ async function task() {
91
+ await doSomething1()
92
+ await doSomething2()
93
+ }
94
+
95
+ release({ task })
96
+ ```
97
+
98
+ #### 类型
99
+
100
+ ```ts
101
+ interface ReleaseCommandOptions {
102
+ remote?: string
103
+ task?(): Promise<void>
104
+ }
105
+ function release(options: ReleaseCommandOptions): Promise<void>
106
+
107
+ interface ChangelogCommandOptions {
108
+ file?: string
109
+ releaseCount?: number
110
+ }
111
+ function changelog({ releaseCount, file }?: ChangelogCommandOptions): Promise<void>
112
+ ```
113
+
114
+ ## License
115
+
116
+ [MIT](https://github.com/varletjs/release/blob/main/LICENSE)
package/bin/index.js CHANGED
@@ -1,21 +1,20 @@
1
- #!/usr/bin/env node
2
- import { release, changelog } from '../dist/index.js'
3
- import { Command } from 'commander'
4
-
5
- const program = new Command()
6
-
7
- program
8
- .command('release')
9
- .option('-r --remote <remote>', 'Remote name')
10
- .option('-o --otp <otp>', 'One-time password')
11
- .description('Release all packages and generate changelogs')
12
- .action(async (options) => release(options))
13
-
14
- program
15
- .command('changelog')
16
- .option('-rc --releaseCount <releaseCount>', 'Release count')
17
- .option('-f --file <file>', 'Changelog filename')
18
- .description('Generate changelog')
19
- .action(async (options) => changelog(options))
20
-
21
- program.parse()
1
+ #!/usr/bin/env node
2
+ import { release, changelog } from '../dist/index.js'
3
+ import { Command } from 'commander'
4
+
5
+ const program = new Command()
6
+
7
+ program
8
+ .command('release')
9
+ .option('-r --remote <remote>', 'Remote name')
10
+ .description('Release all packages and generate changelogs')
11
+ .action(async (options) => release(options))
12
+
13
+ program
14
+ .command('changelog')
15
+ .option('-rc --releaseCount <releaseCount>', 'Release count')
16
+ .option('-f --file <file>', 'Changelog filename')
17
+ .description('Generate changelog')
18
+ .action(async (options) => changelog(options))
19
+
20
+ program.parse()
package/dist/index.cjs CHANGED
@@ -36,13 +36,34 @@ __export(src_exports, {
36
36
  module.exports = __toCommonJS(src_exports);
37
37
 
38
38
  // src/release.ts
39
- var import_nanospinner2 = require("nanospinner");
40
39
  var import_fs_extra2 = __toESM(require("fs-extra"), 1);
41
- var import_execa = require("execa");
42
- var import_rslog = require("rslog");
40
+
41
+ // src/logger.ts
42
+ var import_picocolors = __toESM(require("picocolors"), 1);
43
+ var logger_default = {
44
+ info(text) {
45
+ console.log(text);
46
+ },
47
+ success(text) {
48
+ console.log(import_picocolors.default.green(text));
49
+ },
50
+ warning(text) {
51
+ console.log(import_picocolors.default.yellow(text));
52
+ },
53
+ error(text) {
54
+ console.log(import_picocolors.default.red(text));
55
+ },
56
+ title(text) {
57
+ console.log(import_picocolors.default.cyan(text));
58
+ }
59
+ };
60
+
61
+ // src/release.ts
43
62
  var import_semver = __toESM(require("semver"), 1);
44
- var import_glob = require("glob");
45
63
  var import_inquirer = __toESM(require("inquirer"), 1);
64
+ var import_execa = require("execa");
65
+ var import_nanospinner2 = require("nanospinner");
66
+ var import_glob = require("glob");
46
67
  var import_path2 = require("path");
47
68
 
48
69
  // src/changelog.ts
@@ -73,21 +94,18 @@ async function isWorktreeEmpty() {
73
94
  const ret = await (0, import_execa.execa)("git", ["status", "--porcelain"]);
74
95
  return !ret.stdout;
75
96
  }
76
- async function publish(preRelease, otp) {
97
+ async function publish(preRelease) {
77
98
  const s = (0, import_nanospinner2.createSpinner)("Publishing all packages").start();
78
99
  const args = ["-r", "publish", "--no-git-checks", "--access", "public"];
79
100
  if (preRelease) {
80
101
  args.push("--tag", "alpha");
81
102
  }
82
- if (otp) {
83
- args.push(`--otp=${otp}`);
84
- }
85
103
  const ret = await (0, import_execa.execa)("pnpm", args);
86
104
  if (ret.stderr && ret.stderr.includes("npm ERR!")) {
87
105
  throw new Error("\n" + ret.stderr);
88
106
  } else {
89
107
  s.success({ text: "Publish all packages successfully" });
90
- ret.stdout && import_rslog.logger.info(ret.stdout);
108
+ ret.stdout && logger_default.info(ret.stdout);
91
109
  }
92
110
  }
93
111
  async function pushGit(version, remote = "origin") {
@@ -98,7 +116,7 @@ async function pushGit(version, remote = "origin") {
98
116
  await (0, import_execa.execa)("git", ["push", remote, `v${version}`]);
99
117
  const ret = await (0, import_execa.execa)("git", ["push"]);
100
118
  s.success({ text: "Push remote repository successfully" });
101
- ret.stdout && import_rslog.logger.info(ret.stdout);
119
+ ret.stdout && logger_default.info(ret.stdout);
102
120
  }
103
121
  function updateVersion(version) {
104
122
  const packageJsons = import_glob.glob.sync("packages/*/package.json");
@@ -163,11 +181,11 @@ async function release(options) {
163
181
  try {
164
182
  const currentVersion = readJSONSync((0, import_path2.resolve)(cwd, "package.json")).version;
165
183
  if (!currentVersion) {
166
- import_rslog.logger.error("Your package is missing the version field");
184
+ logger_default.error("Your package is missing the version field");
167
185
  return;
168
186
  }
169
187
  if (!await isWorktreeEmpty()) {
170
- import_rslog.logger.error("Git worktree is not empty, please commit changed");
188
+ logger_default.error("Git worktree is not empty, please commit changed");
171
189
  return;
172
190
  }
173
191
  if (!await confirmRefs(options.remote)) {
@@ -187,22 +205,22 @@ async function release(options) {
187
205
  if (options.task) {
188
206
  await options.task();
189
207
  }
190
- await publish(isPreRelease, options.otp);
208
+ await publish(isPreRelease);
191
209
  if (!isPreRelease) {
192
210
  await changelog();
193
211
  await pushGit(expectVersion, options.remote);
194
212
  }
195
- import_rslog.logger.success(`Release version ${expectVersion} successfully!`);
213
+ logger_default.success(`Release version ${expectVersion} successfully!`);
196
214
  if (isPreRelease) {
197
215
  try {
198
216
  await (0, import_execa.execa)("git", ["restore", "**/package.json"]);
199
217
  await (0, import_execa.execa)("git", ["restore", "package.json"]);
200
218
  } catch {
201
- import_rslog.logger.error("Restore package.json has failed, please restore manually");
219
+ logger_default.error("Restore package.json has failed, please restore manually");
202
220
  }
203
221
  }
204
222
  } catch (error) {
205
- import_rslog.logger.error(error.toString());
223
+ logger_default.error(error.toString());
206
224
  process.exit(1);
207
225
  }
208
226
  }
package/dist/index.d.cts CHANGED
@@ -1,6 +1,5 @@
1
1
  interface ReleaseCommandOptions {
2
2
  remote?: string;
3
- otp?: string;
4
3
  task?(): Promise<void>;
5
4
  }
6
5
  declare function release(options: ReleaseCommandOptions): Promise<void>;
package/dist/index.d.ts CHANGED
@@ -1,6 +1,5 @@
1
1
  interface ReleaseCommandOptions {
2
2
  remote?: string;
3
- otp?: string;
4
3
  task?(): Promise<void>;
5
4
  }
6
5
  declare function release(options: ReleaseCommandOptions): Promise<void>;
package/dist/index.js CHANGED
@@ -1,11 +1,32 @@
1
1
  // src/release.ts
2
- import { createSpinner as createSpinner2 } from "nanospinner";
3
2
  import fse2 from "fs-extra";
4
- import { execa } from "execa";
5
- import { logger } from "rslog";
3
+
4
+ // src/logger.ts
5
+ import pico from "picocolors";
6
+ var logger_default = {
7
+ info(text) {
8
+ console.log(text);
9
+ },
10
+ success(text) {
11
+ console.log(pico.green(text));
12
+ },
13
+ warning(text) {
14
+ console.log(pico.yellow(text));
15
+ },
16
+ error(text) {
17
+ console.log(pico.red(text));
18
+ },
19
+ title(text) {
20
+ console.log(pico.cyan(text));
21
+ }
22
+ };
23
+
24
+ // src/release.ts
6
25
  import semver from "semver";
7
- import { glob } from "glob";
8
26
  import inquirer from "inquirer";
27
+ import { execa } from "execa";
28
+ import { createSpinner as createSpinner2 } from "nanospinner";
29
+ import { glob } from "glob";
9
30
  import { resolve } from "path";
10
31
 
11
32
  // src/changelog.ts
@@ -36,21 +57,18 @@ async function isWorktreeEmpty() {
36
57
  const ret = await execa("git", ["status", "--porcelain"]);
37
58
  return !ret.stdout;
38
59
  }
39
- async function publish(preRelease, otp) {
60
+ async function publish(preRelease) {
40
61
  const s = createSpinner2("Publishing all packages").start();
41
62
  const args = ["-r", "publish", "--no-git-checks", "--access", "public"];
42
63
  if (preRelease) {
43
64
  args.push("--tag", "alpha");
44
65
  }
45
- if (otp) {
46
- args.push(`--otp=${otp}`);
47
- }
48
66
  const ret = await execa("pnpm", args);
49
67
  if (ret.stderr && ret.stderr.includes("npm ERR!")) {
50
68
  throw new Error("\n" + ret.stderr);
51
69
  } else {
52
70
  s.success({ text: "Publish all packages successfully" });
53
- ret.stdout && logger.info(ret.stdout);
71
+ ret.stdout && logger_default.info(ret.stdout);
54
72
  }
55
73
  }
56
74
  async function pushGit(version, remote = "origin") {
@@ -61,7 +79,7 @@ async function pushGit(version, remote = "origin") {
61
79
  await execa("git", ["push", remote, `v${version}`]);
62
80
  const ret = await execa("git", ["push"]);
63
81
  s.success({ text: "Push remote repository successfully" });
64
- ret.stdout && logger.info(ret.stdout);
82
+ ret.stdout && logger_default.info(ret.stdout);
65
83
  }
66
84
  function updateVersion(version) {
67
85
  const packageJsons = glob.sync("packages/*/package.json");
@@ -126,11 +144,11 @@ async function release(options) {
126
144
  try {
127
145
  const currentVersion = readJSONSync(resolve(cwd, "package.json")).version;
128
146
  if (!currentVersion) {
129
- logger.error("Your package is missing the version field");
147
+ logger_default.error("Your package is missing the version field");
130
148
  return;
131
149
  }
132
150
  if (!await isWorktreeEmpty()) {
133
- logger.error("Git worktree is not empty, please commit changed");
151
+ logger_default.error("Git worktree is not empty, please commit changed");
134
152
  return;
135
153
  }
136
154
  if (!await confirmRefs(options.remote)) {
@@ -150,22 +168,22 @@ async function release(options) {
150
168
  if (options.task) {
151
169
  await options.task();
152
170
  }
153
- await publish(isPreRelease, options.otp);
171
+ await publish(isPreRelease);
154
172
  if (!isPreRelease) {
155
173
  await changelog();
156
174
  await pushGit(expectVersion, options.remote);
157
175
  }
158
- logger.success(`Release version ${expectVersion} successfully!`);
176
+ logger_default.success(`Release version ${expectVersion} successfully!`);
159
177
  if (isPreRelease) {
160
178
  try {
161
179
  await execa("git", ["restore", "**/package.json"]);
162
180
  await execa("git", ["restore", "package.json"]);
163
181
  } catch {
164
- logger.error("Restore package.json has failed, please restore manually");
182
+ logger_default.error("Restore package.json has failed, please restore manually");
165
183
  }
166
184
  }
167
185
  } catch (error) {
168
- logger.error(error.toString());
186
+ logger_default.error(error.toString());
169
187
  process.exit(1);
170
188
  }
171
189
  }
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "@varlet/release",
3
3
  "type": "module",
4
- "version": "0.0.1",
4
+ "version": "0.0.3-alpha.1700238601515",
5
5
  "description": "release all packages and generate changelogs",
6
6
  "keywords": [
7
7
  "varlet",
@@ -51,6 +51,7 @@
51
51
  "dependencies": {
52
52
  "commander": "^11.1.0",
53
53
  "conventional-changelog": "^5.1.0",
54
+ "picocolors": "^1.0.0",
54
55
  "execa": "^8.0.1",
55
56
  "fs-extra": "^11.1.1",
56
57
  "glob": "^10.3.10",
@@ -62,9 +63,9 @@
62
63
  },
63
64
  "scripts": {
64
65
  "preinstall": "npx only-allow pnpm",
65
- "build": "tsc --noEmit && tsup",
66
- "dev": "node bin/index.js",
67
- "release": "pnpm run build && pnpm run dev release",
68
- "checkAll": "tsc --noEmit && eslint --ext .ts,.js"
66
+ "dev": "tsup --watch",
67
+ "build": "tsup",
68
+ "release": "pnpm build && node bin/index.js release",
69
+ "lint": "eslint --ext .ts,.js"
69
70
  }
70
71
  }